• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /****************************************************************************
2  *
3  * t1objs.h
4  *
5  *   Type 1 objects manager (specification).
6  *
7  * Copyright 1996-2018 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 T1OBJS_H_
20 #define T1OBJS_H_
21 
22 
23 #include <ft2build.h>
24 #include FT_INTERNAL_OBJECTS_H
25 #include FT_CONFIG_CONFIG_H
26 #include FT_INTERNAL_TYPE1_TYPES_H
27 
28 
29 FT_BEGIN_HEADER
30 
31 
32   /* The following structures must be defined by the hinter */
33   typedef struct T1_Size_Hints_   T1_Size_Hints;
34   typedef struct T1_Glyph_Hints_  T1_Glyph_Hints;
35 
36 
37   /**************************************************************************
38    *
39    * @Type:
40    *   T1_Size
41    *
42    * @Description:
43    *   A handle to a Type 1 size object.
44    */
45   typedef struct T1_SizeRec_*  T1_Size;
46 
47 
48   /**************************************************************************
49    *
50    * @Type:
51    *   T1_GlyphSlot
52    *
53    * @Description:
54    *   A handle to a Type 1 glyph slot object.
55    */
56   typedef struct T1_GlyphSlotRec_*  T1_GlyphSlot;
57 
58 
59   /**************************************************************************
60    *
61    * @Type:
62    *   T1_CharMap
63    *
64    * @Description:
65    *   A handle to a Type 1 character mapping object.
66    *
67    * @Note:
68    *   The Type 1 format doesn't use a charmap but an encoding table.
69    *   The driver is responsible for making up charmap objects
70    *   corresponding to these tables.
71    */
72   typedef struct T1_CharMapRec_*   T1_CharMap;
73 
74 
75   /**************************************************************************
76    *
77    *                 HERE BEGINS THE TYPE1 SPECIFIC STUFF
78    *
79    */
80 
81 
82   /**************************************************************************
83    *
84    * @Type:
85    *   T1_SizeRec
86    *
87    * @Description:
88    *   Type 1 size record.
89    */
90   typedef struct  T1_SizeRec_
91   {
92     FT_SizeRec  root;
93 
94   } T1_SizeRec;
95 
96 
97   FT_LOCAL( void )
98   T1_Size_Done( FT_Size  size );
99 
100   FT_LOCAL( FT_Error )
101   T1_Size_Request( FT_Size          size,
102                    FT_Size_Request  req );
103 
104   FT_LOCAL( FT_Error )
105   T1_Size_Init( FT_Size  size );
106 
107 
108   /**************************************************************************
109    *
110    * @Type:
111    *   T1_GlyphSlotRec
112    *
113    * @Description:
114    *   Type 1 glyph slot record.
115    */
116   typedef struct  T1_GlyphSlotRec_
117   {
118     FT_GlyphSlotRec  root;
119 
120     FT_Bool          hint;
121     FT_Bool          scaled;
122 
123     FT_Fixed         x_scale;
124     FT_Fixed         y_scale;
125 
126     FT_Int           max_points;
127     FT_Int           max_contours;
128 
129   } T1_GlyphSlotRec;
130 
131 
132   FT_LOCAL( FT_Error )
133   T1_Face_Init( FT_Stream      stream,
134                 FT_Face        face,
135                 FT_Int         face_index,
136                 FT_Int         num_params,
137                 FT_Parameter*  params );
138 
139   FT_LOCAL( void )
140   T1_Face_Done( FT_Face  face );
141 
142   FT_LOCAL( FT_Error )
143   T1_GlyphSlot_Init( FT_GlyphSlot  slot );
144 
145   FT_LOCAL( void )
146   T1_GlyphSlot_Done( FT_GlyphSlot  slot );
147 
148   FT_LOCAL( FT_Error )
149   T1_Driver_Init( FT_Module  driver );
150 
151   FT_LOCAL( void )
152   T1_Driver_Done( FT_Module  driver );
153 
154 
155 FT_END_HEADER
156 
157 #endif /* T1OBJS_H_ */
158 
159 
160 /* END */
161