[indic-generator/khmer] Move Khmer overrides to generator
This commit is contained in:
parent
40aa4e8320
commit
c136227f57
|
@ -146,6 +146,8 @@ position_map = {
|
||||||
|
|
||||||
category_overrides = {
|
category_overrides = {
|
||||||
|
|
||||||
|
# Indic
|
||||||
|
|
||||||
0x0930: 'Ra', # Devanagari
|
0x0930: 'Ra', # Devanagari
|
||||||
0x09B0: 'Ra', # Bengali
|
0x09B0: 'Ra', # Bengali
|
||||||
0x09F0: 'Ra', # Bengali
|
0x09F0: 'Ra', # Bengali
|
||||||
|
@ -221,6 +223,28 @@ category_overrides = {
|
||||||
0x2011: 'PLACEHOLDER',
|
0x2011: 'PLACEHOLDER',
|
||||||
|
|
||||||
0x25CC: 'DOTTEDCIRCLE',
|
0x25CC: 'DOTTEDCIRCLE',
|
||||||
|
|
||||||
|
|
||||||
|
# Khmer
|
||||||
|
|
||||||
|
0x179A: 'Ra',
|
||||||
|
|
||||||
|
0x17CC: 'Robatic',
|
||||||
|
0x17C9: 'Robatic',
|
||||||
|
0x17CA: 'Robatic',
|
||||||
|
|
||||||
|
0x17C6: 'Xgroup',
|
||||||
|
0x17CB: 'Xgroup',
|
||||||
|
0x17CD: 'Xgroup',
|
||||||
|
0x17CE: 'Xgroup',
|
||||||
|
0x17CF: 'Xgroup',
|
||||||
|
0x17D0: 'Xgroup',
|
||||||
|
0x17D1: 'Xgroup',
|
||||||
|
|
||||||
|
0x17C7: 'Ygroup',
|
||||||
|
0x17C8: 'Ygroup',
|
||||||
|
0x17DD: 'Ygroup',
|
||||||
|
0x17D3: 'Ygroup', # Just guessing. Uniscribe doesn't categorize it.
|
||||||
}
|
}
|
||||||
position_overrides = {
|
position_overrides = {
|
||||||
|
|
||||||
|
@ -364,6 +388,9 @@ short = [{
|
||||||
"DOTTEDCIRCLE": 'DC',
|
"DOTTEDCIRCLE": 'DC',
|
||||||
"VPst": 'VR',
|
"VPst": 'VR',
|
||||||
"VPre": 'VL',
|
"VPre": 'VL',
|
||||||
|
"Robatic": 'Rt',
|
||||||
|
"Xgroup": 'Xg',
|
||||||
|
"Ygroup": 'Yg',
|
||||||
},{
|
},{
|
||||||
"END": 'X',
|
"END": 'X',
|
||||||
"BASE_C": 'C',
|
"BASE_C": 'C',
|
||||||
|
|
|
@ -24,8 +24,8 @@
|
||||||
#pragma GCC diagnostic ignored "-Wunused-macros"
|
#pragma GCC diagnostic ignored "-Wunused-macros"
|
||||||
|
|
||||||
#define ISC_A OT_A /* 51 chars; A */
|
#define ISC_A OT_A /* 51 chars; A */
|
||||||
#define ISC_C OT_C /* 521 chars; C */
|
#define ISC_C OT_C /* 520 chars; C */
|
||||||
#define ISC_CM OT_CM /* 10 chars; CM */
|
#define ISC_CM OT_CM /* 9 chars; CM */
|
||||||
#define ISC_CS OT_CS /* 2 chars; CS */
|
#define ISC_CS OT_CS /* 2 chars; CS */
|
||||||
#define ISC_Co OT_Coeng /* 2 chars; Coeng */
|
#define ISC_Co OT_Coeng /* 2 chars; Coeng */
|
||||||
#define ISC_DC OT_DOTTEDCIRCLE /* 1 chars; DOTTEDCIRCLE */
|
#define ISC_DC OT_DOTTEDCIRCLE /* 1 chars; DOTTEDCIRCLE */
|
||||||
|
@ -33,32 +33,34 @@
|
||||||
#define ISC_M OT_M /* 160 chars; M */
|
#define ISC_M OT_M /* 160 chars; M */
|
||||||
#define ISC_N OT_N /* 35 chars; N */
|
#define ISC_N OT_N /* 35 chars; N */
|
||||||
#define ISC_GB OT_PLACEHOLDER /* 168 chars; PLACEHOLDER */
|
#define ISC_GB OT_PLACEHOLDER /* 168 chars; PLACEHOLDER */
|
||||||
#define ISC_RS OT_RS /* 2 chars; RS */
|
#define ISC_R OT_Ra /* 12 chars; Ra */
|
||||||
#define ISC_R OT_Ra /* 11 chars; Ra */
|
|
||||||
#define ISC_Rf OT_Repha /* 1 chars; Repha */
|
#define ISC_Rf OT_Repha /* 1 chars; Repha */
|
||||||
#define ISC_SM OT_SM /* 56 chars; SM */
|
#define ISC_Rt OT_Robatic /* 3 chars; Robatic */
|
||||||
|
#define ISC_SM OT_SM /* 48 chars; SM */
|
||||||
#define ISC_S OT_Symbol /* 22 chars; Symbol */
|
#define ISC_S OT_Symbol /* 22 chars; Symbol */
|
||||||
#define ISC_V OT_V /* 190 chars; V */
|
#define ISC_V OT_V /* 190 chars; V */
|
||||||
#define ISC_VA OT_VAbv /* 22 chars; VAbv */
|
#define ISC_VA OT_VAbv /* 20 chars; VAbv */
|
||||||
#define ISC_VB OT_VBlw /* 7 chars; VBlw */
|
#define ISC_VB OT_VBlw /* 7 chars; VBlw */
|
||||||
#define ISC_VL OT_VPre /* 5 chars; VPre */
|
#define ISC_VL OT_VPre /* 5 chars; VPre */
|
||||||
#define ISC_VR OT_VPst /* 15 chars; VPst */
|
#define ISC_VR OT_VPst /* 14 chars; VPst */
|
||||||
#define ISC_X OT_X /* 2 chars; X */
|
#define ISC_X OT_X /* 2 chars; X */
|
||||||
|
#define ISC_Xg OT_Xgroup /* 7 chars; Xgroup */
|
||||||
|
#define ISC_Yg OT_Ygroup /* 4 chars; Ygroup */
|
||||||
#define ISC_ZWJ OT_ZWJ /* 1 chars; ZWJ */
|
#define ISC_ZWJ OT_ZWJ /* 1 chars; ZWJ */
|
||||||
#define ISC_ZWNJ OT_ZWNJ /* 1 chars; ZWNJ */
|
#define ISC_ZWNJ OT_ZWNJ /* 1 chars; ZWNJ */
|
||||||
|
|
||||||
#define IMC_T POS_ABOVE_C /* 29 chars; ABOVE_C */
|
#define IMC_T POS_ABOVE_C /* 25 chars; ABOVE_C */
|
||||||
#define IMC_A POS_AFTER_MAIN /* 3 chars; AFTER_MAIN */
|
#define IMC_A POS_AFTER_MAIN /* 3 chars; AFTER_MAIN */
|
||||||
#define IMC_AP POS_AFTER_POST /* 50 chars; AFTER_POST */
|
#define IMC_AP POS_AFTER_POST /* 50 chars; AFTER_POST */
|
||||||
#define IMC_AS POS_AFTER_SUB /* 60 chars; AFTER_SUB */
|
#define IMC_AS POS_AFTER_SUB /* 60 chars; AFTER_SUB */
|
||||||
#define IMC_C POS_BASE_C /* 903 chars; BASE_C */
|
#define IMC_C POS_BASE_C /* 902 chars; BASE_C */
|
||||||
#define IMC_BS POS_BEFORE_SUB /* 31 chars; BEFORE_SUB */
|
#define IMC_BS POS_BEFORE_SUB /* 31 chars; BEFORE_SUB */
|
||||||
#define IMC_B POS_BELOW_C /* 13 chars; BELOW_C */
|
#define IMC_B POS_BELOW_C /* 13 chars; BELOW_C */
|
||||||
#define IMC_X POS_END /* 42 chars; END */
|
#define IMC_X POS_END /* 56 chars; END */
|
||||||
#define IMC_R POS_POST_C /* 15 chars; POST_C */
|
#define IMC_R POS_POST_C /* 14 chars; POST_C */
|
||||||
#define IMC_L POS_PRE_C /* 5 chars; PRE_C */
|
#define IMC_L POS_PRE_C /* 5 chars; PRE_C */
|
||||||
#define IMC_LM POS_PRE_M /* 16 chars; PRE_M */
|
#define IMC_LM POS_PRE_M /* 16 chars; PRE_M */
|
||||||
#define IMC_SM POS_SMVD /* 128 chars; SMVD */
|
#define IMC_SM POS_SMVD /* 120 chars; SMVD */
|
||||||
|
|
||||||
#pragma GCC diagnostic pop
|
#pragma GCC diagnostic pop
|
||||||
|
|
||||||
|
@ -314,15 +316,15 @@ static const uint16_t indic_table[] = {
|
||||||
/* 1780 */ _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C),
|
/* 1780 */ _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C),
|
||||||
/* 1788 */ _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C),
|
/* 1788 */ _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C),
|
||||||
/* 1790 */ _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C),
|
/* 1790 */ _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C),
|
||||||
/* 1798 */ _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C),
|
/* 1798 */ _(C,C), _(C,C), _(R,C), _(C,C), _(C,C), _(C,C), _(C,C), _(C,C),
|
||||||
/* 17A0 */ _(C,C), _(C,C), _(C,C), _(V,C), _(V,C), _(V,C), _(V,C), _(V,C),
|
/* 17A0 */ _(C,C), _(C,C), _(C,C), _(V,C), _(V,C), _(V,C), _(V,C), _(V,C),
|
||||||
/* 17A8 */ _(V,C), _(V,C), _(V,C), _(V,C), _(V,C), _(V,C), _(V,C), _(V,C),
|
/* 17A8 */ _(V,C), _(V,C), _(V,C), _(V,C), _(V,C), _(V,C), _(V,C), _(V,C),
|
||||||
/* 17B0 */ _(V,C), _(V,C), _(V,C), _(V,C), _(X,X), _(X,X), _(VR,R), _(VA,T),
|
/* 17B0 */ _(V,C), _(V,C), _(V,C), _(V,C), _(X,X), _(X,X), _(VR,R), _(VA,T),
|
||||||
/* 17B8 */ _(VA,T), _(VA,T), _(VA,T), _(VB,B), _(VB,B), _(VB,B), _(VA,T), _(VR,R),
|
/* 17B8 */ _(VA,T), _(VA,T), _(VA,T), _(VB,B), _(VB,B), _(VB,B), _(VA,T), _(VR,R),
|
||||||
/* 17C0 */ _(VR,R), _(VL,L), _(VL,L), _(VL,L), _(VR,R), _(VR,R),_(SM,SM),_(SM,SM),
|
/* 17C0 */ _(VR,R), _(VL,L), _(VL,L), _(VL,L), _(VR,R), _(VR,R), _(Xg,X), _(Yg,X),
|
||||||
/* 17C8 */ _(VR,R), _(RS,T), _(RS,T),_(SM,SM), _(CM,C), _(VA,T),_(SM,SM),_(SM,SM),
|
/* 17C8 */ _(Yg,X), _(Rt,X), _(Rt,X), _(Xg,X), _(Rt,X), _(Xg,X), _(Xg,X), _(Xg,X),
|
||||||
/* 17D0 */_(SM,SM), _(VA,T), _(Co,X),_(SM,SM), _(X,X), _(X,X), _(X,X), _(X,X),
|
/* 17D0 */ _(Xg,X), _(Xg,X), _(Co,X), _(Yg,X), _(X,X), _(X,X), _(X,X), _(X,X),
|
||||||
/* 17D8 */ _(X,X), _(X,X), _(X,X), _(X,X), _(S,SM),_(SM,SM), _(X,X), _(X,X),
|
/* 17D8 */ _(X,X), _(X,X), _(X,X), _(X,X), _(S,SM), _(Yg,X), _(X,X), _(X,X),
|
||||||
/* 17E0 */ _(GB,C), _(GB,C), _(GB,C), _(GB,C), _(GB,C), _(GB,C), _(GB,C), _(GB,C),
|
/* 17E0 */ _(GB,C), _(GB,C), _(GB,C), _(GB,C), _(GB,C), _(GB,C), _(GB,C), _(GB,C),
|
||||||
/* 17E8 */ _(GB,C), _(GB,C), _(X,X), _(X,X), _(X,X), _(X,X), _(X,X), _(X,X),
|
/* 17E8 */ _(GB,C), _(GB,C), _(X,X), _(X,X), _(X,X), _(X,X), _(X,X), _(X,X),
|
||||||
|
|
||||||
|
@ -459,9 +461,9 @@ hb_indic_get_categories (hb_codepoint_t u)
|
||||||
#undef ISC_M
|
#undef ISC_M
|
||||||
#undef ISC_N
|
#undef ISC_N
|
||||||
#undef ISC_GB
|
#undef ISC_GB
|
||||||
#undef ISC_RS
|
|
||||||
#undef ISC_R
|
#undef ISC_R
|
||||||
#undef ISC_Rf
|
#undef ISC_Rf
|
||||||
|
#undef ISC_Rt
|
||||||
#undef ISC_SM
|
#undef ISC_SM
|
||||||
#undef ISC_S
|
#undef ISC_S
|
||||||
#undef ISC_V
|
#undef ISC_V
|
||||||
|
@ -470,6 +472,8 @@ hb_indic_get_categories (hb_codepoint_t u)
|
||||||
#undef ISC_VL
|
#undef ISC_VL
|
||||||
#undef ISC_VR
|
#undef ISC_VR
|
||||||
#undef ISC_X
|
#undef ISC_X
|
||||||
|
#undef ISC_Xg
|
||||||
|
#undef ISC_Yg
|
||||||
#undef ISC_ZWJ
|
#undef ISC_ZWJ
|
||||||
#undef ISC_ZWNJ
|
#undef ISC_ZWNJ
|
||||||
|
|
||||||
|
|
|
@ -180,11 +180,9 @@ set_indic_properties (hb_glyph_info_t &info)
|
||||||
{
|
{
|
||||||
hb_codepoint_t u = info.codepoint;
|
hb_codepoint_t u = info.codepoint;
|
||||||
unsigned int type = hb_indic_get_categories (u);
|
unsigned int type = hb_indic_get_categories (u);
|
||||||
indic_category_t cat = (indic_category_t) (type & 0xFFu);
|
|
||||||
indic_position_t pos = (indic_position_t) (type >> 8);
|
|
||||||
|
|
||||||
info.indic_category() = cat;
|
info.indic_category() = (indic_category_t) (type & 0xFFu);
|
||||||
info.indic_position() = pos;
|
info.indic_position() = (indic_position_t) (type >> 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
struct hb_indic_would_substitute_feature_t
|
struct hb_indic_would_substitute_feature_t
|
||||||
|
|
|
@ -84,44 +84,8 @@ set_khmer_properties (hb_glyph_info_t &info)
|
||||||
{
|
{
|
||||||
hb_codepoint_t u = info.codepoint;
|
hb_codepoint_t u = info.codepoint;
|
||||||
unsigned int type = hb_indic_get_categories (u);
|
unsigned int type = hb_indic_get_categories (u);
|
||||||
khmer_category_t cat = (khmer_category_t) (type & 0xFFu);
|
|
||||||
|
|
||||||
/*
|
info.khmer_category() = (khmer_category_t) (type & 0xFFu);
|
||||||
* Re-assign category
|
|
||||||
*
|
|
||||||
* These categories are experimentally extracted from what Uniscribe allows.
|
|
||||||
*/
|
|
||||||
switch (u)
|
|
||||||
{
|
|
||||||
case 0x179Au:
|
|
||||||
cat = (khmer_category_t) K_Cat(Ra);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 0x17CCu:
|
|
||||||
case 0x17C9u:
|
|
||||||
case 0x17CAu:
|
|
||||||
cat = K_Cat(Robatic);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 0x17C6u:
|
|
||||||
case 0x17CBu:
|
|
||||||
case 0x17CDu:
|
|
||||||
case 0x17CEu:
|
|
||||||
case 0x17CFu:
|
|
||||||
case 0x17D0u:
|
|
||||||
case 0x17D1u:
|
|
||||||
cat = K_Cat(Xgroup);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 0x17C7u:
|
|
||||||
case 0x17C8u:
|
|
||||||
case 0x17DDu:
|
|
||||||
case 0x17D3u: /* Just guessing. Uniscribe doesn't categorize it. */
|
|
||||||
cat = K_Cat(Ygroup);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
info.khmer_category() = cat;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
Loading…
Reference in New Issue