PageRenderTime 83ms CodeModel.GetById 63ms app.highlight 12ms RepoModel.GetById 1ms app.codeStats 1ms

/src/freetype/include/freetype/ttnameid.h

https://bitbucket.org/cabalistic/ogredeps/
C++ Header | 1247 lines | 626 code | 75 blank | 546 comment | 2 complexity | 48f9b4ccaaf618fbed2ccc1c5672df1f MD5 | raw file

Large files files are truncated, but you can click here to view the full file

   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
  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.                                                */
 320  /*                                                                       */
 321  /* The canonical source for the Apple assigned Language ID's is at       */
 322  /*                                                                       */
 323  /*   http://fonts.apple.com/TTRefMan/RM06/Chap6name.html                 */
 324  /*                                                                       */
 325#define TT_MAC_LANGID_ENGLISH                       0
 326#define TT_MAC_LANGID_FRENCH                        1
 327#define TT_MAC_LANGID_GERMAN                        2
 328#define TT_MAC_LANGID_ITALIAN                       3
 329#define TT_MAC_LANGID_DUTCH                         4
 330#define TT_MAC_LANGID_SWEDISH                       5
 331#define TT_MAC_LANGID_SPANISH                       6
 332#define TT_MAC_LANGID_DANISH                        7
 333#define TT_MAC_LANGID_PORTUGUESE                    8
 334#define TT_MAC_LANGID_NORWEGIAN                     9
 335#define TT_MAC_LANGID_HEBREW                       10
 336#define TT_MAC_LANGID_JAPANESE                     11
 337#define TT_MAC_LANGID_ARABIC                       12
 338#define TT_MAC_LANGID_FINNISH                      13
 339#define TT_MAC_LANGID_GREEK                        14
 340#define TT_MAC_LANGID_ICELANDIC                    15
 341#define TT_MAC_LANGID_MALTESE                      16
 342#define TT_MAC_LANGID_TURKISH                      17
 343#define TT_MAC_LANGID_CROATIAN                     18
 344#define TT_MAC_LANGID_CHINESE_TRADITIONAL          19
 345#define TT_MAC_LANGID_URDU                         20
 346#define TT_MAC_LANGID_HINDI                        21
 347#define TT_MAC_LANGID_THAI                         22
 348#define TT_MAC_LANGID_KOREAN                       23
 349#define TT_MAC_LANGID_LITHUANIAN                   24
 350#define TT_MAC_LANGID_POLISH                       25
 351#define TT_MAC_LANGID_HUNGARIAN                    26
 352#define TT_MAC_LANGID_ESTONIAN                     27
 353#define TT_MAC_LANGID_LETTISH                      28
 354#define TT_MAC_LANGID_SAAMISK                      29
 355#define TT_MAC_LANGID_FAEROESE                     30
 356#define TT_MAC_LANGID_FARSI                        31
 357#define TT_MAC_LANGID_RUSSIAN                      32
 358#define TT_MAC_LANGID_CHINESE_SIMPLIFIED           33
 359#define TT_MAC_LANGID_FLEMISH                      34
 360#define TT_MAC_LANGID_IRISH                        35
 361#define TT_MAC_LANGID_ALBANIAN                     36
 362#define TT_MAC_LANGID_ROMANIAN                     37
 363#define TT_MAC_LANGID_CZECH                        38
 364#define TT_MAC_LANGID_SLOVAK                       39
 365#define TT_MAC_LANGID_SLOVENIAN                    40
 366#define TT_MAC_LANGID_YIDDISH                      41
 367#define TT_MAC_LANGID_SERBIAN                      42
 368#define TT_MAC_LANGID_MACEDONIAN                   43
 369#define TT_MAC_LANGID_BULGARIAN                    44
 370#define TT_MAC_LANGID_UKRAINIAN                    45
 371#define TT_MAC_LANGID_BYELORUSSIAN                 46
 372#define TT_MAC_LANGID_UZBEK                        47
 373#define TT_MAC_LANGID_KAZAKH                       48
 374#define TT_MAC_LANGID_AZERBAIJANI                  49
 375#define TT_MAC_LANGID_AZERBAIJANI_CYRILLIC_SCRIPT  49
 376#define TT_MAC_LANGID_AZERBAIJANI_ARABIC_SCRIPT    50
 377#define TT_MAC_LANGID_ARMENIAN                     51
 378#define TT_MAC_LANGID_GEORGIAN                     52
 379#define TT_MAC_LANGID_MOLDAVIAN                    53
 380#define TT_MAC_LANGID_KIRGHIZ                      54
 381#define TT_MAC_LANGID_TAJIKI                       55
 382#define TT_MAC_LANGID_TURKMEN                      56
 383#define TT_MAC_LANGID_MONGOLIAN                    57
 384#define TT_MAC_LANGID_MONGOLIAN_MONGOLIAN_SCRIPT   57
 385#define TT_MAC_LANGID_MONGOLIAN_CYRILLIC_SCRIPT    58
 386#define TT_MAC_LANGID_PASHTO                       59
 387#define TT_MAC_LANGID_KURDISH                      60
 388#define TT_MAC_LANGID_KASHMIRI                     61
 389#define TT_MAC_LANGID_SINDHI                       62
 390#define TT_MAC_LANGID_TIBETAN                      63
 391#define TT_MAC_LANGID_NEPALI                       64
 392#define TT_MAC_LANGID_SANSKRIT                     65
 393#define TT_MAC_LANGID_MARATHI                      66
 394#define TT_MAC_LANGID_BENGALI                      67
 395#define TT_MAC_LANGID_ASSAMESE                     68
 396#define TT_MAC_LANGID_GUJARATI                     69
 397#define TT_MAC_LANGID_PUNJABI                      70
 398#define TT_MAC_LANGID_ORIYA                        71
 399#define TT_MAC_LANGID_MALAYALAM                    72
 400#define TT_MAC_LANGID_KANNADA                      73
 401#define TT_MAC_LANGID_TAMIL                        74
 402#define TT_MAC_LANGID_TELUGU                       75
 403#define TT_MAC_LANGID_SINHALESE                    76
 404#define TT_MAC_LANGID_BURMESE                      77
 405#define TT_MAC_LANGID_KHMER                        78
 406#define TT_MAC_LANGID_LAO                          79
 407#define TT_MAC_LANGID_VIETNAMESE                   80
 408#define TT_MAC_LANGID_INDONESIAN                   81
 409#define TT_MAC_LANGID_TAGALOG                      82
 410#define TT_MAC_LANGID_MALAY_ROMAN_SCRIPT           83
 411#define TT_MAC_LANGID_MALAY_ARABIC_SCRIPT          84
 412#define TT_MAC_LANGID_AMHARIC                      85
 413#define TT_MAC_LANGID_TIGRINYA                     86
 414#define TT_MAC_LANGID_GALLA                        87
 415#define TT_MAC_LANGID_SOMALI                       88
 416#define TT_MAC_LANGID_SWAHILI                      89
 417#define TT_MAC_LANGID_RUANDA                       90
 418#define TT_MAC_LANGID_RUNDI                        91
 419#define TT_MAC_LANGID_CHEWA                        92
 420#define TT_MAC_LANGID_MALAGASY                     93
 421#define TT_MAC_LANGID_ESPERANTO                    94
 422#define TT_MAC_LANGID_WELSH                       128
 423#define TT_MAC_LANGID_BASQUE                      129
 424#define TT_MAC_LANGID_CATALAN                     130
 425#define TT_MAC_LANGID_LATIN                       131
 426#define TT_MAC_LANGID_QUECHUA                     132
 427#define TT_MAC_LANGID_GUARANI                     133
 428#define TT_MAC_LANGID_AYMARA                      134
 429#define TT_MAC_LANGID_TATAR                       135
 430#define TT_MAC_LANGID_UIGHUR                      136
 431#define TT_MAC_LANGID_DZONGKHA                    137
 432#define TT_MAC_LANGID_JAVANESE                    138
 433#define TT_MAC_LANGID_SUNDANESE                   139
 434
 435
 436#if 0  /* these seem to be errors that have been dropped */
 437
 438#define TT_MAC_LANGID_SCOTTISH_GAELIC             140
 439#define TT_MAC_LANGID_IRISH_GAELIC                141
 440
 441#endif
 442
 443
 444  /* The following codes are new as of 2000-03-10 */
 445#define TT_MAC_LANGID_GALICIAN                    140
 446#define TT_MAC_LANGID_AFRIKAANS                   141
 447#define TT_MAC_LANGID_BRETON                      142
 448#define TT_MAC_LANGID_INUKTITUT                   143
 449#define TT_MAC_LANGID_SCOTTISH_GAELIC             144
 450#define TT_MAC_LANGID_MANX_GAELIC                 145
 451#define TT_MAC_LANGID_IRISH_GAELIC                146
 452#define TT_MAC_LANGID_TONGAN                      147
 453#define TT_MAC_LANGID_GREEK_POLYTONIC             148
 454#define TT_MAC_LANGID_GREELANDIC                  149
 455#define TT_MAC_LANGID_AZERBAIJANI_ROMAN_SCRIPT    150
 456
 457
 458  /*************************************************************************/
 459  /*                                                                       */
 460  /* Possible values of the language identifier field in the name records  */
 461  /* of the TTF `name' table if the `platform' identifier code is          */
 462  /* TT_PLATFORM_MICROSOFT.                                                */
 463  /*                                                                       */
 464  /* The canonical source for the MS assigned LCID's (seems to) be at      */
 465  /*                                                                       */
 466  /*   http://www.microsoft.com/globaldev/reference/lcid-all.mspx          */
 467  /*                                                                       */
 468  /* It used to be at various places, among them                           */
 469  /*                                                                       */
 470  /*   http://www.microsoft.com/typography/OTSPEC/lcid-cp.txt              */
 471  /*   http://www.microsoft.com/globaldev/reference/loclanghome.asp        */
 472  /*   http://support.microsoft.com/support/kb/articles/Q224/8/04.ASP      */
 473  /*   http://msdn.microsoft.com/library/en-us/passport25/                 */
 474  /*           NET_Passport_VBScript_Documentation/Single_Sign_In/         */
 475  /*           Advanced_Single_Sign_In/Localization_and_LCIDs.asp          */
 476  /*                                                                       */
 477  /* Hopefully, it seems now that the Globaldev site prevails...           */
 478  /*                                   (updated by Antoine, 2004-02-17)    */
 479
 480#define TT_MS_LANGID_ARABIC_GENERAL                    0x0001
 481#define TT_MS_LANGID_ARABIC_SAUDI_ARABIA               0x0401
 482#define TT_MS_LANGID_ARABIC_IRAQ                       0x0801
 483#define TT_MS_LANGID_ARABIC_EGYPT                      0x0c01
 484#define TT_MS_LANGID_ARABIC_LIBYA                      0x1001
 485#define TT_MS_LANGID_ARABIC_ALGERIA                    0x1401
 486#define TT_MS_LANGID_ARABIC_MOROCCO                    0x1801
 487#define TT_MS_LANGID_ARABIC_TUNISIA                    0x1c01
 488#define TT_MS_LANGID_ARABIC_OMAN                       0x2001
 489#define TT_MS_LANGID_ARABIC_YEMEN                      0x2401
 490#define TT_MS_LANGID_ARABIC_SYRIA                      0x2801
 491#define TT_MS_LANGID_ARABIC_JORDAN                     0x2c01
 492#define TT_MS_LANGID_ARABIC_LEBANON                    0x3001
 493#define TT_MS_LANGID_ARABIC_KUWAIT                     0x3401
 494#define TT_MS_LANGID_ARABIC_UAE                        0x3801
 495#define TT_MS_LANGID_ARABIC_BAHRAIN                    0x3c01
 496#define TT_MS_LANGID_ARABIC_QATAR                      0x4001
 497#define TT_MS_LANGID_BULGARIAN_BULGARIA                0x0402
 498#define TT_MS_LANGID_CATALAN_SPAIN                     0x0403
 499#define TT_MS_LANGID_CHINESE_GENERAL                   0x0004
 500#define TT_MS_LANGID_CHINESE_TAIWAN                    0x0404
 501#define TT_MS_LANGID_CHINESE_PRC                       0x0804
 502#define TT_MS_LANGID_CHINESE_HONG_KONG                 0x0c04
 503#define TT_MS_LANGID_CHINESE_SINGAPORE                 0x1004
 504
 505#if 1  /* this looks like the correct value */
 506#define TT_MS_LANGID_CHINESE_MACAU                     0x1404
 507#else  /* but beware, Microsoft may change its mind...
 508          the most recent Word reference has the following: */
 509#define TT_MS_LANGID_CHINESE_MACAU  TT_MS_LANGID_CHINESE_HONG_KONG
 510#endif
 511
 512#if 0  /* used only with .NET `cultures'; commented out */
 513#define TT_MS_LANGID_CHINESE_TRADITIONAL               0x7C04
 514#endif
 515
 516#define TT_MS_LANGID_CZECH_CZECH_REPUBLIC              0x0405
 517#define TT_MS_LANGID_DANISH_DENMARK                    0x0406
 518#define TT_MS_LANGID_GERMAN_GERMANY                    0x0407
 519#define TT_MS_LANGID_GERMAN_SWITZERLAND                0x0807
 520#define TT_MS_LANGID_GERMAN_AUSTRIA                    0x0c07
 521#define TT_MS_LANGID_GERMAN_LUXEMBOURG                 0x1007
 522#define TT_MS_LANGID_GERMAN_LIECHTENSTEI               0x1407
 523#define TT_MS_LANGID_GREEK_GREECE                      0x0408
 524
 525  /* don't ask what this one means... It is commented out currently. */
 526#if 0
 527#define TT_MS_LANGID_GREEK_GREECE2                     0x2008
 528#endif
 529
 530#define TT_MS_LANGID_ENGLISH_GENERAL                   0x0009
 531#define TT_MS_LANGID_ENGLISH_UNITED_STATES             0x0409
 532#define TT_MS_LANGID_ENGLISH_UNITED_KINGDOM            0x0809
 533#define TT_MS_LANGID_ENGLISH_AUSTRALIA                 0x0c09
 534#define TT_MS_LANGID_ENGLISH_CANADA                    0x1009
 535#define TT_MS_LANGID_ENGLISH_NEW_ZEALAND               0x1409
 536#define TT_MS_LANGID_ENGLISH_IRELAND                   0x1809
 537#define TT_MS_LANGID_ENGLISH_SOUTH_AFRICA              0x1c09
 538#define TT_MS_LANGID_ENGLISH_JAMAICA                   0x2009
 539#define TT_MS_LANGID_ENGLISH_CARIBBEAN                 0x2409
 540#define TT_MS_LANGID_ENGLISH_BELIZE                    0x2809
 541#define TT_MS_LANGID_ENGLISH_TRINIDAD                  0x2c09
 542#define TT_MS_LANGID_ENGLISH_ZIMBABWE                  0x3009
 543#define TT_MS_LANGID_ENGLISH_PHILIPPINES               0x3409
 544#define TT_MS_LANGID_ENGLISH_INDONESIA                 0x3809
 545#define TT_MS_LANGID_ENGLISH_HONG_KONG                 0x3c09
 546#define TT_MS_LANGID_ENGLISH_INDIA                     0x4009
 547#define TT_MS_LANGID_ENGLISH_MALAYSIA                  0x4409
 548#define TT_MS_LANGID_ENGLISH_SINGAPORE                 0x4809
 549#define TT_MS_LANGID_SPANISH_SPAIN_TRADITIONAL_SORT    0x040a
 550#define TT_MS_LANGID_SPANISH_MEXICO                    0x080a
 551#define TT_MS_LANGID_SPANISH_SPAIN_INTERNATIONAL_SORT  0x0c0a
 552#define TT_MS_LANGID_SPANISH_GUATEMALA                 0x100a
 553#define TT_MS_LANGID_SPANISH_COSTA_RICA                0x140a
 554#define TT_MS_LANGID_SPANISH_PANAMA                    0x180a
 555#define TT_MS_LANGID_SPANISH_DOMINICAN_REPUBLIC        0x1c0a
 556#define TT_MS_LANGID_SPANISH_VENEZUELA                 0x200a
 557#define TT_MS_LANGID_SPANISH_COLOMBIA                  0x240a
 558#define TT_MS_LANGID_SPANISH_PERU                      0x280a
 559#define TT_MS_LANGID_SPANISH_ARGENTINA                 0x2c0a
 560#define TT_MS_LANGID_SPANISH_ECUADOR                   0x300a
 561#define TT_MS_LANGID_SPANISH_CHILE                     0x340a
 562#define TT_MS_LANGID_SPANISH_URUGUAY                   0x380a
 563#define TT_MS_LANGID_SPANISH_PARAGUAY                  0x3c0a
 564#define TT_MS_LANGID_SPANISH_BOLIVIA                   0x400a
 565#define TT_MS_LANGID_SPANISH_EL_SALVADOR               0x440a
 566#define TT_MS_LANGID_SPANISH_HONDURAS                  0x480a
 567#define TT_MS_LANGID_SPANISH_NICARAGUA                 0x4c0a
 568#define TT_MS_LANGID_SPANISH_PUERTO_RICO               0x500a
 569#define TT_MS_LANGID_SPANISH_UNITED_STATES             0x540a
 570  /* The following ID blatantly violate MS specs by using a */
 571  /* sublanguage > 0x1F.                                    */
 572#define TT_MS_LANGID_SPANISH_LATIN_AMERICA             0xE40aU
 573#define TT_MS_LANGID_FINNISH_FINLAND                   0x040b
 574#define TT_MS_LANGID_FRENCH_FRANCE                     0x040c
 575#define TT_MS_LANGID_FRENCH_BELGIUM                    0x080c
 576#define TT_MS_LANGID_FRENCH_CANADA                     0x0c0c
 577#define TT_MS_LANGID_FRENCH_SWITZERLAND                0x100c
 578#define TT_MS_LANGID_FRENCH_LUXEMBOURG                 0x140c
 579#define TT_MS_LANGID_FRENCH_MONACO                     0x180c
 580#define TT_MS_LANGID_FRENCH_WEST_INDIES                0x1c0c
 581#define TT_MS_LANGID_FRENCH_REUNION                    0x200c
 582#define TT_MS_LANGID_FRENCH_CONGO                      0x240c
 583  /* which was formerly: */
 584#define TT_MS_LANGID_FRENCH_ZAIRE  TT_MS_LANGID_FRENCH_CONGO
 585#define TT_MS_LANGID_FRENCH_SENEGAL                    0x280c
 586#define TT_MS_LANGID_FRENCH_CAMEROON                   0x2c0c
 587#define TT_MS_LANGID_FRENCH_COTE_D_IVOIRE              0x300c
 588#define TT_MS_LANGID_FRENCH_MALI                       0x340c
 589#define TT_MS_LANGID_FRENCH_MOROCCO                    0x380c
 590#define TT_MS_LANGID_FRENCH_HAITI                      0x3c0c
 591  /* and another violation of the spec (see 0xE40aU) */
 592#define TT_MS_LANGID_FRENCH_NORTH_AFRICA               0xE40cU
 593#define TT_MS_LANGID_HEBREW_ISRAEL                     0x040d
 594#define TT_MS_LANGID_HUNGARIAN_HUNGARY                 0x040e
 595#define TT_MS_LANGID_ICELANDIC_ICELAND                 0x040f
 596#define TT_MS_LANGID_ITALIAN_ITALY                     0x0410
 597#define TT_MS_LANGID_ITALIAN_SWITZERLAND               0x0810
 598#define TT_MS_LANGID_JAPANESE_JAPAN                    0x0411
 599#define TT_MS_LANGID_KOREAN_EXTENDED_WANSUNG_KOREA     0x0412
 600#define TT_MS_LANGID_KOREAN_JOHAB_KOREA                0x0812
 601#define TT_MS_LANGID_DUTCH_NETHERLANDS                 0x0413
 602#define TT_MS_LANGID_DUTCH_BELGIUM                     0x0813
 603#define TT_MS_LANGID_NORWEGIAN_NORWAY_BOKMAL           0x0414
 604#define TT_MS_LANGID_NORWEGIAN_NORWAY_NYNORSK          0x0814
 605#define TT_MS_LANGID_POLISH_POLAND                     0x0415
 606#define TT_MS_LANGID_PORTUGUESE_BRAZIL                 0x0416
 607#define TT_MS_LANGID_PORTUGUESE_PORTUGAL               0x0816
 608#define TT_MS_LANGID_RHAETO_ROMANIC_SWITZERLAND        0x0417
 609#define TT_MS_LANGID_ROMANIAN_ROMANIA                  0x0418
 610#define TT_MS_LANGID_MOLDAVIAN_MOLDAVIA                0x0818
 611#define TT_MS_LANGID_RUSSIAN_RUSSIA                    0x0419
 612#define TT_MS_LANGID_RUSSIAN_MOLDAVIA                  0x0819
 613#define TT_MS_LANGID_CROATIAN_CROATIA                  0x041a
 614#define TT_MS_LANGID_SERBIAN_SERBIA_LATIN              0x081a
 615#define TT_MS_LANGID_SERBIAN_SERBIA_CYRILLIC           0x0c1a
 616
 617#if 0  /* this used to be this value, but it looks like we were wrong */
 618#define TT_MS_LANGID_BOSNIAN_BOSNIA_HERZEGOVINA        0x101a
 619#else  /* current sources say */
 620#define TT_MS_LANGID_CROATIAN_BOSNIA_HERZEGOVINA       0x101a
 621#define TT_MS_LANGID_BOSNIAN_BOSNIA_HERZEGOVINA        0x141a
 622       /* and XPsp2 Platform SDK added (2004-07-26) */
 623       /* Names are shortened to be significant within 40 chars. */
 624#define TT_MS_LANGID_SERBIAN_BOSNIA_HERZ_LATIN         0x181a
 625#define TT_MS_LANGID_SERBIAN_BOSNIA_HERZ_CYRILLIC      0x181a
 626#endif
 627
 628#define TT_MS_LANGID_SLOVAK_SLOVAKIA                   0x041b
 629#define TT_MS_LANGID_ALBANIAN_ALBANIA                  0x041c
 630#define TT_MS_LANGID_SWEDISH_SWEDEN                    0x041d
 631#define TT_MS_LANGID_SWEDISH_FINLAND                   0x081d
 632#define TT_MS_LANGID_THAI_THAILAND                     0x041e
 633#define TT_MS_LANGID_TURKISH_TURKEY                    0x041f
 634#define TT_MS_LANGID_URDU_PAKISTAN                     0x0420
 635#define TT_MS_LANGID_URDU_INDIA                        0x0820
 636#define TT_MS_LANGID_INDONESIAN_INDONESIA              0x0421
 637#define TT_MS_LANGID_UKRAINIAN_UKRAINE                 0x0422
 638#define TT_MS_LANGID_BELARUSIAN_BELARUS                0x0423
 639#define TT_MS_LANGID_SLOVENE_SLOVENIA                  0x0424
 640#define TT_MS_LANGID_ESTONIAN_ESTONIA                  0x0425
 641#define TT_MS_LANGID_LATVIAN_LATVIA                    0x0426
 642#define TT_MS_LANGID_LITHUANIAN_LITHUANIA              0x0427
 643#define TT_MS_LANGID_CLASSIC_LITHUANIAN_LITHUANIA      0x0827
 644#define TT_MS_LANGID_TAJIK_TAJIKISTAN                  0x0428
 645#define TT_MS_LANGID_FARSI_IRAN                        0x0429
 646#define TT_MS_LANGID_VIETNAMESE_VIET_NAM               0x042a
 647#define TT_MS_LANGID_ARMENIAN_ARMENIA                  0x042b
 648#define TT_MS_LANGID_AZERI_AZERBAIJAN_LATIN            0x042c
 649#define TT_MS_LANGID_AZERI_AZERBAIJAN_CYRILLIC         0x082c
 650#define TT_MS_LANGID_BASQUE_SPAIN                      0x042d
 651#define TT_MS_LANGID_SORBIAN_GERMANY                   0x042e
 652#define TT_MS_LANGID_MACEDONIAN_MACEDONIA              0x042f
 653#define TT_MS_LANGID_SUTU_SOUTH_AFRICA                 0x0430
 654#define TT_MS_LANGID_TSONGA_SOUTH_AFRICA               0x0431
 655#define TT_MS_LANGID_TSWANA_SOUTH_AFRICA               0x0432
 656#define TT_MS_LANGID_VENDA_SOUTH_AFRICA                0x0433
 657#define TT_MS_LANGID_XHOSA_SOUTH_AFRICA                0x0434
 658#define TT_MS_LANGID_ZULU_SOUTH_AFRICA                 0x0435
 659#define TT_MS_LANGID_AFRIKAANS_SOUTH_AFRICA            0x0436
 660#define TT_MS_LANGID_GEORGIAN_GEORGIA                  0x0437
 661#define TT_MS_LANGID_FAEROESE_FAEROE_ISLANDS           0x0438
 662#define TT_MS_LANGID_HINDI_INDIA                       0x0439
 663#define TT_MS_LANGID_MALTESE_MALTA                     0x043a
 664  /* Added by XPsp2 Platform SDK (2004-07-26) */
 665#define TT_MS_LANGID_SAMI_NORTHERN_NORWAY              0x043b
 666#define TT_MS_LANGID_SAMI_NORTHERN_SWEDEN              0x083b
 667#define TT_MS_LANGID_SAMI_NORTHERN_FINLAND             0x0C3b
 668#define TT_MS_LANGID_SAMI_LULE_NORWAY                  0x103b
 669#define TT_MS_LANGID_SAMI_LULE_SWEDEN                  0x143b
 670#define TT_MS_LANGID_SAMI_SOUTHERN_NORWAY              0x183b
 671#define TT_MS_LANGID_SAMI_SOUTHERN_SWEDEN              0x1C3b
 672#define TT_MS_LANGID_SAMI_SKOLT_FINLAND                0x203b
 673#define TT_MS_LANGID_SAMI_INARI_FINLAND                0x243b
 674  /* ... and we also keep our old identifier... */
 675#define TT_MS_LANGID_SAAMI_LAPONIA                     0x043b
 676
 677#if 0 /* this seems to be a previous inversion */
 678#define TT_MS_LANGID_IRISH_GAELIC_IRELAND              0x043c
 679#define TT_MS_LANGID_SCOTTISH_GAELIC_UNITED_KINGDOM    0x083c
 680#else
 681#define TT_MS_LANGID_SCOTTISH_GAELIC_UNITED_KINGDOM    0x083c
 682#define TT_MS_LANGID_IRISH_GAELIC_IRELAND              0x043c
 683#endif
 684
 685#define TT_MS_LANGID_YIDDISH_GERMANY                   0x043d
 686#define TT_MS_LANGID_MALAY_MALAYSIA                    0x043e
 687#define TT_MS_LANGID_MALAY_BRUNEI_DARUSSALAM           0x083e
 688#define TT_MS_LANGID_KAZAK_KAZAKSTAN                   0x043f
 689#define TT_MS_LANGID_KIRGHIZ_KIRGHIZSTAN /* Cyrillic*/ 0x0440
 690  /* alias declared in Windows 2000 */
 691#define TT_MS_LANGID_KIRGHIZ_KIRGHIZ_REPUBLIC \
 692          TT_MS_LANGID_KIRGHIZ_KIRGHIZSTAN
 693
 694#define TT_MS_LANGID_SWAHILI_KENYA                     0x0441
 695#define TT_MS_LANGID_TURKMEN_TURKMENISTAN              0x0442
 696#define TT_MS_LANGID_UZBEK_UZBEKISTAN_LATIN            0x0443
 697#define TT_MS_LANGID_UZBEK_UZBEKISTAN_CYRILLIC         0x0843
 698#define TT_MS_LANGID_TATAR_TATARSTAN                   0x0444
 699#define TT_MS_LANGID_BENGALI_INDIA                     0x0445
 700#define TT_MS_LANGID_BENGALI_BANGLADESH                0x0845
 701#define TT_MS_LANGID_PUNJABI_INDIA                     0x0446
 702#define TT_MS_LANGID_PUNJABI_ARABIC_PAKISTAN           0x0846
 703#define TT_MS_LANGID_GUJARATI_INDIA                    0x0447
 704#define TT_MS_LANGID_ORIYA_INDIA                       0x0448
 705#define TT_MS_LANGID_TAMIL_INDIA                       0x0449
 706#define TT_MS_LANGID_TELUGU_INDIA                      0x044a
 707#define TT_MS_LANGID_KANNADA_INDIA                     0x044b
 708#define TT_MS_LANGID_MALAYALAM_INDIA                   0x044c
 709#define TT_MS_LANGID_ASSAMESE_INDIA                    0x044d
 710#define TT_MS_LANGID_MARATHI_INDIA                     0x044e
 711#define TT_MS_LANGID_SANSKRIT_INDIA                    0x044f
 712#define TT_MS_LANGID_MONGOLIAN_MONGOLIA /* Cyrillic */ 0x0450
 713#define TT_MS_LANGID_MONGOLIAN_MONGOLIA_MONGOLIAN      0x0850
 714#define TT_MS_LANGID_TIBETAN_CHINA                     0x0451
 715  /* Don't use the next constant!  It has            */
 716  /*   (1) the wrong spelling (Dzonghka)             */
 717  /*   (2) Microsoft doesn't officially define it -- */
 718  /*       at least it is not in the List of Local   */
 719  /*       ID Values.                                */
 720  /*   (3) Dzongkha is not the same language as      */
 721  /*       Tibetan, so merging it is wrong anyway.   */
 722  /*                                                 */
 723  /* TT_MS_LANGID_TIBETAN_BHUTAN is correct, BTW.    */
 724#define TT_MS_LANGID_DZONGHKA_BHUTAN                   0x0851
 725
 726#if 0
 727  /* the following used to be defined */
 728#define TT_MS_LANGID_TIBETAN_BHUTAN                    0x0451
 729  /* ... but it was changed; */
 730#else
 731  /* So we will continue to #define it, but with the correct value */
 732#define TT_MS_LANGID_TIBETAN_BHUTAN   TT_MS_LANGID_DZONGHKA_BHUTAN
 733#endif
 734
 735#define TT_MS_LANGID_WELSH_WALES                       0x0452
 736#define TT_MS_LANGID_KHMER_CAMBODIA                    0x0453
 737#define TT_MS_LANGID_LAO_LAOS                          0x0454
 738#define TT_MS_LANGID_BURMESE_MYANMAR                   0x0455
 739#define TT_MS_LANGID_GALICIAN_SPAIN                    0x0456
 740#define TT_MS_LANGID_KONKANI_INDIA                     0x0457
 741#define TT_MS_LANGID_MANIPURI_INDIA  /* Bengali */     0x0458
 742#define TT_MS_LANGID_SINDHI_INDIA /* Arabic */         0x0459
 743#define TT_MS_LANGID_SINDHI_PAKISTAN                   0x0859
 744  /* Missing a LCID for Sindhi in Devanagari script */
 745#define TT_MS_LANGID_SYRIAC_SYRIA                      0x045a
 746#define TT_MS_LANGID_SINHALESE_SRI_LANKA               0x045b
 747#define TT_MS_LANGID_CHEROKEE_UNITED_STATES            0x045c
 748#define TT_MS_LANGID_INUKTITUT_CANADA                  0x045d
 749#define TT_MS_LANGID_AMHARIC_ETHIOPIA                  0x045e
 750#define TT_MS_LANGID_TAMAZIGHT_MOROCCO /* Arabic */    0x045f
 751#define TT_MS_LANGID_TAMAZIGHT_MOROCCO_LATIN           0x085f
 752  /* Missing a LCID for Tifinagh script */
 753#define TT_MS_LANGID_KASHMIRI_PAKISTAN /* Arabic */    0x0460
 754  /* Spelled this way by XPsp2 Platform SDK (2004-07-26) */
 755  /* script is yet unclear... might be Arabic, Nagari or Sharada */
 756#define TT_MS_LANGID_KASHMIRI_SASIA                    0x0860
 757  /* ... and aliased (by MS) for compatibility reasons. */
 758#define TT_MS_LANGID_KASHMIRI_INDIA TT_MS_LANGID_KASHMIRI_SASIA
 759#define TT_MS_LANGID_NEPALI_NEPAL                      0x0461
 760#define TT_MS_LANGID_NEPALI_INDIA                      0x0861
 761#define TT_MS_LANGID_FRISIAN_NETHERLANDS               0x0462
 762#define TT_MS_LANGID_PASHTO_AFGHANISTAN                0x0463
 763#define TT_MS_LANGID_FILIPINO_PHILIPPINES              0x0464
 764#define TT_MS_LANGID_DHIVEHI_MALDIVES                  0x0465
 765  /* alias declared in Windows 2000 */
 766#define TT_MS_LANGID_DIVEHI_MALDIVES  TT_MS_LANGID_DHIVEHI_MALDIVES
 767#define TT_MS_LANGID_EDO_NIGERIA                       0x0466
 768#define TT_MS_LANGID_FULFULDE_NIGERIA                  0x0467
 769#define TT_MS_LANGID_HAUSA_NIGERIA                     0x0468
 770#define TT_MS_LANGID_IBIBIO_NIGERIA                    0x0469
 771#define TT_MS_LANGID_YORUBA_NIGERIA                    0x046a
 772#define TT_MS_LANGID_QUECHUA_BOLIVIA                   0x046b
 773#define TT_MS_LANGID_QUECHUA_ECUADOR                   0x086b
 774#define TT_MS_LANGID_QUECHUA_PERU                      0x0c6b
 775#define TT_MS_LANGID_SEPEDI_SOUTH_AFRICA               0x046c
 776  /* Also spelled by XPsp2 Platform SDK (2004-07-26) */
 777#define TT_MS_LANGID_SOTHO_SOUTHERN_SOUTH_AFRICA \
 778          TT_MS_LANGID_SEPEDI_SOUTH_AFRICA
 779  /* language codes 0x046d, 0x046e and 0x046f are (still) unknown. */
 780#define TT_MS_LANGID_IGBO_NIGERIA                      0x0470
 781#define TT_MS_LANGID_KANURI_NIGERIA                    0x0471
 782#define TT_MS_LANGID_OROMO_ETHIOPIA                    0x0472
 783#define TT_MS_LANGID_TIGRIGNA_ETHIOPIA                 0x0473
 784#define TT_MS_LANGID_TIGRIGNA_ERYTHREA                 0x0873
 785  /* also spelled in the `Passport SDK' list as: */
 786#define TT_MS_LANGID_TIGRIGNA_ERYTREA  TT_MS_LANGID_TIGRIGNA_ERYTHREA
 787#define TT_MS_LANGID_GUARANI_PARAGUAY                  0x0474
 788#define TT_MS_LANGID_HAWAIIAN_UNITED_STATES            0x0475
 789#define TT_MS_LANGID_LATIN                             0x0476
 790#define TT_MS_LANGID_SOMALI_SOMALIA                    0x0477
 791  /* Note: Yi does not have a (proper) ISO 639-2 code, since it is mostly */
 792  /*       not written (but OTOH the peculiar writing system is worth     */
 793  /*       studying).                                                     */
 794#define TT_MS_LANGID_YI_CHINA                          0x0478
 795#define TT_MS_LANGID_PAPIAMENTU_NETHERLANDS_ANTILLES   0x0479
 796  /* language codes from 0x047a to 0x047f are (still) unknown. */
 797#define TT_MS_LANGID_UIGHUR_CHINA                      0x0480
 798#define TT_MS_LANGID_MAORI_NEW_ZEALAND                 0x0481
 799
 800#if 0  /* not deemed useful for fonts */
 801#define TT_MS_LANGID_HUMAN_INTERFACE_DEVICE            0x04ff
 802#endif
 803
 804
 805  /*************************************************************************/
 806  /*                                                                       */
 807  /* Possible values of the `name' identifier field in the name records of */
 808  /* the TTF `name' table.  These values are platform independent.         */
 809  /*                                                                       */
 810#define TT_NAME_ID_COPYRIGHT            0
 811#define TT_NAME_ID_FONT_FAMILY          1
 812#define TT_NAME_ID_FONT_SUBFAMILY       2
 813#define TT_NAME_ID_UNIQUE_ID            3
 814#define TT_NAME_ID_FULL_NAME            4
 815#define TT_NAME_ID_VERSION_STRING       5
 816#define TT_NAME_ID_PS_NAME              6
 817#define TT_NAME_ID_TRADEMARK            7
 818
 819  /* the following values are from the OpenType spec */
 820#define TT_NAME_ID_MANUFACTURER         8
 821#define TT_NAME_ID_DESIGNER             9
 822#define TT_NAME_ID_DESCRIPTION          10
 823#define TT_NAME_ID_VENDOR_URL           11
 824#define TT_NAME_ID_DESIGNER_URL         12
 825#define TT_NAME_ID_LICENSE              13
 826#define TT_NAME_ID_LICENSE_URL          14
 827  /* number 15 is reserved */
 828#define TT_NAME_ID_PREFERRED_FAMILY     16
 829#define TT_NAME_ID_PREFERRED_SUBFAMILY  17
 830#define TT_NAME_ID_MAC_FULL_NAME        18
 831
 832  /* The following code is new as of 2000-01-21 */
 833#define TT_NAME_ID_SAMPLE_TEXT          19
 834
 835  /* This is new in OpenType 1.3 */
 836#define TT_NAME_ID_CID_FINDFONT_NAME    20
 837
 838  /* This is new in OpenType 1.5 */
 839#define TT_NAME_ID_WWS_FAMILY           21
 840#define TT_NAME_ID_WWS_SUBFAMILY        22
 841
 842
 843  /*************************************************************************/
 844  /*                                                                       */
 845  /* Bit mask values for the Unicode Ranges from the TTF `OS2 ' table.     */
 846  /*                                                                       */
 847  /* Updated 08-Nov-2008.                                                  */
 848  /*                                                                       */
 849
 850  /* Bit  0   Basic Latin */
 851#define TT_UCR_BASIC_LATIN                     (1L <<  0) /* U+0020-U+007E */
 852  /* Bit  1   C1 Controls and Latin-1 Supplement */
 853#define TT_UCR_LATIN1_SUPPLEMENT               (1L <<  1) /* U+0080-U+00FF */
 854  /* Bit  2   Latin Extended-A */
 855#define TT_UCR_LATIN_EXTENDED_A                (1L <<  2) /* U+0100-U+017F */
 856  /* Bit  3   Latin Extended-B */
 857#define TT_UCR_LATIN_EXTENDED_B                (1L <<  3) /* U+0180-U+024F */
 858  /* Bit  4   IPA Extensions                 */
 859  /*          Phonetic Extensions            */
 860  /*          Phonetic Extensions Supplement */
 861#define TT_UCR_IPA_EXTENSIONS                  (1L <<  4) /* U+0250-U+02AF */
 862                                                          /* U+1D00-U+1D7F */
 863                                                          /* U+1D80-U+1DBF */
 864  /* Bit  5   Spacing Modifier Letters */
 865  /*          Modifier Tone Letters    */
 866#define TT_UCR_SPACING_MODIFIER                (1L <<  5) /* U+02B0-U+02FF */
 867                                                          /* U+A700-U+A71F */
 868  /* Bit  6   Combining Diacritical Marks            */
 869  /*          Combining Diacritical Marks Supplement */
 870#define TT_UCR_COMBINING_DIACRITICS            (1L <<  6) /* U+0300-U+036F */
 871                                                          /* U+1DC0-U+1DFF */
 872  /* Bit  7   Greek and Coptic */
 873#define TT_UCR_GREEK                           (1L <<  7) /* U+0370-U+03FF */
 874  /* Bit  8   Coptic */
 875#define TT_UCR_COPTIC                          (1L <<  8) /* U+2C80-U+2CFF */
 876  /* Bit  9   Cyrillic            */
 877  /*          Cyrillic Supplement */
 878  /*          Cyrillic Extended-A */
 879  /*          Cyrillic Extended-B */
 880#define TT_UCR_CYRILLIC                        (1L <<  9) /* U+0400-U+04FF */
 881                                                          /* U+0500-U+052F */
 882                                                          /* U+2DE0-U+2DFF */
 883                                                          /* U+A640-U+A69F */
 884  /* Bit 10   Armenian */
 885#define TT_UCR_ARMENIAN                        (1L << 10) /* U+0530-U+058F */
 886  /* Bit 11   Hebrew */
 887#define TT_UCR_HEBREW                          (1L << 11) /* U+0590-U+05FF */
 888  /* Bit 12   Vai */
 889#define TT_UCR_VAI                             (1L << 12) /* U+A500-U+A63F */
 890  /* Bit 13   Arabic            */
 891  /*          Arabic Supplement */
 892#define TT_UCR_ARABIC                          (1L << 13) /* U+0600-U+06FF */
 893                                                          /* U+0750-U+077F */
 894  /* Bit 14   NKo */
 895#define TT_UCR_NKO                             (1L << 14) /* U+07C0-U+07FF */
 896  /* Bit 15   Devanagari */
 897#define TT_UCR_DEVANAGARI                      (1L << 15) /* U+0900-U+097F */
 898  /* Bit 16   Bengali */
 899#define TT_UCR_BENGALI                         (1L << 16) /* U+0980-U+09FF */
 900  /* Bit 17   Gurmukhi */
 901#define TT_UCR_GURMUKHI                        (1L << 17) /* U+0A00-U+0A7F */
 902  /* Bit 18   Gujarati */
 903#define TT_UCR_GUJARATI                        (1L << 18) /* U+0A80-U+0AFF */
 904  /* Bit 19   Oriya */
 905#define TT_UCR_ORIYA                           (1L << 19) /* U+0B00-U+0B7F */
 906  /* Bit 20   Tamil */
 907#define TT_UCR_TAMIL                           (1L << 20) /* U+0B80-U+0BFF */
 908  /* Bit 21   Telugu */
 909#define TT_UCR_TELUGU                          (1L << 21) /* U+0C00-U+0C7F */
 910  /* Bit 22   Kannada */
 911#define TT_UCR_KANNADA                         (1L << 22) /* U+0C80-U+0CFF */
 912  /* Bit 23   Malayalam */
 913#define TT_UCR_MALAYALAM                       (1L << 23) /* U+0D00-U+0D7F */
 914  /* Bit 24   Thai */
 915#define TT_UCR_THAI                            (1L << 24) /* U+0E00-U+0E7F */
 916  /* Bit 25   Lao */
 917#define TT_UCR_LAO                             (1L << 25) /* U+0E80-U+0EFF */
 918  /* Bit 26   Georgian            */
 919  /*          Georgian Supplement */
 920#define TT_UCR_GEORGIAN                        (1L << 26) /* U+10A0-U+10FF */
 921                                                          /* U+2D00-U+2D2F */
 922  /* Bit 27   Balinese */
 923#define TT_UCR_BALINESE                        (1L << 27) /* U+1B00-U+1B7F */
 924  /* Bit 28   Hangul Jamo */
 925#define TT_UCR_HANGUL_JAMO                     (1L << 28) /* U+1100-U+11FF */
 926  /* Bit 29   Latin Extended Additional */
 927  /*          Latin Extended-C          */
 928  /*          Latin Extended-D          */
 929#define TT_UCR_LATIN_EXTENDED_ADDITIONAL       (1L << 29) /* U+1E00-U+1EFF */
 930                                                          /* U+2C60-U+2C7F */
 931                                                          /* U+A720-U+A7FF */
 932  /* Bit 30   Greek Extended */
 933#define TT_UCR_GREEK_EXTENDED                  (1L << 30) /* U+1F00-U+1FFF */
 934  /* Bit 31   General Punctuation      */
 935  /*          Supplemental Punctuation */
 936#define TT_UCR_GENERAL_PUNCTUATION             (1L << 31) /* U+2000-U+206F */
 937                                                          /* U+2E00-U+2E7F */
 938  /* Bit 32   Superscripts And Subscripts */
 939#define TT_UCR_SUPERSCRIPTS_SUBSCRIPTS         (1L <<  0) /* U+2070-U+209F */
 940  /* Bit 33   Currency Symbols */
 941#define TT_UCR_CURRENCY_SYMBOLS                (1L <<  1) /* U+20A0-U+20CF */
 942  /* Bit 34   Combining Diacritical Marks For Symbols */
 943#define TT_UCR_COMBINING_DIACRITICS_SYMB       (1L <<  2) /* U+20D0-U+20FF */
 944  /* Bit 35   Letterlike Symbols */
 945#define TT_UCR_LETTERLIKE_SYMBOLS              (1L <<  3) /* U+2100-U+214F */
 946  /* Bit 36   Number Forms */
 947#define TT_UCR_NUMBER_FORMS                    (1L <<  4) /* U+2150-U+218F */
 948  /* Bit 37   Arrows                           */
 949  /*          Supplemental Arrows-A            */
 950  /*          Supplemental Arrows-B            */
 951  /*          Miscellaneous Symbols and Arrows */
 952#define TT_UCR_ARROWS                          (1L <<  5) /* U+2190-U+21FF */
 953                                                          /* U+27F0-U+27FF */
 954                                                          /* U+2900-U+297F */
 955                                                          /* U+2B00-U+2BFF */
 956  /* Bit 38   Mathematical Operators               */
 957  /*          Supplemental Mathematical Operators  */
 958  /*          Miscellaneous Mathematical Symbols-A */
 959  /*          Miscellaneous Mathematical Symbols-B */
 960#define TT_UCR_MATHEMATICAL_OPERATORS          (1L <<  6) /* U+2200-U+22FF */
 961                                                          /* U+2A00-U+2AFF */
 962                                                          /* U+27C0-U+27EF */
 963                                                          /* U+2980-U+29FF */
 964  /* Bit 39 Miscellaneous Technical */
 965#define TT_UCR_MISCELLANEOUS_TECHNICAL         (1L <<  7) /* U+2300-U+23FF */
 966  /* Bit 40   Control Pictures */
 967#define TT_UCR_CONTROL_PICTURES                (1L <<  8) /* U+2400-U+243F */
 968  /* Bit 41   Optical Character Recognition */
 969#define TT_UCR_OCR                             (1L <<  9) /* U+2440-U+245F */
 970  /* Bit 42   Enclosed Alphanumerics */
 971#define TT_UCR_ENCLOSED_ALPHANUMERICS          (1L << 10) /* U+2460-U+24FF */
 972  /* Bit 43   Box Drawing */
 973#define TT_UCR_BOX_DRAWING                     (1L << 11) /* U+2500-U+257F */
 974  /* Bit 44   Block Elements */
 975#define TT_UCR_BLOCK_ELEMENTS                  (1L << 12) /* U+2580-U+259F */
 976  /* Bit 45   Geometric Shapes */
 977#define TT_UCR_GEOMETRIC_SHAPES                (1L << 13) /* U+25A0-U+25FF */
 978  /* Bit 46   Miscellaneous Symbols */
 979#define TT_UCR_MISCELLANEOUS_SYMBOLS           (1L << 14) /* U+2600-U+26FF */
 980  /* Bit 47   Dingbats */
 981#define TT_UCR_DINGBATS                        (1L << 15) /* U+2700-U+27BF */
 982  /* Bit 48   CJK Symbols and Punctuation */
 983#define TT_UCR_CJK_SYMBOLS                     (1L << 16) /* U+3000-U+303F */
 984  /* Bit 49   Hiragana */
 985#define TT_UCR_HIRAGANA                        (1L << 17) /* U+3040-U+309F */
 986  /* Bit 50   Katakana                     */
 987  /*          Katakana Phonetic Extensions */
 988#define TT_UCR_KATAKANA                        (1L << 18) /* U+30A0-U+30FF */
 989                                                          /* U+31F0-U+31FF */
 990  /* Bit 51   Bopomofo          */
 991  /*          Bopomofo Extended */
 992#define TT_UCR_BOPOMOFO                        (1L << 19) /* U+3100-U+312F */
 993                                                          /* U+31A0-U+31BF */
 994  /* Bit 52   Hangul Compatibility Jamo */
 995#define TT_UCR_HANGUL_COMPATIBILITY_JAMO       (1L << 20) /* U+3130-U+318F */
 996  /* Bit 53   Phags-Pa */
 997#define TT_UCR_CJK_MISC                        (1L << 21) /* U+A840-U+A87F */
 998#define TT_UCR_KANBUN  TT_UCR_CJK_MISC /* deprecated */
 999#define TT_UCR_PHAGSPA
1000  /* Bit 54   Enclosed CJK Letters and Months */
1001#define TT_UCR_ENCLOSED_CJK_LETTERS_MONTHS     (1L << 22) /* U+3200-U+32FF */
1002  /* Bit 55   CJK Compatibility */
1003#define TT_UCR_CJK_COMPATIBILITY               (1L << 23) /* U+3300-U+33FF */
1004  /* Bit 56   Hangul Syllables */
1005#define TT_UCR_HANGUL                          (1L << 24) /* U+AC00-U+D7A3 */
1006  /* Bit 57   High Surrogates              */
1007  /*          High Private Use Surrogates  */
1008  /*          Low Surrogates               */
1009  /*                                       */
1010  /* According to OpenType specs v.1.3+,   */
1011  /* setting bit 57 implies that there is  */
1012  /* at least one codepoint beyond the     */
1013  /* Basic Multilingual Plane that is      */
1014  /* supported by this font.  So it really */
1015  /* means >= U+10000                      */
1016#define TT_UCR_SURROGATES                      (1L << 25) /* U+D800-U+DB7F */
1017                                                          /* U+DB80-U+DBFF */
1018                                                 

Large files files are truncated, but you can click here to view the full file