Coverage Report

Created: 2026-04-12 06:05

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libjpeg-turbo.main/src/rdppm.c
Line
Count
Source
1
/*
2
 * rdppm.c
3
 *
4
 * This file was part of the Independent JPEG Group's software:
5
 * Copyright (C) 1991-1997, Thomas G. Lane.
6
 * Modified 2009 by Bill Allombert, Guido Vollbeding.
7
 * libjpeg-turbo Modifications:
8
 * Copyright (C) 2015-2017, 2020-2026, D. R. Commander.
9
 * For conditions of distribution and use, see the accompanying README.ijg
10
 * file.
11
 *
12
 * This file contains routines to read input images in PPM/PGM format.
13
 * The extended 2-byte-per-sample raw PPM/PGM formats are supported.
14
 * The PBMPLUS library is NOT required to compile this software
15
 * (but it is highly useful as a set of PPM image manipulation programs).
16
 *
17
 * These routines may need modification for non-Unix environments or
18
 * specialized applications.  As they stand, they assume input from
19
 * an ordinary stdio stream.  They further assume that reading begins
20
 * at the start of the file; start_input may need work if the
21
 * user interface has already read some data (e.g., to determine that
22
 * the file is indeed PPM format).
23
 */
24
25
#include "cmyk.h"
26
#include "cdjpeg.h"             /* Common decls for cjpeg/djpeg applications */
27
28
#if defined(PPM_SUPPORTED) && \
29
    (BITS_IN_JSAMPLE != 16 || defined(C_LOSSLESS_SUPPORTED))
30
31
32
/* Portions of this code are based on the PBMPLUS library, which is:
33
**
34
** Copyright (C) 1988 by Jef Poskanzer.
35
**
36
** Permission to use, copy, modify, and distribute this software and its
37
** documentation for any purpose and without fee is hereby granted, provided
38
** that the above copyright notice appear in all copies and that both that
39
** copyright notice and this permission notice appear in supporting
40
** documentation.  This software is provided "as is" without express or
41
** implied warranty.
42
*/
43
44
45
#define ReadOK(file, buffer, len) \
46
29.9M
  (fread(buffer, 1, len, file) == ((size_t)(len)))
47
48
static int alpha_index[JPEG_NUMCS] = {
49
  -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 3, 3, 0, 0, -1
50
};
51
52
53
/* Private version of data source object */
54
55
typedef struct {
56
  struct cjpeg_source_struct pub; /* public fields */
57
58
  /* Usually these two pointers point to the same place: */
59
  unsigned char *iobuffer;      /* fread's I/O buffer */
60
  _JSAMPROW pixrow;             /* compressor input buffer */
61
  size_t buffer_width;          /* width of I/O buffer */
62
  _JSAMPLE *rescale;            /* => maxval-remapping array, or NULL */
63
  unsigned int maxval;
64
} ppm_source_struct;
65
66
typedef ppm_source_struct *ppm_source_ptr;
67
68
69
LOCAL(int)
70
pbm_getc(FILE *infile)
71
/* Read next char, skipping over any comments */
72
/* A comment/newline sequence is returned as a newline */
73
315k
{
74
315k
  register int ch;
75
76
315k
  ch = getc(infile);
77
315k
  if (ch == '#') {
78
65.4k
    do {
79
65.4k
      ch = getc(infile);
80
65.4k
    } while (ch != '\n' && ch != EOF);
81
3.54k
  }
82
315k
  return ch;
83
315k
}
Unexecuted instantiation: rdppm-8.c:pbm_getc
rdppm-12.c:pbm_getc
Line
Count
Source
73
315k
{
74
315k
  register int ch;
75
76
315k
  ch = getc(infile);
77
315k
  if (ch == '#') {
78
65.4k
    do {
79
65.4k
      ch = getc(infile);
80
65.4k
    } while (ch != '\n' && ch != EOF);
81
3.54k
  }
82
315k
  return ch;
83
315k
}
Unexecuted instantiation: rdppm-16.c:pbm_getc
84
85
86
LOCAL(unsigned int)
87
read_pbm_integer(j_compress_ptr cinfo, FILE *infile, unsigned int maxval)
88
/* Read an unsigned decimal integer from the PPM file */
89
/* Swallows one trailing character after the integer */
90
/* Note that on a 16-bit-int machine, only values up to 64k can be read. */
91
/* This should not be a problem in practice. */
92
130k
{
93
130k
  register int ch;
94
130k
  register unsigned int val;
95
96
  /* Skip any leading whitespace */
97
138k
  do {
98
138k
    ch = pbm_getc(infile);
99
138k
    if (ch == EOF)
100
2.56k
      ERREXIT(cinfo, JERR_INPUT_EOF);
101
138k
  } while (ch == ' ' || ch == '\t' || ch == '\n' || ch == '\r');
102
103
130k
  if (ch < '0' || ch > '9')
104
327
    ERREXIT(cinfo, JERR_PPM_NONNUMERIC);
105
106
130k
  val = ch - '0';
107
179k
  while ((ch = pbm_getc(infile)) >= '0' && ch <= '9') {
108
49.0k
    val *= 10;
109
49.0k
    val += ch - '0';
110
49.0k
    if (val > maxval)
111
139
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
112
49.0k
  }
113
114
130k
  return val;
115
130k
}
Unexecuted instantiation: rdppm-8.c:read_pbm_integer
rdppm-12.c:read_pbm_integer
Line
Count
Source
92
130k
{
93
130k
  register int ch;
94
130k
  register unsigned int val;
95
96
  /* Skip any leading whitespace */
97
138k
  do {
98
138k
    ch = pbm_getc(infile);
99
138k
    if (ch == EOF)
100
2.56k
      ERREXIT(cinfo, JERR_INPUT_EOF);
101
138k
  } while (ch == ' ' || ch == '\t' || ch == '\n' || ch == '\r');
102
103
130k
  if (ch < '0' || ch > '9')
104
327
    ERREXIT(cinfo, JERR_PPM_NONNUMERIC);
105
106
130k
  val = ch - '0';
107
179k
  while ((ch = pbm_getc(infile)) >= '0' && ch <= '9') {
108
49.0k
    val *= 10;
109
49.0k
    val += ch - '0';
110
49.0k
    if (val > maxval)
111
139
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
112
49.0k
  }
113
114
130k
  return val;
115
130k
}
Unexecuted instantiation: rdppm-16.c:read_pbm_integer
116
117
118
/*
119
 * Read one row of pixels.
120
 *
121
 * We provide several different versions depending on input file format.
122
 * In all cases, input is scaled to cinfo->data_precision.
123
 *
124
 * A really fast path is provided for reading byte/sample raw files with
125
 * maxval <= _MAXJSAMPLE and maxval == (1U << cinfo->data_precision) - 1U,
126
 * which is the normal case for 8-bit data.
127
 */
128
129
130
METHODDEF(JDIMENSION)
131
get_text_gray_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
132
/* This version is for reading text-format PGM files with any maxval */
133
1.24k
{
134
1.24k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
135
1.24k
  FILE *infile = source->pub.input_file;
136
1.24k
  register _JSAMPROW ptr;
137
1.24k
  register _JSAMPLE *rescale = source->rescale;
138
1.24k
  JDIMENSION col;
139
1.24k
  unsigned int maxval = source->maxval;
140
141
1.24k
  ptr = source->pub._buffer[0];
142
3.44k
  for (col = cinfo->image_width; col > 0; col--) {
143
2.19k
    *ptr++ = rescale[read_pbm_integer(cinfo, infile, maxval)];
144
2.19k
  }
145
1.24k
  return 1;
146
1.24k
}
Unexecuted instantiation: rdppm-8.c:get_text_gray_row
rdppm-12.c:get_text_gray_row
Line
Count
Source
133
1.24k
{
134
1.24k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
135
1.24k
  FILE *infile = source->pub.input_file;
136
1.24k
  register _JSAMPROW ptr;
137
1.24k
  register _JSAMPLE *rescale = source->rescale;
138
1.24k
  JDIMENSION col;
139
1.24k
  unsigned int maxval = source->maxval;
140
141
1.24k
  ptr = source->pub._buffer[0];
142
3.44k
  for (col = cinfo->image_width; col > 0; col--) {
143
2.19k
    *ptr++ = rescale[read_pbm_integer(cinfo, infile, maxval)];
144
2.19k
  }
145
1.24k
  return 1;
146
1.24k
}
Unexecuted instantiation: rdppm-16.c:get_text_gray_row
147
148
149
17.5M
#define GRAY_RGB_READ_LOOP(read_op, alpha_set_op) { \
150
118M
  for (col = cinfo->image_width; col > 0; col--) { \
151
101M
    ptr[rindex] = ptr[gindex] = ptr[bindex] = read_op; \
152
101M
    alpha_set_op \
153
101M
    ptr += ps; \
154
101M
  } \
155
17.5M
}
156
157
METHODDEF(JDIMENSION)
158
get_text_gray_rgb_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
159
/* This version is for reading text-format PGM files with any maxval and
160
   converting to extended RGB */
161
6.22k
{
162
6.22k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
163
6.22k
  FILE *infile = source->pub.input_file;
164
6.22k
  register _JSAMPROW ptr;
165
6.22k
  register _JSAMPLE *rescale = source->rescale;
166
6.22k
  JDIMENSION col;
167
6.22k
  unsigned int maxval = source->maxval;
168
6.22k
  register int rindex = rgb_red[cinfo->in_color_space];
169
6.22k
  register int gindex = rgb_green[cinfo->in_color_space];
170
6.22k
  register int bindex = rgb_blue[cinfo->in_color_space];
171
6.22k
  register int aindex = alpha_index[cinfo->in_color_space];
172
6.22k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
173
174
6.22k
  ptr = source->pub._buffer[0];
175
6.22k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
176
1.11k
    if (aindex >= 0)
177
223
      GRAY_RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval),
178
1.11k
                         ptr[aindex] = (_JSAMPLE)maxval;)
179
892
    else
180
892
      GRAY_RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval), {})
181
5.11k
  } else {
182
5.11k
    if (aindex >= 0)
183
1.02k
      GRAY_RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)],
184
5.11k
                         ptr[aindex] = (1 << cinfo->data_precision) - 1;)
185
4.08k
    else
186
4.08k
      GRAY_RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)], {})
187
5.11k
  }
188
6.22k
  return 1;
