Coverage Report

Created: 2026-04-04 06:06

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/xpdf-4.06/splash/SplashMath.h
Line
Count
Source
1
//========================================================================
2
//
3
// SplashMath.h
4
//
5
// Copyright 2003-2013 Glyph & Cog, LLC
6
//
7
//========================================================================
8
9
#ifndef SPLASHMATH_H
10
#define SPLASHMATH_H
11
12
#include <aconf.h>
13
14
#if USE_FIXEDPONT
15
#  include "FixedPoint.h"
16
#else
17
#  include <math.h>
18
#  if (defined(__GNUC__) && defined(__SSE2__)) || \
19
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
20
#    include <emmintrin.h>
21
#  endif
22
#endif
23
#include "SplashTypes.h"
24
25
168M
static inline SplashCoord splashAbs(SplashCoord x) {
26
#if USE_FIXEDPOINT
27
  return FixedPoint::abs(x);
28
#else
29
168M
  return fabs(x);
30
168M
#endif
31
168M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashAbs(double)
Unexecuted instantiation: SplashOutputDev.cc:splashAbs(double)
Splash.cc:splashAbs(double)
Line
Count
Source
25
322k
static inline SplashCoord splashAbs(SplashCoord x) {
26
#if USE_FIXEDPOINT
27
  return FixedPoint::abs(x);
28
#else
29
322k
  return fabs(x);
30
322k
#endif
31
322k
}
Unexecuted instantiation: SplashClip.cc:splashAbs(double)
SplashFontEngine.cc:splashAbs(double)
Line
Count
Source
25
424k
static inline SplashCoord splashAbs(SplashCoord x) {
26
#if USE_FIXEDPOINT
27
  return FixedPoint::abs(x);
28
#else
29
424k
  return fabs(x);
30
424k
#endif
31
424k
}
Unexecuted instantiation: SplashPattern.cc:splashAbs(double)
Unexecuted instantiation: SplashState.cc:splashAbs(double)
SplashXPath.cc:splashAbs(double)
Line
Count
Source
25
167M
static inline SplashCoord splashAbs(SplashCoord x) {
26
#if USE_FIXEDPOINT
27
  return FixedPoint::abs(x);
28
#else
29
167M
  return fabs(x);
30
167M
#endif
31
167M
}
Unexecuted instantiation: SplashXPathScanner.cc:splashAbs(double)
Unexecuted instantiation: ShadingImage.cc:splashAbs(double)
Unexecuted instantiation: SplashFTFontFile.cc:splashAbs(double)
Unexecuted instantiation: SplashFont.cc:splashAbs(double)
Unexecuted instantiation: SplashScreen.cc:splashAbs(double)
Unexecuted instantiation: SplashFTFont.cc:splashAbs(double)
Unexecuted instantiation: fuzz_JBIG2.cc:splashAbs(double)
32
33
// floor() and (int)() are implemented separately, which results
34
// in changing the FPCW multiple times - so we optimize it with
35
// some inline assembly or SSE intrinsics.
36
107M
static inline int splashFloor(SplashCoord x) {
37
#if USE_FIXEDPOINT
38
39
  //--- fixed point
40
41
  return FixedPoint::floor(x);
42
43
#elif (defined(__GNUC__) && defined(__SSE2__)) || \
44
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
45
46
  //--- SSE2 intrinsics
47
  // NB: 64-bit x86 guarantees availability of SSE2.
48
49
107M
  __m128d m1, m2;
50
107M
  int i, s;
51
52
107M
  m1 = _mm_set_sd(x);
53
107M
  i = _mm_cvttsd_si32(m1);
54
107M
  m2 = _mm_cvtsi32_sd(m1, i);
55
107M
  s = _mm_ucomigt_sd(m2, m1);
56
107M
  return i - s;
57
58
#elif defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__)
59
60
  //--- x87 inline assembly (gcc/clang)
61
  // (this code fails on OSX for reasons I don't understand)
62
63
  Gushort oldCW, newCW, t;
64
  int result;
65
66
  __asm__ volatile("fnstcw %0\n"
67
       "movw   %0, %3\n"
68
       "andw   $0xf3ff, %3\n"
69
       "orw    $0x0400, %3\n"
70
       "movw   %3, %1\n"       // round down
71
       "fldcw  %1\n"
72
       "fistl %2\n"
73
       "fldcw  %0\n"
74
       : "=m" (oldCW), "=m" (newCW), "=m" (result), "=r" (t)
75
       : "t" (x));
76
  return result;
77
78
#elif defined(_WIN32) && defined(_M_IX86)
79
80
  //--- x87 inline assembly (VC)
81
82
  Gushort oldCW, newCW;
83
  int result;
84
85
  __asm fld QWORD PTR x
86
  __asm fnstcw WORD PTR oldCW
87
  __asm mov ax, WORD PTR oldCW
88
  __asm and ax, 0xf3ff
89
  __asm or ax, 0x0400
90
  __asm mov WORD PTR newCW, ax     // round down
91
  __asm fldcw WORD PTR newCW
92
  __asm fistp DWORD PTR result
93
  __asm fldcw WORD PTR oldCW
94
  return result;
95
96
#else
97
98
  //--- all others
99
100
  return (int)floor(x);
101
102
#endif
103
107M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashFloor(double)
Unexecuted instantiation: SplashOutputDev.cc:splashFloor(double)
Splash.cc:splashFloor(double)
Line
Count
Source
36
8.39M
static inline int splashFloor(SplashCoord x) {
37
#if USE_FIXEDPOINT
38
39
  //--- fixed point
40
41
  return FixedPoint::floor(x);
42
43
#elif (defined(__GNUC__) && defined(__SSE2__)) || \
44
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
45
46
  //--- SSE2 intrinsics
47
  // NB: 64-bit x86 guarantees availability of SSE2.
48
49
8.39M
  __m128d m1, m2;
50
8.39M
  int i, s;
51
52
8.39M
  m1 = _mm_set_sd(x);
53
8.39M
  i = _mm_cvttsd_si32(m1);
54
8.39M
  m2 = _mm_cvtsi32_sd(m1, i);
55
8.39M
  s = _mm_ucomigt_sd(m2, m1);
56
8.39M
  return i - s;
57
58
#elif defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__)
59
60
  //--- x87 inline assembly (gcc/clang)
61
  // (this code fails on OSX for reasons I don't understand)
62
63
  Gushort oldCW, newCW, t;
64
  int result;
65
66
  __asm__ volatile("fnstcw %0\n"
67
       "movw   %0, %3\n"
68
       "andw   $0xf3ff, %3\n"
69
       "orw    $0x0400, %3\n"
70
       "movw   %3, %1\n"       // round down
71
       "fldcw  %1\n"
72
       "fistl %2\n"
73
       "fldcw  %0\n"
74
       : "=m" (oldCW), "=m" (newCW), "=m" (result), "=r" (t)
75
       : "t" (x));
76
  return result;
77
78
#elif defined(_WIN32) && defined(_M_IX86)
79
80
  //--- x87 inline assembly (VC)
81
82
  Gushort oldCW, newCW;
83
  int result;
84
85
  __asm fld QWORD PTR x
86
  __asm fnstcw WORD PTR oldCW
87
  __asm mov ax, WORD PTR oldCW
88
  __asm and ax, 0xf3ff
89
  __asm or ax, 0x0400
90
  __asm mov WORD PTR newCW, ax     // round down
91
  __asm fldcw WORD PTR newCW
92
  __asm fistp DWORD PTR result
93
  __asm fldcw WORD PTR oldCW
94
  return result;
95
96
#else
97
98
  //--- all others
99
100
  return (int)floor(x);
101
102
#endif
103
8.39M
}
SplashClip.cc:splashFloor(double)
Line
Count
Source
36
152k
static inline int splashFloor(SplashCoord x) {
37
#if USE_FIXEDPOINT
38
39
  //--- fixed point
40
41
  return FixedPoint::floor(x);
42
43
#elif (defined(__GNUC__) && defined(__SSE2__)) || \
44
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
45
46
  //--- SSE2 intrinsics
47
  // NB: 64-bit x86 guarantees availability of SSE2.
48
49
152k
  __m128d m1, m2;
50
152k
  int i, s;
51
52
152k
  m1 = _mm_set_sd(x);
53
152k
  i = _mm_cvttsd_si32(m1);
54
152k
  m2 = _mm_cvtsi32_sd(m1, i);
55
152k
  s = _mm_ucomigt_sd(m2, m1);
56
152k
  return i - s;
57
58
#elif defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__)
59
60
  //--- x87 inline assembly (gcc/clang)
61
  // (this code fails on OSX for reasons I don't understand)
62
63
  Gushort oldCW, newCW, t;
64
  int result;
65
66
  __asm__ volatile("fnstcw %0\n"
67
       "movw   %0, %3\n"
68
       "andw   $0xf3ff, %3\n"
69
       "orw    $0x0400, %3\n"
70
       "movw   %3, %1\n"       // round down
71
       "fldcw  %1\n"
72
       "fistl %2\n"
73
       "fldcw  %0\n"
74
       : "=m" (oldCW), "=m" (newCW), "=m" (result), "=r" (t)
75
       : "t" (x));
76
  return result;
77
78
#elif defined(_WIN32) && defined(_M_IX86)
79
80
  //--- x87 inline assembly (VC)
81
82
  Gushort oldCW, newCW;
83
  int result;
84
85
  __asm fld QWORD PTR x
86
  __asm fnstcw WORD PTR oldCW
87
  __asm mov ax, WORD PTR oldCW
88
  __asm and ax, 0xf3ff
89
  __asm or ax, 0x0400
90
  __asm mov WORD PTR newCW, ax     // round down
91
  __asm fldcw WORD PTR newCW
92
  __asm fistp DWORD PTR result
93
  __asm fldcw WORD PTR oldCW
94
  return result;
95
96
#else
97
98
  //--- all others
99
100
  return (int)floor(x);
101
102
#endif
103
152k
}
Unexecuted instantiation: SplashFontEngine.cc:splashFloor(double)
Unexecuted instantiation: SplashPattern.cc:splashFloor(double)
Unexecuted instantiation: SplashState.cc:splashFloor(double)
SplashXPath.cc:splashFloor(double)
Line
Count
Source
36
32.6M
static inline int splashFloor(SplashCoord x) {
37
#if USE_FIXEDPOINT
38
39
  //--- fixed point
40
41
  return FixedPoint::floor(x);
42
43
#elif (defined(__GNUC__) && defined(__SSE2__)) || \
44
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
45
46
  //--- SSE2 intrinsics
47
  // NB: 64-bit x86 guarantees availability of SSE2.
48
49
32.6M
  __m128d m1, m2;
50
32.6M
  int i, s;
51
52
32.6M
  m1 = _mm_set_sd(x);
53
32.6M
  i = _mm_cvttsd_si32(m1);
54
32.6M
  m2 = _mm_cvtsi32_sd(m1, i);
55
32.6M
  s = _mm_ucomigt_sd(m2, m1);
56
32.6M
  return i - s;
57
58
#elif defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__)
59
60
  //--- x87 inline assembly (gcc/clang)
61
  // (this code fails on OSX for reasons I don't understand)
62
63
  Gushort oldCW, newCW, t;
64
  int result;
65
66
  __asm__ volatile("fnstcw %0\n"
67
       "movw   %0, %3\n"
68
       "andw   $0xf3ff, %3\n"
69
       "orw    $0x0400, %3\n"
70
       "movw   %3, %1\n"       // round down
71
       "fldcw  %1\n"
72
       "fistl %2\n"
73
       "fldcw  %0\n"
74
       : "=m" (oldCW), "=m" (newCW), "=m" (result), "=r" (t)
75
       : "t" (x));
76
  return result;
77
78
#elif defined(_WIN32) && defined(_M_IX86)
79
80
  //--- x87 inline assembly (VC)
81
82
  Gushort oldCW, newCW;
83
  int result;
84
85
  __asm fld QWORD PTR x
86
  __asm fnstcw WORD PTR oldCW
87
  __asm mov ax, WORD PTR oldCW
88
  __asm and ax, 0xf3ff
89
  __asm or ax, 0x0400
90
  __asm mov WORD PTR newCW, ax     // round down
91
  __asm fldcw WORD PTR newCW
92
  __asm fistp DWORD PTR result
93
  __asm fldcw WORD PTR oldCW
94
  return result;
95
96
#else
97
98
  //--- all others
99
100
  return (int)floor(x);
101
102
#endif
103
32.6M
}
SplashXPathScanner.cc:splashFloor(double)
Line
Count
Source
36
44.6M
static inline int splashFloor(SplashCoord x) {
37
#if USE_FIXEDPOINT
38
39
  //--- fixed point
40
41
  return FixedPoint::floor(x);
42
43
#elif (defined(__GNUC__) && defined(__SSE2__)) || \
44
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
45
46
  //--- SSE2 intrinsics
47
  // NB: 64-bit x86 guarantees availability of SSE2.
48
49
44.6M
  __m128d m1, m2;
50
44.6M
  int i, s;
51
52
44.6M
  m1 = _mm_set_sd(x);
53
44.6M
  i = _mm_cvttsd_si32(m1);
54
44.6M
  m2 = _mm_cvtsi32_sd(m1, i);
55
44.6M
  s = _mm_ucomigt_sd(m2, m1);
56
44.6M
  return i - s;
57
58
#elif defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__)
59
60
  //--- x87 inline assembly (gcc/clang)
61
  // (this code fails on OSX for reasons I don't understand)
62
63
  Gushort oldCW, newCW, t;
64
  int result;
65
66
  __asm__ volatile("fnstcw %0\n"
67
       "movw   %0, %3\n"
68
       "andw   $0xf3ff, %3\n"
69
       "orw    $0x0400, %3\n"
70
       "movw   %3, %1\n"       // round down
71
       "fldcw  %1\n"
72
       "fistl %2\n"
73
       "fldcw  %0\n"
74
       : "=m" (oldCW), "=m" (newCW), "=m" (result), "=r" (t)
75
       : "t" (x));
76
  return result;
77
78
#elif defined(_WIN32) && defined(_M_IX86)
79
80
  //--- x87 inline assembly (VC)
81
82
  Gushort oldCW, newCW;
83
  int result;
84
85
  __asm fld QWORD PTR x
86
  __asm fnstcw WORD PTR oldCW
87
  __asm mov ax, WORD PTR oldCW
88
  __asm and ax, 0xf3ff
89
  __asm or ax, 0x0400
90
  __asm mov WORD PTR newCW, ax     // round down
91
  __asm fldcw WORD PTR newCW
92
  __asm fistp DWORD PTR result
93
  __asm fldcw WORD PTR oldCW
94
  return result;
95
96
#else
97
98
  //--- all others
99
100
  return (int)floor(x);
101
102
#endif
103
44.6M
}
Unexecuted instantiation: ShadingImage.cc:splashFloor(double)
Unexecuted instantiation: SplashFTFontFile.cc:splashFloor(double)
Unexecuted instantiation: SplashFont.cc:splashFloor(double)
SplashScreen.cc:splashFloor(double)
Line
Count
Source
36
21.4M
static inline int splashFloor(SplashCoord x) {
37
#if USE_FIXEDPOINT
38
39
  //--- fixed point
40
41
  return FixedPoint::floor(x);
42
43
#elif (defined(__GNUC__) && defined(__SSE2__)) || \
44
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
45
46
  //--- SSE2 intrinsics
47
  // NB: 64-bit x86 guarantees availability of SSE2.
48
49
21.4M
  __m128d m1, m2;
50
21.4M
  int i, s;
51
52
21.4M
  m1 = _mm_set_sd(x);
53
21.4M
  i = _mm_cvttsd_si32(m1);
54
21.4M
  m2 = _mm_cvtsi32_sd(m1, i);
55
21.4M
  s = _mm_ucomigt_sd(m2, m1);
56
21.4M
  return i - s;
57
58
#elif defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__)
59
60
  //--- x87 inline assembly (gcc/clang)
61
  // (this code fails on OSX for reasons I don't understand)
62
63
  Gushort oldCW, newCW, t;
64
  int result;
65
66
  __asm__ volatile("fnstcw %0\n"
67
       "movw   %0, %3\n"
68
       "andw   $0xf3ff, %3\n"
69
       "orw    $0x0400, %3\n"
70
       "movw   %3, %1\n"       // round down
71
       "fldcw  %1\n"
72
       "fistl %2\n"
73
       "fldcw  %0\n"
74
       : "=m" (oldCW), "=m" (newCW), "=m" (result), "=r" (t)
75
       : "t" (x));
76
  return result;
77
78
#elif defined(_WIN32) && defined(_M_IX86)
79
80
  //--- x87 inline assembly (VC)
81
82
  Gushort oldCW, newCW;
83
  int result;
84
85
  __asm fld QWORD PTR x
86
  __asm fnstcw WORD PTR oldCW
87
  __asm mov ax, WORD PTR oldCW
88
  __asm and ax, 0xf3ff
89
  __asm or ax, 0x0400
90
  __asm mov WORD PTR newCW, ax     // round down
91
  __asm fldcw WORD PTR newCW
92
  __asm fistp DWORD PTR result
93
  __asm fldcw WORD PTR oldCW
94
  return result;
95
96
#else
97
98
  //--- all others
99
100
  return (int)floor(x);
101
102
#endif
103
21.4M
}
SplashFTFont.cc:splashFloor(double)
Line
Count
Source
36
8.27k
static inline int splashFloor(SplashCoord x) {
37
#if USE_FIXEDPOINT
38
39
  //--- fixed point
40
41
  return FixedPoint::floor(x);
42
43
#elif (defined(__GNUC__) && defined(__SSE2__)) || \
44
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
45
46
  //--- SSE2 intrinsics
47
  // NB: 64-bit x86 guarantees availability of SSE2.
48
49
8.27k
  __m128d m1, m2;
50
8.27k
  int i, s;
51
52
8.27k
  m1 = _mm_set_sd(x);
53
8.27k
  i = _mm_cvttsd_si32(m1);
54
8.27k
  m2 = _mm_cvtsi32_sd(m1, i);
55
8.27k
  s = _mm_ucomigt_sd(m2, m1);
56
8.27k
  return i - s;
57
58
#elif defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__)
59
60
  //--- x87 inline assembly (gcc/clang)
61
  // (this code fails on OSX for reasons I don't understand)
62
63
  Gushort oldCW, newCW, t;
64
  int result;
65
66
  __asm__ volatile("fnstcw %0\n"
67
       "movw   %0, %3\n"
68
       "andw   $0xf3ff, %3\n"
69
       "orw    $0x0400, %3\n"
70
       "movw   %3, %1\n"       // round down
71
       "fldcw  %1\n"
72
       "fistl %2\n"
73
       "fldcw  %0\n"
74
       : "=m" (oldCW), "=m" (newCW), "=m" (result), "=r" (t)
75
       : "t" (x));
76
  return result;
77
78
#elif defined(_WIN32) && defined(_M_IX86)
79
80
  //--- x87 inline assembly (VC)
81
82
  Gushort oldCW, newCW;
83
  int result;
84
85
  __asm fld QWORD PTR x
86
  __asm fnstcw WORD PTR oldCW
87
  __asm mov ax, WORD PTR oldCW
88
  __asm and ax, 0xf3ff
89
  __asm or ax, 0x0400
90
  __asm mov WORD PTR newCW, ax     // round down
91
  __asm fldcw WORD PTR newCW
92
  __asm fistp DWORD PTR result
93
  __asm fldcw WORD PTR oldCW
94
  return result;
95
96
#else
97
98
  //--- all others
99
100
  return (int)floor(x);
101
102
#endif
103
8.27k
}
Unexecuted instantiation: fuzz_JBIG2.cc:splashFloor(double)
104
105
// ceil() and (int)() are implemented separately, which results
106
// in changing the FPCW multiple times - so we optimize it with
107
// some inline assembly or SSE intrinsics.
108
306k
static inline int splashCeil(SplashCoord x) {
109
#if USE_FIXEDPOINT
110
111
  //--- fixed point
112
113
  return FixedPoint::ceil(x);
114
115
#elif (defined(__GNUC__) && defined(__SSE2__)) || \
116
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
117
118
  //--- SSE2 intrinsics
119
  // NB: 64-bit x86 guarantees availability of SSE2.
120
121
306k
  __m128d m1, m2;
122
306k
  int i, s;
123
124
306k
  m1 = _mm_set_sd(x);
125
306k
  i = _mm_cvttsd_si32(m1);
126
306k
  m2 = _mm_cvtsi32_sd(m1, i);
127
306k
  s = _mm_ucomilt_sd(m2, m1);
128
306k
  return i + s;
129
130
#elif defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__)
131
132
  //--- x87 inline assembly (gcc/clang)
133
  // (this code fails on OSX for reasons I don't understand)
134
135
  Gushort oldCW, newCW, t;
136
  int result;
137
138
  __asm__ volatile("fnstcw %0\n"
139
       "movw   %0, %3\n"
140
       "andw   $0xf3ff, %3\n"
141
       "orw    $0x0800, %3\n"
142
       "movw   %3, %1\n"       // round up
143
       "fldcw  %1\n"
144
       "fistl %2\n"
145
       "fldcw  %0\n"
146
       : "=m" (oldCW), "=m" (newCW), "=m" (result), "=r" (t)
147
       : "t" (x));
148
  return result;
149
150
#elif defined(_WIN32) && defined(_M_IX86)
151
152
  //--- x87 inline assembly (VC)
153
154
  // ceil() and (int)() are implemented separately, which results
155
  // in changing the FPCW multiple times - so we optimize it with
156
  // some inline assembly
157
  Gushort oldCW, newCW;
158
  int result;
159
160
  __asm fld QWORD PTR x
161
  __asm fnstcw WORD PTR oldCW
162
  __asm mov ax, WORD PTR oldCW
163
  __asm and ax, 0xf3ff
164
  __asm or ax, 0x0800
165
  __asm mov WORD PTR newCW, ax     // round up
166
  __asm fldcw WORD PTR newCW
167
  __asm fistp DWORD PTR result
168
  __asm fldcw WORD PTR oldCW
169
  return result;
170
171
#else
172
173
  //--- all others
174
175
  return (int)ceil(x);
176
177
#endif
178
306k
}
Unexecuted instantiation: fuzz_pdfload.cc:splashCeil(double)
Unexecuted instantiation: SplashOutputDev.cc:splashCeil(double)
Splash.cc:splashCeil(double)
Line
Count
Source
108
282
static inline int splashCeil(SplashCoord x) {
109
#if USE_FIXEDPOINT
110
111
  //--- fixed point
112
113
  return FixedPoint::ceil(x);
114
115
#elif (defined(__GNUC__) && defined(__SSE2__)) || \
116
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
117
118
  //--- SSE2 intrinsics
119
  // NB: 64-bit x86 guarantees availability of SSE2.
120
121
282
  __m128d m1, m2;
122
282
  int i, s;
123
124
282
  m1 = _mm_set_sd(x);
125
282
  i = _mm_cvttsd_si32(m1);
126
282
  m2 = _mm_cvtsi32_sd(m1, i);
127
282
  s = _mm_ucomilt_sd(m2, m1);
128
282
  return i + s;
129
130
#elif defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__)
131
132
  //--- x87 inline assembly (gcc/clang)
133
  // (this code fails on OSX for reasons I don't understand)
134
135
  Gushort oldCW, newCW, t;
136
  int result;
137
138
  __asm__ volatile("fnstcw %0\n"
139
       "movw   %0, %3\n"
140
       "andw   $0xf3ff, %3\n"
141
       "orw    $0x0800, %3\n"
142
       "movw   %3, %1\n"       // round up
143
       "fldcw  %1\n"
144
       "fistl %2\n"
145
       "fldcw  %0\n"
146
       : "=m" (oldCW), "=m" (newCW), "=m" (result), "=r" (t)
147
       : "t" (x));
148
  return result;
149
150
#elif defined(_WIN32) && defined(_M_IX86)
151
152
  //--- x87 inline assembly (VC)
153
154
  // ceil() and (int)() are implemented separately, which results
155
  // in changing the FPCW multiple times - so we optimize it with
156
  // some inline assembly
157
  Gushort oldCW, newCW;
158
  int result;
159
160
  __asm fld QWORD PTR x
161
  __asm fnstcw WORD PTR oldCW
162
  __asm mov ax, WORD PTR oldCW
163
  __asm and ax, 0xf3ff
164
  __asm or ax, 0x0800
165
  __asm mov WORD PTR newCW, ax     // round up
166
  __asm fldcw WORD PTR newCW
167
  __asm fistp DWORD PTR result
168
  __asm fldcw WORD PTR oldCW
169
  return result;
170
171
#else
172
173
  //--- all others
174
175
  return (int)ceil(x);
176
177
#endif
178
282
}
SplashClip.cc:splashCeil(double)
Line
Count
Source
108
285k
static inline int splashCeil(SplashCoord x) {
109
#if USE_FIXEDPOINT
110
111
  //--- fixed point
112
113
  return FixedPoint::ceil(x);
114
115
#elif (defined(__GNUC__) && defined(__SSE2__)) || \
116
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
117
118
  //--- SSE2 intrinsics
119
  // NB: 64-bit x86 guarantees availability of SSE2.
120
121
285k
  __m128d m1, m2;
122
285k
  int i, s;
123
124
285k
  m1 = _mm_set_sd(x);
125
285k
  i = _mm_cvttsd_si32(m1);
126
285k
  m2 = _mm_cvtsi32_sd(m1, i);
127
285k
  s = _mm_ucomilt_sd(m2, m1);
128
285k
  return i + s;
129
130
#elif defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__)
131
132
  //--- x87 inline assembly (gcc/clang)
133
  // (this code fails on OSX for reasons I don't understand)
134
135
  Gushort oldCW, newCW, t;
136
  int result;
137
138
  __asm__ volatile("fnstcw %0\n"
139
       "movw   %0, %3\n"
140
       "andw   $0xf3ff, %3\n"
141
       "orw    $0x0800, %3\n"
142
       "movw   %3, %1\n"       // round up
143
       "fldcw  %1\n"
144
       "fistl %2\n"
145
       "fldcw  %0\n"
146
       : "=m" (oldCW), "=m" (newCW), "=m" (result), "=r" (t)
147
       : "t" (x));
148
  return result;
149
150
#elif defined(_WIN32) && defined(_M_IX86)
151
152
  //--- x87 inline assembly (VC)
153
154
  // ceil() and (int)() are implemented separately, which results
155
  // in changing the FPCW multiple times - so we optimize it with
156
  // some inline assembly
157
  Gushort oldCW, newCW;
158
  int result;
159
160
  __asm fld QWORD PTR x
161
  __asm fnstcw WORD PTR oldCW
162
  __asm mov ax, WORD PTR oldCW
163
  __asm and ax, 0xf3ff
164
  __asm or ax, 0x0800
165
  __asm mov WORD PTR newCW, ax     // round up
166
  __asm fldcw WORD PTR newCW
167
  __asm fistp DWORD PTR result
168
  __asm fldcw WORD PTR oldCW
169
  return result;
170
171
#else
172
173
  //--- all others
174
175
  return (int)ceil(x);
176
177
#endif
178
285k
}
Unexecuted instantiation: SplashFontEngine.cc:splashCeil(double)
Unexecuted instantiation: SplashPattern.cc:splashCeil(double)
Unexecuted instantiation: SplashState.cc:splashCeil(double)
Unexecuted instantiation: SplashXPath.cc:splashCeil(double)
SplashXPathScanner.cc:splashCeil(double)
Line
Count
Source
108
19.8k
static inline int splashCeil(SplashCoord x) {
109
#if USE_FIXEDPOINT
110
111
  //--- fixed point
112
113
  return FixedPoint::ceil(x);
114
115
#elif (defined(__GNUC__) && defined(__SSE2__)) || \
116
      (defined(_WIN32) && (_M_IX86_FP == 2 || defined(_M_X64)))
117
118
  //--- SSE2 intrinsics
119
  // NB: 64-bit x86 guarantees availability of SSE2.
120
121
19.8k
  __m128d m1, m2;
122
19.8k
  int i, s;
123
124
19.8k
  m1 = _mm_set_sd(x);
125
19.8k
  i = _mm_cvttsd_si32(m1);
126
19.8k
  m2 = _mm_cvtsi32_sd(m1, i);
127
19.8k
  s = _mm_ucomilt_sd(m2, m1);
128
19.8k
  return i + s;
129
130
#elif defined(__GNUC__) && defined(__i386__) && !defined(__APPLE__)
131
132
  //--- x87 inline assembly (gcc/clang)
133
  // (this code fails on OSX for reasons I don't understand)
134
135
  Gushort oldCW, newCW, t;
136
  int result;
137
138
  __asm__ volatile("fnstcw %0\n"
139
       "movw   %0, %3\n"
140
       "andw   $0xf3ff, %3\n"
141
       "orw    $0x0800, %3\n"
142
       "movw   %3, %1\n"       // round up
143
       "fldcw  %1\n"
144
       "fistl %2\n"
145
       "fldcw  %0\n"
146
       : "=m" (oldCW), "=m" (newCW), "=m" (result), "=r" (t)
147
       : "t" (x));
148
  return result;
149
150
#elif defined(_WIN32) && defined(_M_IX86)
151
152
  //--- x87 inline assembly (VC)
153
154
  // ceil() and (int)() are implemented separately, which results
155
  // in changing the FPCW multiple times - so we optimize it with
156
  // some inline assembly
157
  Gushort oldCW, newCW;
158
  int result;
159
160
  __asm fld QWORD PTR x
161
  __asm fnstcw WORD PTR oldCW
162
  __asm mov ax, WORD PTR oldCW
163
  __asm and ax, 0xf3ff
164
  __asm or ax, 0x0800
165
  __asm mov WORD PTR newCW, ax     // round up
166
  __asm fldcw WORD PTR newCW
167
  __asm fistp DWORD PTR result
168
  __asm fldcw WORD PTR oldCW
169
  return result;
170
171
#else
172
173
  //--- all others
174
175
  return (int)ceil(x);
176
177
#endif
178
19.8k
}
Unexecuted instantiation: ShadingImage.cc:splashCeil(double)
Unexecuted instantiation: SplashFTFontFile.cc:splashCeil(double)
Unexecuted instantiation: SplashFont.cc:splashCeil(double)
Unexecuted instantiation: SplashScreen.cc:splashCeil(double)
Unexecuted instantiation: SplashFTFont.cc:splashCeil(double)
Unexecuted instantiation: fuzz_JBIG2.cc:splashCeil(double)
179
180
53.3M
static inline int splashRound(SplashCoord x) {
181
#if USE_FIXEDPOINT
182
183
  //--- fixed point
184
185
  return FixedPoint::round(x);
186
187
#else
188
189
  //--- all others
190
191
53.3M
  return splashFloor(x + 0.5);
192
193
53.3M
#endif
194
53.3M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashRound(double)
Unexecuted instantiation: SplashOutputDev.cc:splashRound(double)
Splash.cc:splashRound(double)
Line
Count
Source
180
293k
static inline int splashRound(SplashCoord x) {
181
#if USE_FIXEDPOINT
182
183
  //--- fixed point
184
185
  return FixedPoint::round(x);
186
187
#else
188
189
  //--- all others
190
191
293k
  return splashFloor(x + 0.5);
192
193
293k
#endif
194
293k
}
SplashClip.cc:splashRound(double)
Line
Count
Source
180
57.0k
static inline int splashRound(SplashCoord x) {
181
#if USE_FIXEDPOINT
182
183
  //--- fixed point
184
185
  return FixedPoint::round(x);
186
187
#else
188
189
  //--- all others
190
191
57.0k
  return splashFloor(x + 0.5);
192
193
57.0k
#endif
194
57.0k
}
Unexecuted instantiation: SplashFontEngine.cc:splashRound(double)
Unexecuted instantiation: SplashPattern.cc:splashRound(double)
Unexecuted instantiation: SplashState.cc:splashRound(double)
SplashXPath.cc:splashRound(double)
Line
Count
Source
180
31.5M
static inline int splashRound(SplashCoord x) {
181
#if USE_FIXEDPOINT
182
183
  //--- fixed point
184
185
  return FixedPoint::round(x);
186
187
#else
188
189
  //--- all others
190
191
31.5M
  return splashFloor(x + 0.5);
192
193
31.5M
#endif
194
31.5M
}
Unexecuted instantiation: SplashXPathScanner.cc:splashRound(double)
Unexecuted instantiation: ShadingImage.cc:splashRound(double)
Unexecuted instantiation: SplashFTFontFile.cc:splashRound(double)
Unexecuted instantiation: SplashFont.cc:splashRound(double)
SplashScreen.cc:splashRound(double)
Line
Count
Source
180
21.4M
static inline int splashRound(SplashCoord x) {
181
#if USE_FIXEDPOINT
182
183
  //--- fixed point
184
185
  return FixedPoint::round(x);
186
187
#else
188
189
  //--- all others
190
191
21.4M
  return splashFloor(x + 0.5);
192
193
21.4M
#endif
194
21.4M
}
SplashFTFont.cc:splashRound(double)
Line
Count
Source
180
8.27k
static inline int splashRound(SplashCoord x) {
181
#if USE_FIXEDPOINT
182
183
  //--- fixed point
184
185
  return FixedPoint::round(x);
186
187
#else
188
189
  //--- all others
190
191
8.27k
  return splashFloor(x + 0.5);
192
193
8.27k
#endif
194
8.27k
}
Unexecuted instantiation: fuzz_JBIG2.cc:splashRound(double)
195
196
85.4M
static inline SplashCoord splashAvg(SplashCoord x, SplashCoord y) {
197
#if USE_FIXEDPOINT
198
  return FixedPoint::avg(x, y);
199
#else
200
85.4M
  return 0.5 * (x + y);
201
85.4M
#endif
202
85.4M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashAvg(double, double)
Unexecuted instantiation: SplashOutputDev.cc:splashAvg(double, double)
Splash.cc:splashAvg(double, double)
Line
Count
Source
196
85.4M
static inline SplashCoord splashAvg(SplashCoord x, SplashCoord y) {
197
#if USE_FIXEDPOINT
198
  return FixedPoint::avg(x, y);
199
#else
200
85.4M
  return 0.5 * (x + y);
201
85.4M
#endif
202
85.4M
}
Unexecuted instantiation: SplashClip.cc:splashAvg(double, double)
Unexecuted instantiation: SplashFontEngine.cc:splashAvg(double, double)
Unexecuted instantiation: SplashPattern.cc:splashAvg(double, double)
Unexecuted instantiation: SplashState.cc:splashAvg(double, double)
Unexecuted instantiation: SplashXPath.cc:splashAvg(double, double)
Unexecuted instantiation: SplashXPathScanner.cc:splashAvg(double, double)
Unexecuted instantiation: ShadingImage.cc:splashAvg(double, double)
Unexecuted instantiation: SplashFTFontFile.cc:splashAvg(double, double)
Unexecuted instantiation: SplashFont.cc:splashAvg(double, double)
Unexecuted instantiation: SplashScreen.cc:splashAvg(double, double)
Unexecuted instantiation: SplashFTFont.cc:splashAvg(double, double)
Unexecuted instantiation: fuzz_JBIG2.cc:splashAvg(double, double)
203
204
10.3M
static inline SplashCoord splashSqrt(SplashCoord x) {
205
#if USE_FIXEDPOINT
206
  return FixedPoint::sqrt(x);
207
#else
208
10.3M
  return sqrt(x);
209
10.3M
#endif
210
10.3M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashSqrt(double)
Unexecuted instantiation: SplashOutputDev.cc:splashSqrt(double)
Splash.cc:splashSqrt(double)
Line
Count
Source
204
10.3M
static inline SplashCoord splashSqrt(SplashCoord x) {
205
#if USE_FIXEDPOINT
206
  return FixedPoint::sqrt(x);
207
#else
208
10.3M
  return sqrt(x);
209
10.3M
#endif
210
10.3M
}
Unexecuted instantiation: SplashClip.cc:splashSqrt(double)
Unexecuted instantiation: SplashFontEngine.cc:splashSqrt(double)
Unexecuted instantiation: SplashPattern.cc:splashSqrt(double)
Unexecuted instantiation: SplashState.cc:splashSqrt(double)
Unexecuted instantiation: SplashXPath.cc:splashSqrt(double)
Unexecuted instantiation: SplashXPathScanner.cc:splashSqrt(double)
Unexecuted instantiation: ShadingImage.cc:splashSqrt(double)
Unexecuted instantiation: SplashFTFontFile.cc:splashSqrt(double)
Unexecuted instantiation: SplashFont.cc:splashSqrt(double)
Unexecuted instantiation: SplashScreen.cc:splashSqrt(double)
Unexecuted instantiation: SplashFTFont.cc:splashSqrt(double)
Unexecuted instantiation: fuzz_JBIG2.cc:splashSqrt(double)
211
212
20.7M
static inline SplashCoord splashPow(SplashCoord x, SplashCoord y) {
213
#if USE_FIXEDPOINT
214
  return FixedPoint::pow(x, y);
215
#else
216
20.7M
  return pow(x, y);
217
20.7M
#endif
218
20.7M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashPow(double, double)
Unexecuted instantiation: SplashOutputDev.cc:splashPow(double, double)
Unexecuted instantiation: Splash.cc:splashPow(double, double)
Unexecuted instantiation: SplashClip.cc:splashPow(double, double)
Unexecuted instantiation: SplashFontEngine.cc:splashPow(double, double)
Unexecuted instantiation: SplashPattern.cc:splashPow(double, double)
Unexecuted instantiation: SplashState.cc:splashPow(double, double)
Unexecuted instantiation: SplashXPath.cc:splashPow(double, double)
Unexecuted instantiation: SplashXPathScanner.cc:splashPow(double, double)
Unexecuted instantiation: ShadingImage.cc:splashPow(double, double)
Unexecuted instantiation: SplashFTFontFile.cc:splashPow(double, double)
Unexecuted instantiation: SplashFont.cc:splashPow(double, double)
SplashScreen.cc:splashPow(double, double)
Line
Count
Source
212
20.7M
static inline SplashCoord splashPow(SplashCoord x, SplashCoord y) {
213
#if USE_FIXEDPOINT
214
  return FixedPoint::pow(x, y);
215
#else
216
20.7M
  return pow(x, y);
217
20.7M
#endif
218
20.7M
}
Unexecuted instantiation: SplashFTFont.cc:splashPow(double, double)
Unexecuted instantiation: fuzz_JBIG2.cc:splashPow(double, double)
219
220
static inline SplashCoord splashDist(SplashCoord x0, SplashCoord y0,
221
14.1M
             SplashCoord x1, SplashCoord y1) {
222
14.1M
  SplashCoord dx, dy;
223
14.1M
  dx = x1 - x0;
224
14.1M
  dy = y1 - y0;
225
#if USE_FIXEDPOINT
226
  // this handles the situation where dx*dx or dy*dy is too large to
227
  // fit in the 16.16 fixed point format
228
  SplashCoord dxa, dya, d;
229
  dxa = splashAbs(dx);
230
  dya = splashAbs(dy);
231
  if (dxa == 0 && dya == 0) {
232
    return 0;
233
  } else if (dxa > dya) {
234
    d = dya / dxa;
235
    return dxa * FixedPoint::sqrt(d*d + 1);
236
  } else {
237
    d = dxa / dya;
238
    return dya * FixedPoint::sqrt(d*d + 1);
239
  }
240
#else
241
14.1M
  return sqrt(dx * dx + dy * dy);
242
14.1M
#endif
243
14.1M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashDist(double, double, double, double)
Unexecuted instantiation: SplashOutputDev.cc:splashDist(double, double, double, double)
Splash.cc:splashDist(double, double, double, double)
Line
Count
Source
221
14.1M
             SplashCoord x1, SplashCoord y1) {
222
14.1M
  SplashCoord dx, dy;
223
14.1M
  dx = x1 - x0;
224
14.1M
  dy = y1 - y0;
225
#if USE_FIXEDPOINT
226
  // this handles the situation where dx*dx or dy*dy is too large to
227
  // fit in the 16.16 fixed point format
228
  SplashCoord dxa, dya, d;
229
  dxa = splashAbs(dx);
230
  dya = splashAbs(dy);
231
  if (dxa == 0 && dya == 0) {
232
    return 0;
233
  } else if (dxa > dya) {
234
    d = dya / dxa;
235
    return dxa * FixedPoint::sqrt(d*d + 1);
236
  } else {
237
    d = dxa / dya;
238
    return dya * FixedPoint::sqrt(d*d + 1);
239
  }
240
#else
241
14.1M
  return sqrt(dx * dx + dy * dy);
242
14.1M
#endif
243
14.1M
}
Unexecuted instantiation: SplashClip.cc:splashDist(double, double, double, double)
Unexecuted instantiation: SplashFontEngine.cc:splashDist(double, double, double, double)
Unexecuted instantiation: SplashPattern.cc:splashDist(double, double, double, double)
Unexecuted instantiation: SplashState.cc:splashDist(double, double, double, double)
Unexecuted instantiation: SplashXPath.cc:splashDist(double, double, double, double)
Unexecuted instantiation: SplashXPathScanner.cc:splashDist(double, double, double, double)
Unexecuted instantiation: ShadingImage.cc:splashDist(double, double, double, double)
Unexecuted instantiation: SplashFTFontFile.cc:splashDist(double, double, double, double)
Unexecuted instantiation: SplashFont.cc:splashDist(double, double, double, double)
Unexecuted instantiation: SplashScreen.cc:splashDist(double, double, double, double)
SplashFTFont.cc:splashDist(double, double, double, double)
Line
Count
Source
221
16.3k
             SplashCoord x1, SplashCoord y1) {
222
16.3k
  SplashCoord dx, dy;
223
16.3k
  dx = x1 - x0;
224
16.3k
  dy = y1 - y0;
225
#if USE_FIXEDPOINT
226
  // this handles the situation where dx*dx or dy*dy is too large to
227
  // fit in the 16.16 fixed point format
228
  SplashCoord dxa, dya, d;
229
  dxa = splashAbs(dx);
230
  dya = splashAbs(dy);
231
  if (dxa == 0 && dya == 0) {
232
    return 0;
233
  } else if (dxa > dya) {
234
    d = dya / dxa;
235
    return dxa * FixedPoint::sqrt(d*d + 1);
236
  } else {
237
    d = dxa / dya;
238
    return dya * FixedPoint::sqrt(d*d + 1);
239
  }
240
#else
241
16.3k
  return sqrt(dx * dx + dy * dy);
242
16.3k
#endif
243
16.3k
}
Unexecuted instantiation: fuzz_JBIG2.cc:splashDist(double, double, double, double)
244
245
static inline GBool splashCheckDet(SplashCoord m11, SplashCoord m12,
246
           SplashCoord m21, SplashCoord m22,
247
108k
           SplashCoord epsilon) {
248
#if USE_FIXEDPOINT
249
  return FixedPoint::checkDet(m11, m12, m21, m22, epsilon);
250
#else
251
108k
  return fabs(m11 * m22 - m12 * m21) >= epsilon;
252
108k
#endif
253
108k
}
Unexecuted instantiation: fuzz_pdfload.cc:splashCheckDet(double, double, double, double, double)
Unexecuted instantiation: SplashOutputDev.cc:splashCheckDet(double, double, double, double, double)
Splash.cc:splashCheckDet(double, double, double, double, double)
Line
Count
Source
247
65.3k
           SplashCoord epsilon) {
248
#if USE_FIXEDPOINT
249
  return FixedPoint::checkDet(m11, m12, m21, m22, epsilon);
250
#else
251
65.3k
  return fabs(m11 * m22 - m12 * m21) >= epsilon;
252
65.3k
#endif
253
65.3k
}
Unexecuted instantiation: SplashClip.cc:splashCheckDet(double, double, double, double, double)
SplashFontEngine.cc:splashCheckDet(double, double, double, double, double)
Line
Count
Source
247
43.3k
           SplashCoord epsilon) {
248
#if USE_FIXEDPOINT
249
  return FixedPoint::checkDet(m11, m12, m21, m22, epsilon);
250
#else
251
43.3k
  return fabs(m11 * m22 - m12 * m21) >= epsilon;
252
43.3k
#endif
253
43.3k
}
Unexecuted instantiation: SplashPattern.cc:splashCheckDet(double, double, double, double, double)
Unexecuted instantiation: SplashState.cc:splashCheckDet(double, double, double, double, double)
Unexecuted instantiation: SplashXPath.cc:splashCheckDet(double, double, double, double, double)
Unexecuted instantiation: SplashXPathScanner.cc:splashCheckDet(double, double, double, double, double)
Unexecuted instantiation: ShadingImage.cc:splashCheckDet(double, double, double, double, double)
Unexecuted instantiation: SplashFTFontFile.cc:splashCheckDet(double, double, double, double, double)
Unexecuted instantiation: SplashFont.cc:splashCheckDet(double, double, double, double, double)
Unexecuted instantiation: SplashScreen.cc:splashCheckDet(double, double, double, double, double)
Unexecuted instantiation: SplashFTFont.cc:splashCheckDet(double, double, double, double, double)
Unexecuted instantiation: fuzz_JBIG2.cc:splashCheckDet(double, double, double, double, double)
254
255
// Perform stroke adjustment on a SplashCoord range [xMin, xMax),
256
// resulting in an int range [*xMinI, *xMaxI).
257
//
258
// There are several options:
259
//
260
// 1. Round both edge coordinates.
261
//    Pro: adjacent strokes/fills line up without any gaps or
262
//         overlaps
263
//    Con: lines with the same original floating point width can
264
//         end up with different integer widths, e.g.:
265
//               xMin  = 10.1   xMax  = 11.3   (width = 1.2)
266
//           --> xMinI = 10     xMaxI = 11     (width = 1)
267
//         but
268
//               xMin  = 10.4   xMax  = 11.6   (width = 1.2)
269
//           --> xMinI = 10     xMaxI = 12     (width = 2)
270
//
271
// 2. Round the min coordinate; add the ceiling of the width.
272
//    Pro: lines with the same original floating point width will
273
//         always end up with the same integer width
274
//    Con: adjacent strokes/fills can have overlaps (which is
275
//         problematic with transparency)
276
//    (This could use floor on the min coordinate, instead of
277
//    rounding, with similar results.)
278
//    (If the width is rounded instead of using ceiling, the results
279
//    Are similar, except that adjacent strokes/fills can have gaps
280
//    as well as overlaps.)
281
//
282
// 3. Use floor on the min coordinate and ceiling on the max
283
//    coordinate.
284
//    Pro: lines always end up at least as wide as the original
285
//         floating point width
286
//    Con: adjacent strokes/fills can have overlaps, and lines with
287
//         the same original floating point width can end up with
288
//         different integer widths; the integer width can be more
289
//         than one pixel wider than the original width, e.g.:
290
//               xMin  = 10.9   xMax  = 12.1   (width = 1.2)
291
//           --> xMinI = 10     xMaxI = 13     (width = 3)
292
//         but
293
//               xMin  = 10.1   xMax  = 11.3   (width = 1.2)
294
//           --> xMinI = 10     xMaxI = 12     (width = 2)
295
//
296
// 4. Use a hybrid approach, choosing between two of the above
297
//    options, based on width.  E.g., use #2 if width <= 4, and use #1
298
//    if width > 4.
299
//
300
// If w >= 0 and strokeAdjMode is splashStrokeAdjustCAD then a special
301
// mode for projecting line caps is enabled, with w being the
302
// transformed line width.
303
304
static inline void splashStrokeAdjust(SplashCoord xMin, SplashCoord xMax,
305
              int *xMinI, int *xMaxI,
306
              SplashStrokeAdjustMode strokeAdjMode,
307
15.8M
              SplashCoord w = -1) {
308
15.8M
  int x0, x1;
309
310
  // make sure the coords fit in 32-bit ints
311
#if USE_FIXEDPOINT
312
  if (xMin < -32767) {
313
    xMin = -32767;
314
  } else if (xMin > 32767) {
315
    xMin = 32767;
316
  }
317
  if (xMax < -32767) {
318
    xMax = -32767;
319
  } else if (xMax > 32767) {
320
    xMax = 32767;
321
  }
322
#else
323
15.8M
  if (xMin < -1e9) {
324
25.0k
    xMin = -1e9;
325
15.8M
  } else if (xMin > 1e9) {
326
24.9k
    xMin = 1e9;
327
24.9k
  }
328
15.8M
  if (xMax < -1e9) {
329
17.6k
    xMax = -1e9;
330
15.8M
  } else if (xMax > 1e9) {
331
37.9k
    xMax = 1e9;
332
37.9k
  }
333
15.8M
#endif
334
335
  // this will never be called with strokeAdjMode == splashStrokeAdjustOff
336
15.8M
  if (strokeAdjMode == splashStrokeAdjustCAD) {
337
0
    x0 = splashRound(xMin);
338
0
    if (w >= 0) {
339
0
      x1 = splashRound(xMax - w) + splashRound(w);
340
0
    } else {
341
0
      x1 = x0 + splashRound(xMax - xMin);
342
0
    }
343
15.8M
  } else {
344
    // NB: enable exactly one of these.
345
15.8M
#if 1 // 1. Round both edge coordinates.
346
15.8M
    x0 = splashRound(xMin);
347
15.8M
    x1 = splashRound(xMax);
348
15.8M
#endif
349
#if 0 // 2. Round the min coordinate; add the ceiling of the width.
350
    x0 = splashRound(xMin);
351
    x1 = x0 + splashCeil(xMax - xMin);
352
#endif
353
#if 0 // 3. Use floor on the min coord and ceiling on the max coord.
354
    x0 = splashFloor(xMin);
355
    x1 = splashCeil(xMax);
356
#endif
357
#if 0 // 4. Hybrid.
358
    SplashCoord w = xMax - xMin;
359
    x0 = splashRound(xMin);
360
    if (w > 4) {
361
      x1 = splashRound(xMax);
362
    } else {
363
      x1 = x0 + splashRound(w);
364
    }
365
#endif
366
15.8M
  }
367
15.8M
  if (x0 == x1) {
368
14.9M
    if (xMin + xMax < 2 * x0) {
369
57
      --x0;
370
14.9M
    } else {
371
14.9M
      ++x1;
372
14.9M
    }
373
14.9M
  }
374
15.8M
  *xMinI = x0;
375
15.8M
  *xMaxI = x1;
376
15.8M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Unexecuted instantiation: SplashOutputDev.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Splash.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Line
Count
Source
307
64.8k
              SplashCoord w = -1) {
308
64.8k
  int x0, x1;
309
310
  // make sure the coords fit in 32-bit ints
311
#if USE_FIXEDPOINT
312
  if (xMin < -32767) {
313
    xMin = -32767;
314
  } else if (xMin > 32767) {
315
    xMin = 32767;
316
  }
317
  if (xMax < -32767) {
318
    xMax = -32767;
319
  } else if (xMax > 32767) {
320
    xMax = 32767;
321
  }
322
#else
323
64.8k
  if (xMin < -1e9) {
324
25.0k
    xMin = -1e9;
325
39.8k
  } else if (xMin > 1e9) {
326
24.9k
    xMin = 1e9;
327
24.9k
  }
328
64.8k
  if (xMax < -1e9) {
329
17.6k
    xMax = -1e9;
330
47.2k
  } else if (xMax > 1e9) {
331
37.9k
    xMax = 1e9;
332
37.9k
  }
333
64.8k
#endif
334
335
  // this will never be called with strokeAdjMode == splashStrokeAdjustOff
336
64.8k
  if (strokeAdjMode == splashStrokeAdjustCAD) {
337
0
    x0 = splashRound(xMin);
338
0
    if (w >= 0) {
339
0
      x1 = splashRound(xMax - w) + splashRound(w);
340
0
    } else {
341
0
      x1 = x0 + splashRound(xMax - xMin);
342
0
    }
343
64.8k
  } else {
344
    // NB: enable exactly one of these.
345
64.8k
#if 1 // 1. Round both edge coordinates.
346
64.8k
    x0 = splashRound(xMin);
347
64.8k
    x1 = splashRound(xMax);
348
64.8k
#endif
349
#if 0 // 2. Round the min coordinate; add the ceiling of the width.
350
    x0 = splashRound(xMin);
351
    x1 = x0 + splashCeil(xMax - xMin);
352
#endif
353
#if 0 // 3. Use floor on the min coord and ceiling on the max coord.
354
    x0 = splashFloor(xMin);
355
    x1 = splashCeil(xMax);
356
#endif
357
#if 0 // 4. Hybrid.
358
    SplashCoord w = xMax - xMin;
359
    x0 = splashRound(xMin);
360
    if (w > 4) {
361
      x1 = splashRound(xMax);
362
    } else {
363
      x1 = x0 + splashRound(w);
364
    }
365
#endif
366
64.8k
  }
367
64.8k
  if (x0 == x1) {
368
44.3k
    if (xMin + xMax < 2 * x0) {
369
57
      --x0;
370
44.2k
    } else {
371
44.2k
      ++x1;
372
44.2k
    }
373
44.3k
  }
374
64.8k
  *xMinI = x0;
375
64.8k
  *xMaxI = x1;
376
64.8k
}
SplashClip.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Line
Count
Source
307
28.5k
              SplashCoord w = -1) {
308
28.5k
  int x0, x1;
309
310
  // make sure the coords fit in 32-bit ints
311
#if USE_FIXEDPOINT
312
  if (xMin < -32767) {
313
    xMin = -32767;
314
  } else if (xMin > 32767) {
315
    xMin = 32767;
316
  }
317
  if (xMax < -32767) {
318
    xMax = -32767;
319
  } else if (xMax > 32767) {
320
    xMax = 32767;
321
  }
322
#else
323
28.5k
  if (xMin < -1e9) {
324
0
    xMin = -1e9;
325
28.5k
  } else if (xMin > 1e9) {
326
0
    xMin = 1e9;
327
0
  }
328
28.5k
  if (xMax < -1e9) {
329
0
    xMax = -1e9;
330
28.5k
  } else if (xMax > 1e9) {
331
0
    xMax = 1e9;
332
0
  }
333
28.5k
#endif
334
335
  // this will never be called with strokeAdjMode == splashStrokeAdjustOff
336
28.5k
  if (strokeAdjMode == splashStrokeAdjustCAD) {
337
0
    x0 = splashRound(xMin);
338
0
    if (w >= 0) {
339
0
      x1 = splashRound(xMax - w) + splashRound(w);
340
0
    } else {
341
0
      x1 = x0 + splashRound(xMax - xMin);
342
0
    }
343
28.5k
  } else {
344
    // NB: enable exactly one of these.
345
28.5k
#if 1 // 1. Round both edge coordinates.
346
28.5k
    x0 = splashRound(xMin);
347
28.5k
    x1 = splashRound(xMax);
348
28.5k
#endif
349
#if 0 // 2. Round the min coordinate; add the ceiling of the width.
350
    x0 = splashRound(xMin);
351
    x1 = x0 + splashCeil(xMax - xMin);
352
#endif
353
#if 0 // 3. Use floor on the min coord and ceiling on the max coord.
354
    x0 = splashFloor(xMin);
355
    x1 = splashCeil(xMax);
356
#endif
357
#if 0 // 4. Hybrid.
358
    SplashCoord w = xMax - xMin;
359
    x0 = splashRound(xMin);
360
    if (w > 4) {
361
      x1 = splashRound(xMax);
362
    } else {
363
      x1 = x0 + splashRound(w);
364
    }
365
#endif
366
28.5k
  }
367
28.5k
  if (x0 == x1) {
368
2.42k
    if (xMin + xMax < 2 * x0) {
369
0
      --x0;
370
2.42k
    } else {
371
2.42k
      ++x1;
372
2.42k
    }
373
2.42k
  }
374
28.5k
  *xMinI = x0;
375
28.5k
  *xMaxI = x1;
376
28.5k
}
Unexecuted instantiation: SplashFontEngine.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Unexecuted instantiation: SplashPattern.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Unexecuted instantiation: SplashState.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
SplashXPath.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Line
Count
Source
307
15.7M
              SplashCoord w = -1) {
308
15.7M
  int x0, x1;
309
310
  // make sure the coords fit in 32-bit ints
311
#if USE_FIXEDPOINT
312
  if (xMin < -32767) {
313
    xMin = -32767;
314
  } else if (xMin > 32767) {
315
    xMin = 32767;
316
  }
317
  if (xMax < -32767) {
318
    xMax = -32767;
319
  } else if (xMax > 32767) {
320
    xMax = 32767;
321
  }
322
#else
323
15.7M
  if (xMin < -1e9) {
324
0
    xMin = -1e9;
325
15.7M
  } else if (xMin > 1e9) {
326
0
    xMin = 1e9;
327
0
  }
328
15.7M
  if (xMax < -1e9) {
329
0
    xMax = -1e9;
330
15.7M
  } else if (xMax > 1e9) {
331
0
    xMax = 1e9;
332
0
  }
333
15.7M
#endif
334
335
  // this will never be called with strokeAdjMode == splashStrokeAdjustOff
336
15.7M
  if (strokeAdjMode == splashStrokeAdjustCAD) {
337
0
    x0 = splashRound(xMin);
338
0
    if (w >= 0) {
339
0
      x1 = splashRound(xMax - w) + splashRound(w);
340
0
    } else {
341
0
      x1 = x0 + splashRound(xMax - xMin);
342
0
    }
343
15.7M
  } else {
344
    // NB: enable exactly one of these.
345
15.7M
#if 1 // 1. Round both edge coordinates.
346
15.7M
    x0 = splashRound(xMin);
347
15.7M
    x1 = splashRound(xMax);
348
15.7M
#endif
349
#if 0 // 2. Round the min coordinate; add the ceiling of the width.
350
    x0 = splashRound(xMin);
351
    x1 = x0 + splashCeil(xMax - xMin);
352
#endif
353
#if 0 // 3. Use floor on the min coord and ceiling on the max coord.
354
    x0 = splashFloor(xMin);
355
    x1 = splashCeil(xMax);
356
#endif
357
#if 0 // 4. Hybrid.
358
    SplashCoord w = xMax - xMin;
359
    x0 = splashRound(xMin);
360
    if (w > 4) {
361
      x1 = splashRound(xMax);
362
    } else {
363
      x1 = x0 + splashRound(w);
364
    }
365
#endif
366
15.7M
  }
367
15.7M
  if (x0 == x1) {
368
14.8M
    if (xMin + xMax < 2 * x0) {
369
0
      --x0;
370
14.8M
    } else {
371
14.8M
      ++x1;
372
14.8M
    }
373
14.8M
  }
374
15.7M
  *xMinI = x0;
375
15.7M
  *xMaxI = x1;
376
15.7M
}
Unexecuted instantiation: SplashXPathScanner.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Unexecuted instantiation: ShadingImage.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Unexecuted instantiation: SplashFTFontFile.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Unexecuted instantiation: SplashFont.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Unexecuted instantiation: SplashScreen.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Unexecuted instantiation: SplashFTFont.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Unexecuted instantiation: fuzz_JBIG2.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
377
378
#endif