Coverage Report

Created: 2026-05-30 06:25

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
148M
static inline SplashCoord splashAbs(SplashCoord x) {
26
#if USE_FIXEDPOINT
27
  return FixedPoint::abs(x);
28
#else
29
148M
  return fabs(x);
30
148M
#endif
31
148M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashAbs(double)
Unexecuted instantiation: SplashOutputDev.cc:splashAbs(double)
Splash.cc:splashAbs(double)
Line
Count
Source
25
284k
static inline SplashCoord splashAbs(SplashCoord x) {
26
#if USE_FIXEDPOINT
27
  return FixedPoint::abs(x);
28
#else
29
284k
  return fabs(x);
30
284k
#endif
31
284k
}
Unexecuted instantiation: SplashClip.cc:splashAbs(double)
SplashFontEngine.cc:splashAbs(double)
Line
Count
Source
25
299k
static inline SplashCoord splashAbs(SplashCoord x) {
26
#if USE_FIXEDPOINT
27
  return FixedPoint::abs(x);
28
#else
29
299k
  return fabs(x);
30
299k
#endif
31
299k
}
Unexecuted instantiation: SplashPattern.cc:splashAbs(double)
Unexecuted instantiation: SplashState.cc:splashAbs(double)
SplashXPath.cc:splashAbs(double)
Line
Count
Source
25
147M
static inline SplashCoord splashAbs(SplashCoord x) {
26
#if USE_FIXEDPOINT
27
  return FixedPoint::abs(x);
28
#else
29
147M
  return fabs(x);
30
147M
#endif
31
147M
}
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)
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
96.5M
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
96.5M
  __m128d m1, m2;
50
96.5M
  int i, s;
51
52
96.5M
  m1 = _mm_set_sd(x);
53
96.5M
  i = _mm_cvttsd_si32(m1);
54
96.5M
  m2 = _mm_cvtsi32_sd(m1, i);
55
96.5M
  s = _mm_ucomigt_sd(m2, m1);
56
96.5M
  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
96.5M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashFloor(double)
Unexecuted instantiation: SplashOutputDev.cc:splashFloor(double)
Splash.cc:splashFloor(double)
Line
Count
Source
36
13.1M
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
13.1M
  __m128d m1, m2;
50
13.1M
  int i, s;
51
52
13.1M
  m1 = _mm_set_sd(x);
53
13.1M
  i = _mm_cvttsd_si32(m1);
54
13.1M
  m2 = _mm_cvtsi32_sd(m1, i);
55
13.1M
  s = _mm_ucomigt_sd(m2, m1);
56
13.1M
  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
13.1M
}
SplashClip.cc:splashFloor(double)
Line
Count
Source
36
138k
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
138k
  __m128d m1, m2;
50
138k
  int i, s;
51
52
138k
  m1 = _mm_set_sd(x);
53
138k
  i = _mm_cvttsd_si32(m1);
54
138k
  m2 = _mm_cvtsi32_sd(m1, i);
55
138k
  s = _mm_ucomigt_sd(m2, m1);
56
138k
  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
138k
}
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
31.1M
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
31.1M
  __m128d m1, m2;
50
31.1M
  int i, s;
51
52
31.1M
  m1 = _mm_set_sd(x);
53
31.1M
  i = _mm_cvttsd_si32(m1);
54
31.1M
  m2 = _mm_cvtsi32_sd(m1, i);
55
31.1M
  s = _mm_ucomigt_sd(m2, m1);
56
31.1M
  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
31.1M
}
SplashXPathScanner.cc:splashFloor(double)
Line
Count
Source
36
34.8M
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
34.8M
  __m128d m1, m2;
50
34.8M
  int i, s;
51
52
34.8M
  m1 = _mm_set_sd(x);
53
34.8M
  i = _mm_cvttsd_si32(m1);
54
34.8M
  m2 = _mm_cvtsi32_sd(m1, i);
55
34.8M
  s = _mm_ucomigt_sd(m2, m1);
56
34.8M
  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
34.8M
}
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
17.3M
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
17.3M
  __m128d m1, m2;
50
17.3M
  int i, s;
51
52
17.3M
  m1 = _mm_set_sd(x);
53
17.3M
  i = _mm_cvttsd_si32(m1);
54
17.3M
  m2 = _mm_cvtsi32_sd(m1, i);
55
17.3M
  s = _mm_ucomigt_sd(m2, m1);
56
17.3M
  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