189
6.22k
}
Unexecuted instantiation: rdppm-8.c:get_text_gray_rgb_row
rdppm-12.c:get_text_gray_rgb_row
Line
Count
Source
161
6.22k
{
162
6.22k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
163
6.22k
  FILE *infile = source->pub.input_file;
164
6.22k
  register _JSAMPROW ptr;
165
6.22k
  register _JSAMPLE *rescale = source->rescale;
166
6.22k
  JDIMENSION col;
167
6.22k
  unsigned int maxval = source->maxval;
168
6.22k
  register int rindex = rgb_red[cinfo->in_color_space];
169
6.22k
  register int gindex = rgb_green[cinfo->in_color_space];
170
6.22k
  register int bindex = rgb_blue[cinfo->in_color_space];
171
6.22k
  register int aindex = alpha_index[cinfo->in_color_space];
172
6.22k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
173
174
6.22k
  ptr = source->pub._buffer[0];
175
6.22k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
176
1.11k
    if (aindex >= 0)
177
223
      GRAY_RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval),
178
1.11k
                         ptr[aindex] = (_JSAMPLE)maxval;)
179
892
    else
180
892
      GRAY_RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval), {})
181
5.11k
  } else {
182
5.11k
    if (aindex >= 0)
183
1.02k
      GRAY_RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)],
184
5.11k
                         ptr[aindex] = (1 << cinfo->data_precision) - 1;)
185
4.08k
    else
186
4.08k
      GRAY_RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)], {})
187
5.11k
  }
188
6.22k
  return 1;
189
6.22k
}
Unexecuted instantiation: rdppm-16.c:get_text_gray_rgb_row
190
191
192
METHODDEF(JDIMENSION)
193
get_text_gray_cmyk_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
194
/* This version is for reading text-format PGM files with any maxval and
195
   converting to CMYK */
196
1.24k
{
197
1.24k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
198
1.24k
  FILE *infile = source->pub.input_file;
199
1.24k
  register _JSAMPROW ptr;
200
1.24k
  register _JSAMPLE *rescale = source->rescale;
201
1.24k
  JDIMENSION col;
202
1.24k
  unsigned int maxval = source->maxval;
203
204
1.24k
  ptr = source->pub._buffer[0];
205
1.24k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
206
645
    for (col = cinfo->image_width; col > 0; col--) {
207
422
      _JSAMPLE gray = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
208
422
      rgb_to_cmyk(maxval, gray, gray, gray, ptr, ptr + 1, ptr + 2, ptr + 3);
209
422
      ptr += 4;
210
422
    }
211
1.02k
  } else {
212
2.79k
    for (col = cinfo->image_width; col > 0; col--) {
213
1.77k
      _JSAMPLE gray = rescale[read_pbm_integer(cinfo, infile, maxval)];
214
1.77k
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, gray, gray, gray, ptr,
215
1.77k
                  ptr + 1, ptr + 2, ptr + 3);
216
1.77k
      ptr += 4;
217
1.77k
    }
218
1.02k
  }
219
1.24k
  return 1;
220
1.24k
}
Unexecuted instantiation: rdppm-8.c:get_text_gray_cmyk_row
rdppm-12.c:get_text_gray_cmyk_row
Line
Count
Source
196
1.24k
{
197
1.24k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
198
1.24k
  FILE *infile = source->pub.input_file;
199
1.24k
  register _JSAMPROW ptr;
200
1.24k
  register _JSAMPLE *rescale = source->rescale;
201
1.24k
  JDIMENSION col;
202
1.24k
  unsigned int maxval = source->maxval;
203
204
1.24k
  ptr = source->pub._buffer[0];
205
1.24k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
206
645
    for (col = cinfo->image_width; col > 0; col--) {
207
422
      _JSAMPLE gray = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
208
422
      rgb_to_cmyk(maxval, gray, gray, gray, ptr, ptr + 1, ptr + 2, ptr + 3);
209
422
      ptr += 4;
210
422
    }
211
1.02k
  } else {
212
2.79k
    for (col = cinfo->image_width; col > 0; col--) {
213
1.77k
      _JSAMPLE gray = rescale[read_pbm_integer(cinfo, infile, maxval)];
214
1.77k
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, gray, gray, gray, ptr,
215
1.77k
                  ptr + 1, ptr + 2, ptr + 3);
216
1.77k
      ptr += 4;
217
1.77k
    }
218
1.02k
  }
219
1.24k
  return 1;
220
1.24k
}
Unexecuted instantiation: rdppm-16.c:get_text_gray_cmyk_row
221
222
223
4.32M
#define RGB_READ_LOOP(read_op, alpha_set_op) { \
224
36.9M
  for (col = cinfo->image_width; col > 0; col--) { \
225
32.5M
    ptr[rindex] = read_op; \
226
32.5M
    ptr[gindex] = read_op; \
227
32.5M
    ptr[bindex] = read_op; \
228
32.5M
    alpha_set_op \
229
32.5M
    ptr += ps; \
230
32.5M
  } \
231
4.32M
}
232
233
METHODDEF(JDIMENSION)
234
get_text_rgb_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
235
/* This version is for reading text-format PPM files with any maxval */
236
7.14k
{
237
7.14k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
238
7.14k
  FILE *infile = source->pub.input_file;
239
7.14k
  register _JSAMPROW ptr;
240
7.14k
  register _JSAMPLE *rescale = source->rescale;
241
7.14k
  JDIMENSION col;
242
7.14k
  unsigned int maxval = source->maxval;
243
7.14k
  register int rindex = rgb_red[cinfo->in_color_space];
244
7.14k
  register int gindex = rgb_green[cinfo->in_color_space];
245
7.14k
  register int bindex = rgb_blue[cinfo->in_color_space];
246
7.14k
  register int aindex = alpha_index[cinfo->in_color_space];
247
7.14k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
248
249
7.14k
  ptr = source->pub._buffer[0];
250
7.14k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
251
1.34k
    if (aindex >= 0)
252
268
      RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval),
253
1.34k
                    ptr[aindex] = (_JSAMPLE)maxval;)
254
1.07k
    else
255
1.07k
      RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval), {})
256
5.80k
  } else {
257
5.80k
    if (aindex >= 0)
258
1.16k
      RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)],
259
5.80k
                    ptr[aindex] = (1 << cinfo->data_precision) - 1;)
260
4.64k
    else
261
4.64k
      RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)], {})
262
5.80k
  }
263
7.14k
  return 1;
264
7.14k
}
Unexecuted instantiation: rdppm-8.c:get_text_rgb_row
rdppm-12.c:get_text_rgb_row
Line
Count
Source
236
7.14k
{
237
7.14k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
238
7.14k
  FILE *infile = source->pub.input_file;
239
7.14k
  register _JSAMPROW ptr;
240
7.14k
  register _JSAMPLE *rescale = source->rescale;
241
7.14k
  JDIMENSION col;
242
7.14k
  unsigned int maxval = source->maxval;
243
7.14k
  register int rindex = rgb_red[cinfo->in_color_space];
244
7.14k
  register int gindex = rgb_green[cinfo->in_color_space];
245
7.14k
  register int bindex = rgb_blue[cinfo->in_color_space];
246
7.14k
  register int aindex = alpha_index[cinfo->in_color_space];
247
7.14k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
248
249
7.14k
  ptr = source->pub._buffer[0];
250
7.14k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
251
1.34k
    if (aindex >= 0)
252
268
      RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval),
253
1.34k
                    ptr[aindex] = (_JSAMPLE)maxval;)
254
1.07k
    else
255
1.07k
      RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval), {})
256
5.80k
  } else {
257
5.80k
    if (aindex >= 0)
258
1.16k
      RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)],
259
5.80k
                    ptr[aindex] = (1 << cinfo->data_precision) - 1;)
260
4.64k
    else
261
4.64k
      RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)], {})
262
5.80k
  }
263
7.14k
  return 1;
264
7.14k
}
Unexecuted instantiation: rdppm-16.c:get_text_rgb_row
265
266
267
METHODDEF(JDIMENSION)
268
get_text_rgb_cmyk_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
269
/* This version is for reading text-format PPM files with any maxval and
270
   converting to CMYK */
271
1.42k
{
272
1.42k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
273
1.42k
  FILE *infile = source->pub.input_file;
274
1.42k
  register _JSAMPROW ptr;
275
1.42k
  register _JSAMPLE *rescale = source->rescale;
276
1.42k
  JDIMENSION col;
277
1.42k
  unsigned int maxval = source->maxval;
278
279
1.42k
  ptr = source->pub._buffer[0];
280
1.42k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
281
1.72k
    for (col = cinfo->image_width; col > 0; col--) {
282
1.45k
      _JSAMPLE r = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
283
1.45k
      _JSAMPLE g = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
284
1.45k
      _JSAMPLE b = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
285
1.45k
      rgb_to_cmyk(maxval, r, g, b, ptr, ptr + 1, ptr + 2, ptr + 3);
286
1.45k
      ptr += 4;
287
1.45k
    }
288
1.16k
  } else {
289
3.14k
    for (col = cinfo->image_width; col > 0; col--) {
290
1.98k
      _JSAMPLE r = rescale[read_pbm_integer(cinfo, infile, maxval)];
291
1.98k
      _JSAMPLE g = rescale[read_pbm_integer(cinfo, infile, maxval)];
292
1.98k
      _JSAMPLE b = rescale[read_pbm_integer(cinfo, infile, maxval)];
293
1.98k
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, r, g, b, ptr, ptr + 1,
294
1.98k
                  ptr + 2, ptr + 3);
295
1.98k
      ptr += 4;
296
1.98k
    }
297
1.16k
  }
298
1.42k
  return 1;
299
1.42k
}
Unexecuted instantiation: rdppm-8.c:get_text_rgb_cmyk_row
rdppm-12.c:get_text_rgb_cmyk_row
Line
Count
Source
271
1.42k
{
272
1.42k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
273
1.42k
  FILE *infile = source->pub.input_file;
274
1.42k
  register _JSAMPROW ptr;
275
1.42k
  register _JSAMPLE *rescale = source->rescale;
276
1.42k
  JDIMENSION col;
277
1.42k
  unsigned int maxval = source->maxval;
278
279
1.42k
  ptr = source->pub._buffer[0];
280
1.42k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
281
1.72k
    for (col = cinfo->image_width; col > 0; col--) {
282
1.45k
      _JSAMPLE r = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
283
1.45k
      _JSAMPLE g = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
284
1.45k
      _JSAMPLE b = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
285
1.45k
      rgb_to_cmyk(maxval, r, g, b, ptr, ptr + 1, ptr + 2, ptr + 3);
286
1.45k
      ptr += 4;
287
1.45k
    }
288
1.16k
  } else {
289
3.14k
    for (col = cinfo->image_width; col > 0; col--) {
290
1.98k
      _JSAMPLE r = rescale[read_pbm_integer(cinfo, infile, maxval)];
291
1.98k
      _JSAMPLE g = rescale[read_pbm_integer(cinfo, infile, maxval)];
292
1.98k
      _JSAMPLE b = rescale[read_pbm_integer(cinfo, infile, maxval)];
293
1.98k
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, r, g, b, ptr, ptr + 1,
294
1.98k
                  ptr + 2, ptr + 3);
295
1.98k
      ptr += 4;
296
1.98k
    }
