1/***************************************************************************/
2/* */
3/* pshrec.h */
4/* */
5/* Postscript (Type1/Type2) hints recorder (specification). */
6/* */
7/* Copyright 2001-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 /**************************************************************************/
20 /* */
21 /* The functions defined here are called from the Type 1, CID and CFF */
22 /* font drivers to record the hints of a given character/glyph. */
23 /* */
24 /* The hints are recorded in a unified format, and are later processed */
25 /* by the `optimizer' and `fitter' to adjust the outlines to the pixel */
26 /* grid. */
27 /* */
28 /**************************************************************************/
29
30
31#ifndef PSHREC_H_
32#define PSHREC_H_
33
34
35#include <ft2build.h>
36#include FT_INTERNAL_POSTSCRIPT_HINTS_H
37#include "pshglob.h"
38
39
40FT_BEGIN_HEADER
41
42
43 /*************************************************************************/
44 /*************************************************************************/
45 /***** *****/
46 /***** GLYPH HINTS RECORDER INTERNALS *****/
47 /***** *****/
48 /*************************************************************************/
49 /*************************************************************************/
50
51 /* handle to hint record */
52 typedef struct PS_HintRec_* PS_Hint;
53
54 /* hint types */
55 typedef enum PS_Hint_Type_
56 {
57 PS_HINT_TYPE_1 = 1,
58 PS_HINT_TYPE_2 = 2
59
60 } PS_Hint_Type;
61
62
63 /* hint flags */
64#define PS_HINT_FLAG_GHOST 1U
65#define PS_HINT_FLAG_BOTTOM 2U
66
67
68 /* hint descriptor */
69 typedef struct PS_HintRec_
70 {
71 FT_Int pos;
72 FT_Int len;
73 FT_UInt flags;
74
75 } PS_HintRec;
76
77
78#define ps_hint_is_active( x ) ( (x)->flags & PS_HINT_FLAG_ACTIVE )
79#define ps_hint_is_ghost( x ) ( (x)->flags & PS_HINT_FLAG_GHOST )
80#define ps_hint_is_bottom( x ) ( (x)->flags & PS_HINT_FLAG_BOTTOM )
81
82
83 /* hints table descriptor */
84 typedef struct PS_Hint_TableRec_
85 {
86 FT_UInt num_hints;
87 FT_UInt max_hints;
88 PS_Hint hints;
89
90 } PS_Hint_TableRec, *PS_Hint_Table;
91
92
93 /* hint and counter mask descriptor */
94 typedef struct PS_MaskRec_
95 {
96 FT_UInt num_bits;
97 FT_UInt max_bits;
98 FT_Byte* bytes;
99 FT_UInt end_point;
100
101 } PS_MaskRec, *PS_Mask;
102
103
104 /* masks and counters table descriptor */
105 typedef struct PS_Mask_TableRec_
106 {
107 FT_UInt num_masks;
108 FT_UInt max_masks;
109 PS_Mask masks;
110
111 } PS_Mask_TableRec, *PS_Mask_Table;
112
113
114 /* dimension-specific hints descriptor */
115 typedef struct PS_DimensionRec_
116 {
117 PS_Hint_TableRec hints;
118 PS_Mask_TableRec masks;
119 PS_Mask_TableRec counters;
120
121 } PS_DimensionRec, *PS_Dimension;
122
123
124 /* glyph hints descriptor */
125 /* dimension 0 => X coordinates + vertical hints/stems */
126 /* dimension 1 => Y coordinates + horizontal hints/stems */
127 typedef struct PS_HintsRec_
128 {
129 FT_Memory memory;
130 FT_Error error;
131 FT_UInt32 magic;
132 PS_Hint_Type hint_type;
133 PS_DimensionRec dimension[2];
134
135 } PS_HintsRec, *PS_Hints;
136
137 /* */
138
139 /* initialize hints recorder */
140 FT_LOCAL( void )
141 ps_hints_init( PS_Hints hints,
142 FT_Memory memory );
143
144 /* finalize hints recorder */
145 FT_LOCAL( void )
146 ps_hints_done( PS_Hints hints );
147
148 /* initialize Type1 hints recorder interface */
149 FT_LOCAL( void )
150 t1_hints_funcs_init( T1_Hints_FuncsRec* funcs );
151
152 /* initialize Type2 hints recorder interface */
153 FT_LOCAL( void )
154 t2_hints_funcs_init( T2_Hints_FuncsRec* funcs );
155
156
157#ifdef DEBUG_HINTER
158 extern PS_Hints ps_debug_hints;
159 extern int ps_debug_no_horz_hints;
160 extern int ps_debug_no_vert_hints;
161#endif
162
163 /* */
164
165
166FT_END_HEADER
167
168
169#endif /* PSHREC_H_ */
170
171
172/* END */
173