zenilib  0.5.3.0
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
ttnameid.h
Go to the documentation of this 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 
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  /* U+DC00-U+DFFF */
1019 #define TT_UCR_NON_PLANE_0 TT_UCR_SURROGATES
1020  /* Bit 58 Phoenician */
1021 #define TT_UCR_PHOENICIAN (1L << 26) /*U+10900-U+1091F*/
1022  /* Bit 59 CJK Unified Ideographs */
1023  /* CJK Radicals Supplement */
1024  /* Kangxi Radicals */
1025  /* Ideographic Description Characters */
1026  /* CJK Unified Ideographs Extension A */
1027  /* CJK Unified Ideographs Extension B */
1028  /* Kanbun */
1029 #define TT_UCR_CJK_UNIFIED_IDEOGRAPHS (1L << 27) /* U+4E00-U+9FFF */
1030  /* U+2E80-U+2EFF */
1031  /* U+2F00-U+2FDF */
1032  /* U+2FF0-U+2FFF */
1033  /* U+3400-U+4DB5 */
1034  /*U+20000-U+2A6DF*/
1035  /* U+3190-U+319F */
1036  /* Bit 60 Private Use */
1037 #define TT_UCR_PRIVATE_USE (1L << 28) /* U+E000-U+F8FF */
1038  /* Bit 61 CJK Strokes */
1039  /* CJK Compatibility Ideographs */
1040  /* CJK Compatibility Ideographs Supplement */
1041 #define TT_UCR_CJK_COMPATIBILITY_IDEOGRAPHS (1L << 29) /* U+31C0-U+31EF */
1042  /* U+F900-U+FAFF */
1043  /*U+2F800-U+2FA1F*/
1044  /* Bit 62 Alphabetic Presentation Forms */
1045 #define TT_UCR_ALPHABETIC_PRESENTATION_FORMS (1L << 30) /* U+FB00-U+FB4F */
1046  /* Bit 63 Arabic Presentation Forms-A */
1047 #define TT_UCR_ARABIC_PRESENTATIONS_A (1L << 31) /* U+FB50-U+FDFF */
1048  /* Bit 64 Combining Half Marks */
1049 #define TT_UCR_COMBINING_HALF_MARKS (1L << 0) /* U+FE20-U+FE2F */
1050  /* Bit 65 Vertical forms */
1051  /* CJK Compatibility Forms */
1052 #define TT_UCR_CJK_COMPATIBILITY_FORMS (1L << 1) /* U+FE10-U+FE1F */
1053  /* U+FE30-U+FE4F */
1054  /* Bit 66 Small Form Variants */
1055 #define TT_UCR_SMALL_FORM_VARIANTS (1L << 2) /* U+FE50-U+FE6F */
1056  /* Bit 67 Arabic Presentation Forms-B */
1057 #define TT_UCR_ARABIC_PRESENTATIONS_B (1L << 3) /* U+FE70-U+FEFE */
1058  /* Bit 68 Halfwidth and Fullwidth Forms */
1059 #define TT_UCR_HALFWIDTH_FULLWIDTH_FORMS (1L << 4) /* U+FF00-U+FFEF */
1060  /* Bit 69 Specials */
1061 #define TT_UCR_SPECIALS (1L << 5) /* U+FFF0-U+FFFD */
1062  /* Bit 70 Tibetan */
1063 #define TT_UCR_TIBETAN (1L << 6) /* U+0F00-U+0FFF */
1064  /* Bit 71 Syriac */
1065 #define TT_UCR_SYRIAC (1L << 7) /* U+0700-U+074F */
1066  /* Bit 72 Thaana */
1067 #define TT_UCR_THAANA (1L << 8) /* U+0780-U+07BF */
1068  /* Bit 73 Sinhala */
1069 #define TT_UCR_SINHALA (1L << 9) /* U+0D80-U+0DFF */
1070  /* Bit 74 Myanmar */
1071 #define TT_UCR_MYANMAR (1L << 10) /* U+1000-U+109F */
1072  /* Bit 75 Ethiopic */
1073  /* Ethiopic Supplement */
1074  /* Ethiopic Extended */
1075 #define TT_UCR_ETHIOPIC (1L << 11) /* U+1200-U+137F */
1076  /* U+1380-U+139F */
1077  /* U+2D80-U+2DDF */
1078  /* Bit 76 Cherokee */
1079 #define TT_UCR_CHEROKEE (1L << 12) /* U+13A0-U+13FF */
1080  /* Bit 77 Unified Canadian Aboriginal Syllabics */
1081 #define TT_UCR_CANADIAN_ABORIGINAL_SYLLABICS (1L << 13) /* U+1400-U+167F */
1082  /* Bit 78 Ogham */
1083 #define TT_UCR_OGHAM (1L << 14) /* U+1680-U+169F */
1084  /* Bit 79 Runic */
1085 #define TT_UCR_RUNIC (1L << 15) /* U+16A0-U+16FF */
1086  /* Bit 80 Khmer */
1087  /* Khmer Symbols */
1088 #define TT_UCR_KHMER (1L << 16) /* U+1780-U+17FF */
1089  /* U+19E0-U+19FF */
1090  /* Bit 81 Mongolian */
1091 #define TT_UCR_MONGOLIAN (1L << 17) /* U+1800-U+18AF */
1092  /* Bit 82 Braille Patterns */
1093 #define TT_UCR_BRAILLE (1L << 18) /* U+2800-U+28FF */
1094  /* Bit 83 Yi Syllables */
1095  /* Yi Radicals */
1096 #define TT_UCR_YI (1L << 19) /* U+A000-U+A48F */
1097  /* U+A490-U+A4CF */
1098  /* Bit 84 Tagalog */
1099  /* Hanunoo */
1100  /* Buhid */
1101  /* Tagbanwa */
1102 #define TT_UCR_PHILIPPINE (1L << 20) /* U+1700-U+171F */
1103  /* U+1720-U+173F */
1104  /* U+1740-U+175F */
1105  /* U+1760-U+177F */
1106  /* Bit 85 Old Italic */
1107 #define TT_UCR_OLD_ITALIC (1L << 21) /*U+10300-U+1032F*/
1108  /* Bit 86 Gothic */
1109 #define TT_UCR_GOTHIC (1L << 22) /*U+10330-U+1034F*/
1110  /* Bit 87 Deseret */
1111 #define TT_UCR_DESERET (1L << 23) /*U+10400-U+1044F*/
1112  /* Bit 88 Byzantine Musical Symbols */
1113  /* Musical Symbols */
1114  /* Ancient Greek Musical Notation */
1115 #define TT_UCR_MUSICAL_SYMBOLS (1L << 24) /*U+1D000-U+1D0FF*/
1116  /*U+1D100-U+1D1FF*/
1117  /*U+1D200-U+1D24F*/
1118  /* Bit 89 Mathematical Alphanumeric Symbols */
1119 #define TT_UCR_MATH_ALPHANUMERIC_SYMBOLS (1L << 25) /*U+1D400-U+1D7FF*/
1120  /* Bit 90 Private Use (plane 15) */
1121  /* Private Use (plane 16) */
1122 #define TT_UCR_PRIVATE_USE_SUPPLEMENTARY (1L << 26) /*U+F0000-U+FFFFD*/
1123  /*U+100000-U+10FFFD*/
1124  /* Bit 91 Variation Selectors */
1125  /* Variation Selectors Supplement */
1126 #define TT_UCR_VARIATION_SELECTORS (1L << 27) /* U+FE00-U+FE0F */
1127  /*U+E0100-U+E01EF*/
1128  /* Bit 92 Tags */
1129 #define TT_UCR_TAGS (1L << 28) /*U+E0000-U+E007F*/
1130  /* Bit 93 Limbu */
1131 #define TT_UCR_LIMBU (1L << 29) /* U+1900-U+194F */
1132  /* Bit 94 Tai Le */
1133 #define TT_UCR_TAI_LE (1L << 30) /* U+1950-U+197F */
1134  /* Bit 95 New Tai Lue */
1135 #define TT_UCR_NEW_TAI_LUE (1L << 31) /* U+1980-U+19DF */
1136  /* Bit 96 Buginese */
1137 #define TT_UCR_BUGINESE (1L << 0) /* U+1A00-U+1A1F */
1138  /* Bit 97 Glagolitic */
1139 #define TT_UCR_GLAGOLITIC (1L << 1) /* U+2C00-U+2C5F */
1140  /* Bit 98 Tifinagh */
1141 #define TT_UCR_TIFINAGH (1L << 2) /* U+2D30-U+2D7F */
1142  /* Bit 99 Yijing Hexagram Symbols */
1143 #define TT_UCR_YIJING (1L << 3) /* U+4DC0-U+4DFF */
1144  /* Bit 100 Syloti Nagri */
1145 #define TT_UCR_SYLOTI_NAGRI (1L << 4) /* U+A800-U+A82F */
1146  /* Bit 101 Linear B Syllabary */
1147  /* Linear B Ideograms */
1148  /* Aegean Numbers */
1149 #define TT_UCR_LINEAR_B (1L << 5) /*U+10000-U+1007F*/
1150  /*U+10080-U+100FF*/
1151  /*U+10100-U+1013F*/
1152  /* Bit 102 Ancient Greek Numbers */
1153 #define TT_UCR_ANCIENT_GREEK_NUMBERS (1L << 6) /*U+10140-U+1018F*/
1154  /* Bit 103 Ugaritic */
1155 #define TT_UCR_UGARITIC (1L << 7) /*U+10380-U+1039F*/
1156  /* Bit 104 Old Persian */
1157 #define TT_UCR_OLD_PERSIAN (1L << 8) /*U+103A0-U+103DF*/
1158  /* Bit 105 Shavian */
1159 #define TT_UCR_SHAVIAN (1L << 9) /*U+10450-U+1047F*/
1160  /* Bit 106 Osmanya */
1161 #define TT_UCR_OSMANYA (1L << 10) /*U+10480-U+104AF*/
1162  /* Bit 107 Cypriot Syllabary */
1163 #define TT_UCR_CYPRIOT_SYLLABARY (1L << 11) /*U+10800-U+1083F*/
1164  /* Bit 108 Kharoshthi */
1165 #define TT_UCR_KHAROSHTHI (1L << 12) /*U+10A00-U+10A5F*/
1166  /* Bit 109 Tai Xuan Jing Symbols */
1167 #define TT_UCR_TAI_XUAN_JING (1L << 13) /*U+1D300-U+1D35F*/
1168  /* Bit 110 Cuneiform */
1169  /* Cuneiform Numbers and Punctuation */
1170 #define TT_UCR_CUNEIFORM (1L << 14) /*U+12000-U+123FF*/
1171  /*U+12400-U+1247F*/
1172  /* Bit 111 Counting Rod Numerals */
1173 #define TT_UCR_COUNTING_ROD_NUMERALS (1L << 15) /*U+1D360-U+1D37F*/
1174  /* Bit 112 Sundanese */
1175 #define TT_UCR_SUNDANESE (1L << 16) /* U+1B80-U+1BBF */
1176  /* Bit 113 Lepcha */
1177 #define TT_UCR_LEPCHA (1L << 17) /* U+1C00-U+1C4F */
1178  /* Bit 114 Ol Chiki */
1179 #define TT_UCR_OL_CHIKI (1L << 18) /* U+1C50-U+1C7F */
1180  /* Bit 115 Saurashtra */
1181 #define TT_UCR_SAURASHTRA (1L << 19) /* U+A880-U+A8DF */
1182  /* Bit 116 Kayah Li */
1183 #define TT_UCR_KAYAH_LI (1L << 20) /* U+A900-U+A92F */
1184  /* Bit 117 Rejang */
1185 #define TT_UCR_REJANG (1L << 21) /* U+A930-U+A95F */
1186  /* Bit 118 Cham */
1187 #define TT_UCR_CHAM (1L << 22) /* U+AA00-U+AA5F */
1188  /* Bit 119 Ancient Symbols */
1189 #define TT_UCR_ANCIENT_SYMBOLS (1L << 23) /*U+10190-U+101CF*/
1190  /* Bit 120 Phaistos Disc */
1191 #define TT_UCR_PHAISTOS_DISC (1L << 24) /*U+101D0-U+101FF*/
1192  /* Bit 121 Carian */
1193  /* Lycian */
1194  /* Lydian */
1195 #define TT_UCR_OLD_ANATOLIAN (1L << 25) /*U+102A0-U+102DF*/
1196  /*U+10280-U+1029F*/
1197  /*U+10920-U+1093F*/
1198  /* Bit 122 Domino Tiles */
1199  /* Mahjong Tiles */
1200 #define TT_UCR_GAME_TILES (1L << 26) /*U+1F030-U+1F09F*/
1201  /*U+1F000-U+1F02F*/
1202  /* Bit 123-127 Reserved for process-internal usage */
1203 
1204 
1205  /*************************************************************************/
1206  /* */
1207  /* Some compilers have a very limited length of identifiers. */
1208  /* */
1209 #if defined( __TURBOC__ ) && __TURBOC__ < 0x0410 || defined( __PACIFIC__ )
1210 #define HAVE_LIMIT_ON_IDENTS
1211 #endif
1212 
1213 
1214 #ifndef HAVE_LIMIT_ON_IDENTS
1215 
1216 
1217  /*************************************************************************/
1218  /* */
1219  /* Here some alias #defines in order to be clearer. */
1220  /* */
1221  /* These are not always #defined to stay within the 31~character limit */
1222  /* which some compilers have. */
1223  /* */
1224  /* Credits go to Dave Hoo <dhoo@flash.net> for pointing out that modern */
1225  /* Borland compilers (read: from BC++ 3.1 on) can increase this limit. */
1226  /* If you get a warning with such a compiler, use the -i40 switch. */
1227  /* */
1228 #define TT_UCR_ARABIC_PRESENTATION_FORMS_A \
1229  TT_UCR_ARABIC_PRESENTATIONS_A
1230 #define TT_UCR_ARABIC_PRESENTATION_FORMS_B \
1231  TT_UCR_ARABIC_PRESENTATIONS_B
1232 
1233 #define TT_UCR_COMBINING_DIACRITICAL_MARKS \
1234  TT_UCR_COMBINING_DIACRITICS
1235 #define TT_UCR_COMBINING_DIACRITICAL_MARKS_SYMB \
1236  TT_UCR_COMBINING_DIACRITICS_SYMB
1237 
1238 
1239 #endif /* !HAVE_LIMIT_ON_IDENTS */
1240 
1241 
1243 
1244 #endif /* __TTNAMEID_H__ */
1245 
1246 
1247 /* END */
#define FT_END_HEADER
Definition: ftheader.h:54
#define FT_BEGIN_HEADER
Definition: ftheader.h:36