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