]> git.saurik.com Git - wxWidgets.git/blob - src/freetype/cid/cidobjs.c
Don't create a bitmap with dimensions <= 0...
[wxWidgets.git] / src / freetype / cid / cidobjs.c
1 /***************************************************************************/
2 /* */
3 /* cidobjs.c */
4 /* */
5 /* CID objects manager (body). */
6 /* */
7 /* Copyright 1996-2000 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 #include <freetype/internal/ftdebug.h>
20 #include <freetype/internal/ftstream.h>
21
22
23 #ifdef FT_FLAT_COMPILE
24
25 #include "cidgload.h"
26 #include "cidload.h"
27
28 #else
29
30 #include <cid/cidgload.h>
31 #include <cid/cidload.h>
32
33 #endif
34
35
36 #include <freetype/internal/psnames.h>
37
38
39 /*************************************************************************/
40 /* */
41 /* The macro FT_COMPONENT is used in trace mode. It is an implicit */
42 /* parameter of the FT_TRACE() and FT_ERROR() macros, used to print/log */
43 /* messages during execution. */
44 /* */
45 #undef FT_COMPONENT
46 #define FT_COMPONENT trace_cidobjs
47
48
49 /*************************************************************************/
50 /* */
51 /* FACE FUNCTIONS */
52 /* */
53 /*************************************************************************/
54
55
56 /*************************************************************************/
57 /* */
58 /* <Function> */
59 /* CID_Done_Face */
60 /* */
61 /* <Description> */
62 /* Finalizes a given face object. */
63 /* */
64 /* <Input> */
65 /* face :: A pointer to the face object to destroy. */
66 /* */
67 LOCAL_FUNC
68 void CID_Done_Face( CID_Face face )
69 {
70 FT_Memory memory;
71
72
73 if ( face )
74 {
75 CID_Info* cid = &face->cid;
76 T1_FontInfo* info = &cid->font_info;
77
78
79 memory = face->root.memory;
80
81 /* release FontInfo strings */
82 FREE( info->version );
83 FREE( info->notice );
84 FREE( info->full_name );
85 FREE( info->family_name );
86 FREE( info->weight );
87
88 /* release font dictionaries */
89 FREE( cid->font_dicts );
90 cid->num_dicts = 0;
91
92 /* release other strings */
93 FREE( cid->cid_font_name );
94 FREE( cid->registry );
95 FREE( cid->ordering );
96
97 face->root.family_name = 0;
98 face->root.style_name = 0;
99 }
100 }
101
102
103 /*************************************************************************/
104 /* */
105 /* <Function> */
106 /* CID_Init_Face */
107 /* */
108 /* <Description> */
109 /* Initializes a given CID face object. */
110 /* */
111 /* <Input> */
112 /* stream :: The source font stream. */
113 /* */
114 /* face_index :: The index of the font face in the resource. */
115 /* */
116 /* num_params :: Number of additional generic parameters. Ignored. */
117 /* */
118 /* params :: Additional generic parameters. Ignored. */
119 /* */
120 /* <InOut> */
121 /* face :: The newly built face object. */
122 /* */
123 /* <Return> */
124 /* FreeType error code. 0 means success. */
125 /* */
126 LOCAL_FUNC
127 FT_Error CID_Init_Face( FT_Stream stream,
128 CID_Face face,
129 FT_Int face_index,
130 FT_Int num_params,
131 FT_Parameter* params )
132 {
133 FT_Error error;
134 PSNames_Interface* psnames;
135
136 FT_UNUSED( num_params );
137 FT_UNUSED( params );
138 FT_UNUSED( face_index );
139 FT_UNUSED( stream );
140
141
142 face->root.num_faces = 1;
143
144 psnames = (PSNames_Interface*)face->psnames;
145 if ( !psnames )
146 {
147 psnames = (PSNames_Interface*)FT_Get_Module_Interface(
148 FT_FACE_LIBRARY( face ), "psnames" );
149
150 face->psnames = psnames;
151 }
152
153 /* open the tokenizer; this will also check the font format */
154 if ( FILE_Seek( 0 ) )
155 goto Exit;
156
157 error = CID_Open_Face( face );
158 if ( error )
159 goto Exit;
160
161 /* if we just wanted to check the format, leave successfully now */
162 if ( face_index < 0 )
163 goto Exit;
164
165 /* check the face index */
166 if ( face_index != 0 )
167 {
168 FT_ERROR(( "CID_Init_Face: invalid face index\n" ));
169 error = T1_Err_Invalid_Argument;
170 goto Exit;
171 }
172
173 /* Now, load the font program into the face object */
174 {
175 /* Init the face object fields */
176 /* Now set up root face fields */
177 {
178 FT_Face root = (FT_Face)&face->root;
179
180
181 root->num_glyphs = face->cid.cid_count;
182 root->num_charmaps = 0;
183
184 root->face_index = face_index;
185 root->face_flags = FT_FACE_FLAG_SCALABLE;
186
187 root->face_flags |= FT_FACE_FLAG_HORIZONTAL;
188
189 if ( face->cid.font_info.is_fixed_pitch )
190 root->face_flags |= FT_FACE_FLAG_FIXED_WIDTH;
191
192 /* XXX: TODO: add kerning with .afm support */
193
194 /* get style name -- be careful, some broken fonts only */
195 /* have a /FontName dictionary entry! */
196 root->family_name = face->cid.font_info.family_name;
197 if ( root->family_name )
198 {
199 char* full = face->cid.font_info.full_name;
200 char* family = root->family_name;
201
202 while ( *family && *full == *family )
203 {
204 family++;
205 full++;
206 }
207
208 root->style_name = ( *full == ' ' ) ? full + 1
209 : (char *)"Regular";
210 }
211 else
212 {
213 /* do we have a `/FontName'? */
214 if ( face->cid.cid_font_name )
215 {
216 root->family_name = face->cid.cid_font_name;
217 root->style_name = "Regular";
218 }
219 }
220
221 /* no embedded bitmap support */
222 root->num_fixed_sizes = 0;
223 root->available_sizes = 0;
224
225 root->bbox = face->cid.font_bbox;
226 root->units_per_EM = 1000;
227 root->ascender = (FT_Short)face->cid.font_bbox.yMax;
228 root->descender = -(FT_Short)face->cid.font_bbox.yMin;
229 root->height = ( ( root->ascender + root->descender ) * 12 )
230 / 10;
231
232
233 #if 0
234
235 /* now compute the maximum advance width */
236
237 root->max_advance_width = face->type1.private_dict.standard_width[0];
238
239 /* compute max advance width for proportional fonts */
240 if ( !face->type1.font_info.is_fixed_pitch )
241 {
242 FT_Int max_advance;
243
244
245 error = CID_Compute_Max_Advance( face, &max_advance );
246
247 /* in case of error, keep the standard width */
248 if ( !error )
249 root->max_advance_width = max_advance;
250 else
251 error = 0; /* clear error */
252 }
253
254 root->max_advance_height = root->height;
255
256 #endif /* 0 */
257
258 root->underline_position = face->cid.font_info.underline_position;
259 root->underline_thickness = face->cid.font_info.underline_thickness;
260
261 root->max_points = 0;
262 root->max_contours = 0;
263 }
264 }
265
266 #if 0
267
268 /* charmap support - synthetize unicode charmap when possible */
269 {
270 FT_Face root = &face->root;
271 FT_CharMap charmap = face->charmaprecs;
272
273
274 /* synthesize a Unicode charmap if there is support in the `psnames' */
275 /* module */
276 if ( face->psnames )
277 {
278 PSNames_Interface* psnames = (PSNames_Interface*)face->psnames;
279
280
281 if ( psnames->unicode_value )
282 {
283 error = psnames->build_unicodes(
284 root->memory,
285 face->type1.num_glyphs,
286 (const char**)face->type1.glyph_names,
287 &face->unicode_map );
288 if ( !error )
289 {
290 root->charmap = charmap;
291 charmap->face = (FT_Face)face;
292 charmap->encoding = ft_encoding_unicode;
293 charmap->platform_id = 3;
294 charmap->encoding_id = 1;
295 charmap++;
296 }
297
298 /* simply clear the error in case of failure (which really */
299 /* means that out of memory or no unicode glyph names) */
300 error = 0;
301 }
302 }
303
304 /* now, support either the standard, expert, or custom encodings */
305 charmap->face = (FT_Face)face;
306 charmap->platform_id = 7; /* a new platform id for Adobe fonts? */
307
308 switch ( face->type1.encoding_type )
309 {
310 case t1_encoding_standard:
311 charmap->encoding = ft_encoding_adobe_standard;
312 charmap->encoding_id = 0;
313 break;
314
315 case t1_encoding_expert:
316 charmap->encoding = ft_encoding_adobe_expert;
317 charmap->encoding_id = 1;
318 break;
319
320 default:
321 charmap->encoding = ft_encoding_adobe_custom;
322 charmap->encoding_id = 2;
323 break;
324 }
325
326 root->charmaps = face->charmaps;
327 root->num_charmaps = charmap - face->charmaprecs + 1;
328 face->charmaps[0] = &face->charmaprecs[0];
329 face->charmaps[1] = &face->charmaprecs[1];
330 }
331
332 #endif /* 0 */
333
334 Exit:
335 return error;
336 }
337
338
339 /*************************************************************************/
340 /* */
341 /* <Function> */
342 /* CID_Init_Driver */
343 /* */
344 /* <Description> */
345 /* Initializes a given CID driver object. */
346 /* */
347 /* <Input> */
348 /* driver :: A handle to the target driver object. */
349 /* */
350 /* <Return> */
351 /* FreeType error code. 0 means success. */
352 /* */
353 LOCAL_FUNC
354 FT_Error CID_Init_Driver( CID_Driver driver )
355 {
356 FT_UNUSED( driver );
357
358 return T1_Err_Ok;
359 }
360
361
362 /*************************************************************************/
363 /* */
364 /* <Function> */
365 /* CID_Done_Driver */
366 /* */
367 /* <Description> */
368 /* Finalizes a given CID driver. */
369 /* */
370 /* <Input> */
371 /* driver :: A handle to the target CID driver. */
372 /* */
373 LOCAL_DEF
374 void CID_Done_Driver( CID_Driver driver )
375 {
376 FT_UNUSED( driver );
377 }
378
379
380 /* END */