Coverage Report

Created: 2026-03-31 07:04

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/xpdf-4.06/splash/SplashState.cc
Line
Count
Source
1
//========================================================================
2
//
3
// SplashState.cc
4
//
5
// Copyright 2003-2013 Glyph & Cog, LLC
6
//
7
//========================================================================
8
9
#include <aconf.h>
10
11
#include <string.h>
12
#include "gmem.h"
13
#include "gmempp.h"
14
#include "SplashPattern.h"
15
#include "SplashScreen.h"
16
#include "SplashClip.h"
17
#include "SplashBitmap.h"
18
#include "SplashState.h"
19
20
//------------------------------------------------------------------------
21
// SplashState
22
//------------------------------------------------------------------------
23
24
// number of components in each color mode
25
int splashColorModeNComps[] = {
26
  1, 1, 3, 3
27
#if SPLASH_CMYK
28
  , 4
29
#endif
30
};
31
32
SplashState::SplashState(int width, int height, GBool vectorAntialias,
33
398k
       SplashScreenParams *screenParams) {
34
398k
  SplashColor color;
35
398k
  int i;
36
37
398k
  matrix[0] = 1;  matrix[1] = 0;
38
398k
  matrix[2] = 0;  matrix[3] = 1;
39
398k
  matrix[4] = 0;  matrix[5] = 0;
40
398k
  memset(&color, 0, sizeof(SplashColor));
41
398k
  strokePattern = new SplashSolidColor(color);
42
398k
  fillPattern = new SplashSolidColor(color);
43
398k
  screen = new SplashScreen(screenParams);
44
398k
  blendFunc = NULL;
45
398k
  strokeAlpha = 1;
46
398k
  fillAlpha = 1;
47
398k
  lineWidth = 1;
48
398k
  lineCap = splashLineCapButt;
49
398k
  lineJoin = splashLineJoinMiter;
50
398k
  miterLimit = 10;
51
398k
  flatness = 1;
52
398k
  lineDash = NULL;
53
398k
  lineDashLength = 0;
54
398k
  lineDashPhase = 0;
55
398k
  strokeAdjust = splashStrokeAdjustOff;
56
398k
  alphaIsShape = gFalse;
57
398k
  clip = new SplashClip(0, 0, width, height);
58
398k
  clipIsShared = gFalse;
59
398k
  softMask = NULL;
60
398k
  deleteSoftMask = gFalse;
61
398k
  inNonIsolatedGroup = gFalse;
62
398k
  inKnockoutGroup = gFalse;
63
398k
#if SPLASH_CMYK
64
398k
  rgbTransferR = (Guchar *)gmalloc(8 * 256);
65
398k
  rgbTransferG = rgbTransferR + 256;
66
398k
  rgbTransferB = rgbTransferG + 256;
67
398k
  grayTransfer = rgbTransferB + 256;
68
398k
  cmykTransferC = grayTransfer + 256;
69
398k
  cmykTransferM = cmykTransferC + 256;
70
398k
  cmykTransferY = cmykTransferM + 256;
71
398k
  cmykTransferK = cmykTransferY + 256;
72
#else
73
  rgbTransferR = (Guchar *)gmalloc(4 * 256);
74
  rgbTransferG = rgbTransferR + 256;
75
  rgbTransferB = rgbTransferG + 256;
76
  grayTransfer = rgbTransferB + 256;
77
#endif
78
102M
  for (i = 0; i < 256; ++i) {
79
102M
    rgbTransferR[i] = (Guchar)i;
80
102M
    rgbTransferG[i] = (Guchar)i;
81
102M
    rgbTransferB[i] = (Guchar)i;
82
102M
    grayTransfer[i] = (Guchar)i;
83
102M
#if SPLASH_CMYK
84
102M
    cmykTransferC[i] = (Guchar)i;
85
102M
    cmykTransferM[i] = (Guchar)i;
86
102M
    cmykTransferY[i] = (Guchar)i;
87
102M
    cmykTransferK[i] = (Guchar)i;
88
102M
#endif
89
102M
  }
90
398k
  transferIsShared = gFalse;
91
398k
  overprintMask = 0xffffffff;
92
398k
  enablePathSimplification = gFalse;
93
398k
  next = NULL;
94
398k
}
95
96
SplashState::SplashState(int width, int height, GBool vectorAntialias,
97
5.87k
       SplashScreen *screenA) {
98
5.87k
  SplashColor color;
99
5.87k
  int i;
100
101
5.87k
  matrix[0] = 1;  matrix[1] = 0;
102
5.87k
  matrix[2] = 0;  matrix[3] = 1;
103
5.87k
  matrix[4] = 0;  matrix[5] = 0;
104
5.87k
  memset(&color, 0, sizeof(SplashColor));
105
5.87k
  strokePattern = new SplashSolidColor(color);
106
5.87k
  fillPattern = new SplashSolidColor(color);
107
5.87k
  screen = screenA->copy();
108
5.87k
  blendFunc = NULL;
109
5.87k
  strokeAlpha = 1;
110
5.87k
  fillAlpha = 1;
111
5.87k
  lineWidth = 1;
112
5.87k
  lineCap = splashLineCapButt;
113
5.87k
  lineJoin = splashLineJoinMiter;
114
5.87k
  miterLimit = 10;
115
5.87k
  flatness = 1;
116
5.87k
  lineDash = NULL;
117
5.87k
  lineDashLength = 0;
118
5.87k
  lineDashPhase = 0;
119
5.87k
  strokeAdjust = splashStrokeAdjustOff;
120
5.87k
  alphaIsShape = gFalse;
121
5.87k
  clip = new SplashClip(0, 0, width, height);
122
5.87k
  clipIsShared = gFalse;
123
5.87k
  softMask = NULL;
124
5.87k
  deleteSoftMask = gFalse;
125
5.87k
  inNonIsolatedGroup = gFalse;
126
5.87k
  inKnockoutGroup = gFalse;
127
5.87k
#if SPLASH_CMYK
128
5.87k
  rgbTransferR = (Guchar *)gmalloc(8 * 256);
129
5.87k
  rgbTransferG = rgbTransferR + 256;
130
5.87k
  rgbTransferB = rgbTransferG + 256;
131
5.87k
  grayTransfer = rgbTransferB + 256;
132
5.87k
  cmykTransferC = grayTransfer + 256;
133
5.87k
  cmykTransferM = cmykTransferC + 256;
134
5.87k
  cmykTransferY = cmykTransferM + 256;
135
5.87k
  cmykTransferK = cmykTransferY + 256;
136
#else
137
  rgbTransferR = (Guchar *)gmalloc(4 * 256);
138
  rgbTransferG = rgbTransferR + 256;
139
  rgbTransferB = rgbTransferG + 256;
140
  grayTransfer = rgbTransferB + 256;
141
#endif
142
1.51M
  for (i = 0; i < 256; ++i) {
143
1.50M
    rgbTransferR[i] = (Guchar)i;
144
1.50M
    rgbTransferG[i] = (Guchar)i;
145
1.50M
    rgbTransferB[i] = (Guchar)i;
146
1.50M
    grayTransfer[i] = (Guchar)i;
147
1.50M
#if SPLASH_CMYK
148
1.50M
    cmykTransferC[i] = (Guchar)i;
149
1.50M
    cmykTransferM[i] = (Guchar)i;
150
1.50M
    cmykTransferY[i] = (Guchar)i;
151
1.50M
    cmykTransferK[i] = (Guchar)i;
152
1.50M
#endif
153
1.50M
  }
154
5.87k
  transferIsShared = gFalse;
155
5.87k
  overprintMask = 0xffffffff;
156
5.87k
  enablePathSimplification = gFalse;
157
5.87k
  next = NULL;
158
5.87k
}
159
160
2.01M
SplashState::SplashState(SplashState *state) {
161
2.01M
  memcpy(matrix, state->matrix, 6 * sizeof(SplashCoord));
162
2.01M
  strokePattern = state->strokePattern->copy();
163
2.01M
  fillPattern = state->fillPattern->copy();
164
2.01M
  screen = state->screen->copy();
165
2.01M
  blendFunc = state->blendFunc;
166
2.01M
  strokeAlpha = state->strokeAlpha;
167
2.01M
  fillAlpha = state->fillAlpha;
168
2.01M
  lineWidth = state->lineWidth;
169
2.01M
  lineCap = state->lineCap;
170
2.01M
  lineJoin = state->lineJoin;
171
2.01M
  miterLimit = state->miterLimit;
172
2.01M
  flatness = state->flatness;
173
2.01M
  if (state->lineDash) {
174
2.11k
    lineDashLength = state->lineDashLength;
175
2.11k
    lineDash = (SplashCoord *)gmallocn(lineDashLength, sizeof(SplashCoord));
176
2.11k
    memcpy(lineDash, state->lineDash, lineDashLength * sizeof(SplashCoord));
177
2.01M
  } else {
178
2.01M
    lineDash = NULL;
179
2.01M
    lineDashLength = 0;
180
2.01M
  }
181
2.01M
  lineDashPhase = state->lineDashPhase;
182
2.01M
  strokeAdjust = state->strokeAdjust;
183
2.01M
  alphaIsShape = state->alphaIsShape;
184
2.01M
  clip = state->clip;
185
2.01M
  clipIsShared = gTrue;
186
2.01M
  softMask = state->softMask;
187
2.01M
  deleteSoftMask = gFalse;
188
2.01M
  inNonIsolatedGroup = state->inNonIsolatedGroup;
189
2.01M
  inKnockoutGroup = state->inKnockoutGroup;
190
2.01M
  rgbTransferR = state->rgbTransferR;
191
2.01M
  rgbTransferG = state->rgbTransferG;
192
2.01M
  rgbTransferB = state->rgbTransferB;
193
2.01M
  grayTransfer = state->grayTransfer;
194
2.01M
#if SPLASH_CMYK
195
2.01M
  cmykTransferC = state->cmykTransferC;
196
2.01M
  cmykTransferM = state->cmykTransferM;
197
2.01M
  cmykTransferY = state->cmykTransferY;
198
2.01M
  cmykTransferK = state->cmykTransferK;
199
2.01M
#endif
200
2.01M
  transferIsShared = gTrue;
201
2.01M
  overprintMask = state->overprintMask;
202
2.01M
  enablePathSimplification = state->enablePathSimplification;
203
2.01M
  next = NULL;
204
2.01M
}
205
206
2.41M
SplashState::~SplashState() {
207
2.41M
  delete strokePattern;
208
2.41M
  delete fillPattern;
209
2.41M
  delete screen;
210
2.41M
  gfree(lineDash);
211
2.41M
  if (!clipIsShared) {
212
575k
    delete clip;
213
575k
  }
214
2.41M
  if (!transferIsShared) {
215
404k
    gfree(rgbTransferR);
216
404k
  }
217
2.41M
  if (deleteSoftMask && softMask) {
218
832
    delete softMask;
219
832
  }
220
2.41M
}
221
222
941k
void SplashState::setStrokePattern(SplashPattern *strokePatternA) {
223
941k
  delete strokePattern;
224
941k
  strokePattern = strokePatternA;
225
941k
}
226
227
1.94M
void SplashState::setFillPattern(SplashPattern *fillPatternA) {
228
1.94M
  delete fillPattern;
229
1.94M
  fillPattern = fillPatternA;
230
1.94M
}
231
232
0
void SplashState::setScreen(SplashScreen *screenA) {
233
0
  delete screen;
234
0
  screen = screenA;
235
0
}
236
237
void SplashState::setLineDash(SplashCoord *lineDashA, int lineDashLengthA,
238
824k
            SplashCoord lineDashPhaseA) {
239
824k
  gfree(lineDash);
240
824k
  lineDashLength = lineDashLengthA;
241
824k
  if (lineDashLength > 0) {
242
964
    lineDash = (SplashCoord *)gmallocn(lineDashLength, sizeof(SplashCoord));
243
964
    memcpy(lineDash, lineDashA, lineDashLength * sizeof(SplashCoord));
244
823k
  } else {
245
823k
    lineDash = NULL;
246
823k
  }
247
824k
  lineDashPhase = lineDashPhaseA;
248
824k
}
249
250
0
GBool SplashState::lineDashContainsZeroLengthDashes() {
251
0
  int i;
252
253
0
  if (lineDashLength == 0) {
254
0
    return gFalse;
255
0
  }
256
257
  // if the line dash array has an odd number of elements, we need to
258
  // check all of the elements; if the length is even, we only need to
259
  // check even-number elements
260
0
  if (lineDashLength & 1) {
261
0
    for (i = 0; i < lineDashLength; ++i) {
262
0
      if (lineDash[i] == 0) {
263
0
  return gTrue;
264
0
      }
265
0
    }
266
0
  } else {
267
0
    for (i = 0; i < lineDashLength; i += 2) {
268
0
      if (lineDash[i] == 0) {
269
0
  return gTrue;
270
0
      }
271
0
    }
272
0
  }
273
0
  return gFalse;
274
0
}
275
276
void SplashState::clipResetToRect(SplashCoord x0, SplashCoord y0,
277
0
          SplashCoord x1, SplashCoord y1) {
278
0
  if (clipIsShared) {
279
0
    clip = clip->copy();
280
0
    clipIsShared = gFalse;
281
0
  }
282
0
  clip->resetToRect(x0, y0, x1, y1);
283
0
}
284
285
SplashError SplashState::clipToRect(SplashCoord x0, SplashCoord y0,
286
0
            SplashCoord x1, SplashCoord y1) {
287
0
  if (clipIsShared) {
288
0
    clip = clip->copy();
289
0
    clipIsShared = gFalse;
290
0
  }
291
0
  return clip->clipToRect(x0, y0, x1, y1);
292
0
}
293
294
203k
SplashError SplashState::clipToPath(SplashPath *path, GBool eo) {
295
203k
  if (clipIsShared) {
296
170k
    clip = clip->copy();
297
170k
    clipIsShared = gFalse;
298
170k
  }
299
203k
  return clip->clipToPath(path, matrix, flatness, eo,
300
203k
        enablePathSimplification, strokeAdjust);
301
203k
}
302
303
9.64k
void SplashState::setSoftMask(SplashBitmap *softMaskA, GBool deleteBitmap) {
304
9.64k
  if (deleteSoftMask) {
305
3.00k
    delete softMask;
306
3.00k
  }
307
9.64k
  softMask = softMaskA;
308
9.64k
  deleteSoftMask = deleteBitmap;
309
9.64k
}
310
311
void SplashState::setTransfer(Guchar *red, Guchar *green, Guchar *blue,
312
529
            Guchar *gray) {
313
529
#if SPLASH_CMYK
314
529
  int i;
315
529
#endif
316
317
529
  if (transferIsShared) {
318
450
#if SPLASH_CMYK
319
450
    rgbTransferR = (Guchar *)gmalloc(8 * 256);
320
450
    rgbTransferG = rgbTransferR + 256;
321
450
    rgbTransferB = rgbTransferG + 256;
322
450
    grayTransfer = rgbTransferB + 256;
323
450
    cmykTransferC = grayTransfer + 256;
324
450
    cmykTransferM = cmykTransferC + 256;
325
450
    cmykTransferY = cmykTransferM + 256;
326
450
    cmykTransferK = cmykTransferY + 256;
327
#else
328
    rgbTransferR = (Guchar *)gmalloc(4 * 256);
329
    rgbTransferG = rgbTransferR + 256;
330
    rgbTransferB = rgbTransferG + 256;
331
    grayTransfer = rgbTransferB + 256;
332
#endif
333
450
    transferIsShared = gFalse;
334
450
  }
335
529
  memcpy(rgbTransferR, red, 256);
336
529
  memcpy(rgbTransferG, green, 256);
337
529
  memcpy(rgbTransferB, blue, 256);
338
529
  memcpy(grayTransfer, gray, 256);
339
529
#if SPLASH_CMYK
340
135k
  for (i = 0; i < 256; ++i) {
341
135k
    cmykTransferC[i] = (Guchar)(255 - rgbTransferR[255 - i]);
342
135k
    cmykTransferM[i] = (Guchar)(255 - rgbTransferG[255 - i]);
343
135k
    cmykTransferY[i] = (Guchar)(255 - rgbTransferB[255 - i]);
344
135k
    cmykTransferK[i] = (Guchar)(255 - grayTransfer[255 - i]);
345
135k
  }
346
529
#endif
347
529
}
348