297
1.16k
  }
298
1.42k
  return 1;
299
1.42k
}
Unexecuted instantiation: rdppm-16.c:get_text_rgb_cmyk_row
300
301
302
METHODDEF(JDIMENSION)
303
get_scaled_gray_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
304
/* This version is for reading raw-byte-format PGM files with any maxval */
305
3.50M
{
306
3.50M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
307
3.50M
  register _JSAMPROW ptr;
308
3.50M
  register unsigned char *bufferptr;
309
3.50M
  register _JSAMPLE *rescale = source->rescale;
310
3.50M
  JDIMENSION col;
311
312
3.50M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
313
75
    ERREXIT(cinfo, JERR_INPUT_EOF);
314
3.50M
  ptr = source->pub._buffer[0];
315
3.50M
  bufferptr = source->iobuffer;
316
23.7M
  for (col = cinfo->image_width; col > 0; col--) {
317
20.2M
    *ptr++ = rescale[*bufferptr++];
318
20.2M
  }
319
3.50M
  return 1;
320
3.50M
}
Unexecuted instantiation: rdppm-8.c:get_scaled_gray_row
rdppm-12.c:get_scaled_gray_row
Line
Count
Source
305
3.50M
{
306
3.50M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
307
3.50M
  register _JSAMPROW ptr;
308
3.50M
  register unsigned char *bufferptr;
309
3.50M
  register _JSAMPLE *rescale = source->rescale;
310
3.50M
  JDIMENSION col;
311
312
3.50M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
313
75
    ERREXIT(cinfo, JERR_INPUT_EOF);
314
3.50M
  ptr = source->pub._buffer[0];
315
3.50M
  bufferptr = source->iobuffer;
316
23.7M
  for (col = cinfo->image_width; col > 0; col--) {
317
20.2M
    *ptr++ = rescale[*bufferptr++];
318
20.2M
  }
319
3.50M
  return 1;
320
3.50M
}
Unexecuted instantiation: rdppm-16.c:get_scaled_gray_row
321
322
323
METHODDEF(JDIMENSION)
324
get_gray_rgb_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
325
/* This version is for reading raw-byte-format PGM files with any maxval
326
   and converting to extended RGB */
327
17.5M
{
328
17.5M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
329
17.5M
  register _JSAMPROW ptr;
330
17.5M
  register unsigned char *bufferptr;
331
17.5M
  register _JSAMPLE *rescale = source->rescale;
332
17.5M
  JDIMENSION col;
333
17.5M
  unsigned int maxval = source->maxval;
334
17.5M
  register int rindex = rgb_red[cinfo->in_color_space];
335
17.5M
  register int gindex = rgb_green[cinfo->in_color_space];
336
17.5M
  register int bindex = rgb_blue[cinfo->in_color_space];
337
17.5M
  register int aindex = alpha_index[cinfo->in_color_space];
338
17.5M
  register int ps = rgb_pixelsize[cinfo->in_color_space];
339
340
17.5M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
341
375
    ERREXIT(cinfo, JERR_INPUT_EOF);
342
17.5M
  ptr = source->pub._buffer[0];
343
17.5M
  bufferptr = source->iobuffer;
344
17.5M
  if (maxval == (1U << cinfo->data_precision) - 1U) {
345
0
    if (aindex >= 0)
346
0
      GRAY_RGB_READ_LOOP(*bufferptr++, ptr[aindex] = (_JSAMPLE)maxval;)
347
0
    else
348
0
      GRAY_RGB_READ_LOOP(*bufferptr++, {})
349
17.5M
  } else {
350
17.5M
    if (aindex >= 0)
351
3.50M
      GRAY_RGB_READ_LOOP(rescale[*bufferptr++],
352
17.5M
                         ptr[aindex] = (1 << cinfo->data_precision) - 1;)
353
14.0M
    else
354
14.0M
      GRAY_RGB_READ_LOOP(rescale[*bufferptr++], {})
355
17.5M
  }
356
17.5M
  return 1;
357
17.5M
}
Unexecuted instantiation: rdppm-8.c:get_gray_rgb_row
rdppm-12.c:get_gray_rgb_row
Line
Count
Source
327
17.5M
{
328
17.5M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
329
17.5M
  register _JSAMPROW ptr;
330
17.5M
  register unsigned char *bufferptr;
331
17.5M
  register _JSAMPLE *rescale = source->rescale;
332
17.5M
  JDIMENSION col;
333
17.5M
  unsigned int maxval = source->maxval;
334
17.5M
  register int rindex = rgb_red[cinfo->in_color_space];
335
17.5M
  register int gindex = rgb_green[cinfo->in_color_space];
336
17.5M
  register int bindex = rgb_blue[cinfo->in_color_space];
337
17.5M
  register int aindex = alpha_index[cinfo->in_color_space];
338
17.5M
  register int ps = rgb_pixelsize[cinfo->in_color_space];
339
340
17.5M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
341
375
    ERREXIT(cinfo, JERR_INPUT_EOF);
342
17.5M
  ptr = source->pub._buffer[0];
343
17.5M
  bufferptr = source->iobuffer;
344
17.5M
  if (maxval == (1U << cinfo->data_precision) - 1U) {
345
0
    if (aindex >= 0)
346
0
      GRAY_RGB_READ_LOOP(*bufferptr++, ptr[aindex] = (_JSAMPLE)maxval;)
347
0
    else
348
0
      GRAY_RGB_READ_LOOP(*bufferptr++, {})
349
17.5M
  } else {
350
17.5M
    if (aindex >= 0)
351
3.50M
      GRAY_RGB_READ_LOOP(rescale[*bufferptr++],
352
17.5M
                         ptr[aindex] = (1 << cinfo->data_precision) - 1;)
353
14.0M
    else
354
14.0M
      GRAY_RGB_READ_LOOP(rescale[*bufferptr++], {})
355
17.5M
  }
356
17.5M
  return 1;
357
17.5M
}
Unexecuted instantiation: rdppm-16.c:get_gray_rgb_row
358
359
360
METHODDEF(JDIMENSION)
361
get_gray_cmyk_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
362
/* This version is for reading raw-byte-format PGM files with any maxval
363
   and converting to CMYK */
364
3.50M
{
365
3.50M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
366
3.50M
  register _JSAMPROW ptr;
367
3.50M
  register unsigned char *bufferptr;
368
3.50M
  register _JSAMPLE *rescale = source->rescale;
369
3.50M
  JDIMENSION col;
370
3.50M
  unsigned int maxval = source->maxval;
371
372
3.50M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
373
75
    ERREXIT(cinfo, JERR_INPUT_EOF);
374
3.50M
  ptr = source->pub._buffer[0];
375
3.50M
  bufferptr = source->iobuffer;
376
3.50M
  if (maxval == (1U << cinfo->data_precision) - 1U) {
377
0
    for (col = cinfo->image_width; col > 0; col--) {
378
0
      _JSAMPLE gray = *bufferptr++;
379
0
      rgb_to_cmyk(maxval, gray, gray, gray, ptr, ptr + 1, ptr + 2, ptr + 3);
380
0
      ptr += 4;
381
0
    }
382
3.50M
  } else {
383
23.7M
    for (col = cinfo->image_width; col > 0; col--) {
384
20.2M
      _JSAMPLE gray = rescale[*bufferptr++];
385
20.2M
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, gray, gray, gray, ptr,
386
20.2M
                  ptr + 1, ptr + 2, ptr + 3);
387
20.2M
      ptr += 4;
388
20.2M
    }
389
3.50M
  }
390
3.50M
  return 1;
391
3.50M
}
Unexecuted instantiation: rdppm-8.c:get_gray_cmyk_row
rdppm-12.c:get_gray_cmyk_row
Line
Count
Source
364
3.50M
{
365
3.50M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
366
3.50M
  register _JSAMPROW ptr;
367
3.50M
  register unsigned char *bufferptr;
368
3.50M
  register _JSAMPLE *rescale = source->rescale;
369
3.50M
  JDIMENSION col;
370
3.50M
  unsigned int maxval = source->maxval;
371
372
3.50M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
373
75
    ERREXIT(cinfo, JERR_INPUT_EOF);
374
3.50M
  ptr = source->pub._buffer[0];
375
3.50M
  bufferptr = source->iobuffer;
376
3.50M
  if (maxval == (1U << cinfo->data_precision) - 1U) {
377
0
    for (col = cinfo->image_width; col > 0; col--) {
378
0
      _JSAMPLE gray = *bufferptr++;
379
0
      rgb_to_cmyk(maxval, gray, gray, gray, ptr, ptr + 1, ptr + 2, ptr + 3);
380
0
      ptr += 4;
381
0
    }
382
3.50M
  } else {
383
23.7M
    for (col = cinfo->image_width; col > 0; col--) {
384
20.2M
      _JSAMPLE gray = rescale[*bufferptr++];
385
20.2M
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, gray, gray, gray, ptr,
386
20.2M
                  ptr + 1, ptr + 2, ptr + 3);
387
20.2M
      ptr += 4;
388
20.2M
    }
389
3.50M
  }
390
3.50M
  return 1;
