ttnameid.h revision a38fc482eeeb2c1929803c233835369dcf1b8781
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 Unicode 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
839  /*************************************************************************/
840  /*                                                                       */
841  /* Bit mask values for the Unicode Ranges from the TTF `OS2 ' table.     */
842  /*                                                                       */
843  /* Updated 02-Jul-2000.                                                  */
844  /*                                                                       */
845
846  /* General Scripts Area */
847
848  /* Bit  0   Basic Latin */
849#define TT_UCR_BASIC_LATIN                     (1L <<  0) /* U+0020-U+007E */
850  /* Bit  1   C1 Controls and Latin-1 Supplement */
851#define TT_UCR_LATIN1_SUPPLEMENT               (1L <<  1) /* U+0080-U+00FF */
852  /* Bit  2   Latin Extended-A */
853#define TT_UCR_LATIN_EXTENDED_A                (1L <<  2) /* U+0100-U+017F */
854  /* Bit  3   Latin Extended-B */
855#define TT_UCR_LATIN_EXTENDED_B                (1L <<  3) /* U+0180-U+024F */
856  /* Bit  4   IPA Extensions */
857#define TT_UCR_IPA_EXTENSIONS                  (1L <<  4) /* U+0250-U+02AF */
858  /* Bit  5   Spacing Modifier Letters */
859#define TT_UCR_SPACING_MODIFIER                (1L <<  5) /* U+02B0-U+02FF */
860  /* Bit  6   Combining Diacritical Marks */
861#define TT_UCR_COMBINING_DIACRITICS            (1L <<  6) /* U+0300-U+036F */
862  /* Bit  7   Greek and Coptic */
863#define TT_UCR_GREEK                           (1L <<  7) /* U+0370-U+03FF */
864  /* Bit  8 is reserved (was: Greek Symbols and Coptic) */
865  /* Bit  9   Cyrillic               + */
866  /*          Cyrillic Supplementary   */
867#define TT_UCR_CYRILLIC                        (1L <<  9) /* U+0400-U+04FF */
868                                                          /* U+0500-U+052F */
869  /* Bit 10   Armenian */
870#define TT_UCR_ARMENIAN                        (1L << 10) /* U+0530-U+058F */
871  /* Bit 11   Hebrew */
872#define TT_UCR_HEBREW                          (1L << 11) /* U+0590-U+05FF */
873  /* Bit 12 is reserved (was: Hebrew Extended) */
874  /* Bit 13   Arabic */
875#define TT_UCR_ARABIC                          (1L << 13) /* U+0600-U+06FF */
876  /* Bit 14 is reserved (was: Arabic Extended) */
877  /* Bit 15   Devanagari */
878#define TT_UCR_DEVANAGARI                      (1L << 15) /* U+0900-U+097F */
879  /* Bit 16   Bengali */
880#define TT_UCR_BENGALI                         (1L << 16) /* U+0980-U+09FF */
881  /* Bit 17   Gurmukhi */
882#define TT_UCR_GURMUKHI                        (1L << 17) /* U+0A00-U+0A7F */
883  /* Bit 18   Gujarati */
884#define TT_UCR_GUJARATI                        (1L << 18) /* U+0A80-U+0AFF */
885  /* Bit 19   Oriya */
886#define TT_UCR_ORIYA                           (1L << 19) /* U+0B00-U+0B7F */
887  /* Bit 20   Tamil */
888#define TT_UCR_TAMIL                           (1L << 20) /* U+0B80-U+0BFF */
889  /* Bit 21   Telugu */
890#define TT_UCR_TELUGU                          (1L << 21) /* U+0C00-U+0C7F */
891  /* Bit 22   Kannada */
892#define TT_UCR_KANNADA                         (1L << 22) /* U+0C80-U+0CFF */
893  /* Bit 23   Malayalam */
894#define TT_UCR_MALAYALAM                       (1L << 23) /* U+0D00-U+0D7F */
895  /* Bit 24   Thai */
896#define TT_UCR_THAI                            (1L << 24) /* U+0E00-U+0E7F */
897  /* Bit 25   Lao */
898#define TT_UCR_LAO                             (1L << 25) /* U+0E80-U+0EFF */
899  /* Bit 26   Georgian */
900#define TT_UCR_GEORGIAN                        (1L << 26) /* U+10A0-U+10FF */
901  /* Bit 27 is reserved (was Georgian Extended) */
902  /* Bit 28   Hangul Jamo */
903#define TT_UCR_HANGUL_JAMO                     (1L << 28) /* U+1100-U+11FF */
904  /* Bit 29   Latin Extended Additional */
905#define TT_UCR_LATIN_EXTENDED_ADDITIONAL       (1L << 29) /* U+1E00-U+1EFF */
906  /* Bit 30   Greek Extended */
907#define TT_UCR_GREEK_EXTENDED                  (1L << 30) /* U+1F00-U+1FFF */
908
909  /* Symbols Area */
910
911  /* Bit 31   General Punctuation */
912#define TT_UCR_GENERAL_PUNCTUATION             (1L << 31) /* U+2000-U+206F */
913  /* Bit 32   Superscripts And Subscripts */
914#define TT_UCR_SUPERSCRIPTS_SUBSCRIPTS         (1L <<  0) /* U+2070-U+209F */
915  /* Bit 33   Currency Symbols */
916#define TT_UCR_CURRENCY_SYMBOLS                (1L <<  1) /* U+20A0-U+20CF */
917  /* Bit 34   Combining Diacritical Marks For Symbols */
918#define TT_UCR_COMBINING_DIACRITICS_SYMB       (1L <<  2) /* U+20D0-U+20FF */
919  /* Bit 35   Letterlike Symbols */
920#define TT_UCR_LETTERLIKE_SYMBOLS              (1L <<  3) /* U+2100-U+214F */
921  /* Bit 36   Number Forms */
922#define TT_UCR_NUMBER_FORMS                    (1L <<  4) /* U+2150-U+218F */
923  /* Bit 37   Arrows                + */
924  /*          Supplemental Arrows-A + */
925  /*          Supplemental Arrows-B   */
926#define TT_UCR_ARROWS                          (1L <<  5) /* U+2190-U+21FF */
927                                                          /* U+27F0-U+27FF */
928                                                          /* U+2900-U+297F */
929  /* Bit 38   Mathematical Operators               + */
930  /*          Supplemental Mathematical Operators  + */
931  /*          Miscellaneous Mathematical Symbols-A + */
932  /*          Miscellaneous Mathematical Symbols-B   */
933#define TT_UCR_MATHEMATICAL_OPERATORS          (1L <<  6) /* U+2200-U+22FF */
934                                                          /* U+2A00-U+2AFF */
935                                                          /* U+27C0-U+27EF */
936                                                          /* U+2980-U+29FF */
937  /* Bit 39 Miscellaneous Technical */
938#define TT_UCR_MISCELLANEOUS_TECHNICAL         (1L <<  7) /* U+2300-U+23FF */
939  /* Bit 40   Control Pictures */
940#define TT_UCR_CONTROL_PICTURES                (1L <<  8) /* U+2400-U+243F */
941  /* Bit 41   Optical Character Recognition */
942#define TT_UCR_OCR                             (1L <<  9) /* U+2440-U+245F */
943  /* Bit 42   Enclosed Alphanumerics */
944#define TT_UCR_ENCLOSED_ALPHANUMERICS          (1L << 10) /* U+2460-U+24FF */
945  /* Bit 43   Box Drawing */
946#define TT_UCR_BOX_DRAWING                     (1L << 11) /* U+2500-U+257F */
947  /* Bit 44   Block Elements */
948#define TT_UCR_BLOCK_ELEMENTS                  (1L << 12) /* U+2580-U+259F */
949  /* Bit 45   Geometric Shapes */
950#define TT_UCR_GEOMETRIC_SHAPES                (1L << 13) /* U+25A0-U+25FF */
951  /* Bit 46   Miscellaneous Symbols */
952#define TT_UCR_MISCELLANEOUS_SYMBOLS           (1L << 14) /* U+2600-U+26FF */
953  /* Bit 47   Dingbats */
954#define TT_UCR_DINGBATS                        (1L << 15) /* U+2700-U+27BF */
955
956  /* CJK Phonetics and Symbols Area */
957
958  /* Bit 48   CJK Symbols and Punctuation */
959#define TT_UCR_CJK_SYMBOLS                     (1L << 16) /* U+3000-U+303F */
960  /* Bit 49   Hiragana */
961#define TT_UCR_HIRAGANA                        (1L << 17) /* U+3040-U+309F */
962  /* Bit 50   Katakana                     + */
963  /*          Katakana Phonetic Extensions   */
964#define TT_UCR_KATAKANA                        (1L << 18) /* U+30A0-U+30FF */
965                                                          /* U+31F0-U+31FF */
966  /* Bit 51   Bopomofo          + */
967  /*          Bopomofo Extended   */
968#define TT_UCR_BOPOMOFO                        (1L << 19) /* U+3100-U+312F */
969                                                          /* U+31A0-U+31BF */
970  /* Bit 52   Hangul Compatibility Jamo */
971#define TT_UCR_HANGUL_COMPATIBILITY_JAMO       (1L << 20) /* U+3130-U+318F */
972  /* Bit 53   Kanbun */
973#define TT_UCR_CJK_MISC                        (1L << 21) /* U+3190-U+319F */
974#define TT_UCR_KANBUN  TT_UCR_CJK_MISC
975  /* Bit 54   Enclosed CJK Letters and Months */
976#define TT_UCR_ENCLOSED_CJK_LETTERS_MONTHS     (1L << 22) /* U+3200-U+32FF */
977  /* Bit 55   CJK Compatibility */
978#define TT_UCR_CJK_COMPATIBILITY               (1L << 23) /* U+3300-U+33FF */
979
980  /* Hangul Syllables Area */
981
982  /* Bit 56   Hangul */
983#define TT_UCR_HANGUL                          (1L << 24) /* U+AC00-U+D7A3 */
984
985  /* Surrogates Area */
986
987  /* Bit 57   High Surrogates             + */
988  /*          High Private Use Surrogates + */
989  /*          Low Surrogates                */
990#define TT_UCR_SURROGATES                      (1L << 25) /* U+D800-U+DB7F */
991                                                          /* U+DB80-U+DBFF */
992                                                          /* U+DC00-U+DFFF */
993  /* According to OpenType specs v.1.3+, setting bit 57 implies that there */
994  /* is at least one codepoint beyond the Basic Multilingual Plane that is */
995  /* supported by this font.  So it really means:            >= U+10000    */
996
997  /* Bit 58 is reserved for Unicode SubRanges */
998
999  /* CJK Ideographs Area */
1000
1001  /* Bit 59   CJK Unified Ideographs             + */
1002  /*          CJK Radicals Supplement            + */
1003  /*          Kangxi Radicals                    + */
1004  /*          Ideographic Description Characters + */
1005  /*          CJK Unified Ideographs Extension A   */
1006  /*          CJK Unified Ideographs Extension A + */
1007  /*          CJK Unified Ideographs Extension B + */
1008  /*          Kanbun                               */
1009#define TT_UCR_CJK_UNIFIED_IDEOGRAPHS          (1L << 27) /* U+4E00-U+9FFF */
1010                                                          /* U+2E80-U+2EFF */
1011                                                          /* U+2F00-U+2FDF */
1012                                                          /* U+2FF0-U+2FFF */
1013                                                          /* U+3400-U+4DB5 */
1014                                                          /*U+20000-U+2A6DF*/
1015                                                          /* U+3190-U+319F */
1016
1017  /* Private Use Area */
1018
1019  /* Bit 60   Private Use */
1020#define TT_UCR_PRIVATE_USE                     (1L << 28) /* U+E000-U+F8FF */
1021
1022  /* Compatibility Area and Specials */
1023
1024  /* Bit 61   CJK Compatibility Ideographs            + */
1025  /*          CJK Compatibility Ideographs Supplement   */
1026#define TT_UCR_CJK_COMPATIBILITY_IDEOGRAPHS    (1L << 29) /* U+F900-U+FAFF */
1027                                                          /*U+2F800-U+2FA1F*/
1028  /* Bit 62   Alphabetic Presentation Forms */
1029#define TT_UCR_ALPHABETIC_PRESENTATION_FORMS   (1L << 30) /* U+FB00-U+FB4F */
1030  /* Bit 63   Arabic Presentation Forms-A */
1031#define TT_UCR_ARABIC_PRESENTATIONS_A          (1L << 31) /* U+FB50-U+FDFF */
1032  /* Bit 64   Combining Half Marks */
1033#define TT_UCR_COMBINING_HALF_MARKS            (1L <<  0) /* U+FE20-U+FE2F */
1034  /* Bit 65   CJK Compatibility Forms */
1035#define TT_UCR_CJK_COMPATIBILITY_FORMS         (1L <<  1) /* U+FE30-U+FE4F */
1036  /* Bit 66   Small Form Variants */
1037#define TT_UCR_SMALL_FORM_VARIANTS             (1L <<  2) /* U+FE50-U+FE6F */
1038  /* Bit 67   Arabic Presentation Forms-B */
1039#define TT_UCR_ARABIC_PRESENTATIONS_B          (1L <<  3) /* U+FE70-U+FEFE */
1040  /* Bit 68   Halfwidth and Fullwidth Forms */
1041#define TT_UCR_HALFWIDTH_FULLWIDTH_FORMS       (1L <<  4) /* U+FF00-U+FFEF */
1042  /* Bit 69   Specials */
1043#define TT_UCR_SPECIALS                        (1L <<  5) /* U+FFF0-U+FFFD */
1044  /* Bit 70   Tibetan */
1045#define TT_UCR_TIBETAN                         (1L <<  6) /* U+0F00-U+0FFF */
1046  /* Bit 71   Syriac */
1047#define TT_UCR_SYRIAC                          (1L <<  7) /* U+0700-U+074F */
1048  /* Bit 72   Thaana */
1049#define TT_UCR_THAANA                          (1L <<  8) /* U+0780-U+07BF */
1050  /* Bit 73   Sinhala */
1051#define TT_UCR_SINHALA                         (1L <<  9) /* U+0D80-U+0DFF */
1052  /* Bit 74   Myanmar */
1053#define TT_UCR_MYANMAR                         (1L << 10) /* U+1000-U+109F */
1054  /* Bit 75   Ethiopic */
1055#define TT_UCR_ETHIOPIC                        (1L << 11) /* U+1200-U+137F */
1056  /* Bit 76   Cherokee */
1057#define TT_UCR_CHEROKEE                        (1L << 12) /* U+13A0-U+13FF */
1058  /* Bit 77   Unified Canadian Aboriginal Syllabics */
1059#define TT_UCR_CANADIAN_ABORIGINAL_SYLLABICS   (1L << 13) /* U+1400-U+167F */
1060  /* Bit 78   Ogham */
1061#define TT_UCR_OGHAM                           (1L << 14) /* U+1680-U+169F */
1062  /* Bit 79   Runic */
1063#define TT_UCR_RUNIC                           (1L << 15) /* U+16A0-U+16FF */
1064  /* Bit 80   Khmer */
1065#define TT_UCR_KHMER                           (1L << 16) /* U+1780-U+17FF */
1066  /* Bit 81   Mongolian */
1067#define TT_UCR_MONGOLIAN                       (1L << 17) /* U+1800-U+18AF */
1068  /* Bit 82   Braille Patterns */
1069#define TT_UCR_BRAILLE                         (1L << 18) /* U+2800-U+28FF */
1070  /* Bit 83   Yi Syllables + */
1071  /*          Yi Radicals    */
1072#define TT_UCR_YI                              (1L << 19) /* U+A000-U+A48F */
1073                                                          /* U+A490-U+A4CF */
1074  /* Bit 84   Tagalog  + */
1075  /*          Hanunoo  + */
1076  /*          Buhid    + */
1077  /*          Tagbanwa   */
1078#define TT_UCR_PHILIPPINE                      (1L << 20) /* U+1700-U+171F */
1079                                                          /* U+1720-U+173F */
1080                                                          /* U+1740-U+175F */
1081                                                          /* U+1760-U+177F */
1082  /* Bit 85   Old Italic */
1083#define TT_UCR_OLD_ITALIC                      (1L << 21) /*U+10300-U+1032F*/
1084  /* Bit 86   Gothic */
1085#define TT_UCR_GOTHIC                          (1L << 22) /*U+10330-U+1034F*/
1086  /* Bit 87   Deseret */
1087#define TT_UCR_DESERET                         (1L << 23) /*U+10400-U+1044F*/
1088  /* Bit 88   Byzantine Musical Symbols + */
1089  /*          Musical Symbols             */
1090#define TT_UCR_MUSICAL_SYMBOLS                 (1L << 24) /*U+1D000-U+1D0FF*/
1091                                                          /*U+1D100-U+1D1FF*/
1092  /* Bit 89   Mathematical Alphanumeric Symbols */
1093#define TT_UCR_MATH_ALPHANUMERIC_SYMBOLS       (1L << 25) /*U+1D400-U+1D7FF*/
1094  /* Bit 90   Private Use (plane 15) + */
1095  /*          Private Use (plane 16)   */
1096#define TT_UCR_PRIVATE_USE_SUPPLEMENTARY       (1L << 26) /*U+F0000-U+FFFFD*/
1097                                                        /*U+100000-U+10FFFD*/
1098  /* Bit 91   Variation Selectors */
1099#define TT_UCR_VARIATION_SELECTORS             (1L << 27) /* U+FE00-U+FE0F */
1100  /* Bit 92   Tags */
1101#define TT_UCR_TAGS                            (1L << 28) /*U+E0000-U+E007F*/
1102
1103
1104  /*************************************************************************/
1105  /*                                                                       */
1106  /* Some compilers have a very limited length of identifiers.             */
1107  /*                                                                       */
1108#if defined( __TURBOC__ ) && __TURBOC__ < 0x0410 || defined( __PACIFIC__ )
1109#define HAVE_LIMIT_ON_IDENTS
1110#endif
1111
1112
1113#ifndef HAVE_LIMIT_ON_IDENTS
1114
1115
1116  /*************************************************************************/
1117  /*                                                                       */
1118  /* Here some alias #defines in order to be clearer.                      */
1119  /*                                                                       */
1120  /* These are not always #defined to stay within the 31 character limit   */
1121  /* which some compilers have.                                            */
1122  /*                                                                       */
1123  /* Credits go to Dave Hoo <dhoo@flash.net> for pointing out that modern  */
1124  /* Borland compilers (read: from BC++ 3.1 on) can increase this limit.   */
1125  /* If you get a warning with such a compiler, use the -i40 switch.       */
1126  /*                                                                       */
1127#define TT_UCR_ARABIC_PRESENTATION_FORMS_A      \
1128         TT_UCR_ARABIC_PRESENTATIONS_A
1129#define TT_UCR_ARABIC_PRESENTATION_FORMS_B      \
1130         TT_UCR_ARABIC_PRESENTATIONS_B
1131
1132#define TT_UCR_COMBINING_DIACRITICAL_MARKS      \
1133         TT_UCR_COMBINING_DIACRITICS
1134#define TT_UCR_COMBINING_DIACRITICAL_MARKS_SYMB \
1135         TT_UCR_COMBINING_DIACRITICS_SYMB
1136
1137
1138#endif /* !HAVE_LIMIT_ON_IDENTS */
1139
1140
1141FT_END_HEADER
1142
1143#endif /* __TTNAMEID_H__ */
1144
1145
1146/* END */
1147