PageRenderTime 54ms CodeModel.GetById 16ms RepoModel.GetById 0ms app.codeStats 0ms

/src/compiler/android-ndk/jni/freetype/include/freetype/ttnameid.h

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