391
3.50M
}
Unexecuted instantiation: rdppm-16.c:get_gray_cmyk_row
392
393
394
METHODDEF(JDIMENSION)
395
get_rgb_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
396
/* This version is for reading raw-byte-format PPM files with any maxval */
397
4.31M
{
398
4.31M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
399
4.31M
  register _JSAMPROW ptr;
400
4.31M
  register unsigned char *bufferptr;
401
4.31M
  register _JSAMPLE *rescale = source->rescale;
402
4.31M
  JDIMENSION col;
403
4.31M
  unsigned int maxval = source->maxval;
404
4.31M
  register int rindex = rgb_red[cinfo->in_color_space];
405
4.31M
  register int gindex = rgb_green[cinfo->in_color_space];
406
4.31M
  register int bindex = rgb_blue[cinfo->in_color_space];
407
4.31M
  register int aindex = alpha_index[cinfo->in_color_space];
408
4.31M
  register int ps = rgb_pixelsize[cinfo->in_color_space];
409
410
4.31M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
411
465
    ERREXIT(cinfo, JERR_INPUT_EOF);
412
4.31M
  ptr = source->pub._buffer[0];
413
4.31M
  bufferptr = source->iobuffer;
414
4.31M
  if (maxval == (1U << cinfo->data_precision) - 1U) {
415
0
    if (aindex >= 0)
416
0
      RGB_READ_LOOP(*bufferptr++, ptr[aindex] = (_JSAMPLE)maxval;)
417
0
    else
418
0
      RGB_READ_LOOP(*bufferptr++, {})
419
4.31M
  } else {
420
4.31M
    if (aindex >= 0)
421
863k
      RGB_READ_LOOP(rescale[*bufferptr++],
422
4.31M
                    ptr[aindex] = (1 << cinfo->data_precision) - 1;)
423
3.45M
    else
424
3.45M
      RGB_READ_LOOP(rescale[*bufferptr++], {})
425
4.31M
  }
426
4.31M
  return 1;
427
4.31M
}
Unexecuted instantiation: rdppm-8.c:get_rgb_row
rdppm-12.c:get_rgb_row
Line
Count
Source
397
4.31M
{
398
4.31M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
399
4.31M
  register _JSAMPROW ptr;
400
4.31M
  register unsigned char *bufferptr;
401
4.31M
  register _JSAMPLE *rescale = source->rescale;
402
4.31M
  JDIMENSION col;
403
4.31M
  unsigned int maxval = source->maxval;
404
4.31M
  register int rindex = rgb_red[cinfo->in_color_space];
405
4.31M
  register int gindex = rgb_green[cinfo->in_color_space];
406
4.31M
  register int bindex = rgb_blue[cinfo->in_color_space];
407
4.31M
  register int aindex = alpha_index[cinfo->in_color_space];
408
4.31M
  register int ps = rgb_pixelsize[cinfo->in_color_space];
409
410
4.31M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
411
465
    ERREXIT(cinfo, JERR_INPUT_EOF);
412
4.31M
  ptr = source->pub._buffer[0];
413
4.31M
  bufferptr = source->iobuffer;
414
4.31M
  if (maxval == (1U << cinfo->data_precision) - 1U) {
415
0
    if (aindex >= 0)
416
0
      RGB_READ_LOOP(*bufferptr++, ptr[aindex] = (_JSAMPLE)maxval;)
417
0
    else
418
0
      RGB_READ_LOOP(*bufferptr++, {})
419
4.31M
  } else {
420
4.31M
    if (aindex >= 0)
421
863k
      RGB_READ_LOOP(rescale[*bufferptr++],
422
4.31M
                    ptr[aindex] = (1 << cinfo->data_precision) - 1;)
423
3.45M
    else
424
3.45M
      RGB_READ_LOOP(rescale[*bufferptr++], {})
425
4.31M
  }
426
4.31M
  return 1;
427
4.31M
}
Unexecuted instantiation: rdppm-16.c:get_rgb_row
428
429
430
METHODDEF(JDIMENSION)
431
get_rgb_cmyk_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
432
/* This version is for reading raw-byte-format PPM files with any maxval and
433
   converting to CMYK */
434
863k
{
435
863k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
436
863k
  register _JSAMPROW ptr;
437
863k
  register unsigned char *bufferptr;
438
863k
  register _JSAMPLE *rescale = source->rescale;
439
863k
  JDIMENSION col;
440
863k
  unsigned int maxval = source->maxval;
441
442
863k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
443
93
    ERREXIT(cinfo, JERR_INPUT_EOF);
444
863k
  ptr = source->pub._buffer[0];
445
863k
  bufferptr = source->iobuffer;
446
863k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
447
0
    for (col = cinfo->image_width; col > 0; col--) {
448
0
      _JSAMPLE r = *bufferptr++;
449
0
      _JSAMPLE g = *bufferptr++;
450
0
      _JSAMPLE b = *bufferptr++;
451
0
      rgb_to_cmyk(maxval, r, g, b, ptr, ptr + 1, ptr + 2, ptr + 3);
452
0
      ptr += 4;
453
0
    }
454
863k
  } else {
455
7.37M
    for (col = cinfo->image_width; col > 0; col--) {
456
6.51M
      _JSAMPLE r = rescale[*bufferptr++];
457
6.51M
      _JSAMPLE g = rescale[*bufferptr++];
458
6.51M
      _JSAMPLE b = rescale[*bufferptr++];
459
6.51M
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, r, g, b, ptr, ptr + 1,
460
6.51M
                  ptr + 2, ptr + 3);
461
6.51M
      ptr += 4;
462
6.51M
    }
463
863k
  }
464
863k
  return 1;
465
863k
}
Unexecuted instantiation: rdppm-8.c:get_rgb_cmyk_row
rdppm-12.c:get_rgb_cmyk_row
Line
Count
Source
434
863k
{
435
863k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
436
863k
  register _JSAMPROW ptr;
437
863k
  register unsigned char *bufferptr;
438
863k
  register _JSAMPLE *rescale = source->rescale;
439
863k
  JDIMENSION col;
440
863k
  unsigned int maxval = source->maxval;
441
442
863k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
443
93
    ERREXIT(cinfo, JERR_INPUT_EOF);
444
863k
  ptr = source->pub._buffer[0];
445
863k
  bufferptr = source->iobuffer;
446
863k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
447
0
    for (col = cinfo->image_width; col > 0; col--) {
448
0
      _JSAMPLE r = *bufferptr++;
449
0
      _JSAMPLE g = *bufferptr++;
450
0
      _JSAMPLE b = *bufferptr++;
451
0
      rgb_to_cmyk(maxval, r, g, b, ptr, ptr + 1, ptr + 2, ptr + 3);
452
0
      ptr += 4;
453
0
    }
454
863k
  } else {
455
7.37M
    for (col = cinfo->image_width; col > 0; col--) {
456
6.51M
      _JSAMPLE r = rescale[*bufferptr++];
457
6.51M
      _JSAMPLE g = rescale[*bufferptr++];
458
6.51M
      _JSAMPLE b = rescale[*bufferptr++];
459
6.51M
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, r, g, b, ptr, ptr + 1,
460
6.51M
                  ptr + 2, ptr + 3);
461
6.51M
      ptr += 4;
462
6.51M
    }
463
863k
  }
464
863k
  return 1;
465
863k
}
Unexecuted instantiation: rdppm-16.c:get_rgb_cmyk_row
466
467
468
#if BITS_IN_JSAMPLE == 8
469
470
METHODDEF(JDIMENSION)
471
get_raw_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
472
/* This version is for reading raw-byte-format files with
473
 * maxval <= _MAXJSAMPLE and maxval == (1U << cinfo->data_precision) - 1U.
474
 * In this case we just read right into the _JSAMPLE buffer!
475
 * Note that same code works for PPM and PGM files.
476
 */
