2000-07-11 08:12:20 +02:00
|
|
|
/***************************************************************************/
|
|
|
|
/* */
|
2000-10-17 05:38:43 +02:00
|
|
|
/* ttnameid.h */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* */
|
2000-07-14 08:16:47 +02:00
|
|
|
/* TrueType name ID definitions (specification only). */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* */
|
2004-12-04 15:23:50 +01:00
|
|
|
/* Copyright 1996-2002, 2003, 2004 by */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* David Turner, Robert Wilhelm, and Werner Lemberg. */
|
|
|
|
/* */
|
|
|
|
/* This file is part of the FreeType project, and may only be used, */
|
|
|
|
/* modified, and distributed under the terms of the FreeType project */
|
|
|
|
/* license, LICENSE.TXT. By continuing to use, modify, or distribute */
|
|
|
|
/* this file you indicate that you have read the license and */
|
|
|
|
/* understand and accept it fully. */
|
|
|
|
/* */
|
|
|
|
/***************************************************************************/
|
|
|
|
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2000-12-01 00:12:33 +01:00
|
|
|
#ifndef __TTNAMEID_H__
|
|
|
|
#define __TTNAMEID_H__
|
1999-12-17 00:11:37 +01:00
|
|
|
|
|
|
|
|
2000-12-09 01:45:38 +01:00
|
|
|
#include <ft2build.h>
|
|
|
|
|
|
|
|
|
|
|
|
FT_BEGIN_HEADER
|
2000-08-01 15:17:04 +02:00
|
|
|
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/*************************************************************************/
|
|
|
|
/* */
|
|
|
|
/* Possible values for the `platform' identifier code in the name */
|
|
|
|
/* records of the TTF `name' table. */
|
|
|
|
/* */
|
2002-09-05 17:10:54 +02:00
|
|
|
/*************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
|
/***********************************************************************
|
|
|
|
*
|
|
|
|
* @enum:
|
|
|
|
* TT_PLATFORM_XXX
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* A list of valid values for the `platform_id' identifier code in
|
2003-07-25 07:57:21 +02:00
|
|
|
* @FT_CharMapRec and @FT_SfntName structures.
|
2002-09-05 17:10:54 +02:00
|
|
|
*
|
|
|
|
* @values:
|
|
|
|
* TT_PLATFORM_APPLE_UNICODE ::
|
|
|
|
* Used by Apple to indicate a Unicode character map and/or name entry.
|
|
|
|
* See @TT_APPLE_ID_XXX for corresponding `encoding_id' values. Note
|
|
|
|
* that name entries in this format are coded as big-endian UCS-2
|
|
|
|
* character codes _only_.
|
|
|
|
*
|
|
|
|
* TT_PLATFORM_MACINTOSH ::
|
|
|
|
* Used by Apple to indicate a MacOS-specific charmap and/or name entry.
|
|
|
|
* See @TT_MAC_ID_XXX for corresponding `encoding_id' values. Note that
|
|
|
|
* most TrueType fonts contain an Apple roman charmap to be usable on
|
|
|
|
* MacOS systems (even if they contain a Microsoft charmap as well).
|
|
|
|
*
|
|
|
|
* TT_PLATFORM_ISO ::
|
|
|
|
* This value was used to specify Unicode charmaps. It is however
|
|
|
|
* now deprecated. See @TT_ISO_ID_XXX for a list of corresponding
|
|
|
|
* `encoding_id' values.
|
|
|
|
*
|
|
|
|
* TT_PLATFORM_MICROSOFT ::
|
|
|
|
* Used by Microsoft to indicate Windows-specific charmaps. See
|
|
|
|
* @TT_MS_ID_XXX for a list of corresponding `encoding_id' values.
|
|
|
|
* Note that most fonts contain a Unicode charmap using
|
|
|
|
* (@TT_PLATFORM_MICROSOFT, @TT_MS_ID_UNICODE_CS).
|
|
|
|
*
|
|
|
|
* TT_PLATFORM_CUSTOM ::
|
|
|
|
* Used to indicate application-specific charmaps.
|
|
|
|
*
|
|
|
|
* TT_PLATFORM_ADOBE ::
|
|
|
|
* This value isn't part of any font format specification, but is used
|
|
|
|
* by FreeType to report Adobe-specific charmaps in an @FT_CharMapRec
|
|
|
|
* structure. See @TT_ADOBE_ID_XXX.
|
|
|
|
*/
|
* massive re-formatting changes to many, many source files. I don't
want to list them all here. The operations performed were all logical
transformations of the sources:
- trying to convert all enums and constants to CAPITALIZED_STYLE, with
#define definitions like
#define my_old_constants MY_NEW_CONSTANT
- big, big update of the documentation comments
* include/freetype/freetype.h, src/base/ftobjs.c, src/smooth/ftsmooth.c,
include/freetype/ftimage.h: adding support for LCD-optimized rendering
though the new constants/enums:
FT_RENDER_MODE_LCD, FT_RENDER_MODE_LCD_V
FT_PIXEL_MODE_LCD, FT_PIXEL_MODE_LCD_V
this is still work in progress, don't expect everything to work correctly
though most of the features have been implemented.
* adding new FT_LOAD_XXX flags, used to specify both hinting and rendering
targets:
FT_LOAD_TARGET_NORMAL :: anti-aliased hinting & rendering
FT_LOAD_TARGET_MONO :: monochrome bitmaps
FT_LOAD_TARGET_LCD :: horizontal RGB/BGR decimated hinting & rendering
FT_LOAD_TARGET_LCD_V :: vertical RGB/BGR decimated hinting & rendering
note that FT_LOAD_TARGET_NORMAL is 0, which means that the default
behaviour of the font engine is _unchanged_.
2002-08-27 22:20:29 +02:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_PLATFORM_APPLE_UNICODE 0
|
|
|
|
#define TT_PLATFORM_MACINTOSH 1
|
|
|
|
#define TT_PLATFORM_ISO 2 /* deprecated */
|
|
|
|
#define TT_PLATFORM_MICROSOFT 3
|
Updating to OpenType 1.3.
* include/freetype/internal/tttypes.h (TT_CMap0, TT_CMap2, TT_CMap4,
TT_CMap6): Adding field `language'.
(TT_CMapTable): Removing field `language'.
Type of `length' field changed to FT_ULong.
Adding fields for cmaps format 8, 10, and 12.
(TT_CMapGroup): New auxiliary structure.
(TT_CMap8_12, TT_CMap10): New structures.
* include/freetype/tttables.h (TT_HoriHeader, TT_VertHeader):
Removed last element of `Reserved' array.
* include/freetype/ttnameid.h (TT_PLATFORM_CUSTOM, TT_MS_ID_UCS_4,
TT_NAME_ID_CID_FINDFONT_NAME): New macros.
* src/sfnt/ttcmap.c (TT_CharMap_Load): Updated loading of `language'
field to the new structures.
Fixed freeing of arrays in case of unsuccessful loads.
Added support for loading format 8, 10, and 12 cmaps.
(TT_CharMap_Free): Added support for freeing format 8, 10, and 12
cmaps.
(code_to_index4): Small improvement.
(code_to_index6): Ditto.
(code_to_index8_12, code_to_index10): New functions.
* src/sfnt/ttload.c (TT_Load_Metrics_Header): Updated to new
structure.
(TT_Load_CMap): Ditto.
* src/sfnt/sfobjs.c (tt_encodings): Add MS UCS4 table (before MS
Unicode).
* src/type1/t1driver.c (t1_get_name_index): Fix compiler warning.
2001-08-13 13:44:29 +02:00
|
|
|
#define TT_PLATFORM_CUSTOM 4
|
* massive re-formatting changes to many, many source files. I don't
want to list them all here. The operations performed were all logical
transformations of the sources:
- trying to convert all enums and constants to CAPITALIZED_STYLE, with
#define definitions like
#define my_old_constants MY_NEW_CONSTANT
- big, big update of the documentation comments
* include/freetype/freetype.h, src/base/ftobjs.c, src/smooth/ftsmooth.c,
include/freetype/ftimage.h: adding support for LCD-optimized rendering
though the new constants/enums:
FT_RENDER_MODE_LCD, FT_RENDER_MODE_LCD_V
FT_PIXEL_MODE_LCD, FT_PIXEL_MODE_LCD_V
this is still work in progress, don't expect everything to work correctly
though most of the features have been implemented.
* adding new FT_LOAD_XXX flags, used to specify both hinting and rendering
targets:
FT_LOAD_TARGET_NORMAL :: anti-aliased hinting & rendering
FT_LOAD_TARGET_MONO :: monochrome bitmaps
FT_LOAD_TARGET_LCD :: horizontal RGB/BGR decimated hinting & rendering
FT_LOAD_TARGET_LCD_V :: vertical RGB/BGR decimated hinting & rendering
note that FT_LOAD_TARGET_NORMAL is 0, which means that the default
behaviour of the font engine is _unchanged_.
2002-08-27 22:20:29 +02:00
|
|
|
#define TT_PLATFORM_ADOBE 7 /* artificial */
|
|
|
|
|
|
|
|
|
2002-09-05 17:10:54 +02:00
|
|
|
/***********************************************************************
|
|
|
|
*
|
|
|
|
* @enum:
|
|
|
|
* TT_APPLE_ID_XXX
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* A list of valid values for the `encoding_id' for
|
|
|
|
* @TT_PLATFORM_APPLE_UNICODE charmaps and name entries.
|
|
|
|
*
|
|
|
|
* @values:
|
|
|
|
* TT_APPLE_ID_DEFAULT ::
|
|
|
|
* Unicode version 1.0.
|
|
|
|
* TT_APPLE_ID_UNICODE_1_1 ::
|
|
|
|
* Unicode 1.1; specifies Hangul characters starting at U+34xx.
|
|
|
|
* TT_APPLE_ID_ISO_10646 ::
|
2002-11-15 21:05:58 +01:00
|
|
|
* Deprecated (identical to preceding.)
|
2002-09-05 17:10:54 +02:00
|
|
|
* TT_APPLE_ID_UNICODE_2_0 ::
|
2002-11-15 21:05:58 +01:00
|
|
|
* Unicode 2.0 and beyond (UTF-16 BMP only.)
|
2002-09-05 17:10:54 +02:00
|
|
|
* TT_APPLE_ID_UNICODE_32 ::
|
2002-11-15 21:05:58 +01:00
|
|
|
* Unicode 3.1 and beyond, using UTF-32
|
2002-09-05 17:10:54 +02:00
|
|
|
*/
|
|
|
|
|
Updating to OpenType 1.3.
* include/freetype/internal/tttypes.h (TT_CMap0, TT_CMap2, TT_CMap4,
TT_CMap6): Adding field `language'.
(TT_CMapTable): Removing field `language'.
Type of `length' field changed to FT_ULong.
Adding fields for cmaps format 8, 10, and 12.
(TT_CMapGroup): New auxiliary structure.
(TT_CMap8_12, TT_CMap10): New structures.
* include/freetype/tttables.h (TT_HoriHeader, TT_VertHeader):
Removed last element of `Reserved' array.
* include/freetype/ttnameid.h (TT_PLATFORM_CUSTOM, TT_MS_ID_UCS_4,
TT_NAME_ID_CID_FINDFONT_NAME): New macros.
* src/sfnt/ttcmap.c (TT_CharMap_Load): Updated loading of `language'
field to the new structures.
Fixed freeing of arrays in case of unsuccessful loads.
Added support for loading format 8, 10, and 12 cmaps.
(TT_CharMap_Free): Added support for freeing format 8, 10, and 12
cmaps.
(code_to_index4): Small improvement.
(code_to_index6): Ditto.
(code_to_index8_12, code_to_index10): New functions.
* src/sfnt/ttload.c (TT_Load_Metrics_Header): Updated to new
structure.
(TT_Load_CMap): Ditto.
* src/sfnt/sfobjs.c (tt_encodings): Add MS UCS4 table (before MS
Unicode).
* src/type1/t1driver.c (t1_get_name_index): Fix compiler warning.
2001-08-13 13:44:29 +02:00
|
|
|
#define TT_APPLE_ID_DEFAULT 0 /* Unicode 1.0 */
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_APPLE_ID_UNICODE_1_1 1 /* specify Hangul at U+34xx */
|
|
|
|
#define TT_APPLE_ID_ISO_10646 2 /* deprecated */
|
|
|
|
#define TT_APPLE_ID_UNICODE_2_0 3 /* or later */
|
2002-11-15 21:05:58 +01:00
|
|
|
#define TT_APPLE_ID_UNICODE_32 4 /* 2.0 or later, full repertoire */
|
* massive re-formatting changes to many, many source files. I don't
want to list them all here. The operations performed were all logical
transformations of the sources:
- trying to convert all enums and constants to CAPITALIZED_STYLE, with
#define definitions like
#define my_old_constants MY_NEW_CONSTANT
- big, big update of the documentation comments
* include/freetype/freetype.h, src/base/ftobjs.c, src/smooth/ftsmooth.c,
include/freetype/ftimage.h: adding support for LCD-optimized rendering
though the new constants/enums:
FT_RENDER_MODE_LCD, FT_RENDER_MODE_LCD_V
FT_PIXEL_MODE_LCD, FT_PIXEL_MODE_LCD_V
this is still work in progress, don't expect everything to work correctly
though most of the features have been implemented.
* adding new FT_LOAD_XXX flags, used to specify both hinting and rendering
targets:
FT_LOAD_TARGET_NORMAL :: anti-aliased hinting & rendering
FT_LOAD_TARGET_MONO :: monochrome bitmaps
FT_LOAD_TARGET_LCD :: horizontal RGB/BGR decimated hinting & rendering
FT_LOAD_TARGET_LCD_V :: vertical RGB/BGR decimated hinting & rendering
note that FT_LOAD_TARGET_NORMAL is 0, which means that the default
behaviour of the font engine is _unchanged_.
2002-08-27 22:20:29 +02:00
|
|
|
|
|
|
|
|
2002-09-05 17:10:54 +02:00
|
|
|
/***********************************************************************
|
|
|
|
*
|
|
|
|
* @enum:
|
|
|
|
* TT_MAC_ID_XXX
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* A list of valid values for the `encoding_id' for
|
|
|
|
* @TT_PLATFORM_MACINTOSH charmaps and name entries.
|
|
|
|
*
|
|
|
|
* @values:
|
|
|
|
* TT_MAC_ID_ROMAN ::
|
|
|
|
* TT_MAC_ID_JAPANESE ::
|
|
|
|
* TT_MAC_ID_TRADITIONAL_CHINESE ::
|
|
|
|
* TT_MAC_ID_KOREAN ::
|
|
|
|
* TT_MAC_ID_ARABIC ::
|
|
|
|
* TT_MAC_ID_HEBREW ::
|
|
|
|
* TT_MAC_ID_GREEK ::
|
|
|
|
* TT_MAC_ID_RUSSIAN ::
|
|
|
|
* TT_MAC_ID_RSYMBOL ::
|
|
|
|
* TT_MAC_ID_DEVANAGARI ::
|
|
|
|
* TT_MAC_ID_GURMUKHI ::
|
|
|
|
* TT_MAC_ID_GUJARATI ::
|
|
|
|
* TT_MAC_ID_ORIYA ::
|
|
|
|
* TT_MAC_ID_BENGALI ::
|
|
|
|
* TT_MAC_ID_TAMIL ::
|
|
|
|
* TT_MAC_ID_TELUGU ::
|
|
|
|
* TT_MAC_ID_KANNADA ::
|
|
|
|
* TT_MAC_ID_MALAYALAM ::
|
|
|
|
* TT_MAC_ID_SINHALESE ::
|
|
|
|
* TT_MAC_ID_BURMESE ::
|
|
|
|
* TT_MAC_ID_KHMER ::
|
|
|
|
* TT_MAC_ID_THAI ::
|
|
|
|
* TT_MAC_ID_LAOTIAN ::
|
|
|
|
* TT_MAC_ID_GEORGIAN ::
|
|
|
|
* TT_MAC_ID_ARMENIAN ::
|
|
|
|
* TT_MAC_ID_MALDIVIAN ::
|
|
|
|
* TT_MAC_ID_SIMPLIFIED_CHINESE ::
|
|
|
|
* TT_MAC_ID_TIBETAN ::
|
|
|
|
* TT_MAC_ID_MONGOLIAN ::
|
|
|
|
* TT_MAC_ID_GEEZ ::
|
|
|
|
* TT_MAC_ID_SLAVIC ::
|
|
|
|
* TT_MAC_ID_VIETNAMESE ::
|
|
|
|
* TT_MAC_ID_SINDHI ::
|
|
|
|
* TT_MAC_ID_UNINTERP ::
|
|
|
|
*/
|
|
|
|
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_MAC_ID_ROMAN 0
|
|
|
|
#define TT_MAC_ID_JAPANESE 1
|
|
|
|
#define TT_MAC_ID_TRADITIONAL_CHINESE 2
|
|
|
|
#define TT_MAC_ID_KOREAN 3
|
|
|
|
#define TT_MAC_ID_ARABIC 4
|
|
|
|
#define TT_MAC_ID_HEBREW 5
|
|
|
|
#define TT_MAC_ID_GREEK 6
|
|
|
|
#define TT_MAC_ID_RUSSIAN 7
|
|
|
|
#define TT_MAC_ID_RSYMBOL 8
|
|
|
|
#define TT_MAC_ID_DEVANAGARI 9
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MAC_ID_GURMUKHI 10
|
|
|
|
#define TT_MAC_ID_GUJARATI 11
|
|
|
|
#define TT_MAC_ID_ORIYA 12
|
|
|
|
#define TT_MAC_ID_BENGALI 13
|
|
|
|
#define TT_MAC_ID_TAMIL 14
|
|
|
|
#define TT_MAC_ID_TELUGU 15
|
|
|
|
#define TT_MAC_ID_KANNADA 16
|
|
|
|
#define TT_MAC_ID_MALAYALAM 17
|
|
|
|
#define TT_MAC_ID_SINHALESE 18
|
|
|
|
#define TT_MAC_ID_BURMESE 19
|
|
|
|
#define TT_MAC_ID_KHMER 20
|
|
|
|
#define TT_MAC_ID_THAI 21
|
|
|
|
#define TT_MAC_ID_LAOTIAN 22
|
|
|
|
#define TT_MAC_ID_GEORGIAN 23
|
|
|
|
#define TT_MAC_ID_ARMENIAN 24
|
|
|
|
#define TT_MAC_ID_MALDIVIAN 25
|
|
|
|
#define TT_MAC_ID_SIMPLIFIED_CHINESE 25
|
|
|
|
#define TT_MAC_ID_TIBETAN 26
|
|
|
|
#define TT_MAC_ID_MONGOLIAN 27
|
|
|
|
#define TT_MAC_ID_GEEZ 28
|
|
|
|
#define TT_MAC_ID_SLAVIC 29
|
|
|
|
#define TT_MAC_ID_VIETNAMESE 30
|
|
|
|
#define TT_MAC_ID_SINDHI 31
|
|
|
|
#define TT_MAC_ID_UNINTERP 32
|
|
|
|
|
|
|
|
|
2002-09-05 17:10:54 +02:00
|
|
|
/***********************************************************************
|
|
|
|
*
|
|
|
|
* @enum:
|
|
|
|
* TT_ISO_ID_XXX
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* A list of valid values for the `encoding_id' for
|
|
|
|
* @TT_PLATFORM_ISO charmaps and name entries.
|
|
|
|
*
|
|
|
|
* Their use is now deprecated.
|
|
|
|
*
|
|
|
|
* @values:
|
|
|
|
* TT_ISO_ID_7BIT_ASCII ::
|
|
|
|
* ASCII.
|
|
|
|
* TT_ISO_ID_10646 ::
|
|
|
|
* ISO/10646.
|
|
|
|
* TT_ISO_ID_8859_1 ::
|
|
|
|
* Also known as Latin-1.
|
|
|
|
*/
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_ISO_ID_7BIT_ASCII 0
|
|
|
|
#define TT_ISO_ID_10646 1
|
|
|
|
#define TT_ISO_ID_8859_1 2
|
|
|
|
|
|
|
|
|
2002-09-05 17:10:54 +02:00
|
|
|
/***********************************************************************
|
|
|
|
*
|
|
|
|
* @enum:
|
|
|
|
* TT_MS_ID_XXX
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* A list of valid values for the `encoding_id' for
|
|
|
|
* @TT_PLATFORM_MICROSOFT charmaps and name entries.
|
|
|
|
*
|
|
|
|
* @values:
|
2002-09-18 00:57:29 +02:00
|
|
|
* TT_MS_ID_SYMBOL_CS ::
|
2003-09-01 09:06:06 +02:00
|
|
|
* Corresponds to Microsoft symbol encoding. See
|
|
|
|
* @FT_ENCODING_MS_SYMBOL.
|
2002-09-05 17:10:54 +02:00
|
|
|
*
|
|
|
|
* TT_MS_ID_UNICODE_CS ::
|
|
|
|
* Corresponds to a Microsoft WGL4 charmap, matching Unicode. See
|
|
|
|
* @FT_ENCODING_UNICODE.
|
|
|
|
*
|
|
|
|
* TT_MS_ID_SJIS ::
|
2003-09-01 09:06:06 +02:00
|
|
|
* Corresponds to SJIS Japanese encoding. See @FT_ENCODING_SJIS.
|
2002-09-05 17:10:54 +02:00
|
|
|
*
|
|
|
|
* TT_MS_ID_GB2312 ::
|
2003-09-01 09:06:06 +02:00
|
|
|
* Corresponds to Simplified Chinese as used in Mainland China. See
|
|
|
|
* @FT_ENCODING_GB2312.
|
2002-09-05 17:10:54 +02:00
|
|
|
*
|
|
|
|
* TT_MS_ID_BIG_5 ::
|
2003-09-01 09:06:06 +02:00
|
|
|
* Corresponds to Traditional Chinese as used in Taiwan and Hong Kong.
|
|
|
|
* See @FT_ENCODING_BIG5.
|
2002-09-05 17:10:54 +02:00
|
|
|
*
|
|
|
|
* TT_MS_ID_WANSUNG ::
|
2003-09-01 09:06:06 +02:00
|
|
|
* Corresponds to Korean Wansung encoding. See @FT_ENCODING_WANSUNG.
|
2002-09-05 17:10:54 +02:00
|
|
|
*
|
|
|
|
* TT_MS_ID_JOHAB ::
|
2003-09-01 09:06:06 +02:00
|
|
|
* Corresponds to Johab encoding. See @FT_ENCODING_JOHAB.
|
2002-09-05 17:10:54 +02:00
|
|
|
*
|
|
|
|
* TT_MS_ID_UCS_4 ::
|
2003-04-22 09:49:24 +02:00
|
|
|
* Corresponds to UCS-4 or UTF-32 charmaps. This has been added to
|
|
|
|
* the OpenType specification version 1.4 (mid-2001.)
|
2002-09-05 17:10:54 +02:00
|
|
|
*/
|
|
|
|
|
Updating to OpenType 1.3.
* include/freetype/internal/tttypes.h (TT_CMap0, TT_CMap2, TT_CMap4,
TT_CMap6): Adding field `language'.
(TT_CMapTable): Removing field `language'.
Type of `length' field changed to FT_ULong.
Adding fields for cmaps format 8, 10, and 12.
(TT_CMapGroup): New auxiliary structure.
(TT_CMap8_12, TT_CMap10): New structures.
* include/freetype/tttables.h (TT_HoriHeader, TT_VertHeader):
Removed last element of `Reserved' array.
* include/freetype/ttnameid.h (TT_PLATFORM_CUSTOM, TT_MS_ID_UCS_4,
TT_NAME_ID_CID_FINDFONT_NAME): New macros.
* src/sfnt/ttcmap.c (TT_CharMap_Load): Updated loading of `language'
field to the new structures.
Fixed freeing of arrays in case of unsuccessful loads.
Added support for loading format 8, 10, and 12 cmaps.
(TT_CharMap_Free): Added support for freeing format 8, 10, and 12
cmaps.
(code_to_index4): Small improvement.
(code_to_index6): Ditto.
(code_to_index8_12, code_to_index10): New functions.
* src/sfnt/ttload.c (TT_Load_Metrics_Header): Updated to new
structure.
(TT_Load_CMap): Ditto.
* src/sfnt/sfobjs.c (tt_encodings): Add MS UCS4 table (before MS
Unicode).
* src/type1/t1driver.c (t1_get_name_index): Fix compiler warning.
2001-08-13 13:44:29 +02:00
|
|
|
#define TT_MS_ID_SYMBOL_CS 0
|
|
|
|
#define TT_MS_ID_UNICODE_CS 1
|
|
|
|
#define TT_MS_ID_SJIS 2
|
|
|
|
#define TT_MS_ID_GB2312 3
|
|
|
|
#define TT_MS_ID_BIG_5 4
|
|
|
|
#define TT_MS_ID_WANSUNG 5
|
|
|
|
#define TT_MS_ID_JOHAB 6
|
|
|
|
#define TT_MS_ID_UCS_4 10
|
2000-07-11 08:12:20 +02:00
|
|
|
|
|
|
|
|
2002-09-05 17:10:54 +02:00
|
|
|
/***********************************************************************
|
|
|
|
*
|
|
|
|
* @enum:
|
|
|
|
* TT_ADOBE_ID_XXX
|
|
|
|
*
|
|
|
|
* @description:
|
|
|
|
* A list of valid values for the `encoding_id' for
|
|
|
|
* @TT_PLATFORM_ADOBE charmaps. This is a FreeType-specific extension!
|
|
|
|
*
|
|
|
|
* @values:
|
|
|
|
* TT_ADOBE_ID_STANDARD ::
|
|
|
|
* Adobe standard encoding.
|
|
|
|
* TT_ADOBE_ID_EXPERT ::
|
|
|
|
* Adobe expert encoding.
|
|
|
|
* TT_ADOBE_ID_CUSTOM ::
|
|
|
|
* Adobe custom encoding.
|
|
|
|
*/
|
|
|
|
|
2000-10-13 23:00:36 +02:00
|
|
|
#define TT_ADOBE_ID_STANDARD 0
|
|
|
|
#define TT_ADOBE_ID_EXPERT 1
|
|
|
|
#define TT_ADOBE_ID_CUSTOM 2
|
2003-12-18 16:29:20 +01:00
|
|
|
#define TT_ADOBE_ID_LATIN_1 3
|
2000-10-13 23:00:36 +02:00
|
|
|
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/*************************************************************************/
|
|
|
|
/* */
|
|
|
|
/* Possible values of the language identifier field in the name records */
|
|
|
|
/* of the TTF `name' table if the `platform' identifier code is */
|
|
|
|
/* TT_PLATFORM_MACINTOSH. */
|
|
|
|
/* */
|
|
|
|
/* The canonical source for the Apple assigned Language ID's is at */
|
|
|
|
/* */
|
|
|
|
/* http://fonts.apple.com/TTRefMan/RM06/Chap6name.html */
|
|
|
|
/* */
|
|
|
|
#define TT_MAC_LANGID_ENGLISH 0
|
|
|
|
#define TT_MAC_LANGID_FRENCH 1
|
|
|
|
#define TT_MAC_LANGID_GERMAN 2
|
|
|
|
#define TT_MAC_LANGID_ITALIAN 3
|
|
|
|
#define TT_MAC_LANGID_DUTCH 4
|
|
|
|
#define TT_MAC_LANGID_SWEDISH 5
|
|
|
|
#define TT_MAC_LANGID_SPANISH 6
|
|
|
|
#define TT_MAC_LANGID_DANISH 7
|
|
|
|
#define TT_MAC_LANGID_PORTUGUESE 8
|
|
|
|
#define TT_MAC_LANGID_NORWEGIAN 9
|
|
|
|
#define TT_MAC_LANGID_HEBREW 10
|
|
|
|
#define TT_MAC_LANGID_JAPANESE 11
|
|
|
|
#define TT_MAC_LANGID_ARABIC 12
|
|
|
|
#define TT_MAC_LANGID_FINNISH 13
|
|
|
|
#define TT_MAC_LANGID_GREEK 14
|
|
|
|
#define TT_MAC_LANGID_ICELANDIC 15
|
|
|
|
#define TT_MAC_LANGID_MALTESE 16
|
|
|
|
#define TT_MAC_LANGID_TURKISH 17
|
|
|
|
#define TT_MAC_LANGID_CROATIAN 18
|
|
|
|
#define TT_MAC_LANGID_CHINESE_TRADITIONAL 19
|
|
|
|
#define TT_MAC_LANGID_URDU 20
|
|
|
|
#define TT_MAC_LANGID_HINDI 21
|
|
|
|
#define TT_MAC_LANGID_THAI 22
|
|
|
|
#define TT_MAC_LANGID_KOREAN 23
|
|
|
|
#define TT_MAC_LANGID_LITHUANIAN 24
|
|
|
|
#define TT_MAC_LANGID_POLISH 25
|
|
|
|
#define TT_MAC_LANGID_HUNGARIAN 26
|
|
|
|
#define TT_MAC_LANGID_ESTONIAN 27
|
|
|
|
#define TT_MAC_LANGID_LETTISH 28
|
|
|
|
#define TT_MAC_LANGID_SAAMISK 29
|
|
|
|
#define TT_MAC_LANGID_FAEROESE 30
|
|
|
|
#define TT_MAC_LANGID_FARSI 31
|
|
|
|
#define TT_MAC_LANGID_RUSSIAN 32
|
|
|
|
#define TT_MAC_LANGID_CHINESE_SIMPLIFIED 33
|
|
|
|
#define TT_MAC_LANGID_FLEMISH 34
|
|
|
|
#define TT_MAC_LANGID_IRISH 35
|
|
|
|
#define TT_MAC_LANGID_ALBANIAN 36
|
|
|
|
#define TT_MAC_LANGID_ROMANIAN 37
|
|
|
|
#define TT_MAC_LANGID_CZECH 38
|
|
|
|
#define TT_MAC_LANGID_SLOVAK 39
|
|
|
|
#define TT_MAC_LANGID_SLOVENIAN 40
|
|
|
|
#define TT_MAC_LANGID_YIDDISH 41
|
|
|
|
#define TT_MAC_LANGID_SERBIAN 42
|
|
|
|
#define TT_MAC_LANGID_MACEDONIAN 43
|
|
|
|
#define TT_MAC_LANGID_BULGARIAN 44
|
|
|
|
#define TT_MAC_LANGID_UKRAINIAN 45
|
|
|
|
#define TT_MAC_LANGID_BYELORUSSIAN 46
|
|
|
|
#define TT_MAC_LANGID_UZBEK 47
|
|
|
|
#define TT_MAC_LANGID_KAZAKH 48
|
|
|
|
#define TT_MAC_LANGID_AZERBAIJANI 49
|
|
|
|
#define TT_MAC_LANGID_AZERBAIJANI_CYRILLIC_SCRIPT 49
|
|
|
|
#define TT_MAC_LANGID_AZERBAIJANI_ARABIC_SCRIPT 50
|
|
|
|
#define TT_MAC_LANGID_ARMENIAN 51
|
|
|
|
#define TT_MAC_LANGID_GEORGIAN 52
|
|
|
|
#define TT_MAC_LANGID_MOLDAVIAN 53
|
|
|
|
#define TT_MAC_LANGID_KIRGHIZ 54
|
|
|
|
#define TT_MAC_LANGID_TAJIKI 55
|
|
|
|
#define TT_MAC_LANGID_TURKMEN 56
|
|
|
|
#define TT_MAC_LANGID_MONGOLIAN 57
|
|
|
|
#define TT_MAC_LANGID_MONGOLIAN_MONGOLIAN_SCRIPT 57
|
|
|
|
#define TT_MAC_LANGID_MONGOLIAN_CYRILLIC_SCRIPT 58
|
|
|
|
#define TT_MAC_LANGID_PASHTO 59
|
|
|
|
#define TT_MAC_LANGID_KURDISH 60
|
|
|
|
#define TT_MAC_LANGID_KASHMIRI 61
|
|
|
|
#define TT_MAC_LANGID_SINDHI 62
|
|
|
|
#define TT_MAC_LANGID_TIBETAN 63
|
|
|
|
#define TT_MAC_LANGID_NEPALI 64
|
|
|
|
#define TT_MAC_LANGID_SANSKRIT 65
|
|
|
|
#define TT_MAC_LANGID_MARATHI 66
|
|
|
|
#define TT_MAC_LANGID_BENGALI 67
|
|
|
|
#define TT_MAC_LANGID_ASSAMESE 68
|
|
|
|
#define TT_MAC_LANGID_GUJARATI 69
|
|
|
|
#define TT_MAC_LANGID_PUNJABI 70
|
|
|
|
#define TT_MAC_LANGID_ORIYA 71
|
|
|
|
#define TT_MAC_LANGID_MALAYALAM 72
|
|
|
|
#define TT_MAC_LANGID_KANNADA 73
|
|
|
|
#define TT_MAC_LANGID_TAMIL 74
|
|
|
|
#define TT_MAC_LANGID_TELUGU 75
|
|
|
|
#define TT_MAC_LANGID_SINHALESE 76
|
|
|
|
#define TT_MAC_LANGID_BURMESE 77
|
|
|
|
#define TT_MAC_LANGID_KHMER 78
|
|
|
|
#define TT_MAC_LANGID_LAO 79
|
|
|
|
#define TT_MAC_LANGID_VIETNAMESE 80
|
|
|
|
#define TT_MAC_LANGID_INDONESIAN 81
|
|
|
|
#define TT_MAC_LANGID_TAGALOG 82
|
|
|
|
#define TT_MAC_LANGID_MALAY_ROMAN_SCRIPT 83
|
|
|
|
#define TT_MAC_LANGID_MALAY_ARABIC_SCRIPT 84
|
|
|
|
#define TT_MAC_LANGID_AMHARIC 85
|
|
|
|
#define TT_MAC_LANGID_TIGRINYA 86
|
|
|
|
#define TT_MAC_LANGID_GALLA 87
|
|
|
|
#define TT_MAC_LANGID_SOMALI 88
|
|
|
|
#define TT_MAC_LANGID_SWAHILI 89
|
|
|
|
#define TT_MAC_LANGID_RUANDA 90
|
|
|
|
#define TT_MAC_LANGID_RUNDI 91
|
|
|
|
#define TT_MAC_LANGID_CHEWA 92
|
|
|
|
#define TT_MAC_LANGID_MALAGASY 93
|
|
|
|
#define TT_MAC_LANGID_ESPERANTO 94
|
|
|
|
#define TT_MAC_LANGID_WELSH 128
|
|
|
|
#define TT_MAC_LANGID_BASQUE 129
|
|
|
|
#define TT_MAC_LANGID_CATALAN 130
|
|
|
|
#define TT_MAC_LANGID_LATIN 131
|
|
|
|
#define TT_MAC_LANGID_QUECHUA 132
|
|
|
|
#define TT_MAC_LANGID_GUARANI 133
|
|
|
|
#define TT_MAC_LANGID_AYMARA 134
|
|
|
|
#define TT_MAC_LANGID_TATAR 135
|
|
|
|
#define TT_MAC_LANGID_UIGHUR 136
|
|
|
|
#define TT_MAC_LANGID_DZONGKHA 137
|
|
|
|
#define TT_MAC_LANGID_JAVANESE 138
|
|
|
|
#define TT_MAC_LANGID_SUNDANESE 139
|
|
|
|
|
2000-03-23 18:24:28 +01:00
|
|
|
|
|
|
|
#if 0 /* these seem to be errors that have been dropped */
|
2000-07-11 08:12:20 +02:00
|
|
|
|
|
|
|
#define TT_MAC_LANGID_SCOTTISH_GAELIC 140
|
|
|
|
#define TT_MAC_LANGID_IRISH_GAELIC 141
|
|
|
|
|
2000-03-23 18:24:28 +01:00
|
|
|
#endif
|
|
|
|
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* The following codes are new as of 2000-03-10 */
|
|
|
|
#define TT_MAC_LANGID_GALICIAN 140
|
|
|
|
#define TT_MAC_LANGID_AFRIKAANS 141
|
|
|
|
#define TT_MAC_LANGID_BRETON 142
|
|
|
|
#define TT_MAC_LANGID_INUKTITUT 143
|
|
|
|
#define TT_MAC_LANGID_SCOTTISH_GAELIC 144
|
|
|
|
#define TT_MAC_LANGID_MANX_GAELIC 145
|
|
|
|
#define TT_MAC_LANGID_IRISH_GAELIC 146
|
|
|
|
#define TT_MAC_LANGID_TONGAN 147
|
|
|
|
#define TT_MAC_LANGID_GREEK_POLYTONIC 148
|
|
|
|
#define TT_MAC_LANGID_GREELANDIC 149
|
|
|
|
#define TT_MAC_LANGID_AZERBAIJANI_ROMAN_SCRIPT 150
|
|
|
|
|
|
|
|
|
|
|
|
/*************************************************************************/
|
|
|
|
/* */
|
|
|
|
/* Possible values of the language identifier field in the name records */
|
|
|
|
/* of the TTF `name' table if the `platform' identifier code is */
|
|
|
|
/* TT_PLATFORM_MICROSOFT. */
|
|
|
|
/* */
|
2004-12-03 15:58:40 +01:00
|
|
|
/* The canonical source for the MS assigned LCID's (seems to) be at */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* */
|
2004-12-03 15:58:40 +01:00
|
|
|
/* http://www.microsoft.com/globaldev/reference/lcid-all.mspx */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* */
|
2004-12-03 15:58:40 +01:00
|
|
|
/* It used to be at various places, among them */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* */
|
2004-12-03 15:58:40 +01:00
|
|
|
/* http://www.microsoft.com/typography/OTSPEC/lcid-cp.txt */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* http://www.microsoft.com/globaldev/reference/loclanghome.asp */
|
|
|
|
/* http://support.microsoft.com/support/kb/articles/Q224/8/04.ASP */
|
2004-12-03 15:58:40 +01:00
|
|
|
/* http://msdn.microsoft.com/library/en-us/passport25/ */
|
|
|
|
/* NET_Passport_VBScript_Documentation/Single_Sign_In/ */
|
|
|
|
/* Advanced_Single_Sign_In/Localization_and_LCIDs.asp */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* */
|
2004-12-03 15:58:40 +01:00
|
|
|
/* Hopefully, it seems now that the Globaldev site prevails... */
|
|
|
|
/* (updated by Antoine, 2004-02-17) */
|
|
|
|
|
|
|
|
#define TT_MS_LANGID_ARABIC_GENERAL 0x0001
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_ARABIC_SAUDI_ARABIA 0x0401
|
|
|
|
#define TT_MS_LANGID_ARABIC_IRAQ 0x0801
|
|
|
|
#define TT_MS_LANGID_ARABIC_EGYPT 0x0c01
|
|
|
|
#define TT_MS_LANGID_ARABIC_LIBYA 0x1001
|
|
|
|
#define TT_MS_LANGID_ARABIC_ALGERIA 0x1401
|
|
|
|
#define TT_MS_LANGID_ARABIC_MOROCCO 0x1801
|
|
|
|
#define TT_MS_LANGID_ARABIC_TUNISIA 0x1c01
|
|
|
|
#define TT_MS_LANGID_ARABIC_OMAN 0x2001
|
|
|
|
#define TT_MS_LANGID_ARABIC_YEMEN 0x2401
|
|
|
|
#define TT_MS_LANGID_ARABIC_SYRIA 0x2801
|
|
|
|
#define TT_MS_LANGID_ARABIC_JORDAN 0x2c01
|
|
|
|
#define TT_MS_LANGID_ARABIC_LEBANON 0x3001
|
|
|
|
#define TT_MS_LANGID_ARABIC_KUWAIT 0x3401
|
|
|
|
#define TT_MS_LANGID_ARABIC_UAE 0x3801
|
|
|
|
#define TT_MS_LANGID_ARABIC_BAHRAIN 0x3c01
|
|
|
|
#define TT_MS_LANGID_ARABIC_QATAR 0x4001
|
|
|
|
#define TT_MS_LANGID_BULGARIAN_BULGARIA 0x0402
|
|
|
|
#define TT_MS_LANGID_CATALAN_SPAIN 0x0403
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_CHINESE_GENERAL 0x0004
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_CHINESE_TAIWAN 0x0404
|
|
|
|
#define TT_MS_LANGID_CHINESE_PRC 0x0804
|
|
|
|
#define TT_MS_LANGID_CHINESE_HONG_KONG 0x0c04
|
|
|
|
#define TT_MS_LANGID_CHINESE_SINGAPORE 0x1004
|
2001-01-31 04:00:22 +01:00
|
|
|
|
2004-12-03 15:58:40 +01:00
|
|
|
#if 1 /* this looks like the correct value */
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_CHINESE_MACAU 0x1404
|
2001-01-31 04:00:22 +01:00
|
|
|
#else /* but beware, Microsoft may change its mind...
|
2001-12-05 02:22:05 +01:00
|
|
|
the most recent Word reference has the following: */
|
|
|
|
#define TT_MS_LANGID_CHINESE_MACAU TT_MS_LANGID_CHINESE_HONG_KONG
|
2001-01-31 04:00:22 +01:00
|
|
|
#endif
|
|
|
|
|
2004-12-03 15:58:40 +01:00
|
|
|
#if 0 /* used only with .NET "cultures"; commented out */
|
|
|
|
#define TT_MS_LANGID_CHINESE_TRADITIONAL 0x7C04
|
|
|
|
#endif
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_CZECH_CZECH_REPUBLIC 0x0405
|
|
|
|
#define TT_MS_LANGID_DANISH_DENMARK 0x0406
|
|
|
|
#define TT_MS_LANGID_GERMAN_GERMANY 0x0407
|
|
|
|
#define TT_MS_LANGID_GERMAN_SWITZERLAND 0x0807
|
|
|
|
#define TT_MS_LANGID_GERMAN_AUSTRIA 0x0c07
|
|
|
|
#define TT_MS_LANGID_GERMAN_LUXEMBOURG 0x1007
|
|
|
|
#define TT_MS_LANGID_GERMAN_LIECHTENSTEI 0x1407
|
|
|
|
#define TT_MS_LANGID_GREEK_GREECE 0x0408
|
2004-12-03 15:58:40 +01:00
|
|
|
|
|
|
|
/* don't ask what this one means... It is commented out currently. */
|
|
|
|
#if 0
|
|
|
|
#define TT_MS_LANGID_GREEK_GREECE2 0x2008
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define TT_MS_LANGID_ENGLISH_GENERAL 0x0009
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_ENGLISH_UNITED_STATES 0x0409
|
|
|
|
#define TT_MS_LANGID_ENGLISH_UNITED_KINGDOM 0x0809
|
|
|
|
#define TT_MS_LANGID_ENGLISH_AUSTRALIA 0x0c09
|
|
|
|
#define TT_MS_LANGID_ENGLISH_CANADA 0x1009
|
|
|
|
#define TT_MS_LANGID_ENGLISH_NEW_ZEALAND 0x1409
|
|
|
|
#define TT_MS_LANGID_ENGLISH_IRELAND 0x1809
|
|
|
|
#define TT_MS_LANGID_ENGLISH_SOUTH_AFRICA 0x1c09
|
|
|
|
#define TT_MS_LANGID_ENGLISH_JAMAICA 0x2009
|
|
|
|
#define TT_MS_LANGID_ENGLISH_CARIBBEAN 0x2409
|
|
|
|
#define TT_MS_LANGID_ENGLISH_BELIZE 0x2809
|
|
|
|
#define TT_MS_LANGID_ENGLISH_TRINIDAD 0x2c09
|
|
|
|
#define TT_MS_LANGID_ENGLISH_ZIMBABWE 0x3009
|
|
|
|
#define TT_MS_LANGID_ENGLISH_PHILIPPINES 0x3409
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_ENGLISH_INDONESIA 0x3809
|
|
|
|
#define TT_MS_LANGID_ENGLISH_HONG_KONG 0x3c09
|
|
|
|
#define TT_MS_LANGID_ENGLISH_INDIA 0x4009
|
|
|
|
#define TT_MS_LANGID_ENGLISH_MALAYSIA 0x4409
|
|
|
|
#define TT_MS_LANGID_ENGLISH_SINGAPORE 0x4809
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_SPANISH_SPAIN_TRADITIONAL_SORT 0x040a
|
|
|
|
#define TT_MS_LANGID_SPANISH_MEXICO 0x080a
|
|
|
|
#define TT_MS_LANGID_SPANISH_SPAIN_INTERNATIONAL_SORT 0x0c0a
|
|
|
|
#define TT_MS_LANGID_SPANISH_GUATEMALA 0x100a
|
|
|
|
#define TT_MS_LANGID_SPANISH_COSTA_RICA 0x140a
|
|
|
|
#define TT_MS_LANGID_SPANISH_PANAMA 0x180a
|
|
|
|
#define TT_MS_LANGID_SPANISH_DOMINICAN_REPUBLIC 0x1c0a
|
|
|
|
#define TT_MS_LANGID_SPANISH_VENEZUELA 0x200a
|
|
|
|
#define TT_MS_LANGID_SPANISH_COLOMBIA 0x240a
|
|
|
|
#define TT_MS_LANGID_SPANISH_PERU 0x280a
|
|
|
|
#define TT_MS_LANGID_SPANISH_ARGENTINA 0x2c0a
|
|
|
|
#define TT_MS_LANGID_SPANISH_ECUADOR 0x300a
|
|
|
|
#define TT_MS_LANGID_SPANISH_CHILE 0x340a
|
|
|
|
#define TT_MS_LANGID_SPANISH_URUGUAY 0x380a
|
|
|
|
#define TT_MS_LANGID_SPANISH_PARAGUAY 0x3c0a
|
|
|
|
#define TT_MS_LANGID_SPANISH_BOLIVIA 0x400a
|
|
|
|
#define TT_MS_LANGID_SPANISH_EL_SALVADOR 0x440a
|
|
|
|
#define TT_MS_LANGID_SPANISH_HONDURAS 0x480a
|
|
|
|
#define TT_MS_LANGID_SPANISH_NICARAGUA 0x4c0a
|
|
|
|
#define TT_MS_LANGID_SPANISH_PUERTO_RICO 0x500a
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_SPANISH_UNITED_STATES 0x540a
|
|
|
|
/* The following ID blatantly violate MS specs by using a */
|
|
|
|
/* sublanguage > 0x1F. */
|
|
|
|
#define TT_MS_LANGID_SPANISH_LATIN_AMERICA 0xE40aU
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_FINNISH_FINLAND 0x040b
|
|
|
|
#define TT_MS_LANGID_FRENCH_FRANCE 0x040c
|
|
|
|
#define TT_MS_LANGID_FRENCH_BELGIUM 0x080c
|
|
|
|
#define TT_MS_LANGID_FRENCH_CANADA 0x0c0c
|
|
|
|
#define TT_MS_LANGID_FRENCH_SWITZERLAND 0x100c
|
|
|
|
#define TT_MS_LANGID_FRENCH_LUXEMBOURG 0x140c
|
|
|
|
#define TT_MS_LANGID_FRENCH_MONACO 0x180c
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_FRENCH_WEST_INDIES 0x1c0c
|
|
|
|
#define TT_MS_LANGID_FRENCH_REUNION 0x200c
|
|
|
|
#define TT_MS_LANGID_FRENCH_CONGO 0x240c
|
|
|
|
/* which was formerly: */
|
|
|
|
#define TT_MS_LANGID_FRENCH_ZAIRE TT_MS_LANGID_FRENCH_CONGO
|
|
|
|
#define TT_MS_LANGID_FRENCH_SENEGAL 0x280c
|
|
|
|
#define TT_MS_LANGID_FRENCH_CAMEROON 0x2c0c
|
|
|
|
#define TT_MS_LANGID_FRENCH_COTE_D_IVOIRE 0x300c
|
|
|
|
#define TT_MS_LANGID_FRENCH_MALI 0x340c
|
|
|
|
#define TT_MS_LANGID_FRENCH_MOROCCO 0x380c
|
|
|
|
#define TT_MS_LANGID_FRENCH_HAITI 0x3c0c
|
|
|
|
/* and another violation of the spec (see 0xE40aU) */
|
|
|
|
#define TT_MS_LANGID_FRENCH_NORTH_AFRICA 0xE40cU
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_HEBREW_ISRAEL 0x040d
|
|
|
|
#define TT_MS_LANGID_HUNGARIAN_HUNGARY 0x040e
|
|
|
|
#define TT_MS_LANGID_ICELANDIC_ICELAND 0x040f
|
|
|
|
#define TT_MS_LANGID_ITALIAN_ITALY 0x0410
|
|
|
|
#define TT_MS_LANGID_ITALIAN_SWITZERLAND 0x0810
|
|
|
|
#define TT_MS_LANGID_JAPANESE_JAPAN 0x0411
|
|
|
|
#define TT_MS_LANGID_KOREAN_EXTENDED_WANSUNG_KOREA 0x0412
|
|
|
|
#define TT_MS_LANGID_KOREAN_JOHAB_KOREA 0x0812
|
|
|
|
#define TT_MS_LANGID_DUTCH_NETHERLANDS 0x0413
|
|
|
|
#define TT_MS_LANGID_DUTCH_BELGIUM 0x0813
|
|
|
|
#define TT_MS_LANGID_NORWEGIAN_NORWAY_BOKMAL 0x0414
|
|
|
|
#define TT_MS_LANGID_NORWEGIAN_NORWAY_NYNORSK 0x0814
|
|
|
|
#define TT_MS_LANGID_POLISH_POLAND 0x0415
|
|
|
|
#define TT_MS_LANGID_PORTUGUESE_BRAZIL 0x0416
|
|
|
|
#define TT_MS_LANGID_PORTUGUESE_PORTUGAL 0x0816
|
|
|
|
#define TT_MS_LANGID_RHAETO_ROMANIC_SWITZERLAND 0x0417
|
|
|
|
#define TT_MS_LANGID_ROMANIAN_ROMANIA 0x0418
|
|
|
|
#define TT_MS_LANGID_MOLDAVIAN_MOLDAVIA 0x0818
|
|
|
|
#define TT_MS_LANGID_RUSSIAN_RUSSIA 0x0419
|
|
|
|
#define TT_MS_LANGID_RUSSIAN_MOLDAVIA 0x0819
|
|
|
|
#define TT_MS_LANGID_CROATIAN_CROATIA 0x041a
|
|
|
|
#define TT_MS_LANGID_SERBIAN_SERBIA_LATIN 0x081a
|
|
|
|
#define TT_MS_LANGID_SERBIAN_SERBIA_CYRILLIC 0x0c1a
|
2004-12-03 15:58:40 +01:00
|
|
|
|
|
|
|
#if 0 /* this used to be this value, but it looks like we were wrong */
|
|
|
|
#define TT_MS_LANGID_BOSNIAN_BOSNIA_HERZEGOVINA 0x101a
|
|
|
|
#else /* current sources say */
|
|
|
|
#define TT_MS_LANGID_CROATIAN_BOSNIA_HERZEGOVINA 0x101a
|
|
|
|
#define TT_MS_LANGID_BOSNIAN_BOSNIA_HERZEGOVINA 0x141a
|
|
|
|
/* and XPsp2 Platform SDK added (2004-07-26) */
|
|
|
|
/* Names are shortened to be signifiant within 40 chars. */
|
|
|
|
#define TT_MS_LANGID_SERBIAN_BOSNIA_HERZ_LATIN 0x181a
|
|
|
|
#define TT_MS_LANGID_SERBIAN_BOSNIA_HERZ_CYRILLIC 0x181a
|
|
|
|
#endif
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_SLOVAK_SLOVAKIA 0x041b
|
|
|
|
#define TT_MS_LANGID_ALBANIAN_ALBANIA 0x041c
|
|
|
|
#define TT_MS_LANGID_SWEDISH_SWEDEN 0x041d
|
|
|
|
#define TT_MS_LANGID_SWEDISH_FINLAND 0x081d
|
|
|
|
#define TT_MS_LANGID_THAI_THAILAND 0x041e
|
|
|
|
#define TT_MS_LANGID_TURKISH_TURKEY 0x041f
|
|
|
|
#define TT_MS_LANGID_URDU_PAKISTAN 0x0420
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_URDU_INDIA 0x0820
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_INDONESIAN_INDONESIA 0x0421
|
|
|
|
#define TT_MS_LANGID_UKRAINIAN_UKRAINE 0x0422
|
|
|
|
#define TT_MS_LANGID_BELARUSIAN_BELARUS 0x0423
|
|
|
|
#define TT_MS_LANGID_SLOVENE_SLOVENIA 0x0424
|
|
|
|
#define TT_MS_LANGID_ESTONIAN_ESTONIA 0x0425
|
|
|
|
#define TT_MS_LANGID_LATVIAN_LATVIA 0x0426
|
|
|
|
#define TT_MS_LANGID_LITHUANIAN_LITHUANIA 0x0427
|
|
|
|
#define TT_MS_LANGID_CLASSIC_LITHUANIAN_LITHUANIA 0x0827
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_TAJIK_TAJIKISTAN 0x0428
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_FARSI_IRAN 0x0429
|
|
|
|
#define TT_MS_LANGID_VIETNAMESE_VIET_NAM 0x042a
|
|
|
|
#define TT_MS_LANGID_ARMENIAN_ARMENIA 0x042b
|
|
|
|
#define TT_MS_LANGID_AZERI_AZERBAIJAN_LATIN 0x042c
|
|
|
|
#define TT_MS_LANGID_AZERI_AZERBAIJAN_CYRILLIC 0x082c
|
|
|
|
#define TT_MS_LANGID_BASQUE_SPAIN 0x042d
|
|
|
|
#define TT_MS_LANGID_SORBIAN_GERMANY 0x042e
|
|
|
|
#define TT_MS_LANGID_MACEDONIAN_MACEDONIA 0x042f
|
|
|
|
#define TT_MS_LANGID_SUTU_SOUTH_AFRICA 0x0430
|
|
|
|
#define TT_MS_LANGID_TSONGA_SOUTH_AFRICA 0x0431
|
|
|
|
#define TT_MS_LANGID_TSWANA_SOUTH_AFRICA 0x0432
|
|
|
|
#define TT_MS_LANGID_VENDA_SOUTH_AFRICA 0x0433
|
|
|
|
#define TT_MS_LANGID_XHOSA_SOUTH_AFRICA 0x0434
|
|
|
|
#define TT_MS_LANGID_ZULU_SOUTH_AFRICA 0x0435
|
|
|
|
#define TT_MS_LANGID_AFRIKAANS_SOUTH_AFRICA 0x0436
|
|
|
|
#define TT_MS_LANGID_GEORGIAN_GEORGIA 0x0437
|
|
|
|
#define TT_MS_LANGID_FAEROESE_FAEROE_ISLANDS 0x0438
|
|
|
|
#define TT_MS_LANGID_HINDI_INDIA 0x0439
|
|
|
|
#define TT_MS_LANGID_MALTESE_MALTA 0x043a
|
2004-12-03 15:58:40 +01:00
|
|
|
/* Added by XPsp2 Platform SDK (2004-07-26) */
|
|
|
|
#define TT_MS_LANGID_SAMI_NORTHERN_NORWAY 0x043b
|
|
|
|
#define TT_MS_LANGID_SAMI_NORTHERN_SWEDEN 0x083b
|
|
|
|
#define TT_MS_LANGID_SAMI_NORTHERN_FINLAND 0x0C3b
|
|
|
|
#define TT_MS_LANGID_SAMI_LULE_NORWAY 0x103b
|
|
|
|
#define TT_MS_LANGID_SAMI_LULE_SWEDEN 0x143b
|
|
|
|
#define TT_MS_LANGID_SAMI_SOUTHERN_NORWAY 0x183b
|
|
|
|
#define TT_MS_LANGID_SAMI_SOUTHERN_SWEDEN 0x1C3b
|
|
|
|
#define TT_MS_LANGID_SAMI_SKOLT_FINLAND 0x203b
|
|
|
|
#define TT_MS_LANGID_SAMI_INARI_FINLAND 0x243b
|
|
|
|
/* ... and we also keep our old identifier... */
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_SAAMI_LAPONIA 0x043b
|
2001-01-31 04:00:22 +01:00
|
|
|
|
2001-12-05 02:22:05 +01:00
|
|
|
#if 0 /* this seems to be a previous invertion */
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_IRISH_GAELIC_IRELAND 0x043c
|
|
|
|
#define TT_MS_LANGID_SCOTTISH_GAELIC_UNITED_KINGDOM 0x083c
|
2001-01-31 04:00:22 +01:00
|
|
|
#else
|
|
|
|
#define TT_MS_LANGID_SCOTTISH_GAELIC_UNITED_KINGDOM 0x083c
|
|
|
|
#define TT_MS_LANGID_IRISH_GAELIC_IRELAND 0x043c
|
|
|
|
#endif
|
|
|
|
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_YIDDISH_GERMANY 0x043d
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_MALAY_MALAYSIA 0x043e
|
|
|
|
#define TT_MS_LANGID_MALAY_BRUNEI_DARUSSALAM 0x083e
|
|
|
|
#define TT_MS_LANGID_KAZAK_KAZAKSTAN 0x043f
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_KIRGHIZ_KIRGHIZSTAN /* Cyrillic*/ 0x0440
|
|
|
|
/* alias declared in Windows 2000 */
|
|
|
|
#define TT_MS_LANGID_KIRGHIZ_KIRGHIZ_REPUBLIC \
|
|
|
|
TT_MS_LANGID_KIRGHIZ_KIRGHIZSTAN
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_SWAHILI_KENYA 0x0441
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_TURKMEN_TURKMENISTAN 0x0442
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_UZBEK_UZBEKISTAN_LATIN 0x0443
|
|
|
|
#define TT_MS_LANGID_UZBEK_UZBEKISTAN_CYRILLIC 0x0843
|
|
|
|
#define TT_MS_LANGID_TATAR_TATARSTAN 0x0444
|
|
|
|
#define TT_MS_LANGID_BENGALI_INDIA 0x0445
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_BENGALI_BANGLADESH 0x0845
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_PUNJABI_INDIA 0x0446
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_PUNJABI_ARABIC_PAKISTAN 0x0846
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_MS_LANGID_GUJARATI_INDIA 0x0447
|
|
|
|
#define TT_MS_LANGID_ORIYA_INDIA 0x0448
|
|
|
|
#define TT_MS_LANGID_TAMIL_INDIA 0x0449
|
|
|
|
#define TT_MS_LANGID_TELUGU_INDIA 0x044a
|
|
|
|
#define TT_MS_LANGID_KANNADA_INDIA 0x044b
|
|
|
|
#define TT_MS_LANGID_MALAYALAM_INDIA 0x044c
|
|
|
|
#define TT_MS_LANGID_ASSAMESE_INDIA 0x044d
|
|
|
|
#define TT_MS_LANGID_MARATHI_INDIA 0x044e
|
|
|
|
#define TT_MS_LANGID_SANSKRIT_INDIA 0x044f
|
2001-11-20 20:22:13 +01:00
|
|
|
#define TT_MS_LANGID_MONGOLIAN_MONGOLIA /* Cyrillic */ 0x0450
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_MONGOLIAN_MONGOLIA_MONGOLIAN 0x0850
|
2001-11-20 20:22:13 +01:00
|
|
|
#define TT_MS_LANGID_TIBETAN_CHINA 0x0451
|
|
|
|
#define TT_MS_LANGID_DZONGHKA_BHUTAN 0x0851
|
2004-12-03 15:58:40 +01:00
|
|
|
|
|
|
|
#if 0
|
|
|
|
/* the following used to be defined */
|
|
|
|
#define TT_MS_LANGID_TIBETAN_BHUTAN 0x0451
|
|
|
|
/* ... but it was changed; */
|
|
|
|
#else
|
|
|
|
/* So we will continue to #define it, but with the correct value */
|
|
|
|
#define TT_MS_LANGID_TIBETAN_BHUTAN TT_MS_LANGID_DZONGHKA_BHUTAN
|
|
|
|
#endif
|
2001-11-20 20:22:13 +01:00
|
|
|
|
2001-01-31 04:00:22 +01:00
|
|
|
#define TT_MS_LANGID_WELSH_WALES 0x0452
|
|
|
|
#define TT_MS_LANGID_KHMER_CAMBODIA 0x0453
|
|
|
|
#define TT_MS_LANGID_LAO_LAOS 0x0454
|
|
|
|
#define TT_MS_LANGID_BURMESE_MYANMAR 0x0455
|
|
|
|
#define TT_MS_LANGID_GALICIAN_SPAIN 0x0456
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_KONKANI_INDIA 0x0457
|
|
|
|
#define TT_MS_LANGID_MANIPURI_INDIA /* Bengali */ 0x0458
|
|
|
|
#define TT_MS_LANGID_SINDHI_INDIA /* Arabic */ 0x0459
|
|
|
|
#define TT_MS_LANGID_SINDHI_PAKISTAN 0x0859
|
|
|
|
/* Missing a LCID for Sindhi in Devanagari script */
|
2001-11-20 20:22:13 +01:00
|
|
|
#define TT_MS_LANGID_SYRIAC_SYRIA 0x045a
|
|
|
|
#define TT_MS_LANGID_SINHALESE_SRI_LANKA 0x045b
|
2001-03-01 19:00:44 +01:00
|
|
|
#define TT_MS_LANGID_CHEROKEE_UNITED_STATES 0x045c
|
|
|
|
#define TT_MS_LANGID_INUKTITUT_CANADA 0x045d
|
|
|
|
#define TT_MS_LANGID_AMHARIC_ETHIOPIA 0x045e
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_TAMAZIGHT_MOROCCO /* Arabic */ 0x045f
|
2001-03-01 19:00:44 +01:00
|
|
|
#define TT_MS_LANGID_TAMAZIGHT_MOROCCO_LATIN 0x085f
|
2004-12-03 15:58:40 +01:00
|
|
|
/* Missing a LCID for Tifinagh script */
|
|
|
|
#define TT_MS_LANGID_KASHMIRI_PAKISTAN /* Arabic */ 0x0460
|
|
|
|
/* Spelled this way by XPsp2 Platform SDK (2004-07-26) */
|
|
|
|
/* script is yet unclear... might be Arabic, Nagari or Sharada */
|
|
|
|
#define TT_MS_LANGID_KASHMIRI_SASIA 0x0860
|
|
|
|
/* ... and aliased (by MS) for compatibility reasons. */
|
|
|
|
#define TT_MS_LANGID_KASHMIRI_INDIA TT_MS_LANGID_KASHMIRI_SASIA
|
|
|
|
#define TT_MS_LANGID_NEPALI_NEPAL 0x0461
|
|
|
|
#define TT_MS_LANGID_NEPALI_INDIA 0x0861
|
|
|
|
#define TT_MS_LANGID_FRISIAN_NETHERLANDS 0x0462
|
2001-11-20 20:22:13 +01:00
|
|
|
#define TT_MS_LANGID_PASHTO_AFGHANISTAN 0x0463
|
2001-03-01 19:00:44 +01:00
|
|
|
#define TT_MS_LANGID_FILIPINO_PHILIPPINES 0x0464
|
|
|
|
#define TT_MS_LANGID_DHIVEHI_MALDIVES 0x0465
|
2001-12-05 02:22:05 +01:00
|
|
|
/* alias declared in Windows 2000 */
|
|
|
|
#define TT_MS_LANGID_DIVEHI_MALDIVES TT_MS_LANGID_DHIVEHI_MALDIVES
|
|
|
|
#define TT_MS_LANGID_EDO_NIGERIA 0x0466
|
|
|
|
#define TT_MS_LANGID_FULFULDE_NIGERIA 0x0467
|
|
|
|
#define TT_MS_LANGID_HAUSA_NIGERIA 0x0468
|
|
|
|
#define TT_MS_LANGID_IBIBIO_NIGERIA 0x0469
|
|
|
|
#define TT_MS_LANGID_YORUBA_NIGERIA 0x046a
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_QUECHUA_BOLIVIA 0x046b
|
|
|
|
#define TT_MS_LANGID_QUECHUA_ECUADOR 0x086b
|
|
|
|
#define TT_MS_LANGID_QUECHUA_PERU 0x0c6b
|
|
|
|
#define TT_MS_LANGID_SEPEDI_SOUTH_AFRICA 0x046c
|
|
|
|
/* Also spelled by XPsp2 Platform SDK (2004-07-26) */
|
2004-12-04 15:23:50 +01:00
|
|
|
#define TT_MS_LANGID_SOTHO_SOUTHERN_SOUTH_AFRICA \
|
|
|
|
TT_MS_LANGID_SEPEDI_SOUTH_AFRICA
|
2004-12-03 15:58:40 +01:00
|
|
|
/* language codes 0x046d, 0x046e and 0x046f are (still) unknown. */
|
2001-12-05 02:22:05 +01:00
|
|
|
#define TT_MS_LANGID_IGBO_NIGERIA 0x0470
|
|
|
|
#define TT_MS_LANGID_KANURI_NIGERIA 0x0471
|
2004-12-03 15:58:40 +01:00
|
|
|
#define TT_MS_LANGID_OROMO_ETHIOPIA 0x0472
|
|
|
|
#define TT_MS_LANGID_TIGRIGNA_ETHIOPIA 0x0473
|
|
|
|
#define TT_MS_LANGID_TIGRIGNA_ERYTHREA 0x0873
|
|
|
|
/* also spelled in the `Passport SDK' list as: */
|
|
|
|
#define TT_MS_LANGID_TIGRIGNA_ERYTREA TT_MS_LANGID_TIGRIGNA_ERYTHREA
|
2001-12-05 02:22:05 +01:00
|
|
|
#define TT_MS_LANGID_GUARANI_PARAGUAY 0x0474
|
|
|
|
#define TT_MS_LANGID_HAWAIIAN_UNITED_STATES 0x0475
|
|
|
|
#define TT_MS_LANGID_LATIN 0x0476
|
|
|
|
#define TT_MS_LANGID_SOMALI_SOMALIA 0x0477
|
|
|
|
/* Note: Yi does not have a (proper) ISO 639-2 code, since it is mostly */
|
|
|
|
/* not written (but OTOH the peculiar writing system is worth */
|
|
|
|
/* studying). */
|
|
|
|
#define TT_MS_LANGID_YI_CHINA 0x0478
|
|
|
|
#define TT_MS_LANGID_PAPIAMENTU_NETHERLANDS_ANTILLES 0x0479
|
2004-12-03 15:58:40 +01:00
|
|
|
/* language codes from 0x047a to 0x047f are (still) unknown. */
|
|
|
|
#define TT_MS_LANGID_UIGHUR_CHINA 0x0480
|
|
|
|
#define TT_MS_LANGID_MAORI_NEW_ZEALAND 0x0481
|
|
|
|
|
|
|
|
#if 0 /* not deemed useful for fonts */
|
|
|
|
#define TT_MS_LANGID_HUMAN_INTERFACE_DEVICE 0x04ff
|
|
|
|
#endif
|
2001-01-31 04:00:22 +01:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
|
|
|
|
/*************************************************************************/
|
|
|
|
/* */
|
|
|
|
/* Possible values of the `name' identifier field in the name records of */
|
|
|
|
/* the TTF `name' table. These values are platform independent. */
|
|
|
|
/* */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_NAME_ID_COPYRIGHT 0
|
|
|
|
#define TT_NAME_ID_FONT_FAMILY 1
|
|
|
|
#define TT_NAME_ID_FONT_SUBFAMILY 2
|
|
|
|
#define TT_NAME_ID_UNIQUE_ID 3
|
|
|
|
#define TT_NAME_ID_FULL_NAME 4
|
|
|
|
#define TT_NAME_ID_VERSION_STRING 5
|
|
|
|
#define TT_NAME_ID_PS_NAME 6
|
|
|
|
#define TT_NAME_ID_TRADEMARK 7
|
2000-07-11 08:12:20 +02:00
|
|
|
|
2001-12-05 02:22:05 +01:00
|
|
|
/* the following values are from the OpenType spec */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_NAME_ID_MANUFACTURER 8
|
|
|
|
#define TT_NAME_ID_DESIGNER 9
|
|
|
|
#define TT_NAME_ID_DESCRIPTION 10
|
|
|
|
#define TT_NAME_ID_VENDOR_URL 11
|
|
|
|
#define TT_NAME_ID_DESIGNER_URL 12
|
|
|
|
#define TT_NAME_ID_LICENSE 13
|
|
|
|
#define TT_NAME_ID_LICENSE_URL 14
|
2001-12-05 02:22:05 +01:00
|
|
|
/* number 15 is reserved */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_NAME_ID_PREFERRED_FAMILY 16
|
|
|
|
#define TT_NAME_ID_PREFERRED_SUBFAMILY 17
|
|
|
|
#define TT_NAME_ID_MAC_FULL_NAME 18
|
2000-07-11 08:12:20 +02:00
|
|
|
|
2001-12-05 02:22:05 +01:00
|
|
|
/* The following code is new as of 2000-01-21 */
|
2000-03-23 18:24:28 +01:00
|
|
|
#define TT_NAME_ID_SAMPLE_TEXT 19
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2001-12-05 02:22:05 +01:00
|
|
|
/* This is new in OpenType 1.3 */
|
Updating to OpenType 1.3.
* include/freetype/internal/tttypes.h (TT_CMap0, TT_CMap2, TT_CMap4,
TT_CMap6): Adding field `language'.
(TT_CMapTable): Removing field `language'.
Type of `length' field changed to FT_ULong.
Adding fields for cmaps format 8, 10, and 12.
(TT_CMapGroup): New auxiliary structure.
(TT_CMap8_12, TT_CMap10): New structures.
* include/freetype/tttables.h (TT_HoriHeader, TT_VertHeader):
Removed last element of `Reserved' array.
* include/freetype/ttnameid.h (TT_PLATFORM_CUSTOM, TT_MS_ID_UCS_4,
TT_NAME_ID_CID_FINDFONT_NAME): New macros.
* src/sfnt/ttcmap.c (TT_CharMap_Load): Updated loading of `language'
field to the new structures.
Fixed freeing of arrays in case of unsuccessful loads.
Added support for loading format 8, 10, and 12 cmaps.
(TT_CharMap_Free): Added support for freeing format 8, 10, and 12
cmaps.
(code_to_index4): Small improvement.
(code_to_index6): Ditto.
(code_to_index8_12, code_to_index10): New functions.
* src/sfnt/ttload.c (TT_Load_Metrics_Header): Updated to new
structure.
(TT_Load_CMap): Ditto.
* src/sfnt/sfobjs.c (tt_encodings): Add MS UCS4 table (before MS
Unicode).
* src/type1/t1driver.c (t1_get_name_index): Fix compiler warning.
2001-08-13 13:44:29 +02:00
|
|
|
#define TT_NAME_ID_CID_FINDFONT_NAME 20
|
|
|
|
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/*************************************************************************/
|
|
|
|
/* */
|
|
|
|
/* Bit mask values for the Unicode Ranges from the TTF `OS2 ' table. */
|
|
|
|
/* */
|
|
|
|
/* Updated 02-Jul-2000. */
|
|
|
|
/* */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* General Scripts Area */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2001-01-22 16:26:02 +01:00
|
|
|
/* Bit 0 Basic Latin */
|
2000-07-11 08:12:20 +02:00
|
|
|
#define TT_UCR_BASIC_LATIN (1L << 0) /* U+0020-U+007E */
|
|
|
|
/* Bit 1 C1 Controls and Latin-1 Supplement */
|
2001-01-05 06:15:49 +01:00
|
|
|
#define TT_UCR_LATIN1_SUPPLEMENT (1L << 1) /* U+0080-U+00FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 2 Latin Extended-A */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_LATIN_EXTENDED_A (1L << 2) /* U+0100-U+017F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 3 Latin Extended-B */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_LATIN_EXTENDED_B (1L << 3) /* U+0180-U+024F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 4 IPA Extensions */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_IPA_EXTENSIONS (1L << 4) /* U+0250-U+02AF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 5 Spacing Modifier Letters */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_SPACING_MODIFIER (1L << 5) /* U+02B0-U+02FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 6 Combining Diacritical Marks */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_COMBINING_DIACRITICS (1L << 6) /* U+0300-U+036F */
|
2001-01-05 06:15:49 +01:00
|
|
|
/* Bit 7 Greek and Coptic */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_GREEK (1L << 7) /* U+0370-U+03FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 8 is reserved (was: Greek Symbols and Coptic) */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* Bit 9 Cyrillic + */
|
|
|
|
/* Cyrillic Supplementary */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_CYRILLIC (1L << 9) /* U+0400-U+04FF */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* U+0500-U+052F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 10 Armenian */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_ARMENIAN (1L << 10) /* U+0530-U+058F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 11 Hebrew */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_HEBREW (1L << 11) /* U+0590-U+05FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 12 is reserved (was: Hebrew Extended) */
|
|
|
|
/* Bit 13 Arabic */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_ARABIC (1L << 13) /* U+0600-U+06FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 14 is reserved (was: Arabic Extended) */
|
|
|
|
/* Bit 15 Devanagari */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_DEVANAGARI (1L << 15) /* U+0900-U+097F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 16 Bengali */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_BENGALI (1L << 16) /* U+0980-U+09FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 17 Gurmukhi */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_GURMUKHI (1L << 17) /* U+0A00-U+0A7F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 18 Gujarati */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_GUJARATI (1L << 18) /* U+0A80-U+0AFF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 19 Oriya */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_ORIYA (1L << 19) /* U+0B00-U+0B7F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 20 Tamil */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_TAMIL (1L << 20) /* U+0B80-U+0BFF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 21 Telugu */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_TELUGU (1L << 21) /* U+0C00-U+0C7F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 22 Kannada */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_KANNADA (1L << 22) /* U+0C80-U+0CFF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 23 Malayalam */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_MALAYALAM (1L << 23) /* U+0D00-U+0D7F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 24 Thai */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_THAI (1L << 24) /* U+0E00-U+0E7F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 25 Lao */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_LAO (1L << 25) /* U+0E80-U+0EFF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 26 Georgian */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_GEORGIAN (1L << 26) /* U+10A0-U+10FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 27 is reserved (was Georgian Extended) */
|
|
|
|
/* Bit 28 Hangul Jamo */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_HANGUL_JAMO (1L << 28) /* U+1100-U+11FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 29 Latin Extended Additional */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_LATIN_EXTENDED_ADDITIONAL (1L << 29) /* U+1E00-U+1EFF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 30 Greek Extended */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_GREEK_EXTENDED (1L << 30) /* U+1F00-U+1FFF */
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Symbols Area */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 31 General Punctuation */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_GENERAL_PUNCTUATION (1L << 31) /* U+2000-U+206F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 32 Superscripts And Subscripts */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_SUPERSCRIPTS_SUBSCRIPTS (1L << 0) /* U+2070-U+209F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 33 Currency Symbols */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_CURRENCY_SYMBOLS (1L << 1) /* U+20A0-U+20CF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 34 Combining Diacritical Marks For Symbols */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_COMBINING_DIACRITICS_SYMB (1L << 2) /* U+20D0-U+20FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 35 Letterlike Symbols */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_LETTERLIKE_SYMBOLS (1L << 3) /* U+2100-U+214F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 36 Number Forms */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_NUMBER_FORMS (1L << 4) /* U+2150-U+218F */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* Bit 37 Arrows + */
|
|
|
|
/* Supplemental Arrows-A + */
|
|
|
|
/* Supplemental Arrows-B */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_ARROWS (1L << 5) /* U+2190-U+21FF */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* U+27F0-U+27FF */
|
|
|
|
/* U+2900-U+297F */
|
|
|
|
/* Bit 38 Mathematical Operators + */
|
|
|
|
/* Supplemental Mathematical Operators + */
|
|
|
|
/* Miscellaneous Mathematical Symbols-A + */
|
|
|
|
/* Miscellaneous Mathematical Symbols-B */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_MATHEMATICAL_OPERATORS (1L << 6) /* U+2200-U+22FF */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* U+2A00-U+2AFF */
|
|
|
|
/* U+27C0-U+27EF */
|
|
|
|
/* U+2980-U+29FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 39 Miscellaneous Technical */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_MISCELLANEOUS_TECHNICAL (1L << 7) /* U+2300-U+23FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 40 Control Pictures */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_CONTROL_PICTURES (1L << 8) /* U+2400-U+243F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 41 Optical Character Recognition */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_OCR (1L << 9) /* U+2440-U+245F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 42 Enclosed Alphanumerics */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_ENCLOSED_ALPHANUMERICS (1L << 10) /* U+2460-U+24FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 43 Box Drawing */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_BOX_DRAWING (1L << 11) /* U+2500-U+257F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 44 Block Elements */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_BLOCK_ELEMENTS (1L << 12) /* U+2580-U+259F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 45 Geometric Shapes */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_GEOMETRIC_SHAPES (1L << 13) /* U+25A0-U+25FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 46 Miscellaneous Symbols */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_MISCELLANEOUS_SYMBOLS (1L << 14) /* U+2600-U+26FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 47 Dingbats */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_DINGBATS (1L << 15) /* U+2700-U+27BF */
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* CJK Phonetics and Symbols Area */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2001-01-05 06:15:49 +01:00
|
|
|
/* Bit 48 CJK Symbols and Punctuation */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_CJK_SYMBOLS (1L << 16) /* U+3000-U+303F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 49 Hiragana */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_HIRAGANA (1L << 17) /* U+3040-U+309F */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* Bit 50 Katakana + */
|
|
|
|
/* Katakana Phonetic Extensions */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_KATAKANA (1L << 18) /* U+30A0-U+30FF */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* U+31F0-U+31FF */
|
2001-01-05 06:15:49 +01:00
|
|
|
/* Bit 51 Bopomofo + */
|
|
|
|
/* Bopomofo Extended */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_BOPOMOFO (1L << 19) /* U+3100-U+312F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* U+31A0-U+31BF */
|
|
|
|
/* Bit 52 Hangul Compatibility Jamo */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_HANGUL_COMPATIBILITY_JAMO (1L << 20) /* U+3130-U+318F */
|
2001-01-05 06:15:49 +01:00
|
|
|
/* Bit 53 Kanbun */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_CJK_MISC (1L << 21) /* U+3190-U+319F */
|
2001-01-05 06:15:49 +01:00
|
|
|
#define TT_UCR_KANBUN TT_UCR_CJK_MISC
|
|
|
|
/* Bit 54 Enclosed CJK Letters and Months */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_ENCLOSED_CJK_LETTERS_MONTHS (1L << 22) /* U+3200-U+32FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 55 CJK Compatibility */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_CJK_COMPATIBILITY (1L << 23) /* U+3300-U+33FF */
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Hangul Syllables Area */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 56 Hangul */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_HANGUL (1L << 24) /* U+AC00-U+D7A3 */
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Surrogates Area */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2001-01-22 16:26:02 +01:00
|
|
|
/* Bit 57 High Surrogates + */
|
|
|
|
/* High Private Use Surrogates + */
|
|
|
|
/* Low Surrogates */
|
|
|
|
#define TT_UCR_SURROGATES (1L << 25) /* U+D800-U+DB7F */
|
|
|
|
/* U+DB80-U+DBFF */
|
|
|
|
/* U+DC00-U+DFFF */
|
2001-11-20 20:22:13 +01:00
|
|
|
/* According to OpenType specs v.1.3+, setting bit 57 implies that there */
|
|
|
|
/* is at least one codepoint beyond the Basic Multilingual Plane that is */
|
2001-12-05 02:22:05 +01:00
|
|
|
/* supported by this font. So it really means: >= U+10000 */
|
2001-11-20 20:22:13 +01:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 58 is reserved for Unicode SubRanges */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* CJK Ideographs Area */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 59 CJK Unified Ideographs + */
|
2001-01-05 06:15:49 +01:00
|
|
|
/* CJK Radicals Supplement + */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Kangxi Radicals + */
|
2001-01-05 06:15:49 +01:00
|
|
|
/* Ideographic Description Characters + */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* CJK Unified Ideographs Extension A */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* CJK Unified Ideographs Extension A + */
|
|
|
|
/* CJK Unified Ideographs Extension B + */
|
|
|
|
/* Kanbun */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_CJK_UNIFIED_IDEOGRAPHS (1L << 27) /* U+4E00-U+9FFF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* U+2E80-U+2EFF */
|
|
|
|
/* U+2F00-U+2FDF */
|
|
|
|
/* U+2FF0-U+2FFF */
|
2001-01-05 06:15:49 +01:00
|
|
|
/* U+3400-U+4DB5 */
|
2002-11-15 21:05:58 +01:00
|
|
|
/*U+20000-U+2A6DF*/
|
|
|
|
/* U+3190-U+319F */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Private Use Area */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 60 Private Use */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_PRIVATE_USE (1L << 28) /* U+E000-U+F8FF */
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Compatibility Area and Specials */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2002-11-15 21:05:58 +01:00
|
|
|
/* Bit 61 CJK Compatibility Ideographs + */
|
|
|
|
/* CJK Compatibility Ideographs Supplement */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_CJK_COMPATIBILITY_IDEOGRAPHS (1L << 29) /* U+F900-U+FAFF */
|
2002-11-15 21:05:58 +01:00
|
|
|
/*U+2F800-U+2FA1F*/
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 62 Alphabetic Presentation Forms */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_ALPHABETIC_PRESENTATION_FORMS (1L << 30) /* U+FB00-U+FB4F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 63 Arabic Presentation Forms-A */
|
|
|
|
#define TT_UCR_ARABIC_PRESENTATIONS_A (1L << 31) /* U+FB50-U+FDFF */
|
|
|
|
/* Bit 64 Combining Half Marks */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_COMBINING_HALF_MARKS (1L << 0) /* U+FE20-U+FE2F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 65 CJK Compatibility Forms */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_CJK_COMPATIBILITY_FORMS (1L << 1) /* U+FE30-U+FE4F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 66 Small Form Variants */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_SMALL_FORM_VARIANTS (1L << 2) /* U+FE50-U+FE6F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 67 Arabic Presentation Forms-B */
|
|
|
|
#define TT_UCR_ARABIC_PRESENTATIONS_B (1L << 3) /* U+FE70-U+FEFE */
|
2001-01-05 06:15:49 +01:00
|
|
|
/* Bit 68 Halfwidth and Fullwidth Forms */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_HALFWIDTH_FULLWIDTH_FORMS (1L << 4) /* U+FF00-U+FFEF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 69 Specials */
|
|
|
|
#define TT_UCR_SPECIALS (1L << 5) /* U+FFF0-U+FFFD */
|
|
|
|
/* Bit 70 Tibetan */
|
2001-01-05 06:15:49 +01:00
|
|
|
#define TT_UCR_TIBETAN (1L << 6) /* U+0F00-U+0FFF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 71 Syriac */
|
2000-03-23 18:24:28 +01:00
|
|
|
#define TT_UCR_SYRIAC (1L << 7) /* U+0700-U+074F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 72 Thaana */
|
2000-03-23 18:24:28 +01:00
|
|
|
#define TT_UCR_THAANA (1L << 8) /* U+0780-U+07BF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 73 Sinhala */
|
2000-03-23 18:24:28 +01:00
|
|
|
#define TT_UCR_SINHALA (1L << 9) /* U+0D80-U+0DFF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 74 Myanmar */
|
2000-03-23 18:24:28 +01:00
|
|
|
#define TT_UCR_MYANMAR (1L << 10) /* U+1000-U+109F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 75 Ethiopic */
|
2001-01-05 06:15:49 +01:00
|
|
|
#define TT_UCR_ETHIOPIC (1L << 11) /* U+1200-U+137F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 76 Cherokee */
|
2000-03-23 18:24:28 +01:00
|
|
|
#define TT_UCR_CHEROKEE (1L << 12) /* U+13A0-U+13FF */
|
2001-01-05 06:15:49 +01:00
|
|
|
/* Bit 77 Unified Canadian Aboriginal Syllabics */
|
|
|
|
#define TT_UCR_CANADIAN_ABORIGINAL_SYLLABICS (1L << 13) /* U+1400-U+167F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 78 Ogham */
|
2000-03-23 18:24:28 +01:00
|
|
|
#define TT_UCR_OGHAM (1L << 14) /* U+1680-U+169F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 79 Runic */
|
2000-03-23 18:24:28 +01:00
|
|
|
#define TT_UCR_RUNIC (1L << 15) /* U+16A0-U+16FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 80 Khmer */
|
2000-03-23 18:24:28 +01:00
|
|
|
#define TT_UCR_KHMER (1L << 16) /* U+1780-U+17FF */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* Bit 81 Mongolian */
|
2000-03-23 18:24:28 +01:00
|
|
|
#define TT_UCR_MONGOLIAN (1L << 17) /* U+1800-U+18AF */
|
2001-01-05 06:15:49 +01:00
|
|
|
/* Bit 82 Braille Patterns */
|
2000-03-23 18:24:28 +01:00
|
|
|
#define TT_UCR_BRAILLE (1L << 18) /* U+2800-U+28FF */
|
2001-01-05 06:15:49 +01:00
|
|
|
/* Bit 83 Yi Syllables + */
|
|
|
|
/* Yi Radicals */
|
|
|
|
#define TT_UCR_YI (1L << 19) /* U+A000-U+A48F */
|
2000-07-11 08:12:20 +02:00
|
|
|
/* U+A490-U+A4CF */
|
2002-11-15 21:05:58 +01:00
|
|
|
/* Bit 84 Tagalog + */
|
|
|
|
/* Hanunoo + */
|
|
|
|
/* Buhid + */
|
|
|
|
/* Tagbanwa */
|
|
|
|
#define TT_UCR_PHILIPPINE (1L << 20) /* U+1700-U+171F */
|
|
|
|
/* U+1720-U+173F */
|
|
|
|
/* U+1740-U+175F */
|
|
|
|
/* U+1760-U+177F */
|
|
|
|
/* Bit 85 Old Italic */
|
|
|
|
#define TT_UCR_OLD_ITALIC (1L << 21) /*U+10300-U+1032F*/
|
|
|
|
/* Bit 86 Gothic */
|
|
|
|
#define TT_UCR_GOTHIC (1L << 22) /*U+10330-U+1034F*/
|
|
|
|
/* Bit 87 Deseret */
|
|
|
|
#define TT_UCR_DESERET (1L << 23) /*U+10400-U+1044F*/
|
|
|
|
/* Bit 88 Byzantine Musical Symbols + */
|
|
|
|
/* Musical Symbols */
|
|
|
|
#define TT_UCR_MUSICAL_SYMBOLS (1L << 24) /*U+1D000-U+1D0FF*/
|
|
|
|
/*U+1D100-U+1D1FF*/
|
|
|
|
/* Bit 89 Mathematical Alphanumeric Symbols */
|
|
|
|
#define TT_UCR_MATH_ALPHANUMERIC_SYMBOLS (1L << 25) /*U+1D400-U+1D7FF*/
|
|
|
|
/* Bit 90 Private Use (plane 15) + */
|
|
|
|
/* Private Use (plane 16) */
|
|
|
|
#define TT_UCR_PRIVATE_USE_SUPPLEMENTARY (1L << 26) /*U+F0000-U+FFFFD*/
|
|
|
|
/*U+100000-U+10FFFD*/
|
|
|
|
/* Bit 91 Variation Selectors */
|
|
|
|
#define TT_UCR_VARIATION_SELECTORS (1L << 27) /* U+FE00-U+FE0F */
|
|
|
|
/* Bit 92 Tags */
|
|
|
|
#define TT_UCR_TAGS (1L << 28) /*U+E0000-U+E007F*/
|
1999-12-17 00:11:37 +01:00
|
|
|
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/*************************************************************************/
|
|
|
|
/* */
|
|
|
|
/* Some compilers have a very limited length of identifiers. */
|
|
|
|
/* */
|
1999-12-17 00:11:37 +01:00
|
|
|
#if defined( __TURBOC__ ) && __TURBOC__ < 0x0410 || defined( __PACIFIC__ )
|
|
|
|
#define HAVE_LIMIT_ON_IDENTS
|
|
|
|
#endif
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
|
1999-12-17 00:11:37 +01:00
|
|
|
#ifndef HAVE_LIMIT_ON_IDENTS
|
|
|
|
|
2000-04-04 18:46:12 +02:00
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
/*************************************************************************/
|
|
|
|
/* */
|
|
|
|
/* Here some alias #defines in order to be clearer. */
|
|
|
|
/* */
|
|
|
|
/* These are not always #defined to stay within the 31 character limit */
|
|
|
|
/* which some compilers have. */
|
|
|
|
/* */
|
|
|
|
/* Credits go to Dave Hoo <dhoo@flash.net> for pointing out that modern */
|
|
|
|
/* Borland compilers (read: from BC++ 3.1 on) can increase this limit. */
|
|
|
|
/* If you get a warning with such a compiler, use the -i40 switch. */
|
|
|
|
/* */
|
1999-12-17 00:11:37 +01:00
|
|
|
#define TT_UCR_ARABIC_PRESENTATION_FORMS_A \
|
|
|
|
TT_UCR_ARABIC_PRESENTATIONS_A
|
|
|
|
#define TT_UCR_ARABIC_PRESENTATION_FORMS_B \
|
2000-04-04 18:46:12 +02:00
|
|
|
TT_UCR_ARABIC_PRESENTATIONS_B
|
1999-12-17 00:11:37 +01:00
|
|
|
|
|
|
|
#define TT_UCR_COMBINING_DIACRITICAL_MARKS \
|
|
|
|
TT_UCR_COMBINING_DIACRITICS
|
|
|
|
#define TT_UCR_COMBINING_DIACRITICAL_MARKS_SYMB \
|
|
|
|
TT_UCR_COMBINING_DIACRITICS_SYMB
|
|
|
|
|
2000-07-11 08:12:20 +02:00
|
|
|
|
|
|
|
#endif /* !HAVE_LIMIT_ON_IDENTS */
|
|
|
|
|
1999-12-17 00:11:37 +01:00
|
|
|
|
2000-12-09 01:45:38 +01:00
|
|
|
FT_END_HEADER
|
2000-08-01 15:17:04 +02:00
|
|
|
|
2000-12-01 00:12:33 +01:00
|
|
|
#endif /* __TTNAMEID_H__ */
|
1999-12-17 00:11:37 +01:00
|
|
|
|
|
|
|
|
|
|
|
/* END */
|