ttnameid.h 60 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237
  1. /***************************************************************************/
  2. /* */
  3. /* ttnameid.h */
  4. /* */
  5. /* TrueType name ID definitions (specification only). */
  6. /* */
  7. /* Copyright 1996-2004, 2006-2008, 2012, 2013 by */
  8. /* David Turner, Robert Wilhelm, and Werner Lemberg. */
  9. /* */
  10. /* This file is part of the FreeType project, and may only be used, */
  11. /* modified, and distributed under the terms of the FreeType project */
  12. /* license, LICENSE.TXT. By continuing to use, modify, or distribute */
  13. /* this file you indicate that you have read the license and */
  14. /* understand and accept it fully. */
  15. /* */
  16. /***************************************************************************/
  17. #ifndef __TTNAMEID_H__
  18. #define __TTNAMEID_H__
  19. #include <ft2build.h>
  20. FT_BEGIN_HEADER
  21. /*************************************************************************/
  22. /* */
  23. /* <Section> */
  24. /* truetype_tables */
  25. /* */
  26. /*************************************************************************/
  27. /* */
  28. /* Possible values for the `platform' identifier code in the name */
  29. /* records of the TTF `name' table. */
  30. /* */
  31. /*************************************************************************/
  32. /***********************************************************************
  33. *
  34. * @enum:
  35. * TT_PLATFORM_XXX
  36. *
  37. * @description:
  38. * A list of valid values for the `platform_id' identifier code in
  39. * @FT_CharMapRec and @FT_SfntName structures.
  40. *
  41. * @values:
  42. * TT_PLATFORM_APPLE_UNICODE ::
  43. * Used by Apple to indicate a Unicode character map and/or name entry.
  44. * See @TT_APPLE_ID_XXX for corresponding `encoding_id' values. Note
  45. * that name entries in this format are coded as big-endian UCS-2
  46. * character codes _only_.
  47. *
  48. * TT_PLATFORM_MACINTOSH ::
  49. * Used by Apple to indicate a MacOS-specific charmap and/or name entry.
  50. * See @TT_MAC_ID_XXX for corresponding `encoding_id' values. Note that
  51. * most TrueType fonts contain an Apple roman charmap to be usable on
  52. * MacOS systems (even if they contain a Microsoft charmap as well).
  53. *
  54. * TT_PLATFORM_ISO ::
  55. * This value was used to specify ISO/IEC 10646 charmaps. It is however
  56. * now deprecated. See @TT_ISO_ID_XXX for a list of corresponding
  57. * `encoding_id' values.
  58. *
  59. * TT_PLATFORM_MICROSOFT ::
  60. * Used by Microsoft to indicate Windows-specific charmaps. See
  61. * @TT_MS_ID_XXX for a list of corresponding `encoding_id' values.
  62. * Note that most fonts contain a Unicode charmap using
  63. * (TT_PLATFORM_MICROSOFT, @TT_MS_ID_UNICODE_CS).
  64. *
  65. * TT_PLATFORM_CUSTOM ::
  66. * Used to indicate application-specific charmaps.
  67. *
  68. * TT_PLATFORM_ADOBE ::
  69. * This value isn't part of any font format specification, but is used
  70. * by FreeType to report Adobe-specific charmaps in an @FT_CharMapRec
  71. * structure. See @TT_ADOBE_ID_XXX.
  72. */
  73. #define TT_PLATFORM_APPLE_UNICODE 0
  74. #define TT_PLATFORM_MACINTOSH 1
  75. #define TT_PLATFORM_ISO 2 /* deprecated */
  76. #define TT_PLATFORM_MICROSOFT 3
  77. #define TT_PLATFORM_CUSTOM 4
  78. #define TT_PLATFORM_ADOBE 7 /* artificial */
  79. /***********************************************************************
  80. *
  81. * @enum:
  82. * TT_APPLE_ID_XXX
  83. *
  84. * @description:
  85. * A list of valid values for the `encoding_id' for
  86. * @TT_PLATFORM_APPLE_UNICODE charmaps and name entries.
  87. *
  88. * @values:
  89. * TT_APPLE_ID_DEFAULT ::
  90. * Unicode version 1.0.
  91. *
  92. * TT_APPLE_ID_UNICODE_1_1 ::
  93. * Unicode 1.1; specifies Hangul characters starting at U+34xx.
  94. *
  95. * TT_APPLE_ID_ISO_10646 ::
  96. * Deprecated (identical to preceding).
  97. *
  98. * TT_APPLE_ID_UNICODE_2_0 ::
  99. * Unicode 2.0 and beyond (UTF-16 BMP only).
  100. *
  101. * TT_APPLE_ID_UNICODE_32 ::
  102. * Unicode 3.1 and beyond, using UTF-32.
  103. *
  104. * TT_APPLE_ID_VARIANT_SELECTOR ::
  105. * From Adobe, not Apple. Not a normal cmap. Specifies variations
  106. * on a real cmap.
  107. */
  108. #define TT_APPLE_ID_DEFAULT 0 /* Unicode 1.0 */
  109. #define TT_APPLE_ID_UNICODE_1_1 1 /* specify Hangul at U+34xx */
  110. #define TT_APPLE_ID_ISO_10646 2 /* deprecated */
  111. #define TT_APPLE_ID_UNICODE_2_0 3 /* or later */
  112. #define TT_APPLE_ID_UNICODE_32 4 /* 2.0 or later, full repertoire */
  113. #define TT_APPLE_ID_VARIANT_SELECTOR 5 /* variation selector data */
  114. /***********************************************************************
  115. *
  116. * @enum:
  117. * TT_MAC_ID_XXX
  118. *
  119. * @description:
  120. * A list of valid values for the `encoding_id' for
  121. * @TT_PLATFORM_MACINTOSH charmaps and name entries.
  122. *
  123. * @values:
  124. * TT_MAC_ID_ROMAN ::
  125. * TT_MAC_ID_JAPANESE ::
  126. * TT_MAC_ID_TRADITIONAL_CHINESE ::
  127. * TT_MAC_ID_KOREAN ::
  128. * TT_MAC_ID_ARABIC ::
  129. * TT_MAC_ID_HEBREW ::
  130. * TT_MAC_ID_GREEK ::
  131. * TT_MAC_ID_RUSSIAN ::
  132. * TT_MAC_ID_RSYMBOL ::
  133. * TT_MAC_ID_DEVANAGARI ::
  134. * TT_MAC_ID_GURMUKHI ::
  135. * TT_MAC_ID_GUJARATI ::
  136. * TT_MAC_ID_ORIYA ::
  137. * TT_MAC_ID_BENGALI ::
  138. * TT_MAC_ID_TAMIL ::
  139. * TT_MAC_ID_TELUGU ::
  140. * TT_MAC_ID_KANNADA ::
  141. * TT_MAC_ID_MALAYALAM ::
  142. * TT_MAC_ID_SINHALESE ::
  143. * TT_MAC_ID_BURMESE ::
  144. * TT_MAC_ID_KHMER ::
  145. * TT_MAC_ID_THAI ::
  146. * TT_MAC_ID_LAOTIAN ::
  147. * TT_MAC_ID_GEORGIAN ::
  148. * TT_MAC_ID_ARMENIAN ::
  149. * TT_MAC_ID_MALDIVIAN ::
  150. * TT_MAC_ID_SIMPLIFIED_CHINESE ::
  151. * TT_MAC_ID_TIBETAN ::
  152. * TT_MAC_ID_MONGOLIAN ::
  153. * TT_MAC_ID_GEEZ ::
  154. * TT_MAC_ID_SLAVIC ::
  155. * TT_MAC_ID_VIETNAMESE ::
  156. * TT_MAC_ID_SINDHI ::
  157. * TT_MAC_ID_UNINTERP ::
  158. */
  159. #define TT_MAC_ID_ROMAN 0
  160. #define TT_MAC_ID_JAPANESE 1
  161. #define TT_MAC_ID_TRADITIONAL_CHINESE 2
  162. #define TT_MAC_ID_KOREAN 3
  163. #define TT_MAC_ID_ARABIC 4
  164. #define TT_MAC_ID_HEBREW 5
  165. #define TT_MAC_ID_GREEK 6
  166. #define TT_MAC_ID_RUSSIAN 7
  167. #define TT_MAC_ID_RSYMBOL 8
  168. #define TT_MAC_ID_DEVANAGARI 9
  169. #define TT_MAC_ID_GURMUKHI 10
  170. #define TT_MAC_ID_GUJARATI 11
  171. #define TT_MAC_ID_ORIYA 12
  172. #define TT_MAC_ID_BENGALI 13
  173. #define TT_MAC_ID_TAMIL 14
  174. #define TT_MAC_ID_TELUGU 15
  175. #define TT_MAC_ID_KANNADA 16
  176. #define TT_MAC_ID_MALAYALAM 17
  177. #define TT_MAC_ID_SINHALESE 18
  178. #define TT_MAC_ID_BURMESE 19
  179. #define TT_MAC_ID_KHMER 20
  180. #define TT_MAC_ID_THAI 21
  181. #define TT_MAC_ID_LAOTIAN 22
  182. #define TT_MAC_ID_GEORGIAN 23
  183. #define TT_MAC_ID_ARMENIAN 24
  184. #define TT_MAC_ID_MALDIVIAN 25
  185. #define TT_MAC_ID_SIMPLIFIED_CHINESE 25
  186. #define TT_MAC_ID_TIBETAN 26
  187. #define TT_MAC_ID_MONGOLIAN 27
  188. #define TT_MAC_ID_GEEZ 28
  189. #define TT_MAC_ID_SLAVIC 29
  190. #define TT_MAC_ID_VIETNAMESE 30
  191. #define TT_MAC_ID_SINDHI 31
  192. #define TT_MAC_ID_UNINTERP 32
  193. /***********************************************************************
  194. *
  195. * @enum:
  196. * TT_ISO_ID_XXX
  197. *
  198. * @description:
  199. * A list of valid values for the `encoding_id' for
  200. * @TT_PLATFORM_ISO charmaps and name entries.
  201. *
  202. * Their use is now deprecated.
  203. *
  204. * @values:
  205. * TT_ISO_ID_7BIT_ASCII ::
  206. * ASCII.
  207. * TT_ISO_ID_10646 ::
  208. * ISO/10646.
  209. * TT_ISO_ID_8859_1 ::
  210. * Also known as Latin-1.
  211. */
  212. #define TT_ISO_ID_7BIT_ASCII 0
  213. #define TT_ISO_ID_10646 1
  214. #define TT_ISO_ID_8859_1 2
  215. /***********************************************************************
  216. *
  217. * @enum:
  218. * TT_MS_ID_XXX
  219. *
  220. * @description:
  221. * A list of valid values for the `encoding_id' for
  222. * @TT_PLATFORM_MICROSOFT charmaps and name entries.
  223. *
  224. * @values:
  225. * TT_MS_ID_SYMBOL_CS ::
  226. * Corresponds to Microsoft symbol encoding. See
  227. * @FT_ENCODING_MS_SYMBOL.
  228. *
  229. * TT_MS_ID_UNICODE_CS ::
  230. * Corresponds to a Microsoft WGL4 charmap, matching Unicode. See
  231. * @FT_ENCODING_UNICODE.
  232. *
  233. * TT_MS_ID_SJIS ::
  234. * Corresponds to SJIS Japanese encoding. See @FT_ENCODING_SJIS.
  235. *
  236. * TT_MS_ID_GB2312 ::
  237. * Corresponds to Simplified Chinese as used in Mainland China. See
  238. * @FT_ENCODING_GB2312.
  239. *
  240. * TT_MS_ID_BIG_5 ::
  241. * Corresponds to Traditional Chinese as used in Taiwan and Hong Kong.
  242. * See @FT_ENCODING_BIG5.
  243. *
  244. * TT_MS_ID_WANSUNG ::
  245. * Corresponds to Korean Wansung encoding. See @FT_ENCODING_WANSUNG.
  246. *
  247. * TT_MS_ID_JOHAB ::
  248. * Corresponds to Johab encoding. See @FT_ENCODING_JOHAB.
  249. *
  250. * TT_MS_ID_UCS_4 ::
  251. * Corresponds to UCS-4 or UTF-32 charmaps. This has been added to
  252. * the OpenType specification version 1.4 (mid-2001.)
  253. */
  254. #define TT_MS_ID_SYMBOL_CS 0
  255. #define TT_MS_ID_UNICODE_CS 1
  256. #define TT_MS_ID_SJIS 2
  257. #define TT_MS_ID_GB2312 3
  258. #define TT_MS_ID_BIG_5 4
  259. #define TT_MS_ID_WANSUNG 5
  260. #define TT_MS_ID_JOHAB 6
  261. #define TT_MS_ID_UCS_4 10
  262. /***********************************************************************
  263. *
  264. * @enum:
  265. * TT_ADOBE_ID_XXX
  266. *
  267. * @description:
  268. * A list of valid values for the `encoding_id' for
  269. * @TT_PLATFORM_ADOBE charmaps. This is a FreeType-specific extension!
  270. *
  271. * @values:
  272. * TT_ADOBE_ID_STANDARD ::
  273. * Adobe standard encoding.
  274. * TT_ADOBE_ID_EXPERT ::
  275. * Adobe expert encoding.
  276. * TT_ADOBE_ID_CUSTOM ::
  277. * Adobe custom encoding.
  278. * TT_ADOBE_ID_LATIN_1 ::
  279. * Adobe Latin~1 encoding.
  280. */
  281. #define TT_ADOBE_ID_STANDARD 0
  282. #define TT_ADOBE_ID_EXPERT 1
  283. #define TT_ADOBE_ID_CUSTOM 2
  284. #define TT_ADOBE_ID_LATIN_1 3
  285. /*************************************************************************/
  286. /* */
  287. /* Possible values of the language identifier field in the name records */
  288. /* of the TTF `name' table if the `platform' identifier code is */
  289. /* TT_PLATFORM_MACINTOSH. These values are also used as return values */
  290. /* for function @FT_Get_CMap_Language_ID. */
  291. /* */
  292. /* The canonical source for the Apple assigned Language ID's is at */
  293. /* */
  294. /* https://developer.apple.com/fonts/TTRefMan/RM06/Chap6name.html */
  295. /* */
  296. #define TT_MAC_LANGID_ENGLISH 0
  297. #define TT_MAC_LANGID_FRENCH 1
  298. #define TT_MAC_LANGID_GERMAN 2
  299. #define TT_MAC_LANGID_ITALIAN 3
  300. #define TT_MAC_LANGID_DUTCH 4
  301. #define TT_MAC_LANGID_SWEDISH 5
  302. #define TT_MAC_LANGID_SPANISH 6
  303. #define TT_MAC_LANGID_DANISH 7
  304. #define TT_MAC_LANGID_PORTUGUESE 8
  305. #define TT_MAC_LANGID_NORWEGIAN 9
  306. #define TT_MAC_LANGID_HEBREW 10
  307. #define TT_MAC_LANGID_JAPANESE 11
  308. #define TT_MAC_LANGID_ARABIC 12
  309. #define TT_MAC_LANGID_FINNISH 13
  310. #define TT_MAC_LANGID_GREEK 14
  311. #define TT_MAC_LANGID_ICELANDIC 15
  312. #define TT_MAC_LANGID_MALTESE 16
  313. #define TT_MAC_LANGID_TURKISH 17
  314. #define TT_MAC_LANGID_CROATIAN 18
  315. #define TT_MAC_LANGID_CHINESE_TRADITIONAL 19
  316. #define TT_MAC_LANGID_URDU 20
  317. #define TT_MAC_LANGID_HINDI 21
  318. #define TT_MAC_LANGID_THAI 22
  319. #define TT_MAC_LANGID_KOREAN 23
  320. #define TT_MAC_LANGID_LITHUANIAN 24
  321. #define TT_MAC_LANGID_POLISH 25
  322. #define TT_MAC_LANGID_HUNGARIAN 26
  323. #define TT_MAC_LANGID_ESTONIAN 27
  324. #define TT_MAC_LANGID_LETTISH 28
  325. #define TT_MAC_LANGID_SAAMISK 29
  326. #define TT_MAC_LANGID_FAEROESE 30
  327. #define TT_MAC_LANGID_FARSI 31
  328. #define TT_MAC_LANGID_RUSSIAN 32
  329. #define TT_MAC_LANGID_CHINESE_SIMPLIFIED 33
  330. #define TT_MAC_LANGID_FLEMISH 34
  331. #define TT_MAC_LANGID_IRISH 35
  332. #define TT_MAC_LANGID_ALBANIAN 36
  333. #define TT_MAC_LANGID_ROMANIAN 37
  334. #define TT_MAC_LANGID_CZECH 38
  335. #define TT_MAC_LANGID_SLOVAK 39
  336. #define TT_MAC_LANGID_SLOVENIAN 40
  337. #define TT_MAC_LANGID_YIDDISH 41
  338. #define TT_MAC_LANGID_SERBIAN 42
  339. #define TT_MAC_LANGID_MACEDONIAN 43
  340. #define TT_MAC_LANGID_BULGARIAN 44
  341. #define TT_MAC_LANGID_UKRAINIAN 45
  342. #define TT_MAC_LANGID_BYELORUSSIAN 46
  343. #define TT_MAC_LANGID_UZBEK 47
  344. #define TT_MAC_LANGID_KAZAKH 48
  345. #define TT_MAC_LANGID_AZERBAIJANI 49
  346. #define TT_MAC_LANGID_AZERBAIJANI_CYRILLIC_SCRIPT 49
  347. #define TT_MAC_LANGID_AZERBAIJANI_ARABIC_SCRIPT 50
  348. #define TT_MAC_LANGID_ARMENIAN 51
  349. #define TT_MAC_LANGID_GEORGIAN 52
  350. #define TT_MAC_LANGID_MOLDAVIAN 53
  351. #define TT_MAC_LANGID_KIRGHIZ 54
  352. #define TT_MAC_LANGID_TAJIKI 55
  353. #define TT_MAC_LANGID_TURKMEN 56
  354. #define TT_MAC_LANGID_MONGOLIAN 57
  355. #define TT_MAC_LANGID_MONGOLIAN_MONGOLIAN_SCRIPT 57
  356. #define TT_MAC_LANGID_MONGOLIAN_CYRILLIC_SCRIPT 58
  357. #define TT_MAC_LANGID_PASHTO 59
  358. #define TT_MAC_LANGID_KURDISH 60
  359. #define TT_MAC_LANGID_KASHMIRI 61
  360. #define TT_MAC_LANGID_SINDHI 62
  361. #define TT_MAC_LANGID_TIBETAN 63
  362. #define TT_MAC_LANGID_NEPALI 64
  363. #define TT_MAC_LANGID_SANSKRIT 65
  364. #define TT_MAC_LANGID_MARATHI 66
  365. #define TT_MAC_LANGID_BENGALI 67
  366. #define TT_MAC_LANGID_ASSAMESE 68
  367. #define TT_MAC_LANGID_GUJARATI 69
  368. #define TT_MAC_LANGID_PUNJABI 70
  369. #define TT_MAC_LANGID_ORIYA 71
  370. #define TT_MAC_LANGID_MALAYALAM 72
  371. #define TT_MAC_LANGID_KANNADA 73
  372. #define TT_MAC_LANGID_TAMIL 74
  373. #define TT_MAC_LANGID_TELUGU 75
  374. #define TT_MAC_LANGID_SINHALESE 76
  375. #define TT_MAC_LANGID_BURMESE 77
  376. #define TT_MAC_LANGID_KHMER 78
  377. #define TT_MAC_LANGID_LAO 79
  378. #define TT_MAC_LANGID_VIETNAMESE 80
  379. #define TT_MAC_LANGID_INDONESIAN 81
  380. #define TT_MAC_LANGID_TAGALOG 82
  381. #define TT_MAC_LANGID_MALAY_ROMAN_SCRIPT 83
  382. #define TT_MAC_LANGID_MALAY_ARABIC_SCRIPT 84
  383. #define TT_MAC_LANGID_AMHARIC 85
  384. #define TT_MAC_LANGID_TIGRINYA 86
  385. #define TT_MAC_LANGID_GALLA 87
  386. #define TT_MAC_LANGID_SOMALI 88
  387. #define TT_MAC_LANGID_SWAHILI 89
  388. #define TT_MAC_LANGID_RUANDA 90
  389. #define TT_MAC_LANGID_RUNDI 91
  390. #define TT_MAC_LANGID_CHEWA 92
  391. #define TT_MAC_LANGID_MALAGASY 93
  392. #define TT_MAC_LANGID_ESPERANTO 94
  393. #define TT_MAC_LANGID_WELSH 128
  394. #define TT_MAC_LANGID_BASQUE 129
  395. #define TT_MAC_LANGID_CATALAN 130
  396. #define TT_MAC_LANGID_LATIN 131
  397. #define TT_MAC_LANGID_QUECHUA 132
  398. #define TT_MAC_LANGID_GUARANI 133
  399. #define TT_MAC_LANGID_AYMARA 134
  400. #define TT_MAC_LANGID_TATAR 135
  401. #define TT_MAC_LANGID_UIGHUR 136
  402. #define TT_MAC_LANGID_DZONGKHA 137
  403. #define TT_MAC_LANGID_JAVANESE 138
  404. #define TT_MAC_LANGID_SUNDANESE 139
  405. #if 0 /* these seem to be errors that have been dropped */
  406. #define TT_MAC_LANGID_SCOTTISH_GAELIC 140
  407. #define TT_MAC_LANGID_IRISH_GAELIC 141
  408. #endif
  409. /* The following codes are new as of 2000-03-10 */
  410. #define TT_MAC_LANGID_GALICIAN 140
  411. #define TT_MAC_LANGID_AFRIKAANS 141
  412. #define TT_MAC_LANGID_BRETON 142
  413. #define TT_MAC_LANGID_INUKTITUT 143
  414. #define TT_MAC_LANGID_SCOTTISH_GAELIC 144
  415. #define TT_MAC_LANGID_MANX_GAELIC 145
  416. #define TT_MAC_LANGID_IRISH_GAELIC 146
  417. #define TT_MAC_LANGID_TONGAN 147
  418. #define TT_MAC_LANGID_GREEK_POLYTONIC 148
  419. #define TT_MAC_LANGID_GREELANDIC 149
  420. #define TT_MAC_LANGID_AZERBAIJANI_ROMAN_SCRIPT 150
  421. /*************************************************************************/
  422. /* */
  423. /* Possible values of the language identifier field in the name records */
  424. /* of the TTF `name' table if the `platform' identifier code is */
  425. /* TT_PLATFORM_MICROSOFT. */
  426. /* */
  427. /* The canonical source for the MS assigned LCIDs is */
  428. /* */
  429. /* http://www.microsoft.com/globaldev/reference/lcid-all.mspx */
  430. /* */
  431. #define TT_MS_LANGID_ARABIC_GENERAL 0x0001
  432. #define TT_MS_LANGID_ARABIC_SAUDI_ARABIA 0x0401
  433. #define TT_MS_LANGID_ARABIC_IRAQ 0x0801
  434. #define TT_MS_LANGID_ARABIC_EGYPT 0x0c01
  435. #define TT_MS_LANGID_ARABIC_LIBYA 0x1001
  436. #define TT_MS_LANGID_ARABIC_ALGERIA 0x1401
  437. #define TT_MS_LANGID_ARABIC_MOROCCO 0x1801
  438. #define TT_MS_LANGID_ARABIC_TUNISIA 0x1c01
  439. #define TT_MS_LANGID_ARABIC_OMAN 0x2001
  440. #define TT_MS_LANGID_ARABIC_YEMEN 0x2401
  441. #define TT_MS_LANGID_ARABIC_SYRIA 0x2801
  442. #define TT_MS_LANGID_ARABIC_JORDAN 0x2c01
  443. #define TT_MS_LANGID_ARABIC_LEBANON 0x3001
  444. #define TT_MS_LANGID_ARABIC_KUWAIT 0x3401
  445. #define TT_MS_LANGID_ARABIC_UAE 0x3801
  446. #define TT_MS_LANGID_ARABIC_BAHRAIN 0x3c01
  447. #define TT_MS_LANGID_ARABIC_QATAR 0x4001
  448. #define TT_MS_LANGID_BULGARIAN_BULGARIA 0x0402
  449. #define TT_MS_LANGID_CATALAN_SPAIN 0x0403
  450. #define TT_MS_LANGID_CHINESE_GENERAL 0x0004
  451. #define TT_MS_LANGID_CHINESE_TAIWAN 0x0404
  452. #define TT_MS_LANGID_CHINESE_PRC 0x0804
  453. #define TT_MS_LANGID_CHINESE_HONG_KONG 0x0c04
  454. #define TT_MS_LANGID_CHINESE_SINGAPORE 0x1004
  455. #if 1 /* this looks like the correct value */
  456. #define TT_MS_LANGID_CHINESE_MACAU 0x1404
  457. #else /* but beware, Microsoft may change its mind...
  458. the most recent Word reference has the following: */
  459. #define TT_MS_LANGID_CHINESE_MACAU TT_MS_LANGID_CHINESE_HONG_KONG
  460. #endif
  461. #if 0 /* used only with .NET `cultures'; commented out */
  462. #define TT_MS_LANGID_CHINESE_TRADITIONAL 0x7C04
  463. #endif
  464. #define TT_MS_LANGID_CZECH_CZECH_REPUBLIC 0x0405
  465. #define TT_MS_LANGID_DANISH_DENMARK 0x0406
  466. #define TT_MS_LANGID_GERMAN_GERMANY 0x0407
  467. #define TT_MS_LANGID_GERMAN_SWITZERLAND 0x0807
  468. #define TT_MS_LANGID_GERMAN_AUSTRIA 0x0c07
  469. #define TT_MS_LANGID_GERMAN_LUXEMBOURG 0x1007
  470. #define TT_MS_LANGID_GERMAN_LIECHTENSTEI 0x1407
  471. #define TT_MS_LANGID_GREEK_GREECE 0x0408
  472. /* don't ask what this one means... It is commented out currently. */
  473. #if 0
  474. #define TT_MS_LANGID_GREEK_GREECE2 0x2008
  475. #endif
  476. #define TT_MS_LANGID_ENGLISH_GENERAL 0x0009
  477. #define TT_MS_LANGID_ENGLISH_UNITED_STATES 0x0409
  478. #define TT_MS_LANGID_ENGLISH_UNITED_KINGDOM 0x0809
  479. #define TT_MS_LANGID_ENGLISH_AUSTRALIA 0x0c09
  480. #define TT_MS_LANGID_ENGLISH_CANADA 0x1009
  481. #define TT_MS_LANGID_ENGLISH_NEW_ZEALAND 0x1409
  482. #define TT_MS_LANGID_ENGLISH_IRELAND 0x1809
  483. #define TT_MS_LANGID_ENGLISH_SOUTH_AFRICA 0x1c09
  484. #define TT_MS_LANGID_ENGLISH_JAMAICA 0x2009
  485. #define TT_MS_LANGID_ENGLISH_CARIBBEAN 0x2409
  486. #define TT_MS_LANGID_ENGLISH_BELIZE 0x2809
  487. #define TT_MS_LANGID_ENGLISH_TRINIDAD 0x2c09
  488. #define TT_MS_LANGID_ENGLISH_ZIMBABWE 0x3009
  489. #define TT_MS_LANGID_ENGLISH_PHILIPPINES 0x3409
  490. #define TT_MS_LANGID_ENGLISH_INDONESIA 0x3809
  491. #define TT_MS_LANGID_ENGLISH_HONG_KONG 0x3c09
  492. #define TT_MS_LANGID_ENGLISH_INDIA 0x4009
  493. #define TT_MS_LANGID_ENGLISH_MALAYSIA 0x4409
  494. #define TT_MS_LANGID_ENGLISH_SINGAPORE 0x4809
  495. #define TT_MS_LANGID_SPANISH_SPAIN_TRADITIONAL_SORT 0x040a
  496. #define TT_MS_LANGID_SPANISH_MEXICO 0x080a
  497. #define TT_MS_LANGID_SPANISH_SPAIN_INTERNATIONAL_SORT 0x0c0a
  498. #define TT_MS_LANGID_SPANISH_GUATEMALA 0x100a
  499. #define TT_MS_LANGID_SPANISH_COSTA_RICA 0x140a
  500. #define TT_MS_LANGID_SPANISH_PANAMA 0x180a
  501. #define TT_MS_LANGID_SPANISH_DOMINICAN_REPUBLIC 0x1c0a
  502. #define TT_MS_LANGID_SPANISH_VENEZUELA 0x200a
  503. #define TT_MS_LANGID_SPANISH_COLOMBIA 0x240a
  504. #define TT_MS_LANGID_SPANISH_PERU 0x280a
  505. #define TT_MS_LANGID_SPANISH_ARGENTINA 0x2c0a
  506. #define TT_MS_LANGID_SPANISH_ECUADOR 0x300a
  507. #define TT_MS_LANGID_SPANISH_CHILE 0x340a
  508. #define TT_MS_LANGID_SPANISH_URUGUAY 0x380a
  509. #define TT_MS_LANGID_SPANISH_PARAGUAY 0x3c0a
  510. #define TT_MS_LANGID_SPANISH_BOLIVIA 0x400a
  511. #define TT_MS_LANGID_SPANISH_EL_SALVADOR 0x440a
  512. #define TT_MS_LANGID_SPANISH_HONDURAS 0x480a
  513. #define TT_MS_LANGID_SPANISH_NICARAGUA 0x4c0a
  514. #define TT_MS_LANGID_SPANISH_PUERTO_RICO 0x500a
  515. #define TT_MS_LANGID_SPANISH_UNITED_STATES 0x540a
  516. /* The following ID blatantly violate MS specs by using a */
  517. /* sublanguage > 0x1F. */
  518. #define TT_MS_LANGID_SPANISH_LATIN_AMERICA 0xE40aU
  519. #define TT_MS_LANGID_FINNISH_FINLAND 0x040b
  520. #define TT_MS_LANGID_FRENCH_FRANCE 0x040c
  521. #define TT_MS_LANGID_FRENCH_BELGIUM 0x080c
  522. #define TT_MS_LANGID_FRENCH_CANADA 0x0c0c
  523. #define TT_MS_LANGID_FRENCH_SWITZERLAND 0x100c
  524. #define TT_MS_LANGID_FRENCH_LUXEMBOURG 0x140c
  525. #define TT_MS_LANGID_FRENCH_MONACO 0x180c
  526. #define TT_MS_LANGID_FRENCH_WEST_INDIES 0x1c0c
  527. #define TT_MS_LANGID_FRENCH_REUNION 0x200c
  528. #define TT_MS_LANGID_FRENCH_CONGO 0x240c
  529. /* which was formerly: */
  530. #define TT_MS_LANGID_FRENCH_ZAIRE TT_MS_LANGID_FRENCH_CONGO
  531. #define TT_MS_LANGID_FRENCH_SENEGAL 0x280c
  532. #define TT_MS_LANGID_FRENCH_CAMEROON 0x2c0c
  533. #define TT_MS_LANGID_FRENCH_COTE_D_IVOIRE 0x300c
  534. #define TT_MS_LANGID_FRENCH_MALI 0x340c
  535. #define TT_MS_LANGID_FRENCH_MOROCCO 0x380c
  536. #define TT_MS_LANGID_FRENCH_HAITI 0x3c0c
  537. /* and another violation of the spec (see 0xE40aU) */
  538. #define TT_MS_LANGID_FRENCH_NORTH_AFRICA 0xE40cU
  539. #define TT_MS_LANGID_HEBREW_ISRAEL 0x040d
  540. #define TT_MS_LANGID_HUNGARIAN_HUNGARY 0x040e
  541. #define TT_MS_LANGID_ICELANDIC_ICELAND 0x040f
  542. #define TT_MS_LANGID_ITALIAN_ITALY 0x0410
  543. #define TT_MS_LANGID_ITALIAN_SWITZERLAND 0x0810
  544. #define TT_MS_LANGID_JAPANESE_JAPAN 0x0411
  545. #define TT_MS_LANGID_KOREAN_EXTENDED_WANSUNG_KOREA 0x0412
  546. #define TT_MS_LANGID_KOREAN_JOHAB_KOREA 0x0812
  547. #define TT_MS_LANGID_DUTCH_NETHERLANDS 0x0413
  548. #define TT_MS_LANGID_DUTCH_BELGIUM 0x0813
  549. #define TT_MS_LANGID_NORWEGIAN_NORWAY_BOKMAL 0x0414
  550. #define TT_MS_LANGID_NORWEGIAN_NORWAY_NYNORSK 0x0814
  551. #define TT_MS_LANGID_POLISH_POLAND 0x0415
  552. #define TT_MS_LANGID_PORTUGUESE_BRAZIL 0x0416
  553. #define TT_MS_LANGID_PORTUGUESE_PORTUGAL 0x0816
  554. #define TT_MS_LANGID_RHAETO_ROMANIC_SWITZERLAND 0x0417
  555. #define TT_MS_LANGID_ROMANIAN_ROMANIA 0x0418
  556. #define TT_MS_LANGID_MOLDAVIAN_MOLDAVIA 0x0818
  557. #define TT_MS_LANGID_RUSSIAN_RUSSIA 0x0419
  558. #define TT_MS_LANGID_RUSSIAN_MOLDAVIA 0x0819
  559. #define TT_MS_LANGID_CROATIAN_CROATIA 0x041a
  560. #define TT_MS_LANGID_SERBIAN_SERBIA_LATIN 0x081a
  561. #define TT_MS_LANGID_SERBIAN_SERBIA_CYRILLIC 0x0c1a
  562. #if 0 /* this used to be this value, but it looks like we were wrong */
  563. #define TT_MS_LANGID_BOSNIAN_BOSNIA_HERZEGOVINA 0x101a
  564. #else /* current sources say */
  565. #define TT_MS_LANGID_CROATIAN_BOSNIA_HERZEGOVINA 0x101a
  566. #define TT_MS_LANGID_BOSNIAN_BOSNIA_HERZEGOVINA 0x141a
  567. /* and XPsp2 Platform SDK added (2004-07-26) */
  568. /* Names are shortened to be significant within 40 chars. */
  569. #define TT_MS_LANGID_SERBIAN_BOSNIA_HERZ_LATIN 0x181a
  570. #define TT_MS_LANGID_SERBIAN_BOSNIA_HERZ_CYRILLIC 0x181a
  571. #endif
  572. #define TT_MS_LANGID_SLOVAK_SLOVAKIA 0x041b
  573. #define TT_MS_LANGID_ALBANIAN_ALBANIA 0x041c
  574. #define TT_MS_LANGID_SWEDISH_SWEDEN 0x041d
  575. #define TT_MS_LANGID_SWEDISH_FINLAND 0x081d
  576. #define TT_MS_LANGID_THAI_THAILAND 0x041e
  577. #define TT_MS_LANGID_TURKISH_TURKEY 0x041f
  578. #define TT_MS_LANGID_URDU_PAKISTAN 0x0420
  579. #define TT_MS_LANGID_URDU_INDIA 0x0820
  580. #define TT_MS_LANGID_INDONESIAN_INDONESIA 0x0421
  581. #define TT_MS_LANGID_UKRAINIAN_UKRAINE 0x0422
  582. #define TT_MS_LANGID_BELARUSIAN_BELARUS 0x0423
  583. #define TT_MS_LANGID_SLOVENE_SLOVENIA 0x0424
  584. #define TT_MS_LANGID_ESTONIAN_ESTONIA 0x0425
  585. #define TT_MS_LANGID_LATVIAN_LATVIA 0x0426
  586. #define TT_MS_LANGID_LITHUANIAN_LITHUANIA 0x0427
  587. #define TT_MS_LANGID_CLASSIC_LITHUANIAN_LITHUANIA 0x0827
  588. #define TT_MS_LANGID_TAJIK_TAJIKISTAN 0x0428
  589. #define TT_MS_LANGID_FARSI_IRAN 0x0429
  590. #define TT_MS_LANGID_VIETNAMESE_VIET_NAM 0x042a
  591. #define TT_MS_LANGID_ARMENIAN_ARMENIA 0x042b
  592. #define TT_MS_LANGID_AZERI_AZERBAIJAN_LATIN 0x042c
  593. #define TT_MS_LANGID_AZERI_AZERBAIJAN_CYRILLIC 0x082c
  594. #define TT_MS_LANGID_BASQUE_SPAIN 0x042d
  595. #define TT_MS_LANGID_SORBIAN_GERMANY 0x042e
  596. #define TT_MS_LANGID_MACEDONIAN_MACEDONIA 0x042f
  597. #define TT_MS_LANGID_SUTU_SOUTH_AFRICA 0x0430
  598. #define TT_MS_LANGID_TSONGA_SOUTH_AFRICA 0x0431
  599. #define TT_MS_LANGID_TSWANA_SOUTH_AFRICA 0x0432
  600. #define TT_MS_LANGID_VENDA_SOUTH_AFRICA 0x0433
  601. #define TT_MS_LANGID_XHOSA_SOUTH_AFRICA 0x0434
  602. #define TT_MS_LANGID_ZULU_SOUTH_AFRICA 0x0435
  603. #define TT_MS_LANGID_AFRIKAANS_SOUTH_AFRICA 0x0436
  604. #define TT_MS_LANGID_GEORGIAN_GEORGIA 0x0437
  605. #define TT_MS_LANGID_FAEROESE_FAEROE_ISLANDS 0x0438
  606. #define TT_MS_LANGID_HINDI_INDIA 0x0439
  607. #define TT_MS_LANGID_MALTESE_MALTA 0x043a
  608. /* Added by XPsp2 Platform SDK (2004-07-26) */
  609. #define TT_MS_LANGID_SAMI_NORTHERN_NORWAY 0x043b
  610. #define TT_MS_LANGID_SAMI_NORTHERN_SWEDEN 0x083b
  611. #define TT_MS_LANGID_SAMI_NORTHERN_FINLAND 0x0C3b
  612. #define TT_MS_LANGID_SAMI_LULE_NORWAY 0x103b
  613. #define TT_MS_LANGID_SAMI_LULE_SWEDEN 0x143b
  614. #define TT_MS_LANGID_SAMI_SOUTHERN_NORWAY 0x183b
  615. #define TT_MS_LANGID_SAMI_SOUTHERN_SWEDEN 0x1C3b
  616. #define TT_MS_LANGID_SAMI_SKOLT_FINLAND 0x203b
  617. #define TT_MS_LANGID_SAMI_INARI_FINLAND 0x243b
  618. /* ... and we also keep our old identifier... */
  619. #define TT_MS_LANGID_SAAMI_LAPONIA 0x043b
  620. #if 0 /* this seems to be a previous inversion */
  621. #define TT_MS_LANGID_IRISH_GAELIC_IRELAND 0x043c
  622. #define TT_MS_LANGID_SCOTTISH_GAELIC_UNITED_KINGDOM 0x083c
  623. #else
  624. #define TT_MS_LANGID_SCOTTISH_GAELIC_UNITED_KINGDOM 0x083c
  625. #define TT_MS_LANGID_IRISH_GAELIC_IRELAND 0x043c
  626. #endif
  627. #define TT_MS_LANGID_YIDDISH_GERMANY 0x043d
  628. #define TT_MS_LANGID_MALAY_MALAYSIA 0x043e
  629. #define TT_MS_LANGID_MALAY_BRUNEI_DARUSSALAM 0x083e
  630. #define TT_MS_LANGID_KAZAK_KAZAKSTAN 0x043f
  631. #define TT_MS_LANGID_KIRGHIZ_KIRGHIZSTAN /* Cyrillic*/ 0x0440
  632. /* alias declared in Windows 2000 */
  633. #define TT_MS_LANGID_KIRGHIZ_KIRGHIZ_REPUBLIC \
  634. TT_MS_LANGID_KIRGHIZ_KIRGHIZSTAN
  635. #define TT_MS_LANGID_SWAHILI_KENYA 0x0441
  636. #define TT_MS_LANGID_TURKMEN_TURKMENISTAN 0x0442
  637. #define TT_MS_LANGID_UZBEK_UZBEKISTAN_LATIN 0x0443
  638. #define TT_MS_LANGID_UZBEK_UZBEKISTAN_CYRILLIC 0x0843
  639. #define TT_MS_LANGID_TATAR_TATARSTAN 0x0444
  640. #define TT_MS_LANGID_BENGALI_INDIA 0x0445
  641. #define TT_MS_LANGID_BENGALI_BANGLADESH 0x0845
  642. #define TT_MS_LANGID_PUNJABI_INDIA 0x0446
  643. #define TT_MS_LANGID_PUNJABI_ARABIC_PAKISTAN 0x0846
  644. #define TT_MS_LANGID_GUJARATI_INDIA 0x0447
  645. #define TT_MS_LANGID_ORIYA_INDIA 0x0448
  646. #define TT_MS_LANGID_TAMIL_INDIA 0x0449
  647. #define TT_MS_LANGID_TELUGU_INDIA 0x044a
  648. #define TT_MS_LANGID_KANNADA_INDIA 0x044b
  649. #define TT_MS_LANGID_MALAYALAM_INDIA 0x044c
  650. #define TT_MS_LANGID_ASSAMESE_INDIA 0x044d
  651. #define TT_MS_LANGID_MARATHI_INDIA 0x044e
  652. #define TT_MS_LANGID_SANSKRIT_INDIA 0x044f
  653. #define TT_MS_LANGID_MONGOLIAN_MONGOLIA /* Cyrillic */ 0x0450
  654. #define TT_MS_LANGID_MONGOLIAN_MONGOLIA_MONGOLIAN 0x0850
  655. #define TT_MS_LANGID_TIBETAN_CHINA 0x0451
  656. /* Don't use the next constant! It has */
  657. /* (1) the wrong spelling (Dzonghka) */
  658. /* (2) Microsoft doesn't officially define it -- */
  659. /* at least it is not in the List of Local */
  660. /* ID Values. */
  661. /* (3) Dzongkha is not the same language as */
  662. /* Tibetan, so merging it is wrong anyway. */
  663. /* */
  664. /* TT_MS_LANGID_TIBETAN_BHUTAN is correct, BTW. */
  665. #define TT_MS_LANGID_DZONGHKA_BHUTAN 0x0851
  666. #if 0
  667. /* the following used to be defined */
  668. #define TT_MS_LANGID_TIBETAN_BHUTAN 0x0451
  669. /* ... but it was changed; */
  670. #else
  671. /* So we will continue to #define it, but with the correct value */
  672. #define TT_MS_LANGID_TIBETAN_BHUTAN TT_MS_LANGID_DZONGHKA_BHUTAN
  673. #endif
  674. #define TT_MS_LANGID_WELSH_WALES 0x0452
  675. #define TT_MS_LANGID_KHMER_CAMBODIA 0x0453
  676. #define TT_MS_LANGID_LAO_LAOS 0x0454
  677. #define TT_MS_LANGID_BURMESE_MYANMAR 0x0455
  678. #define TT_MS_LANGID_GALICIAN_SPAIN 0x0456
  679. #define TT_MS_LANGID_KONKANI_INDIA 0x0457
  680. #define TT_MS_LANGID_MANIPURI_INDIA /* Bengali */ 0x0458
  681. #define TT_MS_LANGID_SINDHI_INDIA /* Arabic */ 0x0459
  682. #define TT_MS_LANGID_SINDHI_PAKISTAN 0x0859
  683. /* Missing a LCID for Sindhi in Devanagari script */
  684. #define TT_MS_LANGID_SYRIAC_SYRIA 0x045a
  685. #define TT_MS_LANGID_SINHALESE_SRI_LANKA 0x045b
  686. #define TT_MS_LANGID_CHEROKEE_UNITED_STATES 0x045c
  687. #define TT_MS_LANGID_INUKTITUT_CANADA 0x045d
  688. #define TT_MS_LANGID_AMHARIC_ETHIOPIA 0x045e
  689. #define TT_MS_LANGID_TAMAZIGHT_MOROCCO /* Arabic */ 0x045f
  690. #define TT_MS_LANGID_TAMAZIGHT_MOROCCO_LATIN 0x085f
  691. /* Missing a LCID for Tifinagh script */
  692. #define TT_MS_LANGID_KASHMIRI_PAKISTAN /* Arabic */ 0x0460
  693. /* Spelled this way by XPsp2 Platform SDK (2004-07-26) */
  694. /* script is yet unclear... might be Arabic, Nagari or Sharada */
  695. #define TT_MS_LANGID_KASHMIRI_SASIA 0x0860
  696. /* ... and aliased (by MS) for compatibility reasons. */
  697. #define TT_MS_LANGID_KASHMIRI_INDIA TT_MS_LANGID_KASHMIRI_SASIA
  698. #define TT_MS_LANGID_NEPALI_NEPAL 0x0461
  699. #define TT_MS_LANGID_NEPALI_INDIA 0x0861
  700. #define TT_MS_LANGID_FRISIAN_NETHERLANDS 0x0462
  701. #define TT_MS_LANGID_PASHTO_AFGHANISTAN 0x0463
  702. #define TT_MS_LANGID_FILIPINO_PHILIPPINES 0x0464
  703. #define TT_MS_LANGID_DHIVEHI_MALDIVES 0x0465
  704. /* alias declared in Windows 2000 */
  705. #define TT_MS_LANGID_DIVEHI_MALDIVES TT_MS_LANGID_DHIVEHI_MALDIVES
  706. #define TT_MS_LANGID_EDO_NIGERIA 0x0466
  707. #define TT_MS_LANGID_FULFULDE_NIGERIA 0x0467
  708. #define TT_MS_LANGID_HAUSA_NIGERIA 0x0468
  709. #define TT_MS_LANGID_IBIBIO_NIGERIA 0x0469
  710. #define TT_MS_LANGID_YORUBA_NIGERIA 0x046a
  711. #define TT_MS_LANGID_QUECHUA_BOLIVIA 0x046b
  712. #define TT_MS_LANGID_QUECHUA_ECUADOR 0x086b
  713. #define TT_MS_LANGID_QUECHUA_PERU 0x0c6b
  714. #define TT_MS_LANGID_SEPEDI_SOUTH_AFRICA 0x046c
  715. /* Also spelled by XPsp2 Platform SDK (2004-07-26) */
  716. #define TT_MS_LANGID_SOTHO_SOUTHERN_SOUTH_AFRICA \
  717. TT_MS_LANGID_SEPEDI_SOUTH_AFRICA
  718. /* language codes 0x046d, 0x046e and 0x046f are (still) unknown. */
  719. #define TT_MS_LANGID_IGBO_NIGERIA 0x0470
  720. #define TT_MS_LANGID_KANURI_NIGERIA 0x0471
  721. #define TT_MS_LANGID_OROMO_ETHIOPIA 0x0472
  722. #define TT_MS_LANGID_TIGRIGNA_ETHIOPIA 0x0473
  723. #define TT_MS_LANGID_TIGRIGNA_ERYTHREA 0x0873
  724. /* also spelled in the `Passport SDK' list as: */
  725. #define TT_MS_LANGID_TIGRIGNA_ERYTREA TT_MS_LANGID_TIGRIGNA_ERYTHREA
  726. #define TT_MS_LANGID_GUARANI_PARAGUAY 0x0474
  727. #define TT_MS_LANGID_HAWAIIAN_UNITED_STATES 0x0475
  728. #define TT_MS_LANGID_LATIN 0x0476
  729. #define TT_MS_LANGID_SOMALI_SOMALIA 0x0477
  730. /* Note: Yi does not have a (proper) ISO 639-2 code, since it is mostly */
  731. /* not written (but OTOH the peculiar writing system is worth */
  732. /* studying). */
  733. #define TT_MS_LANGID_YI_CHINA 0x0478
  734. #define TT_MS_LANGID_PAPIAMENTU_NETHERLANDS_ANTILLES 0x0479
  735. /* language codes from 0x047a to 0x047f are (still) unknown. */
  736. #define TT_MS_LANGID_UIGHUR_CHINA 0x0480
  737. #define TT_MS_LANGID_MAORI_NEW_ZEALAND 0x0481
  738. #if 0 /* not deemed useful for fonts */
  739. #define TT_MS_LANGID_HUMAN_INTERFACE_DEVICE 0x04ff
  740. #endif
  741. /*************************************************************************/
  742. /* */
  743. /* Possible values of the `name' identifier field in the name records of */
  744. /* the TTF `name' table. These values are platform independent. */
  745. /* */
  746. #define TT_NAME_ID_COPYRIGHT 0
  747. #define TT_NAME_ID_FONT_FAMILY 1
  748. #define TT_NAME_ID_FONT_SUBFAMILY 2
  749. #define TT_NAME_ID_UNIQUE_ID 3
  750. #define TT_NAME_ID_FULL_NAME 4
  751. #define TT_NAME_ID_VERSION_STRING 5
  752. #define TT_NAME_ID_PS_NAME 6
  753. #define TT_NAME_ID_TRADEMARK 7
  754. /* the following values are from the OpenType spec */
  755. #define TT_NAME_ID_MANUFACTURER 8
  756. #define TT_NAME_ID_DESIGNER 9
  757. #define TT_NAME_ID_DESCRIPTION 10
  758. #define TT_NAME_ID_VENDOR_URL 11
  759. #define TT_NAME_ID_DESIGNER_URL 12
  760. #define TT_NAME_ID_LICENSE 13
  761. #define TT_NAME_ID_LICENSE_URL 14
  762. /* number 15 is reserved */
  763. #define TT_NAME_ID_PREFERRED_FAMILY 16
  764. #define TT_NAME_ID_PREFERRED_SUBFAMILY 17
  765. #define TT_NAME_ID_MAC_FULL_NAME 18
  766. /* The following code is new as of 2000-01-21 */
  767. #define TT_NAME_ID_SAMPLE_TEXT 19
  768. /* This is new in OpenType 1.3 */
  769. #define TT_NAME_ID_CID_FINDFONT_NAME 20
  770. /* This is new in OpenType 1.5 */
  771. #define TT_NAME_ID_WWS_FAMILY 21
  772. #define TT_NAME_ID_WWS_SUBFAMILY 22
  773. /*************************************************************************/
  774. /* */
  775. /* Bit mask values for the Unicode Ranges from the TTF `OS2 ' table. */
  776. /* */
  777. /* Updated 08-Nov-2008. */
  778. /* */
  779. /* Bit 0 Basic Latin */
  780. #define TT_UCR_BASIC_LATIN (1L << 0) /* U+0020-U+007E */
  781. /* Bit 1 C1 Controls and Latin-1 Supplement */
  782. #define TT_UCR_LATIN1_SUPPLEMENT (1L << 1) /* U+0080-U+00FF */
  783. /* Bit 2 Latin Extended-A */
  784. #define TT_UCR_LATIN_EXTENDED_A (1L << 2) /* U+0100-U+017F */
  785. /* Bit 3 Latin Extended-B */
  786. #define TT_UCR_LATIN_EXTENDED_B (1L << 3) /* U+0180-U+024F */
  787. /* Bit 4 IPA Extensions */
  788. /* Phonetic Extensions */
  789. /* Phonetic Extensions Supplement */
  790. #define TT_UCR_IPA_EXTENSIONS (1L << 4) /* U+0250-U+02AF */
  791. /* U+1D00-U+1D7F */
  792. /* U+1D80-U+1DBF */
  793. /* Bit 5 Spacing Modifier Letters */
  794. /* Modifier Tone Letters */
  795. #define TT_UCR_SPACING_MODIFIER (1L << 5) /* U+02B0-U+02FF */
  796. /* U+A700-U+A71F */
  797. /* Bit 6 Combining Diacritical Marks */
  798. /* Combining Diacritical Marks Supplement */
  799. #define TT_UCR_COMBINING_DIACRITICS (1L << 6) /* U+0300-U+036F */
  800. /* U+1DC0-U+1DFF */
  801. /* Bit 7 Greek and Coptic */
  802. #define TT_UCR_GREEK (1L << 7) /* U+0370-U+03FF */
  803. /* Bit 8 Coptic */
  804. #define TT_UCR_COPTIC (1L << 8) /* U+2C80-U+2CFF */
  805. /* Bit 9 Cyrillic */
  806. /* Cyrillic Supplement */
  807. /* Cyrillic Extended-A */
  808. /* Cyrillic Extended-B */
  809. #define TT_UCR_CYRILLIC (1L << 9) /* U+0400-U+04FF */
  810. /* U+0500-U+052F */
  811. /* U+2DE0-U+2DFF */
  812. /* U+A640-U+A69F */
  813. /* Bit 10 Armenian */
  814. #define TT_UCR_ARMENIAN (1L << 10) /* U+0530-U+058F */
  815. /* Bit 11 Hebrew */
  816. #define TT_UCR_HEBREW (1L << 11) /* U+0590-U+05FF */
  817. /* Bit 12 Vai */
  818. #define TT_UCR_VAI (1L << 12) /* U+A500-U+A63F */
  819. /* Bit 13 Arabic */
  820. /* Arabic Supplement */
  821. #define TT_UCR_ARABIC (1L << 13) /* U+0600-U+06FF */
  822. /* U+0750-U+077F */
  823. /* Bit 14 NKo */
  824. #define TT_UCR_NKO (1L << 14) /* U+07C0-U+07FF */
  825. /* Bit 15 Devanagari */
  826. #define TT_UCR_DEVANAGARI (1L << 15) /* U+0900-U+097F */
  827. /* Bit 16 Bengali */
  828. #define TT_UCR_BENGALI (1L << 16) /* U+0980-U+09FF */
  829. /* Bit 17 Gurmukhi */
  830. #define TT_UCR_GURMUKHI (1L << 17) /* U+0A00-U+0A7F */
  831. /* Bit 18 Gujarati */
  832. #define TT_UCR_GUJARATI (1L << 18) /* U+0A80-U+0AFF */
  833. /* Bit 19 Oriya */
  834. #define TT_UCR_ORIYA (1L << 19) /* U+0B00-U+0B7F */
  835. /* Bit 20 Tamil */
  836. #define TT_UCR_TAMIL (1L << 20) /* U+0B80-U+0BFF */
  837. /* Bit 21 Telugu */
  838. #define TT_UCR_TELUGU (1L << 21) /* U+0C00-U+0C7F */
  839. /* Bit 22 Kannada */
  840. #define TT_UCR_KANNADA (1L << 22) /* U+0C80-U+0CFF */
  841. /* Bit 23 Malayalam */
  842. #define TT_UCR_MALAYALAM (1L << 23) /* U+0D00-U+0D7F */
  843. /* Bit 24 Thai */
  844. #define TT_UCR_THAI (1L << 24) /* U+0E00-U+0E7F */
  845. /* Bit 25 Lao */
  846. #define TT_UCR_LAO (1L << 25) /* U+0E80-U+0EFF */
  847. /* Bit 26 Georgian */
  848. /* Georgian Supplement */
  849. #define TT_UCR_GEORGIAN (1L << 26) /* U+10A0-U+10FF */
  850. /* U+2D00-U+2D2F */
  851. /* Bit 27 Balinese */
  852. #define TT_UCR_BALINESE (1L << 27) /* U+1B00-U+1B7F */
  853. /* Bit 28 Hangul Jamo */
  854. #define TT_UCR_HANGUL_JAMO (1L << 28) /* U+1100-U+11FF */
  855. /* Bit 29 Latin Extended Additional */
  856. /* Latin Extended-C */
  857. /* Latin Extended-D */
  858. #define TT_UCR_LATIN_EXTENDED_ADDITIONAL (1L << 29) /* U+1E00-U+1EFF */
  859. /* U+2C60-U+2C7F */
  860. /* U+A720-U+A7FF */
  861. /* Bit 30 Greek Extended */
  862. #define TT_UCR_GREEK_EXTENDED (1L << 30) /* U+1F00-U+1FFF */
  863. /* Bit 31 General Punctuation */
  864. /* Supplemental Punctuation */
  865. #define TT_UCR_GENERAL_PUNCTUATION (1L << 31) /* U+2000-U+206F */
  866. /* U+2E00-U+2E7F */
  867. /* Bit 32 Superscripts And Subscripts */
  868. #define TT_UCR_SUPERSCRIPTS_SUBSCRIPTS (1L << 0) /* U+2070-U+209F */
  869. /* Bit 33 Currency Symbols */
  870. #define TT_UCR_CURRENCY_SYMBOLS (1L << 1) /* U+20A0-U+20CF */
  871. /* Bit 34 Combining Diacritical Marks For Symbols */
  872. #define TT_UCR_COMBINING_DIACRITICS_SYMB (1L << 2) /* U+20D0-U+20FF */
  873. /* Bit 35 Letterlike Symbols */
  874. #define TT_UCR_LETTERLIKE_SYMBOLS (1L << 3) /* U+2100-U+214F */
  875. /* Bit 36 Number Forms */
  876. #define TT_UCR_NUMBER_FORMS (1L << 4) /* U+2150-U+218F */
  877. /* Bit 37 Arrows */
  878. /* Supplemental Arrows-A */
  879. /* Supplemental Arrows-B */
  880. /* Miscellaneous Symbols and Arrows */
  881. #define TT_UCR_ARROWS (1L << 5) /* U+2190-U+21FF */
  882. /* U+27F0-U+27FF */
  883. /* U+2900-U+297F */
  884. /* U+2B00-U+2BFF */
  885. /* Bit 38 Mathematical Operators */
  886. /* Supplemental Mathematical Operators */
  887. /* Miscellaneous Mathematical Symbols-A */
  888. /* Miscellaneous Mathematical Symbols-B */
  889. #define TT_UCR_MATHEMATICAL_OPERATORS (1L << 6) /* U+2200-U+22FF */
  890. /* U+2A00-U+2AFF */
  891. /* U+27C0-U+27EF */
  892. /* U+2980-U+29FF */
  893. /* Bit 39 Miscellaneous Technical */
  894. #define TT_UCR_MISCELLANEOUS_TECHNICAL (1L << 7) /* U+2300-U+23FF */
  895. /* Bit 40 Control Pictures */
  896. #define TT_UCR_CONTROL_PICTURES (1L << 8) /* U+2400-U+243F */
  897. /* Bit 41 Optical Character Recognition */
  898. #define TT_UCR_OCR (1L << 9) /* U+2440-U+245F */
  899. /* Bit 42 Enclosed Alphanumerics */
  900. #define TT_UCR_ENCLOSED_ALPHANUMERICS (1L << 10) /* U+2460-U+24FF */
  901. /* Bit 43 Box Drawing */
  902. #define TT_UCR_BOX_DRAWING (1L << 11) /* U+2500-U+257F */
  903. /* Bit 44 Block Elements */
  904. #define TT_UCR_BLOCK_ELEMENTS (1L << 12) /* U+2580-U+259F */
  905. /* Bit 45 Geometric Shapes */
  906. #define TT_UCR_GEOMETRIC_SHAPES (1L << 13) /* U+25A0-U+25FF */
  907. /* Bit 46 Miscellaneous Symbols */
  908. #define TT_UCR_MISCELLANEOUS_SYMBOLS (1L << 14) /* U+2600-U+26FF */
  909. /* Bit 47 Dingbats */
  910. #define TT_UCR_DINGBATS (1L << 15) /* U+2700-U+27BF */
  911. /* Bit 48 CJK Symbols and Punctuation */
  912. #define TT_UCR_CJK_SYMBOLS (1L << 16) /* U+3000-U+303F */
  913. /* Bit 49 Hiragana */
  914. #define TT_UCR_HIRAGANA (1L << 17) /* U+3040-U+309F */
  915. /* Bit 50 Katakana */
  916. /* Katakana Phonetic Extensions */
  917. #define TT_UCR_KATAKANA (1L << 18) /* U+30A0-U+30FF */
  918. /* U+31F0-U+31FF */
  919. /* Bit 51 Bopomofo */
  920. /* Bopomofo Extended */
  921. #define TT_UCR_BOPOMOFO (1L << 19) /* U+3100-U+312F */
  922. /* U+31A0-U+31BF */
  923. /* Bit 52 Hangul Compatibility Jamo */
  924. #define TT_UCR_HANGUL_COMPATIBILITY_JAMO (1L << 20) /* U+3130-U+318F */
  925. /* Bit 53 Phags-Pa */
  926. #define TT_UCR_CJK_MISC (1L << 21) /* U+A840-U+A87F */
  927. #define TT_UCR_KANBUN TT_UCR_CJK_MISC /* deprecated */
  928. #define TT_UCR_PHAGSPA
  929. /* Bit 54 Enclosed CJK Letters and Months */
  930. #define TT_UCR_ENCLOSED_CJK_LETTERS_MONTHS (1L << 22) /* U+3200-U+32FF */
  931. /* Bit 55 CJK Compatibility */
  932. #define TT_UCR_CJK_COMPATIBILITY (1L << 23) /* U+3300-U+33FF */
  933. /* Bit 56 Hangul Syllables */
  934. #define TT_UCR_HANGUL (1L << 24) /* U+AC00-U+D7A3 */
  935. /* Bit 57 High Surrogates */
  936. /* High Private Use Surrogates */
  937. /* Low Surrogates */
  938. /* */
  939. /* According to OpenType specs v.1.3+, */
  940. /* setting bit 57 implies that there is */
  941. /* at least one codepoint beyond the */
  942. /* Basic Multilingual Plane that is */
  943. /* supported by this font. So it really */
  944. /* means >= U+10000 */
  945. #define TT_UCR_SURROGATES (1L << 25) /* U+D800-U+DB7F */
  946. /* U+DB80-U+DBFF */
  947. /* U+DC00-U+DFFF */
  948. #define TT_UCR_NON_PLANE_0 TT_UCR_SURROGATES
  949. /* Bit 58 Phoenician */
  950. #define TT_UCR_PHOENICIAN (1L << 26) /*U+10900-U+1091F*/
  951. /* Bit 59 CJK Unified Ideographs */
  952. /* CJK Radicals Supplement */
  953. /* Kangxi Radicals */
  954. /* Ideographic Description Characters */
  955. /* CJK Unified Ideographs Extension A */
  956. /* CJK Unified Ideographs Extension B */
  957. /* Kanbun */
  958. #define TT_UCR_CJK_UNIFIED_IDEOGRAPHS (1L << 27) /* U+4E00-U+9FFF */
  959. /* U+2E80-U+2EFF */
  960. /* U+2F00-U+2FDF */
  961. /* U+2FF0-U+2FFF */
  962. /* U+3400-U+4DB5 */
  963. /*U+20000-U+2A6DF*/
  964. /* U+3190-U+319F */
  965. /* Bit 60 Private Use */
  966. #define TT_UCR_PRIVATE_USE (1L << 28) /* U+E000-U+F8FF */
  967. /* Bit 61 CJK Strokes */
  968. /* CJK Compatibility Ideographs */
  969. /* CJK Compatibility Ideographs Supplement */
  970. #define TT_UCR_CJK_COMPATIBILITY_IDEOGRAPHS (1L << 29) /* U+31C0-U+31EF */
  971. /* U+F900-U+FAFF */
  972. /*U+2F800-U+2FA1F*/
  973. /* Bit 62 Alphabetic Presentation Forms */
  974. #define TT_UCR_ALPHABETIC_PRESENTATION_FORMS (1L << 30) /* U+FB00-U+FB4F */
  975. /* Bit 63 Arabic Presentation Forms-A */
  976. #define TT_UCR_ARABIC_PRESENTATIONS_A (1L << 31) /* U+FB50-U+FDFF */
  977. /* Bit 64 Combining Half Marks */
  978. #define TT_UCR_COMBINING_HALF_MARKS (1L << 0) /* U+FE20-U+FE2F */
  979. /* Bit 65 Vertical forms */
  980. /* CJK Compatibility Forms */
  981. #define TT_UCR_CJK_COMPATIBILITY_FORMS (1L << 1) /* U+FE10-U+FE1F */
  982. /* U+FE30-U+FE4F */
  983. /* Bit 66 Small Form Variants */
  984. #define TT_UCR_SMALL_FORM_VARIANTS (1L << 2) /* U+FE50-U+FE6F */
  985. /* Bit 67 Arabic Presentation Forms-B */
  986. #define TT_UCR_ARABIC_PRESENTATIONS_B (1L << 3) /* U+FE70-U+FEFE */
  987. /* Bit 68 Halfwidth and Fullwidth Forms */
  988. #define TT_UCR_HALFWIDTH_FULLWIDTH_FORMS (1L << 4) /* U+FF00-U+FFEF */
  989. /* Bit 69 Specials */
  990. #define TT_UCR_SPECIALS (1L << 5) /* U+FFF0-U+FFFD */
  991. /* Bit 70 Tibetan */
  992. #define TT_UCR_TIBETAN (1L << 6) /* U+0F00-U+0FFF */
  993. /* Bit 71 Syriac */
  994. #define TT_UCR_SYRIAC (1L << 7) /* U+0700-U+074F */
  995. /* Bit 72 Thaana */
  996. #define TT_UCR_THAANA (1L << 8) /* U+0780-U+07BF */
  997. /* Bit 73 Sinhala */
  998. #define TT_UCR_SINHALA (1L << 9) /* U+0D80-U+0DFF */
  999. /* Bit 74 Myanmar */
  1000. #define TT_UCR_MYANMAR (1L << 10) /* U+1000-U+109F */
  1001. /* Bit 75 Ethiopic */
  1002. /* Ethiopic Supplement */
  1003. /* Ethiopic Extended */
  1004. #define TT_UCR_ETHIOPIC (1L << 11) /* U+1200-U+137F */
  1005. /* U+1380-U+139F */
  1006. /* U+2D80-U+2DDF */
  1007. /* Bit 76 Cherokee */
  1008. #define TT_UCR_CHEROKEE (1L << 12) /* U+13A0-U+13FF */
  1009. /* Bit 77 Unified Canadian Aboriginal Syllabics */
  1010. #define TT_UCR_CANADIAN_ABORIGINAL_SYLLABICS (1L << 13) /* U+1400-U+167F */
  1011. /* Bit 78 Ogham */
  1012. #define TT_UCR_OGHAM (1L << 14) /* U+1680-U+169F */
  1013. /* Bit 79 Runic */
  1014. #define TT_UCR_RUNIC (1L << 15) /* U+16A0-U+16FF */
  1015. /* Bit 80 Khmer */
  1016. /* Khmer Symbols */
  1017. #define TT_UCR_KHMER (1L << 16) /* U+1780-U+17FF */
  1018. /* U+19E0-U+19FF */
  1019. /* Bit 81 Mongolian */
  1020. #define TT_UCR_MONGOLIAN (1L << 17) /* U+1800-U+18AF */
  1021. /* Bit 82 Braille Patterns */
  1022. #define TT_UCR_BRAILLE (1L << 18) /* U+2800-U+28FF */
  1023. /* Bit 83 Yi Syllables */
  1024. /* Yi Radicals */
  1025. #define TT_UCR_YI (1L << 19) /* U+A000-U+A48F */
  1026. /* U+A490-U+A4CF */
  1027. /* Bit 84 Tagalog */
  1028. /* Hanunoo */
  1029. /* Buhid */
  1030. /* Tagbanwa */
  1031. #define TT_UCR_PHILIPPINE (1L << 20) /* U+1700-U+171F */
  1032. /* U+1720-U+173F */
  1033. /* U+1740-U+175F */
  1034. /* U+1760-U+177F */
  1035. /* Bit 85 Old Italic */
  1036. #define TT_UCR_OLD_ITALIC (1L << 21) /*U+10300-U+1032F*/
  1037. /* Bit 86 Gothic */
  1038. #define TT_UCR_GOTHIC (1L << 22) /*U+10330-U+1034F*/
  1039. /* Bit 87 Deseret */
  1040. #define TT_UCR_DESERET (1L << 23) /*U+10400-U+1044F*/
  1041. /* Bit 88 Byzantine Musical Symbols */
  1042. /* Musical Symbols */
  1043. /* Ancient Greek Musical Notation */
  1044. #define TT_UCR_MUSICAL_SYMBOLS (1L << 24) /*U+1D000-U+1D0FF*/
  1045. /*U+1D100-U+1D1FF*/
  1046. /*U+1D200-U+1D24F*/
  1047. /* Bit 89 Mathematical Alphanumeric Symbols */
  1048. #define TT_UCR_MATH_ALPHANUMERIC_SYMBOLS (1L << 25) /*U+1D400-U+1D7FF*/
  1049. /* Bit 90 Private Use (plane 15) */
  1050. /* Private Use (plane 16) */
  1051. #define TT_UCR_PRIVATE_USE_SUPPLEMENTARY (1L << 26) /*U+F0000-U+FFFFD*/
  1052. /*U+100000-U+10FFFD*/
  1053. /* Bit 91 Variation Selectors */
  1054. /* Variation Selectors Supplement */
  1055. #define TT_UCR_VARIATION_SELECTORS (1L << 27) /* U+FE00-U+FE0F */
  1056. /*U+E0100-U+E01EF*/
  1057. /* Bit 92 Tags */
  1058. #define TT_UCR_TAGS (1L << 28) /*U+E0000-U+E007F*/
  1059. /* Bit 93 Limbu */
  1060. #define TT_UCR_LIMBU (1L << 29) /* U+1900-U+194F */
  1061. /* Bit 94 Tai Le */
  1062. #define TT_UCR_TAI_LE (1L << 30) /* U+1950-U+197F */
  1063. /* Bit 95 New Tai Lue */
  1064. #define TT_UCR_NEW_TAI_LUE (1L << 31) /* U+1980-U+19DF */
  1065. /* Bit 96 Buginese */
  1066. #define TT_UCR_BUGINESE (1L << 0) /* U+1A00-U+1A1F */
  1067. /* Bit 97 Glagolitic */
  1068. #define TT_UCR_GLAGOLITIC (1L << 1) /* U+2C00-U+2C5F */
  1069. /* Bit 98 Tifinagh */
  1070. #define TT_UCR_TIFINAGH (1L << 2) /* U+2D30-U+2D7F */
  1071. /* Bit 99 Yijing Hexagram Symbols */
  1072. #define TT_UCR_YIJING (1L << 3) /* U+4DC0-U+4DFF */
  1073. /* Bit 100 Syloti Nagri */
  1074. #define TT_UCR_SYLOTI_NAGRI (1L << 4) /* U+A800-U+A82F */
  1075. /* Bit 101 Linear B Syllabary */
  1076. /* Linear B Ideograms */
  1077. /* Aegean Numbers */
  1078. #define TT_UCR_LINEAR_B (1L << 5) /*U+10000-U+1007F*/
  1079. /*U+10080-U+100FF*/
  1080. /*U+10100-U+1013F*/
  1081. /* Bit 102 Ancient Greek Numbers */
  1082. #define TT_UCR_ANCIENT_GREEK_NUMBERS (1L << 6) /*U+10140-U+1018F*/
  1083. /* Bit 103 Ugaritic */
  1084. #define TT_UCR_UGARITIC (1L << 7) /*U+10380-U+1039F*/
  1085. /* Bit 104 Old Persian */
  1086. #define TT_UCR_OLD_PERSIAN (1L << 8) /*U+103A0-U+103DF*/
  1087. /* Bit 105 Shavian */
  1088. #define TT_UCR_SHAVIAN (1L << 9) /*U+10450-U+1047F*/
  1089. /* Bit 106 Osmanya */
  1090. #define TT_UCR_OSMANYA (1L << 10) /*U+10480-U+104AF*/
  1091. /* Bit 107 Cypriot Syllabary */
  1092. #define TT_UCR_CYPRIOT_SYLLABARY (1L << 11) /*U+10800-U+1083F*/
  1093. /* Bit 108 Kharoshthi */
  1094. #define TT_UCR_KHAROSHTHI (1L << 12) /*U+10A00-U+10A5F*/
  1095. /* Bit 109 Tai Xuan Jing Symbols */
  1096. #define TT_UCR_TAI_XUAN_JING (1L << 13) /*U+1D300-U+1D35F*/
  1097. /* Bit 110 Cuneiform */
  1098. /* Cuneiform Numbers and Punctuation */
  1099. #define TT_UCR_CUNEIFORM (1L << 14) /*U+12000-U+123FF*/
  1100. /*U+12400-U+1247F*/
  1101. /* Bit 111 Counting Rod Numerals */
  1102. #define TT_UCR_COUNTING_ROD_NUMERALS (1L << 15) /*U+1D360-U+1D37F*/
  1103. /* Bit 112 Sundanese */
  1104. #define TT_UCR_SUNDANESE (1L << 16) /* U+1B80-U+1BBF */
  1105. /* Bit 113 Lepcha */
  1106. #define TT_UCR_LEPCHA (1L << 17) /* U+1C00-U+1C4F */
  1107. /* Bit 114 Ol Chiki */
  1108. #define TT_UCR_OL_CHIKI (1L << 18) /* U+1C50-U+1C7F */
  1109. /* Bit 115 Saurashtra */
  1110. #define TT_UCR_SAURASHTRA (1L << 19) /* U+A880-U+A8DF */
  1111. /* Bit 116 Kayah Li */
  1112. #define TT_UCR_KAYAH_LI (1L << 20) /* U+A900-U+A92F */
  1113. /* Bit 117 Rejang */
  1114. #define TT_UCR_REJANG (1L << 21) /* U+A930-U+A95F */
  1115. /* Bit 118 Cham */
  1116. #define TT_UCR_CHAM (1L << 22) /* U+AA00-U+AA5F */
  1117. /* Bit 119 Ancient Symbols */
  1118. #define TT_UCR_ANCIENT_SYMBOLS (1L << 23) /*U+10190-U+101CF*/
  1119. /* Bit 120 Phaistos Disc */
  1120. #define TT_UCR_PHAISTOS_DISC (1L << 24) /*U+101D0-U+101FF*/
  1121. /* Bit 121 Carian */
  1122. /* Lycian */
  1123. /* Lydian */
  1124. #define TT_UCR_OLD_ANATOLIAN (1L << 25) /*U+102A0-U+102DF*/
  1125. /*U+10280-U+1029F*/
  1126. /*U+10920-U+1093F*/
  1127. /* Bit 122 Domino Tiles */
  1128. /* Mahjong Tiles */
  1129. #define TT_UCR_GAME_TILES (1L << 26) /*U+1F030-U+1F09F*/
  1130. /*U+1F000-U+1F02F*/
  1131. /* Bit 123-127 Reserved for process-internal usage */
  1132. /*************************************************************************/
  1133. /* */
  1134. /* Some compilers have a very limited length of identifiers. */
  1135. /* */
  1136. #if defined( __TURBOC__ ) && __TURBOC__ < 0x0410 || defined( __PACIFIC__ )
  1137. #define HAVE_LIMIT_ON_IDENTS
  1138. #endif
  1139. #ifndef HAVE_LIMIT_ON_IDENTS
  1140. /*************************************************************************/
  1141. /* */
  1142. /* Here some alias #defines in order to be clearer. */
  1143. /* */
  1144. /* These are not always #defined to stay within the 31~character limit, */
  1145. /* which some compilers have. */
  1146. /* */
  1147. /* Credits go to Dave Hoo <[email protected]> for pointing out that modern */
  1148. /* Borland compilers (read: from BC++ 3.1 on) can increase this limit. */
  1149. /* If you get a warning with such a compiler, use the -i40 switch. */
  1150. /* */
  1151. #define TT_UCR_ARABIC_PRESENTATION_FORMS_A \
  1152. TT_UCR_ARABIC_PRESENTATIONS_A
  1153. #define TT_UCR_ARABIC_PRESENTATION_FORMS_B \
  1154. TT_UCR_ARABIC_PRESENTATIONS_B
  1155. #define TT_UCR_COMBINING_DIACRITICAL_MARKS \
  1156. TT_UCR_COMBINING_DIACRITICS
  1157. #define TT_UCR_COMBINING_DIACRITICAL_MARKS_SYMB \
  1158. TT_UCR_COMBINING_DIACRITICS_SYMB
  1159. #endif /* !HAVE_LIMIT_ON_IDENTS */
  1160. FT_END_HEADER
  1161. #endif /* __TTNAMEID_H__ */
  1162. /* END */