1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
|
/* Copyright (C) 2001-2021 Artifex Software, Inc.
All Rights Reserved.
This software is provided AS-IS with no warranty, either express or
implied.
This software is distributed under license and may not be copied,
modified or distributed except as expressly authorized under the terms
of the license contained in the file LICENSE in this distribution.
Refer to licensing information at http://www.artifex.com or contact
Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
CA 94945, U.S.A., +1(415)492-9861, for further information.
*/
/* FontDescriptor structure and API for pdfwrite */
#ifndef gdevpdtd_INCLUDED
# define gdevpdtd_INCLUDED
#include "gdevpdtx.h"
#include "gdevpdtb.h"
/* ================ Types and structures ================ */
/*
* FontDescriptors are handled as pseudo-resources. Multiple Font resources
* may share a descriptor. We don't need to use reference counting to keep
* track of this, since all descriptors persist until the device is closed.
* The CharSet entry in the FontDescriptor for a Type 1 subset font lists
* the glyphs that are included in the subset, so the FontDescriptor cannot
* be written until the font has been written, but we could use an indirect
* object for the CharSet and write the FontDescriptor itself early.
* However, we don't think that is worthwhile, since FontDescriptors are
* small objects compared to the fonts themselves, and it's simpler to keep
* all the FontDescriptors until the end.
*
* Note that FontDescriptors and BaseFonts correspond 1-to-1. While the PDF
* specification allows multiple FontDescriptors for a single BaseFont, this
* has no value: all the information in the FontDescriptor is derived from
* the BaseFont, so all the FontDescriptors for the same BaseFont must be
* the same.
*/
/*
* Font names in PDF files have caused an enormous amount of trouble, so we
* document specifically how they are handled in each structure.
*
* The PDF Reference says that the FontName in a font descriptor must be
* the same as the BaseFont in the font or CIDFont resource(s) that
* reference(s) it.
*
* We never create a font descriptor without also creating a font resource
* that references it, so we set the FontName at the same time as the
* BaseFont of the font resource. For more information, see gdevpdtf.h.
*/
/*
* Start by defining the elements common to font descriptors and sub-font
* (character class) descriptors.
*/
typedef struct pdf_font_descriptor_values_s {
/* Required elements */
int Ascent, CapHeight, Descent, ItalicAngle, StemV;
gs_int_rect FontBBox;
gs_string FontName;
uint Flags;
/* Optional elements (default to 0) */
int AvgWidth, Leading, MaxWidth, MissingWidth, StemH, XHeight;
} pdf_font_descriptor_values_t;
typedef struct pdf_font_descriptor_common_s pdf_font_descriptor_common_t;
struct pdf_font_descriptor_common_s {
pdf_resource_common(pdf_font_descriptor_common_t);
pdf_font_descriptor_values_t values;
};
/*
* Define a (top-level) FontDescriptor. CID-keyed vs. non-CID-keyed fonts
* are distinguished by their FontType.
*/
struct pdf_font_descriptor_s {
pdf_font_descriptor_common_t common;
pdf_base_font_t *base_font;
font_type FontType; /* (copied from base_font) */
bool embed;
struct cid_ { /* (CIDFonts only) */
cos_dict_t *Style;
char Lang[3]; /* 2 chars + \0 */
cos_dict_t *FD; /* value = COS_VALUE_RESOURCE */
} cid;
};
#ifndef pdf_font_descriptor_DEFINED
# define pdf_font_descriptor_DEFINED
typedef struct pdf_font_descriptor_s pdf_font_descriptor_t;
#endif
/* ================ Procedures ================ */
/*
* Allocate a FontDescriptor, initializing the FontType and rid from the
* gs_font.
*/
int pdf_font_descriptor_alloc(gx_device_pdf *pdev,
pdf_font_descriptor_t **ppfd,
gs_font_base *font, bool embed);
int pdf_base_font_free(gx_device_pdf *pdev, pdf_base_font_t *pbfont);
int pdf_font_descriptor_free(gx_device_pdf *pdev, pdf_resource_t *pres);
/*
* Get the object ID of a FontDescriptor.
*/
long pdf_font_descriptor_id(const pdf_font_descriptor_t *pfd);
/*
* For Linearised PDF production, set the usage array of the FontDescriptor
* resoruce and the FontFile resource, based on teh usage of the font.
*/
long pdf_set_font_descriptor_usage(gx_device_pdf *pdev, int parent_id, const pdf_font_descriptor_t *pfd);
/*
* Get the FontType of a FontDescriptor.
*/
font_type pdf_font_descriptor_FontType(const pdf_font_descriptor_t *pfd);
/*
* Get the embedding status of a FontDescriptor.
*/
bool pdf_font_descriptor_embedding(const pdf_font_descriptor_t *pfd);
/*
* Check for subset font.
*/
bool pdf_font_descriptor_is_subset(const pdf_font_descriptor_t *pfd);
/*
* Return a reference to the FontName of a FontDescriptor, similar to
* pdf_base_font_name.
*/
gs_string *pdf_font_descriptor_name(pdf_font_descriptor_t *pfd);
char *pdf_fontfile_hash(void *pfd);
/*
* Return the (copied, subset or complete) font associated with a FontDescriptor.
* This procedure probably shouldn't exist....
*/
gs_font_base *pdf_font_descriptor_font(const pdf_font_descriptor_t *pfd, bool complete);
/*
* Drop the copied complete font associated with a FontDescriptor.
*/
void pdf_font_descriptor_drop_complete_font(const pdf_font_descriptor_t *pfd);
/*
* Return a reference to the name of a FontDescriptor's base font, per
* pdf_base_font_name.
*/
gs_string *pdf_font_descriptor_base_name(const pdf_font_descriptor_t *pfd);
/*
* Copy a glyph from a font to the stable copy. Return 0 if this is a
* new glyph, 1 if it was already copied.
*/
int pdf_font_used_glyph(pdf_font_descriptor_t *pfd, gs_glyph glyph,
gs_font_base *font);
/*
* Compute the FontDescriptor metrics for a font.
*/
int pdf_compute_font_descriptor(gx_device_pdf *pdev, pdf_font_descriptor_t *pfd);
/*
* Finish a FontDescriptor by computing the metric values, and then
* writing the associated embedded font if any.
*/
int pdf_finish_FontDescriptor(gx_device_pdf *pdev,
pdf_resource_t *pfd);
int pdf_finish_resources(gx_device_pdf *pdev, pdf_resource_type_t type,
int (*finish_proc)(gx_device_pdf *,
pdf_resource_t *));
/*
* Write a FontDescriptor.
*/
int pdf_write_FontDescriptor(gx_device_pdf *pdev,
pdf_resource_t *pfd);
/*
* Release a FontDescriptor components.
*/
int pdf_release_FontDescriptor_components(gx_device_pdf *pdev, pdf_resource_t *pfd);
/*
* Mark a FontDescriptor used in a text.
*/
int pdf_mark_font_descriptor_used(gx_device_pdf *pdev, pdf_font_descriptor_t *pfd);
/*
* Mark a FontDescriptor Flags value as symbolic
*/
int mark_font_descriptor_symbolic(const pdf_font_resource_t *pdfont);
#endif /* gdevpdtd_INCLUDED */
|