Imported Upstream version 2.10.4
[platform/upstream/freetype2.git] / include / freetype / internal / services / svpscmap.h
1 /****************************************************************************
2  *
3  * svpscmap.h
4  *
5  *   The FreeType PostScript charmap service (specification).
6  *
7  * Copyright (C) 2003-2020 by
8  * David Turner, Robert Wilhelm, and Werner Lemberg.
9  *
10  * This file is part of the FreeType project, and may only be used,
11  * modified, and distributed under the terms of the FreeType project
12  * license, LICENSE.TXT.  By continuing to use, modify, or distribute
13  * this file you indicate that you have read the license and
14  * understand and accept it fully.
15  *
16  */
17
18
19 #ifndef SVPSCMAP_H_
20 #define SVPSCMAP_H_
21
22 #include <freetype/internal/ftobjs.h>
23
24
25 FT_BEGIN_HEADER
26
27
28 #define FT_SERVICE_ID_POSTSCRIPT_CMAPS  "postscript-cmaps"
29
30
31   /*
32    * Adobe glyph name to unicode value.
33    */
34   typedef FT_UInt32
35   (*PS_Unicode_ValueFunc)( const char*  glyph_name );
36
37   /*
38    * Macintosh name id to glyph name.  `NULL` if invalid index.
39    */
40   typedef const char*
41   (*PS_Macintosh_NameFunc)( FT_UInt  name_index );
42
43   /*
44    * Adobe standard string ID to glyph name.  `NULL` if invalid index.
45    */
46   typedef const char*
47   (*PS_Adobe_Std_StringsFunc)( FT_UInt  string_index );
48
49
50   /*
51    * Simple unicode -> glyph index charmap built from font glyph names table.
52    */
53   typedef struct  PS_UniMap_
54   {
55     FT_UInt32  unicode;      /* bit 31 set: is glyph variant */
56     FT_UInt    glyph_index;
57
58   } PS_UniMap;
59
60
61   typedef struct PS_UnicodesRec_*  PS_Unicodes;
62
63   typedef struct  PS_UnicodesRec_
64   {
65     FT_CMapRec  cmap;
66     FT_UInt     num_maps;
67     PS_UniMap*  maps;
68
69   } PS_UnicodesRec;
70
71
72   /*
73    * A function which returns a glyph name for a given index.  Returns
74    * `NULL` if invalid index.
75    */
76   typedef const char*
77   (*PS_GetGlyphNameFunc)( FT_Pointer  data,
78                           FT_UInt     string_index );
79
80   /*
81    * A function used to release the glyph name returned by
82    * PS_GetGlyphNameFunc, when needed
83    */
84   typedef void
85   (*PS_FreeGlyphNameFunc)( FT_Pointer  data,
86                            const char*  name );
87
88   typedef FT_Error
89   (*PS_Unicodes_InitFunc)( FT_Memory             memory,
90                            PS_Unicodes           unicodes,
91                            FT_UInt               num_glyphs,
92                            PS_GetGlyphNameFunc   get_glyph_name,
93                            PS_FreeGlyphNameFunc  free_glyph_name,
94                            FT_Pointer            glyph_data );
95
96   typedef FT_UInt
97   (*PS_Unicodes_CharIndexFunc)( PS_Unicodes  unicodes,
98                                 FT_UInt32    unicode );
99
100   typedef FT_UInt32
101   (*PS_Unicodes_CharNextFunc)( PS_Unicodes  unicodes,
102                                FT_UInt32   *unicode );
103
104
105   FT_DEFINE_SERVICE( PsCMaps )
106   {
107     PS_Unicode_ValueFunc       unicode_value;
108
109     PS_Unicodes_InitFunc       unicodes_init;
110     PS_Unicodes_CharIndexFunc  unicodes_char_index;
111     PS_Unicodes_CharNextFunc   unicodes_char_next;
112
113     PS_Macintosh_NameFunc      macintosh_name;
114     PS_Adobe_Std_StringsFunc   adobe_std_strings;
115     const unsigned short*      adobe_std_encoding;
116     const unsigned short*      adobe_expert_encoding;
117   };
118
119
120 #define FT_DEFINE_SERVICE_PSCMAPSREC( class_,                               \
121                                       unicode_value_,                       \
122                                       unicodes_init_,                       \
123                                       unicodes_char_index_,                 \
124                                       unicodes_char_next_,                  \
125                                       macintosh_name_,                      \
126                                       adobe_std_strings_,                   \
127                                       adobe_std_encoding_,                  \
128                                       adobe_expert_encoding_ )              \
129   static const FT_Service_PsCMapsRec  class_ =                              \
130   {                                                                         \
131     unicode_value_, unicodes_init_,                                         \
132     unicodes_char_index_, unicodes_char_next_, macintosh_name_,             \
133     adobe_std_strings_, adobe_std_encoding_, adobe_expert_encoding_         \
134   };
135
136   /* */
137
138
139 FT_END_HEADER
140
141
142 #endif /* SVPSCMAP_H_ */
143
144
145 /* END */