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
|
/* Copyright (C) 2001-2006 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 that
license. Refer to licensing information at http://www.artifex.com/
or contact Artifex Software, Inc., 7 Mt. Lassen Drive - Suite A-134,
San Rafael, CA 94903, U.S.A., +1(415)492-9861, for further information.
*/
/* $Id$ */
/* Shared implementation definitions for pdfwrite text and fonts */
#ifndef gdevpdtx_INCLUDED
# define gdevpdtx_INCLUDED
#include "gdevpdt.h"
/*
* The pdfwrite text code is designed in layers. Each layer uses only
* facilities defined in that layer and those below it. The layers and the
* code files that define them are:
*
* Text processing
* gdevpdtt.c - main text processing and utilities
* gdevpdtc.c - processing for composite and CID-based fonts
* gdevpdte.c - processing for Encoding-based (i.e., all other) fonts
* gdevpdts.c - text state bookkeeping
* gdevpdt[st].h - definitions shared by the above
* Font resources
* gdevpdtf.h - interface and public definitions
* gdevpdtf.c - implementation of font resources, except for writing
* gdevpdtw.[hc] - font resource writing
* Font descriptors
* gdevpdtd.h - interface and public definitions
* gdevpdtd.c - implementation of font descriptors
* Base fonts
* gdevpdtb.h - interface and public definitions
* gdevpdtb.c - implementation of base fonts
*
* There is also a module for bitmap font processing:
* gdevpdti.h - interface and public definitions
* gdevpdti.c - implementation of bitmap fonts
* This handles both text processing and font resource management for
* Type 3 bitmap fonts, which don't fit into the layer structure very well.
*/
/* ================ Types and structures ================ */
/*
* Define the structure for managing the text and font state. This is
* made up of several individually opaque components.
*/
#ifndef pdf_bitmap_fonts_DEFINED
# define pdf_bitmap_fonts_DEFINED
typedef struct pdf_bitmap_fonts_s pdf_bitmap_fonts_t;
#endif
#ifndef pdf_outline_fonts_DEFINED
# define pdf_outline_fonts_DEFINED
typedef struct pdf_outline_fonts_s pdf_outline_fonts_t;
#endif
#ifndef pdf_text_state_DEFINED
# define pdf_text_state_DEFINED
typedef struct pdf_text_state_s pdf_text_state_t;
#endif
/*typedef struct pdf_text_data_s pdf_text_data_t;*/ /* gdevpdfx.h */
struct pdf_text_data_s {
pdf_outline_fonts_t *outline_fonts; /* gdevpdtf.c */
pdf_bitmap_fonts_t *bitmap_fonts; /* gdevpdti.c */
pdf_text_state_t *text_state; /* gdevpdts.c */
};
#define private_st_pdf_text_data() /* gdevpdt.c */\
gs_private_st_ptrs3(st_pdf_text_data, pdf_text_data_t, "pdf_text_data_t",\
pdf_text_data_enum_ptrs, pdf_text_data_reloc_ptrs,\
outline_fonts, bitmap_fonts, text_state)
/* ================ Procedures (internal utilities) ================ */
/* The typedef will eventually move to gdevpdfx.h. */
typedef struct pdf_font_resource_s pdf_font_resource_t;
/* ---------------- Font accessing ---------------- */
/* Get the object ID of a font resource. */
long pdf_font_id(const pdf_font_resource_t *pdfont);
/* Register charproc fonts with the page or substream. */
int pdf_used_charproc_resources(gx_device_pdf *pdev, pdf_font_resource_t *pdfont);
#endif /* gdevpdtx_INCLUDED */
|