17.3M
}
SplashFTFont.cc:splashFloor(double)
Line
Count
Source
36
6.14k
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
6.14k
  __m128d m1, m2;
50
6.14k
  int i, s;
51
52
6.14k
  m1 = _mm_set_sd(x);
53
6.14k
  i = _mm_cvttsd_si32(m1);
54
6.14k
  m2 = _mm_cvtsi32_sd(m1, i);
55
6.14k
  s = _mm_ucomigt_sd(m2, m1);
56
6.14k
  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
6.14k
}
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
257k
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
257k
  __m128d m1, m2;
122
257k
  int i, s;
123
124
257k
  m1 = _mm_set_sd(x);
125
257k
  i = _mm_cvttsd_si32(m1);
126
257k
  m2 = _mm_cvtsi32_sd(m1, i);
127
257k
  s = _mm_ucomilt_sd(m2, m1);
128
257k
  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
257k
}
Unexecuted instantiation: fuzz_pdfload.cc:splashCeil(double)
Unexecuted instantiation: SplashOutputDev.cc:splashCeil(double)
Splash.cc:splashCeil(double)
Line
Count
Source
108
204
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
204
  __m128d m1, m2;
122
204
  int i, s;
123
124
204
  m1 = _mm_set_sd(x);
125
204
  i = _mm_cvttsd_si32(m1);
126
204
  m2 = _mm_cvtsi32_sd(m1, i);
127
204
  s = _mm_ucomilt_sd(m2, m1);
128
204
  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
204
}
SplashClip.cc:splashCeil(double)
Line
Count
Source
108
238k
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
238k
  __m128d m1, m2;
122
238k
  int i, s;
123
124
238k
  m1 = _mm_set_sd(x);
125
238k
  i = _mm_cvttsd_si32(m1);
126
238k
  m2 = _mm_cvtsi32_sd(m1, i);
127
238k
  s = _mm_ucomilt_sd(m2, m1);
128
238k
  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
238k
}
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.4k
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.4k
  __m128d m1, m2;
122
19.4k
  int i, s;
123
124
19.4k
  m1 = _mm_set_sd(x);
125
19.4k
  i = _mm_cvttsd_si32(m1);
126
19.4k
  m2 = _mm_cvtsi32_sd(m1, i);
127
19.4k
  s = _mm_ucomilt_sd(m2, m1);
128
19.4k
  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.4k
}
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)
179
180
47.7M
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
47.7M
  return splashFloor(x + 0.5);
192
193
47.7M
#endif
194
47.7M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashRound(double)
Unexecuted instantiation: SplashOutputDev.cc:splashRound(double)
Splash.cc:splashRound(double)
Line
Count
Source
180
224k
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
224k
  return splashFloor(x + 0.5);
192
193
224k
#endif
194
224k
}
SplashClip.cc:splashRound(double)
Line
Count
Source
180
46.8k
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
46.8k
  return splashFloor(x + 0.5);
192
193
46.8k
#endif
194
46.8k
}
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
30.1M
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
30.1M
  return splashFloor(x + 0.5);
192
193
30.1M
#endif
194
30.1M
}
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
17.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
17.3M
  return splashFloor(x + 0.5);
192
193
17.3M
#endif
194
17.3M
}
SplashFTFont.cc:splashRound(double)
Line
Count
Source
180
6.14k
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
6.14k
  return splashFloor(x + 0.5);
192
193
6.14k
#endif
194
6.14k
}
195
196
92.6M
static inline SplashCoord splashAvg(SplashCoord x, SplashCoord y) {
197
#if USE_FIXEDPOINT
198
  return FixedPoint::avg(x, y);
199
#else
200
92.6M
  return 0.5 * (x + y);
201
92.6M
#endif
202
92.6M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashAvg(double, double)
Unexecuted instantiation: SplashOutputDev.cc:splashAvg(double, double)
Splash.cc:splashAvg(double, double)
Line
Count
Source
196
92.6M
static inline SplashCoord splashAvg(SplashCoord x, SplashCoord y) {
197
#if USE_FIXEDPOINT
198
  return FixedPoint::avg(x, y);
199
#else
200
92.6M
  return 0.5 * (x + y);
201
92.6M
#endif
202
92.6M
}
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)
203
204
9.69M
static inline SplashCoord splashSqrt(SplashCoord x) {
205
#if USE_FIXEDPOINT
206
  return FixedPoint::sqrt(x);
207
#else
208
9.69M
  return sqrt(x);
209
9.69M
#endif
210
9.69M
}
Unexecuted instantiation: fuzz_pdfload.cc:splashSqrt(double)
Unexecuted instantiation: SplashOutputDev.cc:splashSqrt(double)
Splash.cc:splashSqrt(double)
Line
Count
Source
204
9.69M
static inline SplashCoord splashSqrt(SplashCoord x) {
205
#if USE_FIXEDPOINT
206
  return FixedPoint::sqrt(x);
207
#else
208
9.69M
  return sqrt(x);
209
9.69M
#endif
210
9.69M
}
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)
211
212
16.6M
static inline SplashCoord splashPow(SplashCoord x, SplashCoord y) {
213
#if USE_FIXEDPOINT
214
  return FixedPoint::pow(x, y);
215
#else
216
16.6M
  return pow(x, y);
217
16.6M
#endif
218
16.6M
}
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
16.6M
static inline SplashCoord splashPow(SplashCoord x, SplashCoord y) {
213
#if USE_FIXEDPOINT
214
  return FixedPoint::pow(x, y);
215
#else
216
16.6M
  return pow(x, y);
217
16.6M
#endif
218
16.6M
}
Unexecuted instantiation: SplashFTFont.cc:splashPow(double, double)
219
220
static inline SplashCoord splashDist(SplashCoord x0, SplashCoord y0,
221
12.7M
             SplashCoord x1, SplashCoord y1) {
222
12.7M
  SplashCoord dx, dy;
223
12.7M
  dx = x1 - x0;
224
12.7M
  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
12.7M
  return sqrt(dx * dx + dy * dy);
242
12.7M
#endif
243
12.7M
}
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
12.7M
             SplashCoord x1, SplashCoord y1) {
222
12.7M
  SplashCoord dx, dy;
223
12.7M
  dx = x1 - x0;
224
12.7M
  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
12.7M
  return sqrt(dx * dx + dy * dy);
242
12.7M
#endif
243
12.7M
}
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
12.1k
             SplashCoord x1, SplashCoord y1) {
222
12.1k
  SplashCoord dx, dy;
223
12.1k
  dx = x1 - x0;
224
12.1k
  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
12.1k
  return sqrt(dx * dx + dy * dy);
242
12.1k
#endif
243
12.1k
}
244
245
static inline GBool splashCheckDet(SplashCoord m11, SplashCoord m12,
246
           SplashCoord m21, SplashCoord m22,
247
80.3k
           SplashCoord epsilon) {
248
#if USE_FIXEDPOINT
249
  return FixedPoint::checkDet(m11, m12, m21, m22, epsilon);
250
#else
251
80.3k
  return fabs(m11 * m22 - m12 * m21) >= epsilon;
252
80.3k
#endif
253
80.3k
}
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
49.6k
           SplashCoord epsilon) {
248
#if USE_FIXEDPOINT
249
  return FixedPoint::checkDet(m11, m12, m21, m22, epsilon);
250
#else
251
49.6k
  return fabs(m11 * m22 - m12 * m21) >= epsilon;
252
49.6k
#endif
253
49.6k
}
Unexecuted instantiation: SplashClip.cc:splashCheckDet(double, double, double, double, double)
SplashFontEngine.cc:splashCheckDet(double, double, double, double, double)
Line
Count
Source
247
30.7k
           SplashCoord epsilon) {
248
#if USE_FIXEDPOINT
249
  return FixedPoint::checkDet(m11, m12, m21, m22, epsilon);
250
#else
251
30.7k
  return fabs(m11 * m22 - m12 * m21) >= epsilon;
252
30.7k
#endif
253
30.7k
}
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)
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.1M
              SplashCoord w = -1) {
308
15.1M
  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.1M
  if (xMin < -1e9) {
324
22.5k
    xMin = -1e9;
325
15.1M
  } else if (xMin > 1e9) {
326
9.94k
    xMin = 1e9;
327
9.94k
  }
328
15.1M
  if (xMax < -1e9) {
329
18.8k
    xMax = -1e9;
330
15.1M
  } else if (xMax > 1e9) {
331
21.3k
    xMax = 1e9;
332
21.3k
  }
333
15.1M
#endif
334
335
  // this will never be called with strokeAdjMode == splashStrokeAdjustOff
336
15.1M
  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.1M
  } else {
344
    // NB: enable exactly one of these.
345
15.1M
#if 1 // 1. Round both edge coordinates.
346
15.1M
    x0 = splashRound(xMin);
347
15.1M
    x1 = splashRound(xMax);
348
15.1M
#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.1M
  }
367
15.1M
  if (x0 == x1) {
368
14.2M
    if (xMin + xMax < 2 * x0) {
369
32
      --x0;
370
14.2M
    } else {
371
14.2M
      ++x1;
372
14.2M
    }
373
14.2M
  }
374
15.1M
  *xMinI = x0;
375
15.1M
  *xMaxI = x1;
376
15.1M
}
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
45.6k
              SplashCoord w = -1) {
308
45.6k
  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
45.6k
  if (xMin < -1e9) {
324
22.5k
    xMin = -1e9;
325
23.1k
  } else if (xMin > 1e9) {
326
9.94k
    xMin = 1e9;
327
9.94k
  }
328
45.6k
  if (xMax < -1e9) {
329
18.8k
    xMax = -1e9;
330
26.8k
  } else if (xMax > 1e9) {
331
21.3k
    xMax = 1e9;
332
21.3k
  }
333
45.6k
#endif
334
335
  // this will never be called with strokeAdjMode == splashStrokeAdjustOff
336
45.6k
  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
45.6k
  } else {
344
    // NB: enable exactly one of these.
345
45.6k
#if 1 // 1. Round both edge coordinates.
346
45.6k
    x0 = splashRound(xMin);
347
45.6k
    x1 = splashRound(xMax);
348
45.6k
#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
45.6k
  }
367
45.6k
  if (x0 == x1) {
368
30.4k
    if (xMin + xMax < 2 * x0) {
369
32
      --x0;
370
30.4k
    } else {
371
30.4k
      ++x1;
372
30.4k
    }
373
30.4k
  }
374
45.6k
  *xMinI = x0;
375
45.6k
  *xMaxI = x1;
376
45.6k
}
SplashClip.cc:splashStrokeAdjust(double, double, int*, int*, SplashStrokeAdjustMode, double)
Line
Count
Source
307
23.4k
              SplashCoord w = -1) {
308
23.4k
  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
23.4k
  if (xMin < -1e9) {
324
0
    xMin = -1e9;
325
23.4k
  } else if (xMin > 1e9) {
326
0
    xMin = 1e9;
327
0
  }
328
23.4k
  if (xMax < -1e9) {
329
0
    xMax = -1e9;
330
23.4k
  } else if (xMax > 1e9) {
331
0
    xMax = 1e9;
332
0
  }
333
23.4k
#endif
334
335
  // this will never be called with strokeAdjMode == splashStrokeAdjustOff
336
23.4k
  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
23.4k
  } else {
344
    // NB: enable exactly one of these.
345
23.4k
#if 1 // 1. Round both edge coordinates.
346
23.4k
    x0 = splashRound(xMin);
347
23.4k
    x1 = splashRound(xMax);
348
23.4k
#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
23.4k
  }
367
23.4k
  if (x0 == x1) {
368
2.16k
    if (xMin + xMax < 2 * x0) {
369
0
      --x0;
370
2.16k
    } else {
371
2.16k
      ++x1;
372
2.16k
    }
373
2.16k
  }
374
23.4k
  *xMinI = x0;
375
23.4k
  *xMaxI = x1;
376
23.4k
}
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.0M
              SplashCoord w = -1) {
308
15.0M
  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.0M
  if (xMin < -1e9) {
324
0
    xMin = -1e9;
325
15.0M
  } else if (xMin > 1e9) {
326
0
    xMin = 1e9;
327
0
  }
328
15.0M
  if (xMax < -1e9) {
329
0
    xMax = -1e9;
330
15.0M
  } else if (xMax > 1e9) {
331
0
    xMax = 1e9;
332
0
  }
333
15.0M
#endif
334
335
  // this will never be called with strokeAdjMode == splashStrokeAdjustOff
336
15.0M
  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.0M
  } else {
344
    // NB: enable exactly one of these.
345
15.0M
#if 1 // 1. Round both edge coordinates.
346
15.0M
    x0 = splashRound(xMin);
347
15.0M
    x1 = splashRound(xMax);
348
15.0M
#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.0M
  }
367
15.0M
  if (x0 == x1) {
368
14.2M
    if (xMin + xMax < 2 * x0) {
369
0
      --x0;
370
14.2M
    } else {
371
14.2M
      ++x1;
372
14.2M
    }
373
14.2M
  }
374
15.0M
  *xMinI = x0;
375
15.0M
  *xMaxI = x1;
376
15.0M
}
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)
377
378
#endif