Coverage Report

Created: 2026-06-22 07:14

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/xpdf-4.06/fofi/FoFiBase.cc
Line
Count
Source
1
//========================================================================
2
//
3
// FoFiBase.cc
4
//
5
// Copyright 1999-2003 Glyph & Cog, LLC
6
//
7
//========================================================================
8
9
#include <aconf.h>
10
11
#include <stdio.h>
12
#include <limits.h>
13
#include "gmem.h"
14
#include "gmempp.h"
15
#include "FoFiBase.h"
16
17
//------------------------------------------------------------------------
18
// FoFiBase
19
//------------------------------------------------------------------------
20
21
10.4k
FoFiBase::FoFiBase(char *fileA, int lenA, GBool freeFileDataA) {
22
10.4k
  fileData = file = (Guchar *)fileA;
23
10.4k
  len = lenA;
24
10.4k
  freeFileData = freeFileDataA;
25
10.4k
}
26
27
10.4k
FoFiBase::~FoFiBase() {
28
10.4k
  if (freeFileData) {
29
6.36k
    gfree(fileData);
30
6.36k
  }
31
10.4k
}
32
33
6.13k
char *FoFiBase::readFile(char *fileName, int *fileLen) {
34
6.13k
  FILE *f;
35
6.13k
  char *buf;
36
6.13k
  int n;
37
38
6.13k
  if (!(f = fopen(fileName, "rb"))) {
39
0
    return NULL;
40
0
  }
41
6.13k
  fseek(f, 0, SEEK_END);
42
6.13k
  n = (int)ftell(f);
43
6.13k
  if (n < 0) {
44
0
    fclose(f);
45
0
    return NULL;
46
0
  }
47
6.13k
  fseek(f, 0, SEEK_SET);
48
6.13k
  buf = (char *)gmalloc(n);
49
6.13k
  if ((int)fread(buf, 1, n, f) != n) {
50
0
    gfree(buf);
51
0
    fclose(f);
52
0
    return NULL;
53
0
  }
54
6.13k
  fclose(f);
55
6.13k
  *fileLen = n;
56
6.13k
  return buf;
57
6.13k
}
58
59
0
int FoFiBase::getS8(int pos, GBool *ok) {
60
0
  int x;
61
62
0
  if (pos < 0 || pos >= len) {
63
0
    *ok = gFalse;
64
0
    return 0;
65
0
  }
66
0
  x = file[pos];
67
0
  if (x & 0x80) {
68
0
    x |= ~0xff;
69
0
  }
70
0
  return x;
71
0
}
72
73
185M
int FoFiBase::getU8(int pos, GBool *ok) {
74
185M
  if (pos < 0 || pos >= len) {
75
131M
    *ok = gFalse;
76
131M
    return 0;
77
131M
  }
78
53.6M
  return file[pos];
79
185M
}
80
81
20.0k
int FoFiBase::getS16BE(int pos, GBool *ok) {
82
20.0k
  int x;
83
84
20.0k
  if (pos < 0 || pos > INT_MAX - 1 || pos+1 >= len) {
85
15
    *ok = gFalse;
86
15
    return 0;
87
15
  }
88
20.0k
  x = file[pos];
89
20.0k
  x = (x << 8) + file[pos+1];
90
20.0k
  if (x & 0x8000) {
91
6.55k
    x |= ~0xffff;
92
6.55k
  }
93
20.0k
  return x;
94
20.0k
}
95
96
7.87M
int FoFiBase::getU16BE(int pos, GBool *ok) {
97
7.87M
  int x;
98
99
7.87M
  if (pos < 0 || pos > INT_MAX - 1 || pos+1 >= len) {
100
697k
    *ok = gFalse;
101
697k
    return 0;
102
697k
  }
103
7.17M
  x = file[pos];
104
7.17M
  x = (x << 8) + file[pos+1];
105
7.17M
  return x;
106
7.87M
}
107
108
0
int FoFiBase::getS32BE(int pos, GBool *ok) {
109
0
  int x;
110
111
0
  if (pos < 0 || pos > INT_MAX - 3 || pos+3 >= len) {
112
0
    *ok = gFalse;
113
0
    return 0;
114
0
  }
115
0
  x = file[pos];
116
0
  x = (x << 8) + file[pos+1];
117
0
  x = (x << 8) + file[pos+2];
118
0
  x = (x << 8) + file[pos+3];
119
0
  if (x & 0x80000000) {
120
0
    x |= ~0xffffffff;
121
0
  }
122
0
  return x;
123
0
}
124
125
3.61M
Guint FoFiBase::getU32BE(int pos, GBool *ok) {
126
3.61M
  Guint x;
127
128
3.61M
  if (pos < 0 || pos > INT_MAX - 3 || pos+3 >= len) {
129
351k
    *ok = gFalse;
130
351k
    return 0;
131
351k
  }
132
3.26M
  x = file[pos];
133
3.26M
  x = (x << 8) + file[pos+1];
134
3.26M
  x = (x << 8) + file[pos+2];
135
3.26M
  x = (x << 8) + file[pos+3];
136
3.26M
  return x;
137
3.61M
}
138
139
238
Guint FoFiBase::getU32LE(int pos, GBool *ok) {
140
238
  Guint x;
141
142
238
  if (pos < 0 || pos > INT_MAX - 3 || pos+3 >= len) {
143
0
    *ok = gFalse;
144
0
    return 0;
145
0
  }
146
238
  x = file[pos+3];
147
238
  x = (x << 8) + file[pos+2];
148
238
  x = (x << 8) + file[pos+1];
149
238
  x = (x << 8) + file[pos];
150
238
  return x;
151
238
}
152
153
1.00M
Guint FoFiBase::getUVarBE(int pos, int size, GBool *ok) {
154
1.00M
  Guint x;
155
1.00M
  int i;
156
157
1.00M
  if (pos < 0 || pos > INT_MAX - size || pos + size > len) {
158
3.83k
    *ok = gFalse;
159
3.83k
    return 0;
160
3.83k
  }
161
1.00M
  x = 0;
162
4.36M
  for (i = 0; i < size; ++i) {
163
3.36M
    x = (x << 8) + file[pos + i];
164
3.36M
  }
165
1.00M
  return x;
166
1.00M
}
167
168
462k
GBool FoFiBase::checkRegion(int pos, int size) {
169
462k
  return pos >= 0 &&
170
462k
         size >= 0 &&
171
462k
         size <= INT_MAX - pos &&
172
434k
         pos + size <= len;
173
462k
}