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
|
/* Copyright (C) 2001-2006 artofcode LLC.
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$ */
/* Private graphics state definition for Ghostscript library */
#ifndef gzstate_INCLUDED
# define gzstate_INCLUDED
#include "gscpm.h"
#include "gscspace.h"
#include "gsrefct.h"
#include "gxdcolor.h"
#include "gxistate.h"
#include "gsstate.h"
#include "gxstate.h"
/* Opaque types referenced by the graphics state. */
#ifndef gx_path_DEFINED
# define gx_path_DEFINED
typedef struct gx_path_s gx_path;
#endif
#ifndef gx_clip_path_DEFINED
# define gx_clip_path_DEFINED
typedef struct gx_clip_path_s gx_clip_path;
#endif
#ifndef gx_clip_stack_DEFINED
# define gx_clip_stack_DEFINED
typedef struct gx_clip_stack_s gx_clip_stack_t;
#endif
#ifndef gs_color_space_DEFINED
# define gs_color_space_DEFINED
typedef struct gs_color_space_s gs_color_space;
#endif
#ifndef gs_client_color_DEFINED
# define gs_client_color_DEFINED
typedef struct gs_client_color_s gs_client_color;
#endif
#ifndef gs_font_DEFINED
# define gs_font_DEFINED
typedef struct gs_font_s gs_font;
#endif
#ifndef gs_transparency_group_DEFINED
# define gs_transparency_group_DEFINED
typedef struct gs_transparency_group_s gs_transparency_group_t;
#endif
#ifndef gs_device_filter_stack_DEFINED
# define gs_device_filter_stack_DEFINED
typedef struct gs_device_filter_stack_s gs_device_filter_stack_t;
#endif
/* Device filter stack structure is defined here so that gstate
lifecycle operations can access reference count; implementation is
in gsdfilt.c.
*/
#ifndef gs_device_filter_DEFINED
# define gs_device_filter_DEFINED
typedef struct gs_device_filter_s gs_device_filter_t;
#endif
/* This is the base structure from which device filters are derived. */
struct gs_device_filter_stack_s {
gs_device_filter_stack_t *next;
gs_device_filter_t *df;
gx_device *next_device;
rc_header rc;
};
/* Graphics state structure. */
struct gs_state_s {
gs_imager_state_common; /* imager state, must be first */
gs_state *saved; /* previous state from gsave */
/* Transformation: */
gs_matrix ctm_inverse;
bool ctm_inverse_valid; /* true if ctm_inverse = ctm^-1 */
gs_matrix ctm_default;
bool ctm_default_set; /* if true, use ctm_default; */
/* if false, ask device */
/* Paths: */
gx_path *path;
gx_clip_path *clip_path;
gx_clip_stack_t *clip_stack; /* (LanguageLevel 3 only) */
gx_clip_path *view_clip; /* (may be 0, or have rule = 0) */
/* Effective clip path cache */
gs_id effective_clip_id; /* (key) clip path id */
gs_id effective_view_clip_id; /* (key) view clip path id */
gx_clip_path *effective_clip_path; /* (value) effective clip path, */
/* possibly = clip_path or view_clip */
bool effective_clip_shared; /* true iff e.c.p. = c.p. or v.c. */
/* Color (device-independent): */
gs_color_space *color_space; /* after substitution */
gs_client_color *ccolor;
/* Color caches: */
gx_device_color *dev_color;
/* Font: */
gs_font *font;
gs_font *root_font;
gs_matrix_fixed char_tm; /* font matrix * ctm */
#define char_tm_only(pgs) *(gs_matrix *)&(pgs)->char_tm
bool char_tm_valid; /* true if char_tm is valid */
gs_in_cache_device_t in_cachedevice; /* (see gscpm.h) */
gs_char_path_mode in_charpath; /* (see gscpm.h) */
gs_state *show_gstate; /* gstate when show was invoked */
/* (so charpath can append to path) */
/* Other stuff: */
int level; /* incremented by 1 per gsave */
gx_device *device;
#undef gs_currentdevice_inline
#define gs_currentdevice_inline(pgs) ((pgs)->device)
gs_device_filter_stack_t *dfilter_stack;
gs_transparency_group_t *transparency_group_stack; /* (PDF 1.4 only) */
/* Client data: */
/*void *client_data;*/ /* in imager state */
#define gs_state_client_data(pgs) ((pgs)->client_data)
gs_state_client_procs client_procs;
};
#define public_st_gs_state() /* in gsstate.c */\
gs_public_st_composite(st_gs_state, gs_state, "gs_state",\
gs_state_enum_ptrs, gs_state_reloc_ptrs)
/*
* Enumerate the pointers in a graphics state, other than the ones in the
* imager state, and device, which must be handled specially.
*/
#define gs_state_do_ptrs(m)\
m(0,saved) m(1,path) m(2,clip_path) m(3,clip_stack)\
m(4,view_clip) m(5,effective_clip_path)\
m(6,color_space) m(7,ccolor) m(8,dev_color)\
m(9,font) m(10,root_font) m(11,show_gstate) /*m(---,device)*/\
m(12,transparency_group_stack)
#define gs_state_num_ptrs 13
/* The following macro is used for development purpose for designating places
where current point is changed. Clients must not use it. */
#define gx_setcurrentpoint(pgs, xx, yy)\
(pgs)->current_point.x = xx;\
(pgs)->current_point.y = yy;
#endif /* gzstate_INCLUDED */
|