Commit e5ad5cd1 authored by Aric Stewart's avatar Aric Stewart Committed by Alexandre Julliard

usp10: Add Tifinagh script.

parent be9369e7
...@@ -666,6 +666,7 @@ static const ScriptShapeData ShapingData[] = ...@@ -666,6 +666,7 @@ static const ScriptShapeData ShapingData[] =
{{ ethiopic_features, 4}, NULL, "ethi", "", NULL, NULL}, {{ ethiopic_features, 4}, NULL, "ethi", "", NULL, NULL},
{{ mongolian_features, 4}, NULL, "mong", "", ContextualShape_Mongolian, NULL}, {{ mongolian_features, 4}, NULL, "mong", "", ContextualShape_Mongolian, NULL},
{{ mongolian_features, 4}, NULL, "mong", "", ContextualShape_Mongolian, NULL}, {{ mongolian_features, 4}, NULL, "mong", "", ContextualShape_Mongolian, NULL},
{{ no_features, 0}, NULL, "tfng", "", NULL, NULL},
}; };
static INT GSUB_is_glyph_covered(LPCVOID table , UINT glyph) static INT GSUB_is_glyph_covered(LPCVOID table , UINT glyph)
......
...@@ -160,6 +160,7 @@ static inline void _test_items_ok(LPCWSTR string, DWORD cchString, ...@@ -160,6 +160,7 @@ static inline void _test_items_ok(LPCWSTR string, DWORD cchString,
#define yi_tag MS_MAKE_TAG('y','i',' ',' ') #define yi_tag MS_MAKE_TAG('y','i',' ',' ')
#define ethi_tag MS_MAKE_TAG('e','t','h','i') #define ethi_tag MS_MAKE_TAG('e','t','h','i')
#define mong_tag MS_MAKE_TAG('m','o','n','g') #define mong_tag MS_MAKE_TAG('m','o','n','g')
#define tfng_tag MS_MAKE_TAG('t','f','n','g')
static void test_ScriptItemize( void ) static void test_ScriptItemize( void )
{ {
...@@ -380,6 +381,11 @@ static void test_ScriptItemize( void ) ...@@ -380,6 +381,11 @@ static void test_ScriptItemize( void )
static const int b351[2] = {2,2}; static const int b351[2] = {2,2};
static const int b352[2] = {2,3}; static const int b352[2] = {2,3};
/* Tifinagh */
static const WCHAR test36[] = {0x2d5c,0x2d49,0x2d3c,0x2d49,0x2d4f,0x2d30,0x2d56};
static const itemTest t361[2] = {{{0,0,0,0,0},0,0,0,0,tfng_tag,TRUE,{-1,-1,-1,-1,latn_tag}},{{0,0,0,0,0},7,0,0,0,-1,FALSE}};
static const itemTest t362[2] = {{{0,0,0,0,0},0,0,0,2,tfng_tag,TRUE,{-1,1,1,1,latn_tag}},{{0,0,0,0,0},7,0,0,0,-1,FALSE}};
SCRIPT_ITEM items[15]; SCRIPT_ITEM items[15];
SCRIPT_CONTROL Control; SCRIPT_CONTROL Control;
SCRIPT_STATE State; SCRIPT_STATE State;
...@@ -448,6 +454,7 @@ static void test_ScriptItemize( void ) ...@@ -448,6 +454,7 @@ static void test_ScriptItemize( void )
test_items_ok(test33,4,NULL,NULL,1,t331,FALSE,0); test_items_ok(test33,4,NULL,NULL,1,t331,FALSE,0);
test_items_ok(test34,3,NULL,NULL,1,t341,FALSE,0); test_items_ok(test34,3,NULL,NULL,1,t341,FALSE,0);
test_items_ok(test35,13,NULL,NULL,1,t351,FALSE,b351); test_items_ok(test35,13,NULL,NULL,1,t351,FALSE,b351);
test_items_ok(test36,7,NULL,NULL,1,t361,FALSE,0);
State.uBidiLevel = 0; State.uBidiLevel = 0;
test_items_ok(test1,4,&Control,&State,1,t11,FALSE,0); test_items_ok(test1,4,&Control,&State,1,t11,FALSE,0);
...@@ -490,6 +497,7 @@ static void test_ScriptItemize( void ) ...@@ -490,6 +497,7 @@ static void test_ScriptItemize( void )
test_items_ok(test33,4,&Control,&State,1,t331,FALSE,0); test_items_ok(test33,4,&Control,&State,1,t331,FALSE,0);
test_items_ok(test34,3,&Control,&State,1,t341,FALSE,0); test_items_ok(test34,3,&Control,&State,1,t341,FALSE,0);
test_items_ok(test35,13,&Control,&State,1,t351,FALSE,b351); test_items_ok(test35,13,&Control,&State,1,t351,FALSE,b351);
test_items_ok(test36,7,&Control,&State,1,t361,FALSE,0);
State.uBidiLevel = 1; State.uBidiLevel = 1;
test_items_ok(test1,4,&Control,&State,1,t12,FALSE,0); test_items_ok(test1,4,&Control,&State,1,t12,FALSE,0);
...@@ -532,6 +540,7 @@ static void test_ScriptItemize( void ) ...@@ -532,6 +540,7 @@ static void test_ScriptItemize( void )
test_items_ok(test33,4,&Control,&State,1,t332,FALSE,0); test_items_ok(test33,4,&Control,&State,1,t332,FALSE,0);
test_items_ok(test34,3,&Control,&State,1,t342,FALSE,b342); test_items_ok(test34,3,&Control,&State,1,t342,FALSE,b342);
test_items_ok(test35,13,&Control,&State,1,t352,FALSE,b352); test_items_ok(test35,13,&Control,&State,1,t352,FALSE,b352);
test_items_ok(test36,7,&Control,&State,1,t362,FALSE,0);
State.uBidiLevel = 1; State.uBidiLevel = 1;
Control.fMergeNeutralItems = TRUE; Control.fMergeNeutralItems = TRUE;
...@@ -575,6 +584,7 @@ static void test_ScriptItemize( void ) ...@@ -575,6 +584,7 @@ static void test_ScriptItemize( void )
test_items_ok(test33,4,&Control,&State,1,t332,FALSE,0); test_items_ok(test33,4,&Control,&State,1,t332,FALSE,0);
test_items_ok(test34,3,&Control,&State,1,t342,FALSE,b342); test_items_ok(test34,3,&Control,&State,1,t342,FALSE,b342);
test_items_ok(test35,13,&Control,&State,1,t352,FALSE,b352); test_items_ok(test35,13,&Control,&State,1,t352,FALSE,b352);
test_items_ok(test36,7,&Control,&State,1,t362,FALSE,0);
} }
static inline void _test_shape_ok(int valid, HDC hdc, LPCWSTR string, static inline void _test_shape_ok(int valid, HDC hdc, LPCWSTR string,
......
...@@ -171,6 +171,8 @@ static const scriptRange scriptRanges[] = { ...@@ -171,6 +171,8 @@ static const scriptRange scriptRanges[] = {
{ Script_Latin, 0x2c60, 0x2c7f, 0, 0}, { Script_Latin, 0x2c60, 0x2c7f, 0, 0},
/* Georgian: U+2D00–U+2D2F */ /* Georgian: U+2D00–U+2D2F */
{ Script_Georgian, 0x2d00, 0x2d2f, 0, 0}, { Script_Georgian, 0x2d00, 0x2d2f, 0, 0},
/* Tifinagh: U+2D30–U+2D7F */
{ Script_Tifinagh, 0x2d30, 0x2d7f, 0, 0},
/* Ethiopic Extensions: U+2D80–U+2DDF */ /* Ethiopic Extensions: U+2D80–U+2DDF */
{ Script_Ethiopic, 0x2d80, 0x2ddf, 0, 0}, { Script_Ethiopic, 0x2d80, 0x2ddf, 0, 0},
/* Cyrillic Extended-A: U+2DE0–U+2DFF */ /* Cyrillic Extended-A: U+2DE0–U+2DFF */
...@@ -532,6 +534,10 @@ static const scriptData scriptInformation[] = { ...@@ -532,6 +534,10 @@ static const scriptData scriptInformation[] = {
{LANG_MONGOLIAN, 1, 1, 0, 0, DEFAULT_CHARSET, 0, 0, 0, 0, 0, 0, 0, 0, 0}, {LANG_MONGOLIAN, 1, 1, 0, 0, DEFAULT_CHARSET, 0, 0, 0, 0, 0, 0, 0, 0, 0},
MS_MAKE_TAG('m','o','n','g'), MS_MAKE_TAG('m','o','n','g'),
{'M','o','n','g','o','l','i','a','n',' ','B','a','i','t','i'}}, {'M','o','n','g','o','l','i','a','n',' ','B','a','i','t','i'}},
{{Script_Tifinagh, 0, 0, 0, 0, 0, 0, { 0,0,0,0,0,0,0,0,0,0,0}},
{0, 0, 1, 0, 0, DEFAULT_CHARSET, 0, 0, 0, 0, 0, 0, 0, 0, 0},
MS_MAKE_TAG('t','f','n','g'),
{'E','b','r','i','m','a'}},
}; };
static const SCRIPT_PROPERTIES *script_props[] = static const SCRIPT_PROPERTIES *script_props[] =
...@@ -567,7 +573,8 @@ static const SCRIPT_PROPERTIES *script_props[] = ...@@ -567,7 +573,8 @@ static const SCRIPT_PROPERTIES *script_props[] =
&scriptInformation[56].props, &scriptInformation[57].props, &scriptInformation[56].props, &scriptInformation[57].props,
&scriptInformation[58].props, &scriptInformation[59].props, &scriptInformation[58].props, &scriptInformation[59].props,
&scriptInformation[60].props, &scriptInformation[61].props, &scriptInformation[60].props, &scriptInformation[61].props,
&scriptInformation[62].props, &scriptInformation[63].props &scriptInformation[62].props, &scriptInformation[63].props,
&scriptInformation[64].props
}; };
typedef struct { typedef struct {
......
...@@ -95,6 +95,7 @@ ...@@ -95,6 +95,7 @@
#define Script_Ethiopic_Numeric 61 #define Script_Ethiopic_Numeric 61
#define Script_Mongolian 62 #define Script_Mongolian 62
#define Script_Mongolian_Numeric 63 #define Script_Mongolian_Numeric 63
#define Script_Tifinagh 64
#define GLYPH_BLOCK_SHIFT 8 #define GLYPH_BLOCK_SHIFT 8
#define GLYPH_BLOCK_SIZE (1UL << GLYPH_BLOCK_SHIFT) #define GLYPH_BLOCK_SIZE (1UL << GLYPH_BLOCK_SHIFT)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment