1
/***************************************************************************/
5
/* TrueType name ID definitions (specification only). */
7
/* Copyright 1996-2015 by */
8
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
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. */
16
/***************************************************************************/
19
#ifndef __TTNAMEID_H__
20
#define __TTNAMEID_H__
29
/*************************************************************************/
36
/*************************************************************************/
38
/* Possible values for the `platform' identifier code in the name */
39
/* records of the TTF `name' table. */
41
/*************************************************************************/
44
/***********************************************************************
50
* A list of valid values for the `platform_id' identifier code in
51
* @FT_CharMapRec and @FT_SfntName structures.
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_.
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).
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.
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).
77
* TT_PLATFORM_CUSTOM ::
78
* Used to indicate application-specific charmaps.
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.
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 */
94
/***********************************************************************
100
* A list of valid values for the `encoding_id' for
101
* @TT_PLATFORM_APPLE_UNICODE charmaps and name entries.
104
* TT_APPLE_ID_DEFAULT ::
105
* Unicode version 1.0.
107
* TT_APPLE_ID_UNICODE_1_1 ::
108
* Unicode 1.1; specifies Hangul characters starting at U+34xx.
110
* TT_APPLE_ID_ISO_10646 ::
111
* Deprecated (identical to preceding).
113
* TT_APPLE_ID_UNICODE_2_0 ::
114
* Unicode 2.0 and beyond (UTF-16 BMP only).
116
* TT_APPLE_ID_UNICODE_32 ::
117
* Unicode 3.1 and beyond, using UTF-32.
119
* TT_APPLE_ID_VARIANT_SELECTOR ::
120
* From Adobe, not Apple. Not a normal cmap. Specifies variations
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 */
132
/***********************************************************************
138
* A list of valid values for the `encoding_id' for
139
* @TT_PLATFORM_MACINTOSH charmaps and name entries.
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 ::
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 ::
155
* TT_MAC_ID_BENGALI ::
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 ::
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 ::
172
* TT_MAC_ID_SLAVIC ::
173
* TT_MAC_ID_VIETNAMESE ::
174
* TT_MAC_ID_SINDHI ::
175
* TT_MAC_ID_UNINTERP ::
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
214
/***********************************************************************
220
* A list of valid values for the `encoding_id' for
221
* @TT_PLATFORM_ISO charmaps and name entries.
223
* Their use is now deprecated.
226
* TT_ISO_ID_7BIT_ASCII ::
230
* TT_ISO_ID_8859_1 ::
231
* Also known as Latin-1.
234
#define TT_ISO_ID_7BIT_ASCII 0
235
#define TT_ISO_ID_10646 1
236
#define TT_ISO_ID_8859_1 2
239
/***********************************************************************
245
* A list of valid values for the `encoding_id' for
246
* @TT_PLATFORM_MICROSOFT charmaps and name entries.
249
* TT_MS_ID_SYMBOL_CS ::
250
* Corresponds to Microsoft symbol encoding. See
251
* @FT_ENCODING_MS_SYMBOL.
253
* TT_MS_ID_UNICODE_CS ::
254
* Corresponds to a Microsoft WGL4 charmap, matching Unicode. See
255
* @FT_ENCODING_UNICODE.
258
* Corresponds to SJIS Japanese encoding. See @FT_ENCODING_SJIS.
261
* Corresponds to Simplified Chinese as used in Mainland China. See
262
* @FT_ENCODING_GB2312.
265
* Corresponds to Traditional Chinese as used in Taiwan and Hong Kong.
266
* See @FT_ENCODING_BIG5.
268
* TT_MS_ID_WANSUNG ::
269
* Corresponds to Korean Wansung encoding. See @FT_ENCODING_WANSUNG.
272
* Corresponds to Johab encoding. See @FT_ENCODING_JOHAB.
275
* Corresponds to UCS-4 or UTF-32 charmaps. This has been added to
276
* the OpenType specification version 1.4 (mid-2001.)
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
289
/***********************************************************************
295
* A list of valid values for the `encoding_id' for
296
* @TT_PLATFORM_ADOBE charmaps. This is a FreeType-specific extension!
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.
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
315
/*************************************************************************/
317
/* Possible values of the language identifier field in the name records */
318
/* of the TTF `name' table if the `platform' identifier code is */
319
/* TT_PLATFORM_MACINTOSH. These values are also used as return values */
320
/* for function @FT_Get_CMap_Language_ID. */
322
/* The canonical source for the Apple assigned Language ID's is at */
324
/* https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6name.html */
326
#define TT_MAC_LANGID_ENGLISH 0
327
#define TT_MAC_LANGID_FRENCH 1
328
#define TT_MAC_LANGID_GERMAN 2
329
#define TT_MAC_LANGID_ITALIAN 3
330
#define TT_MAC_LANGID_DUTCH 4
331
#define TT_MAC_LANGID_SWEDISH 5
332
#define TT_MAC_LANGID_SPANISH 6
333
#define TT_MAC_LANGID_DANISH 7
334
#define TT_MAC_LANGID_PORTUGUESE 8
335
#define TT_MAC_LANGID_NORWEGIAN 9
336
#define TT_MAC_LANGID_HEBREW 10
337
#define TT_MAC_LANGID_JAPANESE 11
338
#define TT_MAC_LANGID_ARABIC 12
339
#define TT_MAC_LANGID_FINNISH 13
340
#define TT_MAC_LANGID_GREEK 14
341
#define TT_MAC_LANGID_ICELANDIC 15
342
#define TT_MAC_LANGID_MALTESE 16
343
#define TT_MAC_LANGID_TURKISH 17
344
#define TT_MAC_LANGID_CROATIAN 18
345
#define TT_MAC_LANGID_CHINESE_TRADITIONAL 19
346
#define TT_MAC_LANGID_URDU 20
347
#define TT_MAC_LANGID_HINDI 21
348
#define TT_MAC_LANGID_THAI 22
349
#define TT_MAC_LANGID_KOREAN 23
350
#define TT_MAC_LANGID_LITHUANIAN 24
351
#define TT_MAC_LANGID_POLISH 25
352
#define TT_MAC_LANGID_HUNGARIAN 26
353
#define TT_MAC_LANGID_ESTONIAN 27
354
#define TT_MAC_LANGID_LETTISH 28
355
#define TT_MAC_LANGID_SAAMISK 29
356
#define TT_MAC_LANGID_FAEROESE 30
357
#define TT_MAC_LANGID_FARSI 31
358
#define TT_MAC_LANGID_RUSSIAN 32
359
#define TT_MAC_LANGID_CHINESE_SIMPLIFIED 33
360
#define TT_MAC_LANGID_FLEMISH 34
361
#define TT_MAC_LANGID_IRISH 35
362
#define TT_MAC_LANGID_ALBANIAN 36
363
#define TT_MAC_LANGID_ROMANIAN 37
364
#define TT_MAC_LANGID_CZECH 38
365
#define TT_MAC_LANGID_SLOVAK 39
366
#define TT_MAC_LANGID_SLOVENIAN 40
367
#define TT_MAC_LANGID_YIDDISH 41
368
#define TT_MAC_LANGID_SERBIAN 42
369
#define TT_MAC_LANGID_MACEDONIAN 43
370
#define TT_MAC_LANGID_BULGARIAN 44
371
#define TT_MAC_LANGID_UKRAINIAN 45
372
#define TT_MAC_LANGID_BYELORUSSIAN 46
373
#define TT_MAC_LANGID_UZBEK 47
374
#define TT_MAC_LANGID_KAZAKH 48
375
#define TT_MAC_LANGID_AZERBAIJANI 49
376
#define TT_MAC_LANGID_AZERBAIJANI_CYRILLIC_SCRIPT 49
377
#define TT_MAC_LANGID_AZERBAIJANI_ARABIC_SCRIPT 50
378
#define TT_MAC_LANGID_ARMENIAN 51
379
#define TT_MAC_LANGID_GEORGIAN 52
380
#define TT_MAC_LANGID_MOLDAVIAN 53
381
#define TT_MAC_LANGID_KIRGHIZ 54
382
#define TT_MAC_LANGID_TAJIKI 55
383
#define TT_MAC_LANGID_TURKMEN 56
384
#define TT_MAC_LANGID_MONGOLIAN 57
385
#define TT_MAC_LANGID_MONGOLIAN_MONGOLIAN_SCRIPT 57
386
#define TT_MAC_LANGID_MONGOLIAN_CYRILLIC_SCRIPT 58
387
#define TT_MAC_LANGID_PASHTO 59
388
#define TT_MAC_LANGID_KURDISH 60
389
#define TT_MAC_LANGID_KASHMIRI 61
390
#define TT_MAC_LANGID_SINDHI 62
391
#define TT_MAC_LANGID_TIBETAN 63
392
#define TT_MAC_LANGID_NEPALI 64
393
#define TT_MAC_LANGID_SANSKRIT 65
394
#define TT_MAC_LANGID_MARATHI 66
395
#define TT_MAC_LANGID_BENGALI 67
396
#define TT_MAC_LANGID_ASSAMESE 68
397
#define TT_MAC_LANGID_GUJARATI 69
398
#define TT_MAC_LANGID_PUNJABI 70
399
#define TT_MAC_LANGID_ORIYA 71
400
#define TT_MAC_LANGID_MALAYALAM 72
401
#define TT_MAC_LANGID_KANNADA 73
402
#define TT_MAC_LANGID_TAMIL 74
403
#define TT_MAC_LANGID_TELUGU 75
404
#define TT_MAC_LANGID_SINHALESE 76
405
#define TT_MAC_LANGID_BURMESE 77
406
#define TT_MAC_LANGID_KHMER 78
407
#define TT_MAC_LANGID_LAO 79
408
#define TT_MAC_LANGID_VIETNAMESE 80
409
#define TT_MAC_LANGID_INDONESIAN 81
410
#define TT_MAC_LANGID_TAGALOG 82
411
#define TT_MAC_LANGID_MALAY_ROMAN_SCRIPT 83
412
#define TT_MAC_LANGID_MALAY_ARABIC_SCRIPT 84
413
#define TT_MAC_LANGID_AMHARIC 85
414
#define TT_MAC_LANGID_TIGRINYA 86
415
#define TT_MAC_LANGID_GALLA 87
416
#define TT_MAC_LANGID_SOMALI 88
417
#define TT_MAC_LANGID_SWAHILI 89
418
#define TT_MAC_LANGID_RUANDA 90
419
#define TT_MAC_LANGID_RUNDI 91
420
#define TT_MAC_LANGID_CHEWA 92
421
#define TT_MAC_LANGID_MALAGASY 93
422
#define TT_MAC_LANGID_ESPERANTO 94
423
#define TT_MAC_LANGID_WELSH 128
424
#define TT_MAC_LANGID_BASQUE 129
425
#define TT_MAC_LANGID_CATALAN 130
426
#define TT_MAC_LANGID_LATIN 131
427
#define TT_MAC_LANGID_QUECHUA 132
428
#define TT_MAC_LANGID_GUARANI 133
429
#define TT_MAC_LANGID_AYMARA 134
430
#define TT_MAC_LANGID_TATAR 135
431
#define TT_MAC_LANGID_UIGHUR 136
432
#define TT_MAC_LANGID_DZONGKHA 137
433
#define TT_MAC_LANGID_JAVANESE 138
434
#define TT_MAC_LANGID_SUNDANESE 139
437
#if 0 /* these seem to be errors that have been dropped */
439
#define TT_MAC_LANGID_SCOTTISH_GAELIC 140
440
#define TT_MAC_LANGID_IRISH_GAELIC 141
445
/* The following codes are new as of 2000-03-10 */
446
#define TT_MAC_LANGID_GALICIAN 140
447
#define TT_MAC_LANGID_AFRIKAANS 141
448
#define TT_MAC_LANGID_BRETON 142
449
#define TT_MAC_LANGID_INUKTITUT 143
450
#define TT_MAC_LANGID_SCOTTISH_GAELIC 144
451
#define TT_MAC_LANGID_MANX_GAELIC 145
452
#define TT_MAC_LANGID_IRISH_GAELIC 146
453
#define TT_MAC_LANGID_TONGAN 147
454
#define TT_MAC_LANGID_GREEK_POLYTONIC 148
455
#define TT_MAC_LANGID_GREELANDIC 149
456
#define TT_MAC_LANGID_AZERBAIJANI_ROMAN_SCRIPT 150
459
/*************************************************************************/
461
/* Possible values of the language identifier field in the name records */
462
/* of the TTF `name' table if the `platform' identifier code is */
463
/* TT_PLATFORM_MICROSOFT. */
465
/* The canonical source for the MS assigned LCIDs is */
467
/* http://www.microsoft.com/globaldev/reference/lcid-all.mspx */
470
#define TT_MS_LANGID_ARABIC_GENERAL 0x0001
471
#define TT_MS_LANGID_ARABIC_SAUDI_ARABIA 0x0401
472
#define TT_MS_LANGID_ARABIC_IRAQ 0x0801
473
#define TT_MS_LANGID_ARABIC_EGYPT 0x0C01
474
#define TT_MS_LANGID_ARABIC_LIBYA 0x1001
475
#define TT_MS_LANGID_ARABIC_ALGERIA 0x1401
476
#define TT_MS_LANGID_ARABIC_MOROCCO 0x1801
477
#define TT_MS_LANGID_ARABIC_TUNISIA 0x1C01
478
#define TT_MS_LANGID_ARABIC_OMAN 0x2001
479
#define TT_MS_LANGID_ARABIC_YEMEN 0x2401
480
#define TT_MS_LANGID_ARABIC_SYRIA 0x2801
481
#define TT_MS_LANGID_ARABIC_JORDAN 0x2C01
482
#define TT_MS_LANGID_ARABIC_LEBANON 0x3001
483
#define TT_MS_LANGID_ARABIC_KUWAIT 0x3401
484
#define TT_MS_LANGID_ARABIC_UAE 0x3801
485
#define TT_MS_LANGID_ARABIC_BAHRAIN 0x3C01
486
#define TT_MS_LANGID_ARABIC_QATAR 0x4001
487
#define TT_MS_LANGID_BULGARIAN_BULGARIA 0x0402
488
#define TT_MS_LANGID_CATALAN_SPAIN 0x0403
489
#define TT_MS_LANGID_CHINESE_GENERAL 0x0004
490
#define TT_MS_LANGID_CHINESE_TAIWAN 0x0404
491
#define TT_MS_LANGID_CHINESE_PRC 0x0804
492
#define TT_MS_LANGID_CHINESE_HONG_KONG 0x0C04
493
#define TT_MS_LANGID_CHINESE_SINGAPORE 0x1004
495
#if 1 /* this looks like the correct value */
496
#define TT_MS_LANGID_CHINESE_MACAU 0x1404
497
#else /* but beware, Microsoft may change its mind...
498
the most recent Word reference has the following: */
499
#define TT_MS_LANGID_CHINESE_MACAU TT_MS_LANGID_CHINESE_HONG_KONG
502
#if 0 /* used only with .NET `cultures'; commented out */
503
#define TT_MS_LANGID_CHINESE_TRADITIONAL 0x7C04
506
#define TT_MS_LANGID_CZECH_CZECH_REPUBLIC 0x0405
507
#define TT_MS_LANGID_DANISH_DENMARK 0x0406
508
#define TT_MS_LANGID_GERMAN_GERMANY 0x0407
509
#define TT_MS_LANGID_GERMAN_SWITZERLAND 0x0807
510
#define TT_MS_LANGID_GERMAN_AUSTRIA 0x0C07
511
#define TT_MS_LANGID_GERMAN_LUXEMBOURG 0x1007
512
#define TT_MS_LANGID_GERMAN_LIECHTENSTEI 0x1407
513
#define TT_MS_LANGID_GREEK_GREECE 0x0408
515
/* don't ask what this one means... It is commented out currently. */
517
#define TT_MS_LANGID_GREEK_GREECE2 0x2008
520
#define TT_MS_LANGID_ENGLISH_GENERAL 0x0009
521
#define TT_MS_LANGID_ENGLISH_UNITED_STATES 0x0409
522
#define TT_MS_LANGID_ENGLISH_UNITED_KINGDOM 0x0809
523
#define TT_MS_LANGID_ENGLISH_AUSTRALIA 0x0C09
524
#define TT_MS_LANGID_ENGLISH_CANADA 0x1009
525
#define TT_MS_LANGID_ENGLISH_NEW_ZEALAND 0x1409
526
#define TT_MS_LANGID_ENGLISH_IRELAND 0x1809
527
#define TT_MS_LANGID_ENGLISH_SOUTH_AFRICA 0x1C09
528
#define TT_MS_LANGID_ENGLISH_JAMAICA 0x2009
529
#define TT_MS_LANGID_ENGLISH_CARIBBEAN 0x2409
530
#define TT_MS_LANGID_ENGLISH_BELIZE 0x2809
531
#define TT_MS_LANGID_ENGLISH_TRINIDAD 0x2C09
532
#define TT_MS_LANGID_ENGLISH_ZIMBABWE 0x3009
533
#define TT_MS_LANGID_ENGLISH_PHILIPPINES 0x3409
534
#define TT_MS_LANGID_ENGLISH_INDONESIA 0x3809
535
#define TT_MS_LANGID_ENGLISH_HONG_KONG 0x3C09
536
#define TT_MS_LANGID_ENGLISH_INDIA 0x4009
537
#define TT_MS_LANGID_ENGLISH_MALAYSIA 0x4409
538
#define TT_MS_LANGID_ENGLISH_SINGAPORE 0x4809
539
#define TT_MS_LANGID_SPANISH_SPAIN_TRADITIONAL_SORT 0x040A
540
#define TT_MS_LANGID_SPANISH_MEXICO 0x080A
541
#define TT_MS_LANGID_SPANISH_SPAIN_INTERNATIONAL_SORT 0x0C0A
542
#define TT_MS_LANGID_SPANISH_GUATEMALA 0x100A
543
#define TT_MS_LANGID_SPANISH_COSTA_RICA 0x140A
544
#define TT_MS_LANGID_SPANISH_PANAMA 0x180A
545
#define TT_MS_LANGID_SPANISH_DOMINICAN_REPUBLIC 0x1C0A
546
#define TT_MS_LANGID_SPANISH_VENEZUELA 0x200A
547
#define TT_MS_LANGID_SPANISH_COLOMBIA 0x240A
548
#define TT_MS_LANGID_SPANISH_PERU 0x280A
549
#define TT_MS_LANGID_SPANISH_ARGENTINA 0x2C0A
550
#define TT_MS_LANGID_SPANISH_ECUADOR 0x300A
551
#define TT_MS_LANGID_SPANISH_CHILE 0x340A
552
#define TT_MS_LANGID_SPANISH_URUGUAY 0x380A
553
#define TT_MS_LANGID_SPANISH_PARAGUAY 0x3C0A
554
#define TT_MS_LANGID_SPANISH_BOLIVIA 0x400A
555
#define TT_MS_LANGID_SPANISH_EL_SALVADOR 0x440A
556
#define TT_MS_LANGID_SPANISH_HONDURAS 0x480A
557
#define TT_MS_LANGID_SPANISH_NICARAGUA 0x4C0A
558
#define TT_MS_LANGID_SPANISH_PUERTO_RICO 0x500A
559
#define TT_MS_LANGID_SPANISH_UNITED_STATES 0x540A
560
/* The following ID blatantly violate MS specs by using a */
561
/* sublanguage > 0x1F. */
562
#define TT_MS_LANGID_SPANISH_LATIN_AMERICA 0xE40AU
563
#define TT_MS_LANGID_FINNISH_FINLAND 0x040B
564
#define TT_MS_LANGID_FRENCH_FRANCE 0x040C
565
#define TT_MS_LANGID_FRENCH_BELGIUM 0x080C
566
#define TT_MS_LANGID_FRENCH_CANADA 0x0C0C
567
#define TT_MS_LANGID_FRENCH_SWITZERLAND 0x100C
568
#define TT_MS_LANGID_FRENCH_LUXEMBOURG 0x140C
569
#define TT_MS_LANGID_FRENCH_MONACO 0x180C
570
#define TT_MS_LANGID_FRENCH_WEST_INDIES 0x1C0C
571
#define TT_MS_LANGID_FRENCH_REUNION 0x200C
572
#define TT_MS_LANGID_FRENCH_CONGO 0x240C
573
/* which was formerly: */
574
#define TT_MS_LANGID_FRENCH_ZAIRE TT_MS_LANGID_FRENCH_CONGO
575
#define TT_MS_LANGID_FRENCH_SENEGAL 0x280C
576
#define TT_MS_LANGID_FRENCH_CAMEROON 0x2C0C
577
#define TT_MS_LANGID_FRENCH_COTE_D_IVOIRE 0x300C
578
#define TT_MS_LANGID_FRENCH_MALI 0x340C
579
#define TT_MS_LANGID_FRENCH_MOROCCO 0x380C
580
#define TT_MS_LANGID_FRENCH_HAITI 0x3C0C
581
/* and another violation of the spec (see 0xE40AU) */
582
#define TT_MS_LANGID_FRENCH_NORTH_AFRICA 0xE40CU
583
#define TT_MS_LANGID_HEBREW_ISRAEL 0x040D
584
#define TT_MS_LANGID_HUNGARIAN_HUNGARY 0x040E
585
#define TT_MS_LANGID_ICELANDIC_ICELAND 0x040F
586
#define TT_MS_LANGID_ITALIAN_ITALY 0x0410
587
#define TT_MS_LANGID_ITALIAN_SWITZERLAND 0x0810
588
#define TT_MS_LANGID_JAPANESE_JAPAN 0x0411
589
#define TT_MS_LANGID_KOREAN_EXTENDED_WANSUNG_KOREA 0x0412
590
#define TT_MS_LANGID_KOREAN_JOHAB_KOREA 0x0812
591
#define TT_MS_LANGID_DUTCH_NETHERLANDS 0x0413
592
#define TT_MS_LANGID_DUTCH_BELGIUM 0x0813
593
#define TT_MS_LANGID_NORWEGIAN_NORWAY_BOKMAL 0x0414
594
#define TT_MS_LANGID_NORWEGIAN_NORWAY_NYNORSK 0x0814
595
#define TT_MS_LANGID_POLISH_POLAND 0x0415
596
#define TT_MS_LANGID_PORTUGUESE_BRAZIL 0x0416
597
#define TT_MS_LANGID_PORTUGUESE_PORTUGAL 0x0816
598
#define TT_MS_LANGID_RHAETO_ROMANIC_SWITZERLAND 0x0417
599
#define TT_MS_LANGID_ROMANIAN_ROMANIA 0x0418
600
#define TT_MS_LANGID_MOLDAVIAN_MOLDAVIA 0x0818
601
#define TT_MS_LANGID_RUSSIAN_RUSSIA 0x0419
602
#define TT_MS_LANGID_RUSSIAN_MOLDAVIA 0x0819
603
#define TT_MS_LANGID_CROATIAN_CROATIA 0x041A
604
#define TT_MS_LANGID_SERBIAN_SERBIA_LATIN 0x081A
605
#define TT_MS_LANGID_SERBIAN_SERBIA_CYRILLIC 0x0C1A
607
#if 0 /* this used to be this value, but it looks like we were wrong */
608
#define TT_MS_LANGID_BOSNIAN_BOSNIA_HERZEGOVINA 0x101A
609
#else /* current sources say */
610
#define TT_MS_LANGID_CROATIAN_BOSNIA_HERZEGOVINA 0x101A
611
#define TT_MS_LANGID_BOSNIAN_BOSNIA_HERZEGOVINA 0x141A
612
/* and XPsp2 Platform SDK added (2004-07-26) */
613
/* Names are shortened to be significant within 40 chars. */
614
#define TT_MS_LANGID_SERBIAN_BOSNIA_HERZ_LATIN 0x181A
615
#define TT_MS_LANGID_SERBIAN_BOSNIA_HERZ_CYRILLIC 0x181A
618
#define TT_MS_LANGID_SLOVAK_SLOVAKIA 0x041B
619
#define TT_MS_LANGID_ALBANIAN_ALBANIA 0x041C
620
#define TT_MS_LANGID_SWEDISH_SWEDEN 0x041D
621
#define TT_MS_LANGID_SWEDISH_FINLAND 0x081D
622
#define TT_MS_LANGID_THAI_THAILAND 0x041E
623
#define TT_MS_LANGID_TURKISH_TURKEY 0x041F
624
#define TT_MS_LANGID_URDU_PAKISTAN 0x0420
625
#define TT_MS_LANGID_URDU_INDIA 0x0820
626
#define TT_MS_LANGID_INDONESIAN_INDONESIA 0x0421
627
#define TT_MS_LANGID_UKRAINIAN_UKRAINE 0x0422
628
#define TT_MS_LANGID_BELARUSIAN_BELARUS 0x0423
629
#define TT_MS_LANGID_SLOVENE_SLOVENIA 0x0424
630
#define TT_MS_LANGID_ESTONIAN_ESTONIA 0x0425
631
#define TT_MS_LANGID_LATVIAN_LATVIA 0x0426
632
#define TT_MS_LANGID_LITHUANIAN_LITHUANIA 0x0427
633
#define TT_MS_LANGID_CLASSIC_LITHUANIAN_LITHUANIA 0x0827
634
#define TT_MS_LANGID_TAJIK_TAJIKISTAN 0x0428
635
#define TT_MS_LANGID_FARSI_IRAN 0x0429
636
#define TT_MS_LANGID_VIETNAMESE_VIET_NAM 0x042A
637
#define TT_MS_LANGID_ARMENIAN_ARMENIA 0x042B
638
#define TT_MS_LANGID_AZERI_AZERBAIJAN_LATIN 0x042C
639
#define TT_MS_LANGID_AZERI_AZERBAIJAN_CYRILLIC 0x082C
640
#define TT_MS_LANGID_BASQUE_SPAIN 0x042D
641
#define TT_MS_LANGID_SORBIAN_GERMANY 0x042E
642
#define TT_MS_LANGID_MACEDONIAN_MACEDONIA 0x042F
643
#define TT_MS_LANGID_SUTU_SOUTH_AFRICA 0x0430
644
#define TT_MS_LANGID_TSONGA_SOUTH_AFRICA 0x0431
645
#define TT_MS_LANGID_TSWANA_SOUTH_AFRICA 0x0432
646
#define TT_MS_LANGID_VENDA_SOUTH_AFRICA 0x0433
647
#define TT_MS_LANGID_XHOSA_SOUTH_AFRICA 0x0434
648
#define TT_MS_LANGID_ZULU_SOUTH_AFRICA 0x0435
649
#define TT_MS_LANGID_AFRIKAANS_SOUTH_AFRICA 0x0436
650
#define TT_MS_LANGID_GEORGIAN_GEORGIA 0x0437
651
#define TT_MS_LANGID_FAEROESE_FAEROE_ISLANDS 0x0438
652
#define TT_MS_LANGID_HINDI_INDIA 0x0439
653
#define TT_MS_LANGID_MALTESE_MALTA 0x043A
654
/* Added by XPsp2 Platform SDK (2004-07-26) */
655
#define TT_MS_LANGID_SAMI_NORTHERN_NORWAY 0x043B
656
#define TT_MS_LANGID_SAMI_NORTHERN_SWEDEN 0x083B
657
#define TT_MS_LANGID_SAMI_NORTHERN_FINLAND 0x0C3B
658
#define TT_MS_LANGID_SAMI_LULE_NORWAY 0x103B
659
#define TT_MS_LANGID_SAMI_LULE_SWEDEN 0x143B
660
#define TT_MS_LANGID_SAMI_SOUTHERN_NORWAY 0x183B
661
#define TT_MS_LANGID_SAMI_SOUTHERN_SWEDEN 0x1C3B
662
#define TT_MS_LANGID_SAMI_SKOLT_FINLAND 0x203B
663
#define TT_MS_LANGID_SAMI_INARI_FINLAND 0x243B
664
/* ... and we also keep our old identifier... */
665
#define TT_MS_LANGID_SAAMI_LAPONIA 0x043B
667
#if 0 /* this seems to be a previous inversion */
668
#define TT_MS_LANGID_IRISH_GAELIC_IRELAND 0x043C
669
#define TT_MS_LANGID_SCOTTISH_GAELIC_UNITED_KINGDOM 0x083C
671
#define TT_MS_LANGID_SCOTTISH_GAELIC_UNITED_KINGDOM 0x083C
672
#define TT_MS_LANGID_IRISH_GAELIC_IRELAND 0x043C
675
#define TT_MS_LANGID_YIDDISH_GERMANY 0x043D
676
#define TT_MS_LANGID_MALAY_MALAYSIA 0x043E
677
#define TT_MS_LANGID_MALAY_BRUNEI_DARUSSALAM 0x083E
678
#define TT_MS_LANGID_KAZAK_KAZAKSTAN 0x043F
679
#define TT_MS_LANGID_KIRGHIZ_KIRGHIZSTAN /* Cyrillic*/ 0x0440
680
/* alias declared in Windows 2000 */
681
#define TT_MS_LANGID_KIRGHIZ_KIRGHIZ_REPUBLIC \
682
TT_MS_LANGID_KIRGHIZ_KIRGHIZSTAN
684
#define TT_MS_LANGID_SWAHILI_KENYA 0x0441
685
#define TT_MS_LANGID_TURKMEN_TURKMENISTAN 0x0442
686
#define TT_MS_LANGID_UZBEK_UZBEKISTAN_LATIN 0x0443
687
#define TT_MS_LANGID_UZBEK_UZBEKISTAN_CYRILLIC 0x0843
688
#define TT_MS_LANGID_TATAR_TATARSTAN 0x0444
689
#define TT_MS_LANGID_BENGALI_INDIA 0x0445
690
#define TT_MS_LANGID_BENGALI_BANGLADESH 0x0845
691
#define TT_MS_LANGID_PUNJABI_INDIA 0x0446
692
#define TT_MS_LANGID_PUNJABI_ARABIC_PAKISTAN 0x0846
693
#define TT_MS_LANGID_GUJARATI_INDIA 0x0447
694
#define TT_MS_LANGID_ORIYA_INDIA 0x0448
695
#define TT_MS_LANGID_TAMIL_INDIA 0x0449
696
#define TT_MS_LANGID_TELUGU_INDIA 0x044A
697
#define TT_MS_LANGID_KANNADA_INDIA 0x044B
698
#define TT_MS_LANGID_MALAYALAM_INDIA 0x044C
699
#define TT_MS_LANGID_ASSAMESE_INDIA 0x044D
700
#define TT_MS_LANGID_MARATHI_INDIA 0x044E
701
#define TT_MS_LANGID_SANSKRIT_INDIA 0x044F
702
#define TT_MS_LANGID_MONGOLIAN_MONGOLIA /* Cyrillic */ 0x0450
703
#define TT_MS_LANGID_MONGOLIAN_MONGOLIA_MONGOLIAN 0x0850
704
#define TT_MS_LANGID_TIBETAN_CHINA 0x0451
705
/* Don't use the next constant! It has */
706
/* (1) the wrong spelling (Dzonghka) */
707
/* (2) Microsoft doesn't officially define it -- */
708
/* at least it is not in the List of Local */
710
/* (3) Dzongkha is not the same language as */
711
/* Tibetan, so merging it is wrong anyway. */
713
/* TT_MS_LANGID_TIBETAN_BHUTAN is correct, BTW. */
714
#define TT_MS_LANGID_DZONGHKA_BHUTAN 0x0851
717
/* the following used to be defined */
718
#define TT_MS_LANGID_TIBETAN_BHUTAN 0x0451
719
/* ... but it was changed; */
721
/* So we will continue to #define it, but with the correct value */
722
#define TT_MS_LANGID_TIBETAN_BHUTAN TT_MS_LANGID_DZONGHKA_BHUTAN
725
#define TT_MS_LANGID_WELSH_WALES 0x0452
726
#define TT_MS_LANGID_KHMER_CAMBODIA 0x0453
727
#define TT_MS_LANGID_LAO_LAOS 0x0454
728
#define TT_MS_LANGID_BURMESE_MYANMAR 0x0455
729
#define TT_MS_LANGID_GALICIAN_SPAIN 0x0456
730
#define TT_MS_LANGID_KONKANI_INDIA 0x0457
731
#define TT_MS_LANGID_MANIPURI_INDIA /* Bengali */ 0x0458
732
#define TT_MS_LANGID_SINDHI_INDIA /* Arabic */ 0x0459
733
#define TT_MS_LANGID_SINDHI_PAKISTAN 0x0859
734
/* Missing a LCID for Sindhi in Devanagari script */
735
#define TT_MS_LANGID_SYRIAC_SYRIA 0x045A
736
#define TT_MS_LANGID_SINHALESE_SRI_LANKA 0x045B
737
#define TT_MS_LANGID_CHEROKEE_UNITED_STATES 0x045C
738
#define TT_MS_LANGID_INUKTITUT_CANADA 0x045D
739
#define TT_MS_LANGID_AMHARIC_ETHIOPIA 0x045E
740
#define TT_MS_LANGID_TAMAZIGHT_MOROCCO /* Arabic */ 0x045F
741
#define TT_MS_LANGID_TAMAZIGHT_MOROCCO_LATIN 0x085F
742
/* Missing a LCID for Tifinagh script */
743
#define TT_MS_LANGID_KASHMIRI_PAKISTAN /* Arabic */ 0x0460
744
/* Spelled this way by XPsp2 Platform SDK (2004-07-26) */
745
/* script is yet unclear... might be Arabic, Nagari or Sharada */
746
#define TT_MS_LANGID_KASHMIRI_SASIA 0x0860
747
/* ... and aliased (by MS) for compatibility reasons. */
748
#define TT_MS_LANGID_KASHMIRI_INDIA TT_MS_LANGID_KASHMIRI_SASIA
749
#define TT_MS_LANGID_NEPALI_NEPAL 0x0461
750
#define TT_MS_LANGID_NEPALI_INDIA 0x0861
751
#define TT_MS_LANGID_FRISIAN_NETHERLANDS 0x0462
752
#define TT_MS_LANGID_PASHTO_AFGHANISTAN 0x0463
753
#define TT_MS_LANGID_FILIPINO_PHILIPPINES 0x0464
754
#define TT_MS_LANGID_DHIVEHI_MALDIVES 0x0465
755
/* alias declared in Windows 2000 */
756
#define TT_MS_LANGID_DIVEHI_MALDIVES TT_MS_LANGID_DHIVEHI_MALDIVES
757
#define TT_MS_LANGID_EDO_NIGERIA 0x0466
758
#define TT_MS_LANGID_FULFULDE_NIGERIA 0x0467
759
#define TT_MS_LANGID_HAUSA_NIGERIA 0x0468
760
#define TT_MS_LANGID_IBIBIO_NIGERIA 0x0469
761
#define TT_MS_LANGID_YORUBA_NIGERIA 0x046A
762
#define TT_MS_LANGID_QUECHUA_BOLIVIA 0x046B
763
#define TT_MS_LANGID_QUECHUA_ECUADOR 0x086B
764
#define TT_MS_LANGID_QUECHUA_PERU 0x0C6B
765
#define TT_MS_LANGID_SEPEDI_SOUTH_AFRICA 0x046C
766
/* Also spelled by XPsp2 Platform SDK (2004-07-26) */
767
#define TT_MS_LANGID_SOTHO_SOUTHERN_SOUTH_AFRICA \
768
TT_MS_LANGID_SEPEDI_SOUTH_AFRICA
769
/* language codes 0x046D, 0x046E and 0x046F are (still) unknown. */
770
#define TT_MS_LANGID_IGBO_NIGERIA 0x0470
771
#define TT_MS_LANGID_KANURI_NIGERIA 0x0471
772
#define TT_MS_LANGID_OROMO_ETHIOPIA 0x0472
773
#define TT_MS_LANGID_TIGRIGNA_ETHIOPIA 0x0473
774
#define TT_MS_LANGID_TIGRIGNA_ERYTHREA 0x0873
775
/* also spelled in the `Passport SDK' list as: */
776
#define TT_MS_LANGID_TIGRIGNA_ERYTREA TT_MS_LANGID_TIGRIGNA_ERYTHREA
777
#define TT_MS_LANGID_GUARANI_PARAGUAY 0x0474
778
#define TT_MS_LANGID_HAWAIIAN_UNITED_STATES 0x0475
779
#define TT_MS_LANGID_LATIN 0x0476
780
#define TT_MS_LANGID_SOMALI_SOMALIA 0x0477
781
/* Note: Yi does not have a (proper) ISO 639-2 code, since it is mostly */
782
/* not written (but OTOH the peculiar writing system is worth */
784
#define TT_MS_LANGID_YI_CHINA 0x0478
785
#define TT_MS_LANGID_PAPIAMENTU_NETHERLANDS_ANTILLES 0x0479
786
/* language codes from 0x047A to 0x047F are (still) unknown. */
787
#define TT_MS_LANGID_UIGHUR_CHINA 0x0480
788
#define TT_MS_LANGID_MAORI_NEW_ZEALAND 0x0481
790
#if 0 /* not deemed useful for fonts */
791
#define TT_MS_LANGID_HUMAN_INTERFACE_DEVICE 0x04FF
795
/*************************************************************************/
797
/* Possible values of the `name' identifier field in the name records of */
798
/* the TTF `name' table. These values are platform independent. */
800
#define TT_NAME_ID_COPYRIGHT 0
801
#define TT_NAME_ID_FONT_FAMILY 1
802
#define TT_NAME_ID_FONT_SUBFAMILY 2
803
#define TT_NAME_ID_UNIQUE_ID 3
804
#define TT_NAME_ID_FULL_NAME 4
805
#define TT_NAME_ID_VERSION_STRING 5
806
#define TT_NAME_ID_PS_NAME 6
807
#define TT_NAME_ID_TRADEMARK 7
809
/* the following values are from the OpenType spec */
810
#define TT_NAME_ID_MANUFACTURER 8
811
#define TT_NAME_ID_DESIGNER 9
812
#define TT_NAME_ID_DESCRIPTION 10
813
#define TT_NAME_ID_VENDOR_URL 11
814
#define TT_NAME_ID_DESIGNER_URL 12
815
#define TT_NAME_ID_LICENSE 13
816
#define TT_NAME_ID_LICENSE_URL 14
817
/* number 15 is reserved */
818
#define TT_NAME_ID_PREFERRED_FAMILY 16
819
#define TT_NAME_ID_PREFERRED_SUBFAMILY 17
820
#define TT_NAME_ID_MAC_FULL_NAME 18
822
/* The following code is new as of 2000-01-21 */
823
#define TT_NAME_ID_SAMPLE_TEXT 19
825
/* This is new in OpenType 1.3 */
826
#define TT_NAME_ID_CID_FINDFONT_NAME 20
828
/* This is new in OpenType 1.5 */
829
#define TT_NAME_ID_WWS_FAMILY 21
830
#define TT_NAME_ID_WWS_SUBFAMILY 22
833
/*************************************************************************/
835
/* Bit mask values for the Unicode Ranges from the TTF `OS2 ' table. */
837
/* Updated 08-Nov-2008. */
840
/* Bit 0 Basic Latin */
841
#define TT_UCR_BASIC_LATIN (1L << 0) /* U+0020-U+007E */
842
/* Bit 1 C1 Controls and Latin-1 Supplement */
843
#define TT_UCR_LATIN1_SUPPLEMENT (1L << 1) /* U+0080-U+00FF */
844
/* Bit 2 Latin Extended-A */
845
#define TT_UCR_LATIN_EXTENDED_A (1L << 2) /* U+0100-U+017F */
846
/* Bit 3 Latin Extended-B */
847
#define TT_UCR_LATIN_EXTENDED_B (1L << 3) /* U+0180-U+024F */
848
/* Bit 4 IPA Extensions */
849
/* Phonetic Extensions */
850
/* Phonetic Extensions Supplement */
851
#define TT_UCR_IPA_EXTENSIONS (1L << 4) /* U+0250-U+02AF */
854
/* Bit 5 Spacing Modifier Letters */
855
/* Modifier Tone Letters */
856
#define TT_UCR_SPACING_MODIFIER (1L << 5) /* U+02B0-U+02FF */
858
/* Bit 6 Combining Diacritical Marks */
859
/* Combining Diacritical Marks Supplement */
860
#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 */
865
#define TT_UCR_COPTIC (1L << 8) /* U+2C80-U+2CFF */
867
/* Cyrillic Supplement */
868
/* Cyrillic Extended-A */
869
/* Cyrillic Extended-B */
870
#define TT_UCR_CYRILLIC (1L << 9) /* U+0400-U+04FF */
874
/* Bit 10 Armenian */
875
#define TT_UCR_ARMENIAN (1L << 10) /* U+0530-U+058F */
877
#define TT_UCR_HEBREW (1L << 11) /* U+0590-U+05FF */
879
#define TT_UCR_VAI (1L << 12) /* U+A500-U+A63F */
881
/* Arabic Supplement */
882
#define TT_UCR_ARABIC (1L << 13) /* U+0600-U+06FF */
885
#define TT_UCR_NKO (1L << 14) /* U+07C0-U+07FF */
886
/* Bit 15 Devanagari */
887
#define TT_UCR_DEVANAGARI (1L << 15) /* U+0900-U+097F */
889
#define TT_UCR_BENGALI (1L << 16) /* U+0980-U+09FF */
890
/* Bit 17 Gurmukhi */
891
#define TT_UCR_GURMUKHI (1L << 17) /* U+0A00-U+0A7F */
892
/* Bit 18 Gujarati */
893
#define TT_UCR_GUJARATI (1L << 18) /* U+0A80-U+0AFF */
895
#define TT_UCR_ORIYA (1L << 19) /* U+0B00-U+0B7F */
897
#define TT_UCR_TAMIL (1L << 20) /* U+0B80-U+0BFF */
899
#define TT_UCR_TELUGU (1L << 21) /* U+0C00-U+0C7F */
901
#define TT_UCR_KANNADA (1L << 22) /* U+0C80-U+0CFF */
902
/* Bit 23 Malayalam */
903
#define TT_UCR_MALAYALAM (1L << 23) /* U+0D00-U+0D7F */
905
#define TT_UCR_THAI (1L << 24) /* U+0E00-U+0E7F */
907
#define TT_UCR_LAO (1L << 25) /* U+0E80-U+0EFF */
908
/* Bit 26 Georgian */
909
/* Georgian Supplement */
910
#define TT_UCR_GEORGIAN (1L << 26) /* U+10A0-U+10FF */
912
/* Bit 27 Balinese */
913
#define TT_UCR_BALINESE (1L << 27) /* U+1B00-U+1B7F */
914
/* Bit 28 Hangul Jamo */
915
#define TT_UCR_HANGUL_JAMO (1L << 28) /* U+1100-U+11FF */
916
/* Bit 29 Latin Extended Additional */
917
/* Latin Extended-C */
918
/* Latin Extended-D */
919
#define TT_UCR_LATIN_EXTENDED_ADDITIONAL (1L << 29) /* U+1E00-U+1EFF */
922
/* Bit 30 Greek Extended */
923
#define TT_UCR_GREEK_EXTENDED (1L << 30) /* U+1F00-U+1FFF */
924
/* Bit 31 General Punctuation */
925
/* Supplemental Punctuation */
926
#define TT_UCR_GENERAL_PUNCTUATION (1L << 31) /* U+2000-U+206F */
928
/* Bit 32 Superscripts And Subscripts */
929
#define TT_UCR_SUPERSCRIPTS_SUBSCRIPTS (1L << 0) /* U+2070-U+209F */
930
/* Bit 33 Currency Symbols */
931
#define TT_UCR_CURRENCY_SYMBOLS (1L << 1) /* U+20A0-U+20CF */
932
/* Bit 34 Combining Diacritical Marks For Symbols */
933
#define TT_UCR_COMBINING_DIACRITICS_SYMB (1L << 2) /* U+20D0-U+20FF */
934
/* Bit 35 Letterlike Symbols */
935
#define TT_UCR_LETTERLIKE_SYMBOLS (1L << 3) /* U+2100-U+214F */
936
/* Bit 36 Number Forms */
937
#define TT_UCR_NUMBER_FORMS (1L << 4) /* U+2150-U+218F */
939
/* Supplemental Arrows-A */
940
/* Supplemental Arrows-B */
941
/* Miscellaneous Symbols and Arrows */
942
#define TT_UCR_ARROWS (1L << 5) /* U+2190-U+21FF */
946
/* Bit 38 Mathematical Operators */
947
/* Supplemental Mathematical Operators */
948
/* Miscellaneous Mathematical Symbols-A */
949
/* Miscellaneous Mathematical Symbols-B */
950
#define TT_UCR_MATHEMATICAL_OPERATORS (1L << 6) /* U+2200-U+22FF */
954
/* Bit 39 Miscellaneous Technical */
955
#define TT_UCR_MISCELLANEOUS_TECHNICAL (1L << 7) /* U+2300-U+23FF */
956
/* Bit 40 Control Pictures */
957
#define TT_UCR_CONTROL_PICTURES (1L << 8) /* U+2400-U+243F */
958
/* Bit 41 Optical Character Recognition */
959
#define TT_UCR_OCR (1L << 9) /* U+2440-U+245F */
960
/* Bit 42 Enclosed Alphanumerics */
961
#define TT_UCR_ENCLOSED_ALPHANUMERICS (1L << 10) /* U+2460-U+24FF */
962
/* Bit 43 Box Drawing */
963
#define TT_UCR_BOX_DRAWING (1L << 11) /* U+2500-U+257F */
964
/* Bit 44 Block Elements */
965
#define TT_UCR_BLOCK_ELEMENTS (1L << 12) /* U+2580-U+259F */
966
/* Bit 45 Geometric Shapes */
967
#define TT_UCR_GEOMETRIC_SHAPES (1L << 13) /* U+25A0-U+25FF */
968
/* Bit 46 Miscellaneous Symbols */
969
#define TT_UCR_MISCELLANEOUS_SYMBOLS (1L << 14) /* U+2600-U+26FF */
970
/* Bit 47 Dingbats */
971
#define TT_UCR_DINGBATS (1L << 15) /* U+2700-U+27BF */
972
/* Bit 48 CJK Symbols and Punctuation */
973
#define TT_UCR_CJK_SYMBOLS (1L << 16) /* U+3000-U+303F */
974
/* Bit 49 Hiragana */
975
#define TT_UCR_HIRAGANA (1L << 17) /* U+3040-U+309F */
976
/* Bit 50 Katakana */
977
/* Katakana Phonetic Extensions */
978
#define TT_UCR_KATAKANA (1L << 18) /* U+30A0-U+30FF */
980
/* Bit 51 Bopomofo */
981
/* Bopomofo Extended */
982
#define TT_UCR_BOPOMOFO (1L << 19) /* U+3100-U+312F */
984
/* Bit 52 Hangul Compatibility Jamo */
985
#define TT_UCR_HANGUL_COMPATIBILITY_JAMO (1L << 20) /* U+3130-U+318F */
986
/* Bit 53 Phags-Pa */
987
#define TT_UCR_CJK_MISC (1L << 21) /* U+A840-U+A87F */
988
#define TT_UCR_KANBUN TT_UCR_CJK_MISC /* deprecated */
989
#define TT_UCR_PHAGSPA
990
/* Bit 54 Enclosed CJK Letters and Months */
991
#define TT_UCR_ENCLOSED_CJK_LETTERS_MONTHS (1L << 22) /* U+3200-U+32FF */
992
/* Bit 55 CJK Compatibility */
993
#define TT_UCR_CJK_COMPATIBILITY (1L << 23) /* U+3300-U+33FF */
994
/* Bit 56 Hangul Syllables */
995
#define TT_UCR_HANGUL (1L << 24) /* U+AC00-U+D7A3 */
996
/* Bit 57 High Surrogates */
997
/* High Private Use Surrogates */
1000
/* According to OpenType specs v.1.3+, */
1001
/* setting bit 57 implies that there is */
1002
/* at least one codepoint beyond the */
1003
/* Basic Multilingual Plane that is */
1004
/* supported by this font. So it really */
1005
/* means >= U+10000 */
1006
#define TT_UCR_SURROGATES (1L << 25) /* U+D800-U+DB7F */
1009
#define TT_UCR_NON_PLANE_0 TT_UCR_SURROGATES
1010
/* Bit 58 Phoenician */
1011
#define TT_UCR_PHOENICIAN (1L << 26) /*U+10900-U+1091F*/
1012
/* Bit 59 CJK Unified Ideographs */
1013
/* CJK Radicals Supplement */
1014
/* Kangxi Radicals */
1015
/* Ideographic Description Characters */
1016
/* CJK Unified Ideographs Extension A */
1017
/* CJK Unified Ideographs Extension B */
1019
#define TT_UCR_CJK_UNIFIED_IDEOGRAPHS (1L << 27) /* U+4E00-U+9FFF */
1026
/* Bit 60 Private Use */
1027
#define TT_UCR_PRIVATE_USE (1L << 28) /* U+E000-U+F8FF */
1028
/* Bit 61 CJK Strokes */
1029
/* CJK Compatibility Ideographs */
1030
/* CJK Compatibility Ideographs Supplement */
1031
#define TT_UCR_CJK_COMPATIBILITY_IDEOGRAPHS (1L << 29) /* U+31C0-U+31EF */
1034
/* Bit 62 Alphabetic Presentation Forms */
1035
#define TT_UCR_ALPHABETIC_PRESENTATION_FORMS (1L << 30) /* U+FB00-U+FB4F */
1036
/* Bit 63 Arabic Presentation Forms-A */
1037
#define TT_UCR_ARABIC_PRESENTATIONS_A (1L << 31) /* U+FB50-U+FDFF */
1038
/* Bit 64 Combining Half Marks */
1039
#define TT_UCR_COMBINING_HALF_MARKS (1L << 0) /* U+FE20-U+FE2F */
1040
/* Bit 65 Vertical forms */
1041
/* CJK Compatibility Forms */
1042
#define TT_UCR_CJK_COMPATIBILITY_FORMS (1L << 1) /* U+FE10-U+FE1F */
1044
/* Bit 66 Small Form Variants */
1045
#define TT_UCR_SMALL_FORM_VARIANTS (1L << 2) /* U+FE50-U+FE6F */
1046
/* Bit 67 Arabic Presentation Forms-B */
1047
#define TT_UCR_ARABIC_PRESENTATIONS_B (1L << 3) /* U+FE70-U+FEFE */
1048
/* Bit 68 Halfwidth and Fullwidth Forms */
1049
#define TT_UCR_HALFWIDTH_FULLWIDTH_FORMS (1L << 4) /* U+FF00-U+FFEF */
1050
/* Bit 69 Specials */
1051
#define TT_UCR_SPECIALS (1L << 5) /* U+FFF0-U+FFFD */
1052
/* Bit 70 Tibetan */
1053
#define TT_UCR_TIBETAN (1L << 6) /* U+0F00-U+0FFF */
1055
#define TT_UCR_SYRIAC (1L << 7) /* U+0700-U+074F */
1057
#define TT_UCR_THAANA (1L << 8) /* U+0780-U+07BF */
1058
/* Bit 73 Sinhala */
1059
#define TT_UCR_SINHALA (1L << 9) /* U+0D80-U+0DFF */
1060
/* Bit 74 Myanmar */
1061
#define TT_UCR_MYANMAR (1L << 10) /* U+1000-U+109F */
1062
/* Bit 75 Ethiopic */
1063
/* Ethiopic Supplement */
1064
/* Ethiopic Extended */
1065
#define TT_UCR_ETHIOPIC (1L << 11) /* U+1200-U+137F */
1068
/* Bit 76 Cherokee */
1069
#define TT_UCR_CHEROKEE (1L << 12) /* U+13A0-U+13FF */
1070
/* Bit 77 Unified Canadian Aboriginal Syllabics */
1071
#define TT_UCR_CANADIAN_ABORIGINAL_SYLLABICS (1L << 13) /* U+1400-U+167F */
1073
#define TT_UCR_OGHAM (1L << 14) /* U+1680-U+169F */
1075
#define TT_UCR_RUNIC (1L << 15) /* U+16A0-U+16FF */
1078
#define TT_UCR_KHMER (1L << 16) /* U+1780-U+17FF */
1080
/* Bit 81 Mongolian */
1081
#define TT_UCR_MONGOLIAN (1L << 17) /* U+1800-U+18AF */
1082
/* Bit 82 Braille Patterns */
1083
#define TT_UCR_BRAILLE (1L << 18) /* U+2800-U+28FF */
1084
/* Bit 83 Yi Syllables */
1086
#define TT_UCR_YI (1L << 19) /* U+A000-U+A48F */
1088
/* Bit 84 Tagalog */
1092
#define TT_UCR_PHILIPPINE (1L << 20) /* U+1700-U+171F */
1096
/* Bit 85 Old Italic */
1097
#define TT_UCR_OLD_ITALIC (1L << 21) /*U+10300-U+1032F*/
1099
#define TT_UCR_GOTHIC (1L << 22) /*U+10330-U+1034F*/
1100
/* Bit 87 Deseret */
1101
#define TT_UCR_DESERET (1L << 23) /*U+10400-U+1044F*/
1102
/* Bit 88 Byzantine Musical Symbols */
1103
/* Musical Symbols */
1104
/* Ancient Greek Musical Notation */
1105
#define TT_UCR_MUSICAL_SYMBOLS (1L << 24) /*U+1D000-U+1D0FF*/
1108
/* Bit 89 Mathematical Alphanumeric Symbols */
1109
#define TT_UCR_MATH_ALPHANUMERIC_SYMBOLS (1L << 25) /*U+1D400-U+1D7FF*/
1110
/* Bit 90 Private Use (plane 15) */
1111
/* Private Use (plane 16) */
1112
#define TT_UCR_PRIVATE_USE_SUPPLEMENTARY (1L << 26) /*U+F0000-U+FFFFD*/
1113
/*U+100000-U+10FFFD*/
1114
/* Bit 91 Variation Selectors */
1115
/* Variation Selectors Supplement */
1116
#define TT_UCR_VARIATION_SELECTORS (1L << 27) /* U+FE00-U+FE0F */
1119
#define TT_UCR_TAGS (1L << 28) /*U+E0000-U+E007F*/
1121
#define TT_UCR_LIMBU (1L << 29) /* U+1900-U+194F */
1123
#define TT_UCR_TAI_LE (1L << 30) /* U+1950-U+197F */
1124
/* Bit 95 New Tai Lue */
1125
#define TT_UCR_NEW_TAI_LUE (1L << 31) /* U+1980-U+19DF */
1126
/* Bit 96 Buginese */
1127
#define TT_UCR_BUGINESE (1L << 0) /* U+1A00-U+1A1F */
1128
/* Bit 97 Glagolitic */
1129
#define TT_UCR_GLAGOLITIC (1L << 1) /* U+2C00-U+2C5F */
1130
/* Bit 98 Tifinagh */
1131
#define TT_UCR_TIFINAGH (1L << 2) /* U+2D30-U+2D7F */
1132
/* Bit 99 Yijing Hexagram Symbols */
1133
#define TT_UCR_YIJING (1L << 3) /* U+4DC0-U+4DFF */
1134
/* Bit 100 Syloti Nagri */
1135
#define TT_UCR_SYLOTI_NAGRI (1L << 4) /* U+A800-U+A82F */
1136
/* Bit 101 Linear B Syllabary */
1137
/* Linear B Ideograms */
1138
/* Aegean Numbers */
1139
#define TT_UCR_LINEAR_B (1L << 5) /*U+10000-U+1007F*/
1142
/* Bit 102 Ancient Greek Numbers */
1143
#define TT_UCR_ANCIENT_GREEK_NUMBERS (1L << 6) /*U+10140-U+1018F*/
1144
/* Bit 103 Ugaritic */
1145
#define TT_UCR_UGARITIC (1L << 7) /*U+10380-U+1039F*/
1146
/* Bit 104 Old Persian */
1147
#define TT_UCR_OLD_PERSIAN (1L << 8) /*U+103A0-U+103DF*/
1148
/* Bit 105 Shavian */
1149
#define TT_UCR_SHAVIAN (1L << 9) /*U+10450-U+1047F*/
1150
/* Bit 106 Osmanya */
1151
#define TT_UCR_OSMANYA (1L << 10) /*U+10480-U+104AF*/
1152
/* Bit 107 Cypriot Syllabary */
1153
#define TT_UCR_CYPRIOT_SYLLABARY (1L << 11) /*U+10800-U+1083F*/
1154
/* Bit 108 Kharoshthi */
1155
#define TT_UCR_KHAROSHTHI (1L << 12) /*U+10A00-U+10A5F*/
1156
/* Bit 109 Tai Xuan Jing Symbols */
1157
#define TT_UCR_TAI_XUAN_JING (1L << 13) /*U+1D300-U+1D35F*/
1158
/* Bit 110 Cuneiform */
1159
/* Cuneiform Numbers and Punctuation */
1160
#define TT_UCR_CUNEIFORM (1L << 14) /*U+12000-U+123FF*/
1162
/* Bit 111 Counting Rod Numerals */
1163
#define TT_UCR_COUNTING_ROD_NUMERALS (1L << 15) /*U+1D360-U+1D37F*/
1164
/* Bit 112 Sundanese */
1165
#define TT_UCR_SUNDANESE (1L << 16) /* U+1B80-U+1BBF */
1166
/* Bit 113 Lepcha */
1167
#define TT_UCR_LEPCHA (1L << 17) /* U+1C00-U+1C4F */
1168
/* Bit 114 Ol Chiki */
1169
#define TT_UCR_OL_CHIKI (1L << 18) /* U+1C50-U+1C7F */
1170
/* Bit 115 Saurashtra */
1171
#define TT_UCR_SAURASHTRA (1L << 19) /* U+A880-U+A8DF */
1172
/* Bit 116 Kayah Li */
1173
#define TT_UCR_KAYAH_LI (1L << 20) /* U+A900-U+A92F */
1174
/* Bit 117 Rejang */
1175
#define TT_UCR_REJANG (1L << 21) /* U+A930-U+A95F */
1177
#define TT_UCR_CHAM (1L << 22) /* U+AA00-U+AA5F */
1178
/* Bit 119 Ancient Symbols */
1179
#define TT_UCR_ANCIENT_SYMBOLS (1L << 23) /*U+10190-U+101CF*/
1180
/* Bit 120 Phaistos Disc */
1181
#define TT_UCR_PHAISTOS_DISC (1L << 24) /*U+101D0-U+101FF*/
1182
/* Bit 121 Carian */
1185
#define TT_UCR_OLD_ANATOLIAN (1L << 25) /*U+102A0-U+102DF*/
1188
/* Bit 122 Domino Tiles */
1190
#define TT_UCR_GAME_TILES (1L << 26) /*U+1F030-U+1F09F*/
1192
/* Bit 123-127 Reserved for process-internal usage */
1195
/*************************************************************************/
1197
/* Some compilers have a very limited length of identifiers. */
1199
#if defined( __TURBOC__ ) && __TURBOC__ < 0x0410 || defined( __PACIFIC__ )
1200
#define HAVE_LIMIT_ON_IDENTS
1204
#ifndef HAVE_LIMIT_ON_IDENTS
1207
/*************************************************************************/
1209
/* Here some alias #defines in order to be clearer. */
1211
/* These are not always #defined to stay within the 31~character limit, */
1212
/* which some compilers have. */
1214
/* Credits go to Dave Hoo <dhoo@flash.net> for pointing out that modern */
1215
/* Borland compilers (read: from BC++ 3.1 on) can increase this limit. */
1216
/* If you get a warning with such a compiler, use the -i40 switch. */
1218
#define TT_UCR_ARABIC_PRESENTATION_FORMS_A \
1219
TT_UCR_ARABIC_PRESENTATIONS_A
1220
#define TT_UCR_ARABIC_PRESENTATION_FORMS_B \
1221
TT_UCR_ARABIC_PRESENTATIONS_B
1223
#define TT_UCR_COMBINING_DIACRITICAL_MARKS \
1224
TT_UCR_COMBINING_DIACRITICS
1225
#define TT_UCR_COMBINING_DIACRITICAL_MARKS_SYMB \
1226
TT_UCR_COMBINING_DIACRITICS_SYMB
1229
#endif /* !HAVE_LIMIT_ON_IDENTS */
1234
#endif /* __TTNAMEID_H__ */