477
0
{
478
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
479
480
0
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
481
0
    ERREXIT(cinfo, JERR_INPUT_EOF);
482
0
  return 1;
483
0
}
484
485
#endif
486
487
488
METHODDEF(JDIMENSION)
489
get_word_gray_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
490
/* This version is for reading raw-word-format PGM files with any maxval */
491
34.6k
{
492
34.6k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
493
34.6k
  register _JSAMPROW ptr;
494
34.6k
  register unsigned char *bufferptr;
495
34.6k
  register _JSAMPLE *rescale = source->rescale;
496
34.6k
  JDIMENSION col;
497
34.6k
  unsigned int maxval = source->maxval;
498
499
34.6k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
500
84
    ERREXIT(cinfo, JERR_INPUT_EOF);
501
34.6k
  ptr = source->pub._buffer[0];
502
34.6k
  bufferptr = source->iobuffer;
503
70.3k
  for (col = cinfo->image_width; col > 0; col--) {
504
35.7k
    register unsigned int temp;
505
35.7k
    temp  = (*bufferptr++) << 8;
506
35.7k
    temp |= (*bufferptr++);
507
35.7k
    if (temp > maxval)
508
57
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
509
35.7k
    *ptr++ = rescale[temp];
510
35.7k
  }
511
34.6k
  return 1;
512
34.6k
}
Unexecuted instantiation: rdppm-8.c:get_word_gray_row
rdppm-12.c:get_word_gray_row
Line
Count
Source
491
34.6k
{
492
34.6k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
493
34.6k
  register _JSAMPROW ptr;
494
34.6k
  register unsigned char *bufferptr;
495
34.6k
  register _JSAMPLE *rescale = source->rescale;
496
34.6k
  JDIMENSION col;
497
34.6k
  unsigned int maxval = source->maxval;
498
499
34.6k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
500
84
    ERREXIT(cinfo, JERR_INPUT_EOF);
501
34.6k
  ptr = source->pub._buffer[0];
502
34.6k
  bufferptr = source->iobuffer;
503
70.3k
  for (col = cinfo->image_width; col > 0; col--) {
504
35.7k
    register unsigned int temp;
505
35.7k
    temp  = (*bufferptr++) << 8;
506
35.7k
    temp |= (*bufferptr++);
507
35.7k
    if (temp > maxval)
508
57
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
509
35.7k
    *ptr++ = rescale[temp];
510
35.7k
  }
511
34.6k
  return 1;
512
34.6k
}
Unexecuted instantiation: rdppm-16.c:get_word_gray_row
513
514
515
METHODDEF(JDIMENSION)
516
get_word_gray_rgb_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
517
/* This version is for reading raw-word-format PGM files with any maxval */
518
173k
{
519
173k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
520
173k
  register _JSAMPROW ptr;
521
173k
  register unsigned char *bufferptr;
522
173k
  register _JSAMPLE *rescale = source->rescale;
523
173k
  JDIMENSION col;
524
173k
  unsigned int maxval = source->maxval;
525
173k
  register int rindex = rgb_red[cinfo->in_color_space];
526
173k
  register int gindex = rgb_green[cinfo->in_color_space];
527
173k
  register int bindex = rgb_blue[cinfo->in_color_space];
528
173k
  register int aindex = alpha_index[cinfo->in_color_space];
529
173k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
530
531
173k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
532
420
    ERREXIT(cinfo, JERR_INPUT_EOF);
533
173k
  ptr = source->pub._buffer[0];
534
173k
  bufferptr = source->iobuffer;
535
351k
  for (col = cinfo->image_width; col > 0; col--) {
536
178k
    register unsigned int temp;
537
178k
    temp  = (*bufferptr++) << 8;
538
178k
    temp |= (*bufferptr++);
539
178k
    if (temp > maxval)
540
285
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
541
178k
    ptr[rindex] = ptr[gindex] = ptr[bindex] = rescale[temp];
542
178k
    if (aindex >= 0)
543
35.7k
      ptr[aindex] = (1 << cinfo->data_precision) - 1;
544
178k
    ptr += ps;
545
178k
  }
546
173k
  return 1;
547
173k
}
Unexecuted instantiation: rdppm-8.c:get_word_gray_rgb_row
rdppm-12.c:get_word_gray_rgb_row
Line
Count
Source
518
173k
{
519
173k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
520
173k
  register _JSAMPROW ptr;
521
173k
  register unsigned char *bufferptr;
522
173k
  register _JSAMPLE *rescale = source->rescale;
523
173k
  JDIMENSION col;
524
173k
  unsigned int maxval = source->maxval;
525
173k
  register int rindex = rgb_red[cinfo->in_color_space];
526
173k
  register int gindex = rgb_green[cinfo->in_color_space];
527
173k
  register int bindex = rgb_blue[cinfo->in_color_space];
528
173k
  register int aindex = alpha_index[cinfo->in_color_space];
529
173k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
530
531
173k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
532
420
    ERREXIT(cinfo, JERR_INPUT_EOF);
533
173k
  ptr = source->pub._buffer[0];
534
173k
  bufferptr = source->iobuffer;
535
351k
  for (col = cinfo->image_width; col > 0; col--) {
536
178k
    register unsigned int temp;
537
178k
    temp  = (*bufferptr++) << 8;
538
178k
    temp |= (*bufferptr++);
539
178k
    if (temp > maxval)
540
285
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
541
178k
    ptr[rindex] = ptr[gindex] = ptr[bindex] = rescale[temp];
542
178k
    if (aindex >= 0)
543
35.7k
      ptr[aindex] = (1 << cinfo->data_precision) - 1;
544
178k
    ptr += ps;
545
178k
  }
546
173k
  return 1;
547
173k
}
Unexecuted instantiation: rdppm-16.c:get_word_gray_rgb_row
548
549
550
METHODDEF(JDIMENSION)
551
get_word_gray_cmyk_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
552
/* This version is for reading raw-word-format PGM files with any maxval */
553
34.6k
{
554
34.6k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
555
34.6k
  register _JSAMPROW ptr;
556
34.6k
  register unsigned char *bufferptr;
557
34.6k
  register _JSAMPLE *rescale = source->rescale;
558
34.6k
  JDIMENSION col;
559
34.6k
  unsigned int maxval = source->maxval;
560
561
34.6k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
562
84
    ERREXIT(cinfo, JERR_INPUT_EOF);
563
34.6k
  ptr = source->pub._buffer[0];
564
34.6k
  bufferptr = source->iobuffer;
565
34.6k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
566
1.09k
    for (col = cinfo->image_width; col > 0; col--) {
567
823
      register unsigned int gray;
568
823
      gray  = (*bufferptr++) << 8;
569
823
      gray |= (*bufferptr++);
570
823
      if (gray > maxval)
571
20
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
572
823
      rgb_to_cmyk(maxval, (_JSAMPLE)gray, (_JSAMPLE)gray, (_JSAMPLE)gray, ptr,
573
823
                  ptr + 1, ptr + 2, ptr + 3);
574
823
      ptr += 4;
575
823
    }
576
34.3k
  } else {
577
69.2k
    for (col = cinfo->image_width; col > 0; col--) {
578
34.9k
      register unsigned int temp;
579
34.9k
      _JSAMPLE gray;
580
34.9k
      temp  = (*bufferptr++) << 8;
581
34.9k
      temp |= (*bufferptr++);
582
34.9k
      if (temp > maxval)
583
37
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
584
34.9k
      gray = rescale[temp];
585
34.9k
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, gray, gray, gray, ptr,
586
34.9k
                  ptr + 1, ptr + 2, ptr + 3);
587
34.9k
      ptr += 4;
588
34.9k
    }
589
34.3k
  }
590
34.6k
  return 1;
591
34.6k
}
Unexecuted instantiation: rdppm-8.c:get_word_gray_cmyk_row
rdppm-12.c:get_word_gray_cmyk_row
Line
Count
Source
553
34.6k
{
554
34.6k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
555
34.6k
  register _JSAMPROW ptr;
556
34.6k
  register unsigned char *bufferptr;
557
34.6k
  register _JSAMPLE *rescale = source->rescale;
558
34.6k
  JDIMENSION col;
559
34.6k
  unsigned int maxval = source->maxval;
560
561
34.6k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
562
84
    ERREXIT(cinfo, JERR_INPUT_EOF);
563
34.6k
  ptr = source->pub._buffer[0];
564
34.6k
  bufferptr = source->iobuffer;
565
34.6k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
566
1.09k
    for (col = cinfo->image_width; col > 0; col--) {
567
823
      register unsigned int gray;
568
823
      gray  = (*bufferptr++) << 8;
569
823
      gray |= (*bufferptr++);
570
823
      if (gray > maxval)
571
20
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
572
823
      rgb_to_cmyk(maxval, (_JSAMPLE)gray, (_JSAMPLE)gray, (_JSAMPLE)gray, ptr,
573
823
                  ptr + 1, ptr + 2, ptr + 3);
574
823
      ptr += 4;
575
823
    }
576
34.3k
  } else {
577
69.2k
    for (col = cinfo->image_width; col > 0; col--) {
578
34.9k
      register unsigned int temp;
579
34.9k
      _JSAMPLE gray;
580
34.9k
      temp  = (*bufferptr++) << 8;
581
34.9k
      temp |= (*bufferptr++);
582
34.9k
      if (temp > maxval)
583
37
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
584
34.9k
      gray = rescale[temp];
585
34.9k
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, gray, gray, gray, ptr,
586
34.9k
                  ptr + 1, ptr + 2, ptr + 3);
587
34.9k
      ptr += 4;
588
34.9k
    }
589
34.3k
  }
590
34.6k
  return 1;
591
34.6k
}
Unexecuted instantiation: rdppm-16.c:get_word_gray_cmyk_row
592
593
594
METHODDEF(JDIMENSION)
595
get_word_rgb_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
596
/* This version is for reading raw-word-format PPM files with any maxval */
597
15.4k
{
598
15.4k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
599
15.4k
  register _JSAMPROW ptr;
600
15.4k
  register unsigned char *bufferptr;
601
15.4k
  register _JSAMPLE *rescale = source->rescale;
602
15.4k
  JDIMENSION col;
603
15.4k
  unsigned int maxval = source->maxval;
604
15.4k
  register int rindex = rgb_red[cinfo->in_color_space];
605
15.4k
  register int gindex = rgb_green[cinfo->in_color_space];
606
15.4k
  register int bindex = rgb_blue[cinfo->in_color_space];
607
15.4k
  register int aindex = alpha_index[cinfo->in_color_space];
608
15.4k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
609
610
15.4k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
611
570
    ERREXIT(cinfo, JERR_INPUT_EOF);
612
15.4k
  ptr = source->pub._buffer[0];
613
15.4k
  bufferptr = source->iobuffer;
614
37.1k
  for (col = cinfo->image_width; col > 0; col--) {
615
21.7k
    register unsigned int temp;
616
21.7k
    temp  = (*bufferptr++) << 8;
617
21.7k
    temp |= (*bufferptr++);
618
21.7k
    if (temp > maxval)
619
230
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
620
21.7k
    ptr[rindex] = rescale[temp];
621
21.7k
    temp  = (*bufferptr++) << 8;
622
21.7k
    temp |= (*bufferptr++);
623
21.7k
    if (temp > maxval)
624
230
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
625
21.7k
    ptr[gindex] = rescale[temp];
626
21.7k
    temp  = (*bufferptr++) << 8;
627
21.7k
    temp |= (*bufferptr++);
628
21.7k
    if (temp > maxval)
629
195
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
630
21.7k
    ptr[bindex] = rescale[temp];
631
21.7k
    if (aindex >= 0)
632
4.22k
      ptr[aindex] = (1 << cinfo->data_precision) - 1;
633
21.7k
    ptr += ps;
634
21.7k
  }
635
15.4k
  return 1;
636
15.4k
}
Unexecuted instantiation: rdppm-8.c:get_word_rgb_row
rdppm-12.c:get_word_rgb_row
Line
Count
Source
597
15.4k
{
598
15.4k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
599
15.4k
  register _JSAMPROW ptr;
600
15.4k
  register unsigned char *bufferptr;
601
15.4k
  register _JSAMPLE *rescale = source->rescale;
602
15.4k
  JDIMENSION col;
603
15.4k
  unsigned int maxval = source->maxval;
604
15.4k
  register int rindex = rgb_red[cinfo->in_color_space];
605
15.4k
  register int gindex = rgb_green[cinfo->in_color_space];
606
15.4k
  register int bindex = rgb_blue[cinfo->in_color_space];
607
15.4k
  register int aindex = alpha_index[cinfo->in_color_space];
608
15.4k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
609
610
15.4k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
611
570
    ERREXIT(cinfo, JERR_INPUT_EOF);
612
15.4k
  ptr = source->pub._buffer[0];
613
15.4k
  bufferptr = source->iobuffer;
614
37.1k
  for (col = cinfo->image_width; col > 0; col--) {
615
21.7k
    register unsigned int temp;
616
21.7k
    temp  = (*bufferptr++) << 8;
617
21.7k
    temp |= (*bufferptr++);
618
21.7k
    if (temp > maxval)
619
230
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
620
21.7k
    ptr[rindex] = rescale[temp];
621
21.7k
    temp  = (*bufferptr++) << 8;
622
21.7k
    temp |= (*bufferptr++);
623
21.7k
    if (temp > maxval)
624
230
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
625
21.7k
    ptr[gindex] = rescale[temp];
626
21.7k
    temp  = (*bufferptr++) << 8;
627
21.7k
    temp |= (*bufferptr++);
628
21.7k
    if (temp > maxval)
629
195
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
630
21.7k
    ptr[bindex] = rescale[temp];
631
21.7k
    if (aindex >= 0)
632
4.22k
      ptr[aindex] = (1 << cinfo->data_precision) - 1;
633
21.7k
    ptr += ps;
634
21.7k
  }
635
15.4k
  return 1;
636
15.4k
}
Unexecuted instantiation: rdppm-16.c:get_word_rgb_row
637
638
639
METHODDEF(JDIMENSION)
640
get_word_rgb_cmyk_row(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
641
/* This version is for reading raw-word-format PPM files with any maxval */
642
3.08k
{
643
3.08k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
644
3.08k
  register _JSAMPROW ptr;
645
3.08k
  register unsigned char *bufferptr;
646
3.08k
  register _JSAMPLE *rescale = source->rescale;
647
3.08k
  JDIMENSION col;
648
3.08k
  unsigned int maxval = source->maxval;
649
650
3.08k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
651
114
    ERREXIT(cinfo, JERR_INPUT_EOF);
652
3.08k
  ptr = source->pub._buffer[0];
653
3.08k
  bufferptr = source->iobuffer;
654
3.08k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
655
1.57k
    for (col = cinfo->image_width; col > 0; col--) {
656
1.07k
      register unsigned int r, g, b;
657
1.07k
      r  = (*bufferptr++) << 8;
658
1.07k
      r |= (*bufferptr++);
659
1.07k
      if (r > maxval)
660
17
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
661
1.07k
      g  = (*bufferptr++) << 8;
662
1.07k
      g |= (*bufferptr++);
663
1.07k
      if (g > maxval)
664
20
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
665
1.07k
      b  = (*bufferptr++) << 8;
666
1.07k
      b |= (*bufferptr++);
667
1.07k
      if (b > maxval)
668
19
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
669
1.07k
      rgb_to_cmyk(maxval, (_JSAMPLE)r, (_JSAMPLE)g, (_JSAMPLE)b, ptr, ptr + 1,
670
1.07k
                  ptr + 2, ptr + 3);
671
1.07k
      ptr += 4;
672
1.07k
    }
673
2.57k
  } else {
674
5.85k
    for (col = cinfo->image_width; col > 0; col--) {
675
3.27k
      register unsigned int r, g, b;
676
3.27k
      r  = (*bufferptr++) << 8;
677
3.27k
      r |= (*bufferptr++);
678
3.27k
      if (r > maxval)
679
29
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
680
3.27k
      g  = (*bufferptr++) << 8;
681
3.27k
      g |= (*bufferptr++);
682
3.27k
      if (g > maxval)
683
26
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
684
3.27k
      b  = (*bufferptr++) << 8;
685
3.27k
      b |= (*bufferptr++);
686
3.27k
      if (b > maxval)
687
20
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
688
3.27k
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, rescale[r], rescale[g],
689
3.27k
                  rescale[b], ptr, ptr + 1, ptr + 2, ptr + 3);
690
3.27k
      ptr += 4;
691
3.27k
    }
692
2.57k
  }
693
3.08k
  return 1;
694
3.08k
}
Unexecuted instantiation: rdppm-8.c:get_word_rgb_cmyk_row
rdppm-12.c:get_word_rgb_cmyk_row
Line
Count
Source
642
3.08k
{
643
3.08k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
644
3.08k
  register _JSAMPROW ptr;
645
3.08k
  register unsigned char *bufferptr;
646
3.08k
  register _JSAMPLE *rescale = source->rescale;
647
3.08k
  JDIMENSION col;
648
3.08k
  unsigned int maxval = source->maxval;
649
650
3.08k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
651
114
    ERREXIT(cinfo, JERR_INPUT_EOF);
652
3.08k
  ptr = source->pub._buffer[0];
653
3.08k
  bufferptr = source->iobuffer;
654
3.08k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
655
1.57k
    for (col = cinfo->image_width; col > 0; col--) {
656
1.07k
      register unsigned int r, g, b;
657
1.07k
      r  = (*bufferptr++) << 8;
658
1.07k
      r |= (*bufferptr++);
659
1.07k
      if (r > maxval)
660
17
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
661
1.07k
      g  = (*bufferptr++) << 8;
662
1.07k
      g |= (*bufferptr++);
663
1.07k
      if (g > maxval)
664
20
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
665
1.07k
      b  = (*bufferptr++) << 8;
666
1.07k
      b |= (*bufferptr++);
667
1.07k
      if (b > maxval)
668
19
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
669
1.07k
      rgb_to_cmyk(maxval, (_JSAMPLE)r, (_JSAMPLE)g, (_JSAMPLE)b, ptr, ptr + 1,
670
1.07k
                  ptr + 2, ptr + 3);
671
1.07k
      ptr += 4;
672
1.07k
    }
673
2.57k
  } else {
674
5.85k
    for (col = cinfo->image_width; col > 0; col--) {
675
3.27k
      register unsigned int r, g, b;
676
3.27k
      r  = (*bufferptr++) << 8;
677
3.27k
      r |= (*bufferptr++);
678
3.27k
      if (r > maxval)
679
29
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
680
3.27k
      g  = (*bufferptr++) << 8;
681
3.27k
      g |= (*bufferptr++);
682
3.27k
      if (g > maxval)
683
26
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
684
3.27k
      b  = (*bufferptr++) << 8;
685
3.27k
      b |= (*bufferptr++);
686
3.27k
      if (b > maxval)
687
20
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
688
3.27k
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, rescale[r], rescale[g],
689
3.27k
                  rescale[b], ptr, ptr + 1, ptr + 2, ptr + 3);
690
3.27k
      ptr += 4;
691
3.27k
    }
692
2.57k
  }
693
3.08k
  return 1;
694
3.08k
}
Unexecuted instantiation: rdppm-16.c:get_word_rgb_cmyk_row
695
696
697
/*
698
 * Read the file header; return image size and component count.
699
 */
700
701
METHODDEF(void)
702
start_input_ppm(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
703
18.9k
{
704
18.9k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
705
18.9k
  int c;
706
18.9k
  unsigned int w, h, maxval;
707
18.9k
  boolean need_iobuffer, use_raw_buffer, need_rescale;
708
709
18.9k
  if (getc(source->pub.input_file) != 'P')
710
0
    ERREXIT(cinfo, JERR_PPM_NOT);
711
712
18.9k
  c = getc(source->pub.input_file); /* subformat discriminator character */
713
714
  /* detect unsupported variants (ie, PBM) before trying to read header */
715
18.9k
  switch (c) {
716
1.47k
  case '2':                     /* it's a text-format PGM file */
717
3.09k
  case '3':                     /* it's a text-format PPM file */
718
14.5k
  case '5':                     /* it's a raw-format PGM file */
719
18.9k
  case '6':                     /* it's a raw-format PPM file */
720
18.9k
    break;
721
49
  default:
722
49
    ERREXIT(cinfo, JERR_PPM_NOT);
723
49
    break;
724
18.9k
  }
725
726
  /* fetch the remaining header info */
727
18.9k
  w = read_pbm_integer(cinfo, source->pub.input_file, 65535);
728
18.9k
  h = read_pbm_integer(cinfo, source->pub.input_file, 65535);
729
18.9k
  maxval = read_pbm_integer(cinfo, source->pub.input_file, 65535);
730
731
18.9k
  if (w <= 0 || h <= 0 || maxval <= 0) /* error check */
732
35
    ERREXIT(cinfo, JERR_PPM_NOT);
733
18.9k
  if (w > JPEG_MAX_DIMENSION || h > JPEG_MAX_DIMENSION)
734
21
    ERREXIT1(cinfo, JERR_IMAGE_TOO_BIG, JPEG_MAX_DIMENSION);
735
18.9k
  if (sinfo->max_pixels && (unsigned long long)w * h > sinfo->max_pixels)
736
252
    ERREXIT1(cinfo, JERR_IMAGE_TOO_BIG, sinfo->max_pixels);
737
738
18.9k
  cinfo->image_width = (JDIMENSION)w;
739
18.9k
  cinfo->image_height = (JDIMENSION)h;
740
18.9k
  source->maxval = maxval;
741
742
  /* initialize flags to most common settings */
743
18.9k
  need_iobuffer = TRUE;         /* do we need an I/O buffer? */
744
18.9k
  use_raw_buffer = FALSE;       /* do we map input buffer onto I/O buffer? */
745
18.9k
  need_rescale = TRUE;          /* do we need a rescale array? */
746
747
18.9k
  switch (c) {
748
1.02k
  case '2':                     /* it's a text-format PGM file */
749
1.02k
    if (cinfo->in_color_space == JCS_UNKNOWN ||
750
1.02k
        cinfo->in_color_space == JCS_RGB)
751
0
      cinfo->in_color_space = JCS_GRAYSCALE;
752
1.02k
    TRACEMS3(cinfo, 1, JTRC_PGM_TEXT, w, h, maxval);
753
1.02k
    if (cinfo->in_color_space == JCS_GRAYSCALE)
754
146
      source->pub.get_pixel_rows = get_text_gray_row;
755
876
    else if (IsExtRGB(cinfo->in_color_space))
756
730
      source->pub.get_pixel_rows = get_text_gray_rgb_row;
757
146
    else if (cinfo->in_color_space == JCS_CMYK)
758
146
      source->pub.get_pixel_rows = get_text_gray_cmyk_row;
759
0
    else
760
0
      ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
761
1.02k
    need_iobuffer = FALSE;
762
1.02k
    break;
763
764
1.23k
  case '3':                     /* it's a text-format PPM file */
765
1.23k
    if (cinfo->in_color_space == JCS_UNKNOWN)
766
0
      cinfo->in_color_space = JCS_EXT_RGB;
767
1.23k
    TRACEMS3(cinfo, 1, JTRC_PPM_TEXT, w, h, maxval);
768
1.23k
    if (IsExtRGB(cinfo->in_color_space))
769
885
      source->pub.get_pixel_rows = get_text_rgb_row;
770
354
    else if (cinfo->in_color_space == JCS_CMYK)
771
177
      source->pub.get_pixel_rows = get_text_rgb_cmyk_row;
772
177
    else
773
177
      ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
774
1.23k
    need_iobuffer = FALSE;
775
1.23k
    break;
776
777
10.9k
  case '5':                     /* it's a raw-format PGM file */
778
10.9k
    if (cinfo->in_color_space == JCS_UNKNOWN ||
779
10.9k
        cinfo->in_color_space == JCS_RGB)
780
0
      cinfo->in_color_space = JCS_GRAYSCALE;
781
10.9k
    TRACEMS3(cinfo, 1, JTRC_PGM, w, h, maxval);
782
10.9k
    if (maxval > 255) {
783
1.08k
      if (cinfo->in_color_space == JCS_GRAYSCALE)
784
155
        source->pub.get_pixel_rows = get_word_gray_row;
785
930
      else if (IsExtRGB(cinfo->in_color_space))
786
775
        source->pub.get_pixel_rows = get_word_gray_rgb_row;
787
155
      else if (cinfo->in_color_space == JCS_CMYK)
788
155
        source->pub.get_pixel_rows = get_word_gray_cmyk_row;
789
0
      else
790
0
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
791
#if BITS_IN_JSAMPLE == 8
792
0
    } else if (maxval <= _MAXJSAMPLE &&
793
0
               maxval == ((1U << cinfo->data_precision) - 1U) &&
794
0
               cinfo->in_color_space == JCS_GRAYSCALE) {
795
0
      source->pub.get_pixel_rows = get_raw_row;
796
0
      use_raw_buffer = TRUE;
797
0
      need_rescale = FALSE;
798
#endif
799
9.91k
    } else {
800
9.91k
      if (cinfo->in_color_space == JCS_GRAYSCALE)
801
1.41k
        source->pub.get_pixel_rows = get_scaled_gray_row;
802
8.49k
      else if (IsExtRGB(cinfo->in_color_space))
803
7.08k
        source->pub.get_pixel_rows = get_gray_rgb_row;
804
1.41k
      else if (cinfo->in_color_space == JCS_CMYK)
805
1.41k
        source->pub.get_pixel_rows = get_gray_cmyk_row;
806
0
      else
807
0
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
808
9.91k
    }
809
10.9k
    break;
810
811
4.12k
  case '6':                     /* it's a raw-format PPM file */
812
4.12k
    if (cinfo->in_color_space == JCS_UNKNOWN)
813
0
      cinfo->in_color_space = JCS_EXT_RGB;
814
4.12k
    TRACEMS3(cinfo, 1, JTRC_PPM, w, h, maxval);
815
4.12k
    if (maxval > 255) {
816
1.77k
      if (IsExtRGB(cinfo->in_color_space))
817
1.27k
        source->pub.get_pixel_rows = get_word_rgb_row;
818
508
      else if (cinfo->in_color_space == JCS_CMYK)
819
254
        source->pub.get_pixel_rows = get_word_rgb_cmyk_row;
820
254
      else
821
254
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
822
#if BITS_IN_JSAMPLE == 8
823
0
    } else if (maxval <= _MAXJSAMPLE &&
824
0
               maxval == ((1U << cinfo->data_precision) - 1U) &&
825
0
#if RGB_RED == 0 && RGB_GREEN == 1 && RGB_BLUE == 2 && RGB_PIXELSIZE == 3
826
0
               (cinfo->in_color_space == JCS_EXT_RGB ||
827
0
                cinfo->in_color_space == JCS_RGB)) {
828
#else
829
               cinfo->in_color_space == JCS_EXT_RGB) {
830
#endif
831
0
      source->pub.get_pixel_rows = get_raw_row;
832
0
      use_raw_buffer = TRUE;
833
0
      need_rescale = FALSE;
834
#endif
835
2.34k
    } else {
836
2.34k
      if (IsExtRGB(cinfo->in_color_space))
837
1.67k
        source->pub.get_pixel_rows = get_rgb_row;
838
670
      else if (cinfo->in_color_space == JCS_CMYK)
839
335
        source->pub.get_pixel_rows = get_rgb_cmyk_row;
840
335
      else
841
335
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
842
2.34k
    }
843
4.12k
    break;
844
18.9k
  }
845
846
16.6k
  if (IsExtRGB(cinfo->in_color_space))
847
12.4k
    cinfo->input_components = rgb_pixelsize[cinfo->in_color_space];
848
4.20k
  else if (cinfo->in_color_space == JCS_GRAYSCALE)
849
1.71k
    cinfo->input_components = 1;
850
2.48k
  else if (cinfo->in_color_space == JCS_CMYK)
851
2.48k
    cinfo->input_components = 4;
852
853
  /* Allocate space for I/O buffer: 1 or 3 bytes or words/pixel. */
854
16.6k
  if (need_iobuffer) {
855
14.5k
    if (c == '6')
856
3.53k
      source->buffer_width = (size_t)w * 3 * (maxval <= 255 ? 1 : 2);
857
10.9k
    else
858
10.9k
      source->buffer_width = (size_t)w * (maxval <= 255 ? 1 : 2);
859
14.5k
    source->iobuffer = (unsigned char *)
860
14.5k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
861
14.5k
                                  source->buffer_width);
862
14.5k
  }
863
864
  /* Create compressor input buffer. */
865
16.6k
  if (use_raw_buffer) {
866
    /* For unscaled raw-input case, we can just map it onto the I/O buffer. */
867
    /* Synthesize a _JSAMPARRAY pointer structure */
868
0
    source->pixrow = (_JSAMPROW)source->iobuffer;
869
0
    source->pub._buffer = &source->pixrow;
870
0
    source->pub.buffer_height = 1;
871
16.6k
  } else {
872
    /* Need to translate anyway, so make a separate sample buffer. */
873
16.6k
    source->pub._buffer = (_JSAMPARRAY)(*cinfo->mem->alloc_sarray)
874
16.6k
      ((j_common_ptr)cinfo, JPOOL_IMAGE,
875
16.6k
       (JDIMENSION)w * cinfo->input_components, (JDIMENSION)1);
876
16.6k
    source->pub.buffer_height = 1;
877
16.6k
  }
878
879
  /* Compute the rescaling array if required. */
880
16.6k
  if (need_rescale) {
881
16.6k
    size_t val, half_maxval;
882
883
    /* On 16-bit-int machines we have to be careful of maxval = 65535 */
884
16.6k
    source->rescale = (_JSAMPLE *)
885
16.6k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
886
16.6k
                                  (MAX(maxval, 255) + 1L) * sizeof(_JSAMPLE));
887
16.6k
    memset(source->rescale, 0, (MAX(maxval, 255) + 1L) * sizeof(_JSAMPLE));
888
16.6k
    half_maxval = (size_t)maxval / 2;
889
28.4M
    for (val = 0; val <= (size_t)maxval; val++) {
890
      /* The multiplication here must be done in 32 bits to avoid overflow */
891
28.3M
      source->rescale[val] =
892
28.3M
        (_JSAMPLE)((val * ((1 << cinfo->data_precision) - 1) + half_maxval) /
893
28.3M
                   maxval);
894
28.3M
    }
895
16.6k
  }
896
16.6k
}
Unexecuted instantiation: rdppm-8.c:start_input_ppm
rdppm-12.c:start_input_ppm
Line
Count
Source
703
18.9k
{
704
18.9k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
705
18.9k
  int c;
706
18.9k
  unsigned int w, h, maxval;
707
18.9k
  boolean need_iobuffer, use_raw_buffer, need_rescale;
708
709
18.9k
  if (getc(source->pub.input_file) != 'P')
710
0
    ERREXIT(cinfo, JERR_PPM_NOT);
711
712
18.9k
  c = getc(source->pub.input_file); /* subformat discriminator character */
713
714
  /* detect unsupported variants (ie, PBM) before trying to read header */
715
18.9k
  switch (c) {
716
1.47k
  case '2':                     /* it's a text-format PGM file */
717
3.09k
  case '3':                     /* it's a text-format PPM file */
718
14.5k
  case '5':                     /* it's a raw-format PGM file */
719
18.9k
  case '6':                     /* it's a raw-format PPM file */
720
18.9k
    break;
721
49
  default:
722
49
    ERREXIT(cinfo, JERR_PPM_NOT);
723
49
    break;
724
18.9k
  }
725
726
  /* fetch the remaining header info */
727
18.9k
  w = read_pbm_integer(cinfo, source->pub.input_file, 65535);
728
18.9k
  h = read_pbm_integer(cinfo, source->pub.input_file, 65535);
729
18.9k
  maxval = read_pbm_integer(cinfo, source->pub.input_file, 65535);
730
731
18.9k
  if (w <= 0 || h <= 0 || maxval <= 0) /* error check */
732
35
    ERREXIT(cinfo, JERR_PPM_NOT);
733
18.9k
  if (w > JPEG_MAX_DIMENSION || h > JPEG_MAX_DIMENSION)
734
21
    ERREXIT1(cinfo, JERR_IMAGE_TOO_BIG, JPEG_MAX_DIMENSION);
735
18.9k
  if (sinfo->max_pixels && (unsigned long long)w * h > sinfo->max_pixels)
736
252
    ERREXIT1(cinfo, JERR_IMAGE_TOO_BIG, sinfo->max_pixels);
737
738
18.9k
  cinfo->image_width = (JDIMENSION)w;
739
18.9k
  cinfo->image_height = (JDIMENSION)h;
740
18.9k
  source->maxval = maxval;
741
742
  /* initialize flags to most common settings */
743
18.9k
  need_iobuffer = TRUE;         /* do we need an I/O buffer? */
744
18.9k
  use_raw_buffer = FALSE;       /* do we map input buffer onto I/O buffer? */
745
18.9k
  need_rescale = TRUE;          /* do we need a rescale array? */
746
747
18.9k
  switch (c) {
748
1.02k
  case '2':                     /* it's a text-format PGM file */
749
1.02k
    if (cinfo->in_color_space == JCS_UNKNOWN ||
750
1.02k
        cinfo->in_color_space == JCS_RGB)
751
0
      cinfo->in_color_space = JCS_GRAYSCALE;
752
1.02k
    TRACEMS3(cinfo, 1, JTRC_PGM_TEXT, w, h, maxval);
753
1.02k
    if (cinfo->in_color_space == JCS_GRAYSCALE)
754
146
      source->pub.get_pixel_rows = get_text_gray_row;
755
876
    else if (IsExtRGB(cinfo->in_color_space))
756
730
      source->pub.get_pixel_rows = get_text_gray_rgb_row;
757
146
    else if (cinfo->in_color_space == JCS_CMYK)
758
146
      source->pub.get_pixel_rows = get_text_gray_cmyk_row;
759
0
    else
760
0
      ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
761
1.02k
    need_iobuffer = FALSE;
762
1.02k
    break;
763
764
1.23k
  case '3':                     /* it's a text-format PPM file */
765
1.23k
    if (cinfo->in_color_space == JCS_UNKNOWN)
766
0
      cinfo->in_color_space = JCS_EXT_RGB;
767
1.23k
    TRACEMS3(cinfo, 1, JTRC_PPM_TEXT, w, h, maxval);
768
1.23k
    if (IsExtRGB(cinfo->in_color_space))
769
885
      source->pub.get_pixel_rows = get_text_rgb_row;
770
354
    else if (cinfo->in_color_space == JCS_CMYK)
771
177
      source->pub.get_pixel_rows = get_text_rgb_cmyk_row;
772
177
    else
773
177
      ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
774
1.23k
    need_iobuffer = FALSE;
775
1.23k
    break;
776
777
10.9k
  case '5':                     /* it's a raw-format PGM file */
778
10.9k
    if (cinfo->in_color_space == JCS_UNKNOWN ||
779
10.9k
        cinfo->in_color_space == JCS_RGB)
780
0
      cinfo->in_color_space = JCS_GRAYSCALE;
781
10.9k
    TRACEMS3(cinfo, 1, JTRC_PGM, w, h, maxval);
782
10.9k
    if (maxval > 255) {
783
1.08k
      if (cinfo->in_color_space == JCS_GRAYSCALE)
784
155
        source->pub.get_pixel_rows = get_word_gray_row;
785
930
      else if (IsExtRGB(cinfo->in_color_space))
786
775
        source->pub.get_pixel_rows = get_word_gray_rgb_row;
787
155
      else if (cinfo->in_color_space == JCS_CMYK)
788
155
        source->pub.get_pixel_rows = get_word_gray_cmyk_row;
789
0
      else
790
0
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
791
#if BITS_IN_JSAMPLE == 8
792
    } else if (maxval <= _MAXJSAMPLE &&
793
               maxval == ((1U << cinfo->data_precision) - 1U) &&
794
               cinfo->in_color_space == JCS_GRAYSCALE) {
795
      source->pub.get_pixel_rows = get_raw_row;
796
      use_raw_buffer = TRUE;
797
      need_rescale = FALSE;
798
#endif
799
9.91k
    } else {
800
9.91k
      if (cinfo->in_color_space == JCS_GRAYSCALE)
801
1.41k
        source->pub.get_pixel_rows = get_scaled_gray_row;
802
8.49k
      else if (IsExtRGB(cinfo->in_color_space))
803
7.08k
        source->pub.get_pixel_rows = get_gray_rgb_row;
804
1.41k
      else if (cinfo->in_color_space == JCS_CMYK)
805
1.41k
        source->pub.get_pixel_rows = get_gray_cmyk_row;
806
0
      else
807
0
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
808
9.91k
    }
809
10.9k
    break;
810
811
4.12k
  case '6':                     /* it's a raw-format PPM file */
812
4.12k
    if (cinfo->in_color_space == JCS_UNKNOWN)
813
0
      cinfo->in_color_space = JCS_EXT_RGB;
814
4.12k
    TRACEMS3(cinfo, 1, JTRC_PPM, w, h, maxval);
815
4.12k
    if (maxval > 255) {
816
1.77k
      if (IsExtRGB(cinfo->in_color_space))
817
1.27k
        source->pub.get_pixel_rows = get_word_rgb_row;
818
508
      else if (cinfo->in_color_space == JCS_CMYK)
819
254
        source->pub.get_pixel_rows = get_word_rgb_cmyk_row;
820
254
      else
821
254
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
822
#if BITS_IN_JSAMPLE == 8
823
    } else if (maxval <= _MAXJSAMPLE &&
824
               maxval == ((1U << cinfo->data_precision) - 1U) &&
825
#if RGB_RED == 0 && RGB_GREEN == 1 && RGB_BLUE == 2 && RGB_PIXELSIZE == 3
826
               (cinfo->in_color_space == JCS_EXT_RGB ||
827
                cinfo->in_color_space == JCS_RGB)) {
828
#else
829
               cinfo->in_color_space == JCS_EXT_RGB) {
830
#endif
831
      source->pub.get_pixel_rows = get_raw_row;
832
      use_raw_buffer = TRUE;
833
      need_rescale = FALSE;
834
#endif
835
2.34k
    } else {
836
2.34k
      if (IsExtRGB(cinfo->in_color_space))
837
1.67k
        source->pub.get_pixel_rows = get_rgb_row;
838
670
      else if (cinfo->in_color_space == JCS_CMYK)
839
335
        source->pub.get_pixel_rows = get_rgb_cmyk_row;
840
335
      else
841
335
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
842
2.34k
    }
843
4.12k
    break;
844
18.9k
  }
845
846
16.6k
  if (IsExtRGB(cinfo->in_color_space))
847
12.4k
    cinfo->input_components = rgb_pixelsize[cinfo->in_color_space];
848
4.20k
  else if (cinfo->in_color_space == JCS_GRAYSCALE)
849
1.71k
    cinfo->input_components = 1;
850
2.48k
  else if (cinfo->in_color_space == JCS_CMYK)
851
2.48k
    cinfo->input_components = 4;
852
853
  /* Allocate space for I/O buffer: 1 or 3 bytes or words/pixel. */
854
16.6k
  if (need_iobuffer) {
855
14.5k
    if (c == '6')
856
3.53k
      source->buffer_width = (size_t)w * 3 * (maxval <= 255 ? 1 : 2);
857
10.9k
    else
858
10.9k
      source->buffer_width = (size_t)w * (maxval <= 255 ? 1 : 2);
859
14.5k
    source->iobuffer = (unsigned char *)
860
14.5k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
861
14.5k
                                  source->buffer_width);
862
14.5k
  }
863
864
  /* Create compressor input buffer. */
865
16.6k
  if (use_raw_buffer) {
866
    /* For unscaled raw-input case, we can just map it onto the I/O buffer. */
867
    /* Synthesize a _JSAMPARRAY pointer structure */
868
0
    source->pixrow = (_JSAMPROW)source->iobuffer;
869
0
    source->pub._buffer = &source->pixrow;
870
0
    source->pub.buffer_height = 1;
871
16.6k
  } else {
872
    /* Need to translate anyway, so make a separate sample buffer. */
873
16.6k
    source->pub._buffer = (_JSAMPARRAY)(*cinfo->mem->alloc_sarray)
874
16.6k
      ((j_common_ptr)cinfo, JPOOL_IMAGE,
875
16.6k
       (JDIMENSION)w * cinfo->input_components, (JDIMENSION)1);
876
16.6k
    source->pub.buffer_height = 1;
877
16.6k
  }
878
879
  /* Compute the rescaling array if required. */
880
16.6k
  if (need_rescale) {
881
16.6k
    size_t val, half_maxval;
882
883
    /* On 16-bit-int machines we have to be careful of maxval = 65535 */
884
16.6k
    source->rescale = (_JSAMPLE *)
885
16.6k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
886
16.6k
                                  (MAX(maxval, 255) + 1L) * sizeof(_JSAMPLE));
887
16.6k
    memset(source->rescale, 0, (MAX(maxval, 255) + 1L) * sizeof(_JSAMPLE));
888
16.6k
    half_maxval = (size_t)maxval / 2;
889
28.4M
    for (val = 0; val <= (size_t)maxval; val++) {
890
      /* The multiplication here must be done in 32 bits to avoid overflow */
891
28.3M
      source->rescale[val] =
892
28.3M
        (_JSAMPLE)((val * ((1 << cinfo->data_precision) - 1) + half_maxval) /
893
28.3M
                   maxval);
894
28.3M
    }
895
16.6k
  }
896
16.6k
}
Unexecuted instantiation: rdppm-16.c:start_input_ppm
897
898
899
METHODDEF(boolean)
900
read_icc_profile_ppm(j_compress_ptr cinfo, cjpeg_source_ptr sinfo,
901
                     JOCTET **icc_data_ptr, unsigned int *icc_data_len)
902
0
{
903
0
  return FALSE;
904
0
}
Unexecuted instantiation: rdppm-8.c:read_icc_profile_ppm
Unexecuted instantiation: rdppm-12.c:read_icc_profile_ppm
Unexecuted instantiation: rdppm-16.c:read_icc_profile_ppm
905
906
907
/*
908
 * Finish up at the end of the file.
909
 */
910
911
METHODDEF(void)
912
finish_input_ppm(j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
913
18.9k
{
914
  /* no work */
915
18.9k
}
Unexecuted instantiation: rdppm-8.c:finish_input_ppm
rdppm-12.c:finish_input_ppm
Line
Count
Source
913
18.9k
{
914
  /* no work */
915
18.9k
}
Unexecuted instantiation: rdppm-16.c:finish_input_ppm
916
917
918
/*
919
 * The module selection routine for PPM format input.
920
 */
921
922
GLOBAL(cjpeg_source_ptr)
923
_jinit_read_ppm(j_compress_ptr cinfo)
924
18.9k
{
925
18.9k
  ppm_source_ptr source;
926
927
#if BITS_IN_JSAMPLE == 8
928
0
  if (cinfo->data_precision > BITS_IN_JSAMPLE || cinfo->data_precision < 2)
929
#else
930
18.9k
  if (cinfo->data_precision > BITS_IN_JSAMPLE ||
931
18.9k
      cinfo->data_precision < BITS_IN_JSAMPLE - 3)
932
0
#endif
933
0
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
934
935
  /* Create module interface object */
936
18.9k
  source = (ppm_source_ptr)
937
18.9k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
938
18.9k
                                sizeof(ppm_source_struct));
939
  /* Fill in method ptrs, except get_pixel_rows which start_input sets */
940
18.9k
  source->pub.start_input = start_input_ppm;
941
18.9k
  source->pub.read_icc_profile = read_icc_profile_ppm;
942
18.9k
  source->pub.finish_input = finish_input_ppm;
943
18.9k
  source->pub.max_pixels = 0;
944
945
18.9k
  return (cjpeg_source_ptr)source;
946
18.9k
}
Unexecuted instantiation: jinit_read_ppm
j12init_read_ppm
Line
Count
Source
924
18.9k
{
925
18.9k
  ppm_source_ptr source;
926
927
#if BITS_IN_JSAMPLE == 8
928
  if (cinfo->data_precision > BITS_IN_JSAMPLE || cinfo->data_precision < 2)
929
#else
930
18.9k
  if (cinfo->data_precision > BITS_IN_JSAMPLE ||
931
18.9k
      cinfo->data_precision < BITS_IN_JSAMPLE - 3)
932
0
#endif
933
0
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
934
935
  /* Create module interface object */
936
18.9k
  source = (ppm_source_ptr)
937
18.9k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
938
18.9k
                                sizeof(ppm_source_struct));
939
  /* Fill in method ptrs, except get_pixel_rows which start_input sets */
940
18.9k
  source->pub.start_input = start_input_ppm;
941
18.9k
  source->pub.read_icc_profile = read_icc_profile_ppm;
942
18.9k
  source->pub.finish_input = finish_input_ppm;
943
18.9k
  source->pub.max_pixels = 0;
944
945
18.9k
  return (cjpeg_source_ptr)source;
946
18.9k
}
Unexecuted instantiation: j16init_read_ppm
947
948
#endif /* defined(PPM_SUPPORTED) &&
949
          (BITS_IN_JSAMPLE != 16 || defined(C_LOSSLESS_SUPPORTED)) */