Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
e5ad5cd1
Commit
e5ad5cd1
authored
Dec 14, 2011
by
Aric Stewart
Committed by
Alexandre Julliard
Dec 14, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
usp10: Add Tifinagh script.
parent
be9369e7
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
20 additions
and
1 deletion
+20
-1
shape.c
dlls/usp10/shape.c
+1
-0
usp10.c
dlls/usp10/tests/usp10.c
+10
-0
usp10.c
dlls/usp10/usp10.c
+8
-1
usp10_internal.h
dlls/usp10/usp10_internal.h
+1
-0
No files found.
dlls/usp10/shape.c
View file @
e5ad5cd1
...
@@ -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
)
...
...
dlls/usp10/tests/usp10.c
View file @
e5ad5cd1
...
@@ -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
,
...
...
dlls/usp10/usp10.c
View file @
e5ad5cd1
...
@@ -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
{
...
...
dlls/usp10/usp10_internal.h
View file @
e5ad5cd1
...
@@ -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)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment