Coverage Report

Created: 2026-05-11 06:56

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
23.4M
  (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
241k
{
74
241k
  register int ch;
75
76
241k
  ch = getc(infile);
77
241k
  if (ch == '#') {
78
56.9k
    do {
79
56.9k
      ch = getc(infile);
80
56.9k
    } while (ch != '\n' && ch != EOF);
81
3.85k
  }
82
241k
  return ch;
83
241k
}
rdppm-8.c:pbm_getc
Line
Count
Source
73
241k
{
74
241k
  register int ch;
75
76
241k
  ch = getc(infile);
77
241k
  if (ch == '#') {
78
56.9k
    do {
79
56.9k
      ch = getc(infile);
80
56.9k
    } while (ch != '\n' && ch != EOF);
81
3.85k
  }
82
241k
  return ch;
83
241k
}
Unexecuted instantiation: rdppm-12.c:pbm_getc
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
102k
{
93
102k
  register int ch;
94
102k
  register unsigned int val;
95
96
  /* Skip any leading whitespace */
97
109k
  do {
98
109k
    ch = pbm_getc(infile);
99
109k
    if (ch == EOF)
100
2.02k
      ERREXIT(cinfo, JERR_INPUT_EOF);
101
109k
  } while (ch == ' ' || ch == '\t' || ch == '\n' || ch == '\r');
102
103
102k
  if (ch < '0' || ch > '9')
104
224
    ERREXIT(cinfo, JERR_PPM_NONNUMERIC);
105
106
102k
  val = ch - '0';
107
134k
  while ((ch = pbm_getc(infile)) >= '0' && ch <= '9') {
108
32.3k
    val *= 10;
109
32.3k
    val += ch - '0';
110
32.3k
    if (val > maxval)
111
114
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
112
32.3k
  }
113
114
102k
  return val;
115
102k
}
rdppm-8.c:read_pbm_integer
Line
Count
Source
92
102k
{
93
102k
  register int ch;
94
102k
  register unsigned int val;
95
96
  /* Skip any leading whitespace */
97
109k
  do {
98
109k
    ch = pbm_getc(infile);
99
109k
    if (ch == EOF)
100
2.02k
      ERREXIT(cinfo, JERR_INPUT_EOF);
101
109k
  } while (ch == ' ' || ch == '\t' || ch == '\n' || ch == '\r');
102
103
102k
  if (ch < '0' || ch > '9')
104
224
    ERREXIT(cinfo, JERR_PPM_NONNUMERIC);
105
106
102k
  val = ch - '0';
107
134k
  while ((ch = pbm_getc(infile)) >= '0' && ch <= '9') {
108
32.3k
    val *= 10;
109
32.3k
    val += ch - '0';
110
32.3k
    if (val > maxval)
111
114
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
112
32.3k
  }
113
114
102k
  return val;
115
102k
}
Unexecuted instantiation: rdppm-12.c:read_pbm_integer
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
2.00k
{
134
2.00k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
135
2.00k
  FILE *infile = source->pub.input_file;
136
2.00k
  register _JSAMPROW ptr;
137
2.00k
  register _JSAMPLE *rescale = source->rescale;
138
2.00k
  JDIMENSION col;
139
2.00k
  unsigned int maxval = source->maxval;
140
141
2.00k
  ptr = source->pub._buffer[0];
142
5.46k
  for (col = cinfo->image_width; col > 0; col--) {
143
3.45k
    *ptr++ = rescale[read_pbm_integer(cinfo, infile, maxval)];
144
3.45k
  }
145
2.00k
  return 1;
146
2.00k
}
rdppm-8.c:get_text_gray_row
Line
Count
Source
133
2.00k
{
134
2.00k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
135
2.00k
  FILE *infile = source->pub.input_file;
136
2.00k
  register _JSAMPROW ptr;
137
2.00k
  register _JSAMPLE *rescale = source->rescale;
138
2.00k
  JDIMENSION col;
139
2.00k
  unsigned int maxval = source->maxval;
140
141
2.00k
  ptr = source->pub._buffer[0];
142
5.46k
  for (col = cinfo->image_width; col > 0; col--) {
143
3.45k
    *ptr++ = rescale[read_pbm_integer(cinfo, infile, maxval)];
144
3.45k
  }
145
2.00k
  return 1;
146
2.00k
}
Unexecuted instantiation: rdppm-12.c:get_text_gray_row
Unexecuted instantiation: rdppm-16.c:get_text_gray_row
147
148
149
19.4M
#define GRAY_RGB_READ_LOOP(read_op, alpha_set_op) { \
150
67.1M
  for (col = cinfo->image_width; col > 0; col--) { \
151
47.6M
    ptr[rindex] = ptr[gindex] = ptr[bindex] = read_op; \
152
47.6M
    alpha_set_op \
153
47.6M
    ptr += ps; \
154
47.6M
  } \
155
19.4M
}
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
10.0k
{
162
10.0k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
163
10.0k
  FILE *infile = source->pub.input_file;
164
10.0k
  register _JSAMPROW ptr;
165
10.0k
  register _JSAMPLE *rescale = source->rescale;
166
10.0k
  JDIMENSION col;
167
10.0k
  unsigned int maxval = source->maxval;
168
10.0k
  register int rindex = rgb_red[cinfo->in_color_space];
169
10.0k
  register int gindex = rgb_green[cinfo->in_color_space];
170
10.0k
  register int bindex = rgb_blue[cinfo->in_color_space];
171
10.0k
  register int aindex = alpha_index[cinfo->in_color_space];
172
10.0k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
173
174
10.0k
  ptr = source->pub._buffer[0];
175
10.0k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
176
2.65k
    if (aindex >= 0)
177
0
      GRAY_RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval),
178
2.65k
                         ptr[aindex] = (_JSAMPLE)maxval;)
179
2.65k
    else
180
2.65k
      GRAY_RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval), {})
181
7.39k
  } else {
182
7.39k
    if (aindex >= 0)
183
0
      GRAY_RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)],
184
7.39k
                         ptr[aindex] = (1 << cinfo->data_precision) - 1;)
185
7.39k
    else
186
7.39k
      GRAY_RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)], {})
187
7.39k
  }
188
10.0k
  return 1;
189
10.0k
}
rdppm-8.c:get_text_gray_rgb_row
Line
Count
Source
161
10.0k
{
162
10.0k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
163
10.0k
  FILE *infile = source->pub.input_file;
164
10.0k
  register _JSAMPROW ptr;
165
10.0k
  register _JSAMPLE *rescale = source->rescale;
166
10.0k
  JDIMENSION col;
167
10.0k
  unsigned int maxval = source->maxval;
168
10.0k
  register int rindex = rgb_red[cinfo->in_color_space];
169
10.0k
  register int gindex = rgb_green[cinfo->in_color_space];
170
10.0k
  register int bindex = rgb_blue[cinfo->in_color_space];
171
10.0k
  register int aindex = alpha_index[cinfo->in_color_space];
172
10.0k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
173
174
10.0k
  ptr = source->pub._buffer[0];
175
10.0k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
176
2.65k
    if (aindex >= 0)
177
0
      GRAY_RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval),
178
2.65k
                         ptr[aindex] = (_JSAMPLE)maxval;)
179
2.65k
    else
180
2.65k
      GRAY_RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval), {})
181
7.39k
  } else {
182
7.39k
    if (aindex >= 0)
183
0
      GRAY_RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)],
184
7.39k
                         ptr[aindex] = (1 << cinfo->data_precision) - 1;)
185
7.39k
    else
186
7.39k
      GRAY_RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)], {})
187
7.39k
  }
188
10.0k
  return 1;
189
10.0k
}
Unexecuted instantiation: rdppm-12.c:get_text_gray_rgb_row
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
0
{
197
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
198
0
  FILE *infile = source->pub.input_file;
199
0
  register _JSAMPROW ptr;
200
0
  register _JSAMPLE *rescale = source->rescale;
201
0
  JDIMENSION col;
202
0
  unsigned int maxval = source->maxval;
203
204
0
  ptr = source->pub._buffer[0];
205
0
  if (maxval == (1U << cinfo->data_precision) - 1U) {
206
0
    for (col = cinfo->image_width; col > 0; col--) {
207
0
      _JSAMPLE gray = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
208
0
      rgb_to_cmyk(maxval, gray, gray, gray, ptr, ptr + 1, ptr + 2, ptr + 3);
209
0
      ptr += 4;
210
0
    }
211
0
  } else {
212
0
    for (col = cinfo->image_width; col > 0; col--) {
213
0
      _JSAMPLE gray = rescale[read_pbm_integer(cinfo, infile, maxval)];
214
0
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, gray, gray, gray, ptr,
215
0
                  ptr + 1, ptr + 2, ptr + 3);
216
0
      ptr += 4;
217
0
    }
218
0
  }
219
0
  return 1;
220
0
}
Unexecuted instantiation: rdppm-8.c:get_text_gray_cmyk_row
Unexecuted instantiation: rdppm-12.c:get_text_gray_cmyk_row
Unexecuted instantiation: rdppm-16.c:get_text_gray_cmyk_row
221
222
223
69.1k
#define RGB_READ_LOOP(read_op, alpha_set_op) { \
224
156k
  for (col = cinfo->image_width; col > 0; col--) { \
225
86.9k
    ptr[rindex] = read_op; \
226
86.9k
    ptr[gindex] = read_op; \
227
86.9k
    ptr[bindex] = read_op; \
228
86.9k
    alpha_set_op \
229
86.9k
    ptr += ps; \
230
86.9k
  } \
231
69.1k
}
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
9.33k
{
237
9.33k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
238
9.33k
  FILE *infile = source->pub.input_file;
239
9.33k
  register _JSAMPROW ptr;
240
9.33k
  register _JSAMPLE *rescale = source->rescale;
241
9.33k
  JDIMENSION col;
242
9.33k
  unsigned int maxval = source->maxval;
243
9.33k
  register int rindex = rgb_red[cinfo->in_color_space];
244
9.33k
  register int gindex = rgb_green[cinfo->in_color_space];
245
9.33k
  register int bindex = rgb_blue[cinfo->in_color_space];
246
9.33k
  register int aindex = alpha_index[cinfo->in_color_space];
247
9.33k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
248
249
9.33k
  ptr = source->pub._buffer[0];
250
9.33k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
251
3.00k
    if (aindex >= 0)
252
0
      RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval),
253
3.00k
                    ptr[aindex] = (_JSAMPLE)maxval;)
254
3.00k
    else
255
3.00k
      RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval), {})
256
6.33k
  } else {
257
6.33k
    if (aindex >= 0)
258
0
      RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)],
259
6.33k
                    ptr[aindex] = (1 << cinfo->data_precision) - 1;)
260
6.33k
    else
261
6.33k
      RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)], {})
262
6.33k
  }
263
9.33k
  return 1;
264
9.33k
}
rdppm-8.c:get_text_rgb_row
Line
Count
Source
236
9.33k
{
237
9.33k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
238
9.33k
  FILE *infile = source->pub.input_file;
239
9.33k
  register _JSAMPROW ptr;
240
9.33k
  register _JSAMPLE *rescale = source->rescale;
241
9.33k
  JDIMENSION col;
242
9.33k
  unsigned int maxval = source->maxval;
243
9.33k
  register int rindex = rgb_red[cinfo->in_color_space];
244
9.33k
  register int gindex = rgb_green[cinfo->in_color_space];
245
9.33k
  register int bindex = rgb_blue[cinfo->in_color_space];
246
9.33k
  register int aindex = alpha_index[cinfo->in_color_space];
247
9.33k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
248
249
9.33k
  ptr = source->pub._buffer[0];
250
9.33k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
251
3.00k
    if (aindex >= 0)
252
0
      RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval),
253
3.00k
                    ptr[aindex] = (_JSAMPLE)maxval;)
254
3.00k
    else
255
3.00k
      RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval), {})
256
6.33k
  } else {
257
6.33k
    if (aindex >= 0)
258
0
      RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)],
259
6.33k
                    ptr[aindex] = (1 << cinfo->data_precision) - 1;)
260
6.33k
    else
261
6.33k
      RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)], {})
262
6.33k
  }
263
9.33k
  return 1;
264
9.33k
}
Unexecuted instantiation: rdppm-12.c:get_text_rgb_row
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
0
{
272
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
273
0
  FILE *infile = source->pub.input_file;
274
0
  register _JSAMPROW ptr;
275
0
  register _JSAMPLE *rescale = source->rescale;
276
0
  JDIMENSION col;
277
0
  unsigned int maxval = source->maxval;
278
279
0
  ptr = source->pub._buffer[0];
280
0
  if (maxval == (1U << cinfo->data_precision) - 1U) {
281
0
    for (col = cinfo->image_width; col > 0; col--) {
282
0
      _JSAMPLE r = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
283
0
      _JSAMPLE g = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
284
0
      _JSAMPLE b = (_JSAMPLE)read_pbm_integer(cinfo, infile, maxval);
285
0
      rgb_to_cmyk(maxval, r, g, b, ptr, ptr + 1, ptr + 2, ptr + 3);
286
0
      ptr += 4;
287
0
    }
288
0
  } else {
289
0
    for (col = cinfo->image_width; col > 0; col--) {
290
0
      _JSAMPLE r = rescale[read_pbm_integer(cinfo, infile, maxval)];
291
0
      _JSAMPLE g = rescale[read_pbm_integer(cinfo, infile, maxval)];
292
0
      _JSAMPLE b = rescale[read_pbm_integer(cinfo, infile, maxval)];
293
0
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, r, g, b, ptr, ptr + 1,
294
0
                  ptr + 2, ptr + 3);
295
0
      ptr += 4;
296
0
    }
297
0
  }
298
0
  return 1;
299
0
}
Unexecuted instantiation: rdppm-8.c:get_text_rgb_cmyk_row
Unexecuted instantiation: rdppm-12.c:get_text_rgb_cmyk_row
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.57M
{
306
3.57M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
307
3.57M
  register _JSAMPROW ptr;
308
3.57M
  register unsigned char *bufferptr;
309
3.57M
  register _JSAMPLE *rescale = source->rescale;
310
3.57M
  JDIMENSION col;
311
312
3.57M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
313
70
    ERREXIT(cinfo, JERR_INPUT_EOF);
314
3.57M
  ptr = source->pub._buffer[0];
315
3.57M
  bufferptr = source->iobuffer;
316
12.3M
  for (col = cinfo->image_width; col > 0; col--) {
317
8.81M
    *ptr++ = rescale[*bufferptr++];
318
8.81M
  }
319
3.57M
  return 1;
320
3.57M
}
rdppm-8.c:get_scaled_gray_row
Line
Count
Source
305
3.57M
{
306
3.57M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
307
3.57M
  register _JSAMPROW ptr;
308
3.57M
  register unsigned char *bufferptr;
309
3.57M
  register _JSAMPLE *rescale = source->rescale;
310
3.57M
  JDIMENSION col;
311
312
3.57M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
313
70
    ERREXIT(cinfo, JERR_INPUT_EOF);
314
3.57M
  ptr = source->pub._buffer[0];
315
3.57M
  bufferptr = source->iobuffer;
316
12.3M
  for (col = cinfo->image_width; col > 0; col--) {
317
8.81M
    *ptr++ = rescale[*bufferptr++];
318
8.81M
  }
319
3.57M
  return 1;
320
3.57M
}
Unexecuted instantiation: rdppm-12.c:get_scaled_gray_row
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
19.4M
{
328
19.4M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
329
19.4M
  register _JSAMPROW ptr;
330
19.4M
  register unsigned char *bufferptr;
331
19.4M
  register _JSAMPLE *rescale = source->rescale;
332
19.4M
  JDIMENSION col;
333
19.4M
  unsigned int maxval = source->maxval;
334
19.4M
  register int rindex = rgb_red[cinfo->in_color_space];
335
19.4M
  register int gindex = rgb_green[cinfo->in_color_space];
336
19.4M
  register int bindex = rgb_blue[cinfo->in_color_space];
337
19.4M
  register int aindex = alpha_index[cinfo->in_color_space];
338
19.4M
  register int ps = rgb_pixelsize[cinfo->in_color_space];
339
340
19.4M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
341
465
    ERREXIT(cinfo, JERR_INPUT_EOF);
342
19.4M
  ptr = source->pub._buffer[0];
343
19.4M
  bufferptr = source->iobuffer;
344
19.4M
  if (maxval == (1U << cinfo->data_precision) - 1U) {
345
1.57M
    if (aindex >= 0)
346
0
      GRAY_RGB_READ_LOOP(*bufferptr++, ptr[aindex] = (_JSAMPLE)maxval;)
347
1.57M
    else
348
1.57M
      GRAY_RGB_READ_LOOP(*bufferptr++, {})
349
17.8M
  } else {
350
17.8M
    if (aindex >= 0)
351
0
      GRAY_RGB_READ_LOOP(rescale[*bufferptr++],
352
17.8M
                         ptr[aindex] = (1 << cinfo->data_precision) - 1;)
353
17.8M
    else
354
17.8M
      GRAY_RGB_READ_LOOP(rescale[*bufferptr++], {})
355
17.8M
  }
356
19.4M
  return 1;
357
19.4M
}
rdppm-8.c:get_gray_rgb_row
Line
Count
Source
327
19.4M
{
328
19.4M
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
329
19.4M
  register _JSAMPROW ptr;
330
19.4M
  register unsigned char *bufferptr;
331
19.4M
  register _JSAMPLE *rescale = source->rescale;
332
19.4M
  JDIMENSION col;
333
19.4M
  unsigned int maxval = source->maxval;
334
19.4M
  register int rindex = rgb_red[cinfo->in_color_space];
335
19.4M
  register int gindex = rgb_green[cinfo->in_color_space];
336
19.4M
  register int bindex = rgb_blue[cinfo->in_color_space];
337
19.4M
  register int aindex = alpha_index[cinfo->in_color_space];
338
19.4M
  register int ps = rgb_pixelsize[cinfo->in_color_space];
339
340
19.4M
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
341
465
    ERREXIT(cinfo, JERR_INPUT_EOF);
342
19.4M
  ptr = source->pub._buffer[0];
343
19.4M
  bufferptr = source->iobuffer;
344
19.4M
  if (maxval == (1U << cinfo->data_precision) - 1U) {
345
1.57M
    if (aindex >= 0)
346
0
      GRAY_RGB_READ_LOOP(*bufferptr++, ptr[aindex] = (_JSAMPLE)maxval;)
347
1.57M
    else
348
1.57M
      GRAY_RGB_READ_LOOP(*bufferptr++, {})
349
17.8M
  } else {
350
17.8M
    if (aindex >= 0)
351
0
      GRAY_RGB_READ_LOOP(rescale[*bufferptr++],
352
17.8M
                         ptr[aindex] = (1 << cinfo->data_precision) - 1;)
353
17.8M
    else
354
17.8M
      GRAY_RGB_READ_LOOP(rescale[*bufferptr++], {})
355
17.8M
  }
356
19.4M
  return 1;
357
19.4M
}
Unexecuted instantiation: rdppm-12.c:get_gray_rgb_row
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
0
{
365
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
366
0
  register _JSAMPROW ptr;
367
0
  register unsigned char *bufferptr;
368
0
  register _JSAMPLE *rescale = source->rescale;
369
0
  JDIMENSION col;
370
0
  unsigned int maxval = source->maxval;
371
372
0
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
373
0
    ERREXIT(cinfo, JERR_INPUT_EOF);
374
0
  ptr = source->pub._buffer[0];
375
0
  bufferptr = source->iobuffer;
376
0
  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
0
  } else {
383
0
    for (col = cinfo->image_width; col > 0; col--) {
384
0
      _JSAMPLE gray = rescale[*bufferptr++];
385
0
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, gray, gray, gray, ptr,
386
0
                  ptr + 1, ptr + 2, ptr + 3);
387
0
      ptr += 4;
388
0
    }
389
0
  }
390
0
  return 1;
391
0
}
Unexecuted instantiation: rdppm-8.c:get_gray_cmyk_row
Unexecuted instantiation: rdppm-12.c:get_gray_cmyk_row
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
59.8k
{
398
59.8k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
399
59.8k
  register _JSAMPROW ptr;
400
59.8k
  register unsigned char *bufferptr;
401
59.8k
  register _JSAMPLE *rescale = source->rescale;
402
59.8k
  JDIMENSION col;
403
59.8k
  unsigned int maxval = source->maxval;
404
59.8k
  register int rindex = rgb_red[cinfo->in_color_space];
405
59.8k
  register int gindex = rgb_green[cinfo->in_color_space];
406
59.8k
  register int bindex = rgb_blue[cinfo->in_color_space];
407
59.8k
  register int aindex = alpha_index[cinfo->in_color_space];
408
59.8k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
409
410
59.8k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
411
421
    ERREXIT(cinfo, JERR_INPUT_EOF);
412
59.8k
  ptr = source->pub._buffer[0];
413
59.8k
  bufferptr = source->iobuffer;
414
59.8k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
415
9.02k
    if (aindex >= 0)
416
0
      RGB_READ_LOOP(*bufferptr++, ptr[aindex] = (_JSAMPLE)maxval;)
417
9.02k
    else
418
9.02k
      RGB_READ_LOOP(*bufferptr++, {})
419
50.8k
  } else {
420
50.8k
    if (aindex >= 0)
421
0
      RGB_READ_LOOP(rescale[*bufferptr++],
422
50.8k
                    ptr[aindex] = (1 << cinfo->data_precision) - 1;)
423
50.8k
    else
424
50.8k
      RGB_READ_LOOP(rescale[*bufferptr++], {})
425
50.8k
  }
426
59.8k
  return 1;
427
59.8k
}
rdppm-8.c:get_rgb_row
Line
Count
Source
397
59.8k
{
398
59.8k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
399
59.8k
  register _JSAMPROW ptr;
400
59.8k
  register unsigned char *bufferptr;
401
59.8k
  register _JSAMPLE *rescale = source->rescale;
402
59.8k
  JDIMENSION col;
403
59.8k
  unsigned int maxval = source->maxval;
404
59.8k
  register int rindex = rgb_red[cinfo->in_color_space];
405
59.8k
  register int gindex = rgb_green[cinfo->in_color_space];
406
59.8k
  register int bindex = rgb_blue[cinfo->in_color_space];
407
59.8k
  register int aindex = alpha_index[cinfo->in_color_space];
408
59.8k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
409
410
59.8k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
411
421
    ERREXIT(cinfo, JERR_INPUT_EOF);
412
59.8k
  ptr = source->pub._buffer[0];
413
59.8k
  bufferptr = source->iobuffer;
414
59.8k
  if (maxval == (1U << cinfo->data_precision) - 1U) {
415
9.02k
    if (aindex >= 0)
416
0
      RGB_READ_LOOP(*bufferptr++, ptr[aindex] = (_JSAMPLE)maxval;)
417
9.02k
    else
418
9.02k
      RGB_READ_LOOP(*bufferptr++, {})
419
50.8k
  } else {
420
50.8k
    if (aindex >= 0)
421
0
      RGB_READ_LOOP(rescale[*bufferptr++],
422
50.8k
                    ptr[aindex] = (1 << cinfo->data_precision) - 1;)
423
50.8k
    else
424
50.8k
      RGB_READ_LOOP(rescale[*bufferptr++], {})
425
50.8k
  }
426
59.8k
  return 1;
427
59.8k
}
Unexecuted instantiation: rdppm-12.c:get_rgb_row
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
0
{
435
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
436
0
  register _JSAMPROW ptr;
437
0
  register unsigned char *bufferptr;
438
0
  register _JSAMPLE *rescale = source->rescale;
439
0
  JDIMENSION col;
440
0
  unsigned int maxval = source->maxval;
441
442
0
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
443
0
    ERREXIT(cinfo, JERR_INPUT_EOF);
444
0
  ptr = source->pub._buffer[0];
445
0
  bufferptr = source->iobuffer;
446
0
  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
0
  } else {
455
0
    for (col = cinfo->image_width; col > 0; col--) {
456
0
      _JSAMPLE r = rescale[*bufferptr++];
457
0
      _JSAMPLE g = rescale[*bufferptr++];
458
0
      _JSAMPLE b = rescale[*bufferptr++];
459
0
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, r, g, b, ptr, ptr + 1,
460
0
                  ptr + 2, ptr + 3);
461
0
      ptr += 4;
462
0
    }
463
0
  }
464
0
  return 1;
465
0
}
Unexecuted instantiation: rdppm-8.c:get_rgb_cmyk_row
Unexecuted instantiation: rdppm-12.c:get_rgb_cmyk_row
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
318k
{
478
318k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
479
480
318k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
481
37
    ERREXIT(cinfo, JERR_INPUT_EOF);
482
318k
  return 1;
483
318k
}
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
1.72k
{
492
1.72k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
493
1.72k
  register _JSAMPROW ptr;
494
1.72k
  register unsigned char *bufferptr;
495
1.72k
  register _JSAMPLE *rescale = source->rescale;
496
1.72k
  JDIMENSION col;
497
1.72k
  unsigned int maxval = source->maxval;
498
499
1.72k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
500
53
    ERREXIT(cinfo, JERR_INPUT_EOF);
501
1.72k
  ptr = source->pub._buffer[0];
502
1.72k
  bufferptr = source->iobuffer;
503
46.1k
  for (col = cinfo->image_width; col > 0; col--) {
504
44.4k
    register unsigned int temp;
505
44.4k
    temp  = (*bufferptr++) << 8;
506
44.4k
    temp |= (*bufferptr++);
507
44.4k
    if (temp > maxval)
508
31
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
509
44.4k
    *ptr++ = rescale[temp];
510
44.4k
  }
511
1.72k
  return 1;
512
1.72k
}
rdppm-8.c:get_word_gray_row
Line
Count
Source
491
1.72k
{
492
1.72k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
493
1.72k
  register _JSAMPROW ptr;
494
1.72k
  register unsigned char *bufferptr;
495
1.72k
  register _JSAMPLE *rescale = source->rescale;
496
1.72k
  JDIMENSION col;
497
1.72k
  unsigned int maxval = source->maxval;
498
499
1.72k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
500
53
    ERREXIT(cinfo, JERR_INPUT_EOF);
501
1.72k
  ptr = source->pub._buffer[0];
502
1.72k
  bufferptr = source->iobuffer;
503
46.1k
  for (col = cinfo->image_width; col > 0; col--) {
504
44.4k
    register unsigned int temp;
505
44.4k
    temp  = (*bufferptr++) << 8;
506
44.4k
    temp |= (*bufferptr++);
507
44.4k
    if (temp > maxval)
508
31
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
509
44.4k
    *ptr++ = rescale[temp];
510
44.4k
  }
511
1.72k
  return 1;
512
1.72k
}
Unexecuted instantiation: rdppm-12.c:get_word_gray_row
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
8.63k
{
519
8.63k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
520
8.63k
  register _JSAMPROW ptr;
521
8.63k
  register unsigned char *bufferptr;
522
8.63k
  register _JSAMPLE *rescale = source->rescale;
523
8.63k
  JDIMENSION col;
524
8.63k
  unsigned int maxval = source->maxval;
525
8.63k
  register int rindex = rgb_red[cinfo->in_color_space];
526
8.63k
  register int gindex = rgb_green[cinfo->in_color_space];
527
8.63k
  register int bindex = rgb_blue[cinfo->in_color_space];
528
8.63k
  register int aindex = alpha_index[cinfo->in_color_space];
529
8.63k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
530
531
8.63k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
532
265
    ERREXIT(cinfo, JERR_INPUT_EOF);
533
8.63k
  ptr = source->pub._buffer[0];
534
8.63k
  bufferptr = source->iobuffer;
535
230k
  for (col = cinfo->image_width; col > 0; col--) {
536
222k
    register unsigned int temp;
537
222k
    temp  = (*bufferptr++) << 8;
538
222k
    temp |= (*bufferptr++);
539
222k
    if (temp > maxval)
540
155
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
541
222k
    ptr[rindex] = ptr[gindex] = ptr[bindex] = rescale[temp];
542
222k
    if (aindex >= 0)
543
0
      ptr[aindex] = (1 << cinfo->data_precision) - 1;
544
222k
    ptr += ps;
545
222k
  }
546
8.63k
  return 1;
547
8.63k
}
rdppm-8.c:get_word_gray_rgb_row
Line
Count
Source
518
8.63k
{
519
8.63k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
520
8.63k
  register _JSAMPROW ptr;
521
8.63k
  register unsigned char *bufferptr;
522
8.63k
  register _JSAMPLE *rescale = source->rescale;
523
8.63k
  JDIMENSION col;
524
8.63k
  unsigned int maxval = source->maxval;
525
8.63k
  register int rindex = rgb_red[cinfo->in_color_space];
526
8.63k
  register int gindex = rgb_green[cinfo->in_color_space];
527
8.63k
  register int bindex = rgb_blue[cinfo->in_color_space];
528
8.63k
  register int aindex = alpha_index[cinfo->in_color_space];
529
8.63k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
530
531
8.63k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
532
265
    ERREXIT(cinfo, JERR_INPUT_EOF);
533
8.63k
  ptr = source->pub._buffer[0];
534
8.63k
  bufferptr = source->iobuffer;
535
230k
  for (col = cinfo->image_width; col > 0; col--) {
536
222k
    register unsigned int temp;
537
222k
    temp  = (*bufferptr++) << 8;
538
222k
    temp |= (*bufferptr++);
539
222k
    if (temp > maxval)
540
155
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
541
222k
    ptr[rindex] = ptr[gindex] = ptr[bindex] = rescale[temp];
542
222k
    if (aindex >= 0)
543
0
      ptr[aindex] = (1 << cinfo->data_precision) - 1;
544
222k
    ptr += ps;
545
222k
  }
546
8.63k
  return 1;
547
8.63k
}
Unexecuted instantiation: rdppm-12.c:get_word_gray_rgb_row
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
0
{
554
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
555
0
  register _JSAMPROW ptr;
556
0
  register unsigned char *bufferptr;
557
0
  register _JSAMPLE *rescale = source->rescale;
558
0
  JDIMENSION col;
559
0
  unsigned int maxval = source->maxval;
560
561
0
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
562
0
    ERREXIT(cinfo, JERR_INPUT_EOF);
563
0
  ptr = source->pub._buffer[0];
564
0
  bufferptr = source->iobuffer;
565
0
  if (maxval == (1U << cinfo->data_precision) - 1U) {
566
0
    for (col = cinfo->image_width; col > 0; col--) {
567
0
      register unsigned int gray;
568
0
      gray  = (*bufferptr++) << 8;
569
0
      gray |= (*bufferptr++);
570
0
      if (gray > maxval)
571
0
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
572
0
      rgb_to_cmyk(maxval, (_JSAMPLE)gray, (_JSAMPLE)gray, (_JSAMPLE)gray, ptr,
573
0
                  ptr + 1, ptr + 2, ptr + 3);
574
0
      ptr += 4;
575
0
    }
576
0
  } else {
577
0
    for (col = cinfo->image_width; col > 0; col--) {
578
0
      register unsigned int temp;
579
0
      _JSAMPLE gray;
580
0
      temp  = (*bufferptr++) << 8;
581
0
      temp |= (*bufferptr++);
582
0
      if (temp > maxval)
583
0
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
584
0
      gray = rescale[temp];
585
0
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, gray, gray, gray, ptr,
586
0
                  ptr + 1, ptr + 2, ptr + 3);
587
0
      ptr += 4;
588
0
    }
589
0
  }
590
0
  return 1;
591
0
}
Unexecuted instantiation: rdppm-8.c:get_word_gray_cmyk_row
Unexecuted instantiation: rdppm-12.c:get_word_gray_cmyk_row
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
10.2k
{
598
10.2k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
599
10.2k
  register _JSAMPROW ptr;
600
10.2k
  register unsigned char *bufferptr;
601
10.2k
  register _JSAMPLE *rescale = source->rescale;
602
10.2k
  JDIMENSION col;
603
10.2k
  unsigned int maxval = source->maxval;
604
10.2k
  register int rindex = rgb_red[cinfo->in_color_space];
605
10.2k
  register int gindex = rgb_green[cinfo->in_color_space];
606
10.2k
  register int bindex = rgb_blue[cinfo->in_color_space];
607
10.2k
  register int aindex = alpha_index[cinfo->in_color_space];
608
10.2k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
609
610
10.2k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
611
240
    ERREXIT(cinfo, JERR_INPUT_EOF);
612
10.2k
  ptr = source->pub._buffer[0];
613
10.2k
  bufferptr = source->iobuffer;
614
24.1k
  for (col = cinfo->image_width; col > 0; col--) {
615
13.9k
    register unsigned int temp;
616
13.9k
    temp  = (*bufferptr++) << 8;
617
13.9k
    temp |= (*bufferptr++);
618
13.9k
    if (temp > maxval)
619
60
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
620
13.9k
    ptr[rindex] = rescale[temp];
621
13.9k
    temp  = (*bufferptr++) << 8;
622
13.9k
    temp |= (*bufferptr++);
623
13.9k
    if (temp > maxval)
624
120
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
625
13.9k
    ptr[gindex] = rescale[temp];
626
13.9k
    temp  = (*bufferptr++) << 8;
627
13.9k
    temp |= (*bufferptr++);
628
13.9k
    if (temp > maxval)
629
120
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
630
13.9k
    ptr[bindex] = rescale[temp];
631
13.9k
    if (aindex >= 0)
632
0
      ptr[aindex] = (1 << cinfo->data_precision) - 1;
633
13.9k
    ptr += ps;
634
13.9k
  }
635
10.2k
  return 1;
636
10.2k
}
rdppm-8.c:get_word_rgb_row
Line
Count
Source
597
10.2k
{
598
10.2k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
599
10.2k
  register _JSAMPROW ptr;
600
10.2k
  register unsigned char *bufferptr;
601
10.2k
  register _JSAMPLE *rescale = source->rescale;
602
10.2k
  JDIMENSION col;
603
10.2k
  unsigned int maxval = source->maxval;
604
10.2k
  register int rindex = rgb_red[cinfo->in_color_space];
605
10.2k
  register int gindex = rgb_green[cinfo->in_color_space];
606
10.2k
  register int bindex = rgb_blue[cinfo->in_color_space];
607
10.2k
  register int aindex = alpha_index[cinfo->in_color_space];
608
10.2k
  register int ps = rgb_pixelsize[cinfo->in_color_space];
609
610
10.2k
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
611
240
    ERREXIT(cinfo, JERR_INPUT_EOF);
612
10.2k
  ptr = source->pub._buffer[0];
613
10.2k
  bufferptr = source->iobuffer;
614
24.1k
  for (col = cinfo->image_width; col > 0; col--) {
615
13.9k
    register unsigned int temp;
616
13.9k
    temp  = (*bufferptr++) << 8;
617
13.9k
    temp |= (*bufferptr++);
618
13.9k
    if (temp > maxval)
619
60
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
620
13.9k
    ptr[rindex] = rescale[temp];
621
13.9k
    temp  = (*bufferptr++) << 8;
622
13.9k
    temp |= (*bufferptr++);
623
13.9k
    if (temp > maxval)
624
120
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
625
13.9k
    ptr[gindex] = rescale[temp];
626
13.9k
    temp  = (*bufferptr++) << 8;
627
13.9k
    temp |= (*bufferptr++);
628
13.9k
    if (temp > maxval)
629
120
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
630
13.9k
    ptr[bindex] = rescale[temp];
631
13.9k
    if (aindex >= 0)
632
0
      ptr[aindex] = (1 << cinfo->data_precision) - 1;
633
13.9k
    ptr += ps;
634
13.9k
  }
635
10.2k
  return 1;
636
10.2k
}
Unexecuted instantiation: rdppm-12.c:get_word_rgb_row
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
0
{
643
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
644
0
  register _JSAMPROW ptr;
645
0
  register unsigned char *bufferptr;
646
0
  register _JSAMPLE *rescale = source->rescale;
647
0
  JDIMENSION col;
648
0
  unsigned int maxval = source->maxval;
649
650
0
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
651
0
    ERREXIT(cinfo, JERR_INPUT_EOF);
652
0
  ptr = source->pub._buffer[0];
653
0
  bufferptr = source->iobuffer;
654
0
  if (maxval == (1U << cinfo->data_precision) - 1U) {
655
0
    for (col = cinfo->image_width; col > 0; col--) {
656
0
      register unsigned int r, g, b;
657
0
      r  = (*bufferptr++) << 8;
658
0
      r |= (*bufferptr++);
659
0
      if (r > maxval)
660
0
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
661
0
      g  = (*bufferptr++) << 8;
662
0
      g |= (*bufferptr++);
663
0
      if (g > maxval)
664
0
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
665
0
      b  = (*bufferptr++) << 8;
666
0
      b |= (*bufferptr++);
667
0
      if (b > maxval)
668
0
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
669
0
      rgb_to_cmyk(maxval, (_JSAMPLE)r, (_JSAMPLE)g, (_JSAMPLE)b, ptr, ptr + 1,
670
0
                  ptr + 2, ptr + 3);
671
0
      ptr += 4;
672
0
    }
673
0
  } else {
674
0
    for (col = cinfo->image_width; col > 0; col--) {
675
0
      register unsigned int r, g, b;
676
0
      r  = (*bufferptr++) << 8;
677
0
      r |= (*bufferptr++);
678
0
      if (r > maxval)
679
0
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
680
0
      g  = (*bufferptr++) << 8;
681
0
      g |= (*bufferptr++);
682
0
      if (g > maxval)
683
0
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
684
0
      b  = (*bufferptr++) << 8;
685
0
      b |= (*bufferptr++);
686
0
      if (b > maxval)
687
0
        ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
688
0
      rgb_to_cmyk((1 << cinfo->data_precision) - 1, rescale[r], rescale[g],
689
0
                  rescale[b], ptr, ptr + 1, ptr + 2, ptr + 3);
690
0
      ptr += 4;
691
0
    }
692
0
  }
693
0
  return 1;
694
0
}
Unexecuted instantiation: rdppm-8.c:get_word_rgb_cmyk_row
Unexecuted instantiation: rdppm-12.c:get_word_rgb_cmyk_row
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
13.4k
{
704
13.4k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
705
13.4k
  int c;
706
13.4k
  unsigned int w, h, maxval;
707
13.4k
  boolean need_iobuffer, use_raw_buffer, need_rescale;
708
709
13.4k
  if (getc(source->pub.input_file) != 'P')
710
0
    ERREXIT(cinfo, JERR_PPM_NOT);
711
712
13.4k
  c = getc(source->pub.input_file); /* subformat discriminator character */
713
714
  /* detect unsupported variants (ie, PBM) before trying to read header */
715
13.4k
  switch (c) {
716
1.14k
  case '2':                     /* it's a text-format PGM file */
717
2.16k
  case '3':                     /* it's a text-format PPM file */
718
11.0k
  case '5':                     /* it's a raw-format PGM file */
719
13.3k
  case '6':                     /* it's a raw-format PPM file */
720
13.3k
    break;
721
48
  default:
722
48
    ERREXIT(cinfo, JERR_PPM_NOT);
723
48
    break;
724
13.4k
  }
725
726
  /* fetch the remaining header info */
727
13.3k
  w = read_pbm_integer(cinfo, source->pub.input_file, 65535);
728
13.3k
  h = read_pbm_integer(cinfo, source->pub.input_file, 65535);
729
13.3k
  maxval = read_pbm_integer(cinfo, source->pub.input_file, 65535);
730
731
13.3k
  if (w <= 0 || h <= 0 || maxval <= 0) /* error check */
732
18
    ERREXIT(cinfo, JERR_PPM_NOT);
733
13.3k
  if (w > JPEG_MAX_DIMENSION || h > JPEG_MAX_DIMENSION)
734
12
    ERREXIT1(cinfo, JERR_IMAGE_TOO_BIG, JPEG_MAX_DIMENSION);
735
13.3k
  if (sinfo->max_pixels && (unsigned long long)w * h > sinfo->max_pixels)
736
222
    ERREXIT1(cinfo, JERR_IMAGE_TOO_BIG, sinfo->max_pixels);
737
738
13.3k
  cinfo->image_width = (JDIMENSION)w;
739
13.3k
  cinfo->image_height = (JDIMENSION)h;
740
13.3k
  source->maxval = maxval;
741
742
  /* initialize flags to most common settings */
743
13.3k
  need_iobuffer = TRUE;         /* do we need an I/O buffer? */
744
13.3k
  use_raw_buffer = FALSE;       /* do we map input buffer onto I/O buffer? */
745
13.3k
  need_rescale = TRUE;          /* do we need a rescale array? */
746
747
13.3k
  switch (c) {
748
774
  case '2':                     /* it's a text-format PGM file */
749
774
    if (cinfo->in_color_space == JCS_UNKNOWN ||
750
774
        cinfo->in_color_space == JCS_RGB)
751
0
      cinfo->in_color_space = JCS_GRAYSCALE;
752
774
    TRACEMS3(cinfo, 1, JTRC_PGM_TEXT, w, h, maxval);
753
774
    if (cinfo->in_color_space == JCS_GRAYSCALE)
754
129
      source->pub.get_pixel_rows = get_text_gray_row;
755
645
    else if (IsExtRGB(cinfo->in_color_space))
756
645
      source->pub.get_pixel_rows = get_text_gray_rgb_row;
757
0
    else if (cinfo->in_color_space == JCS_CMYK)
758
0
      source->pub.get_pixel_rows = get_text_gray_cmyk_row;
759
0
    else
760
0
      ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
761
774
    need_iobuffer = FALSE;
762
774
    break;
763
764
804
  case '3':                     /* it's a text-format PPM file */
765
804
    if (cinfo->in_color_space == JCS_UNKNOWN)
766
0
      cinfo->in_color_space = JCS_EXT_RGB;
767
804
    TRACEMS3(cinfo, 1, JTRC_PPM_TEXT, w, h, maxval);
768
804
    if (IsExtRGB(cinfo->in_color_space))
769
670
      source->pub.get_pixel_rows = get_text_rgb_row;
770
134
    else if (cinfo->in_color_space == JCS_CMYK)
771
0
      source->pub.get_pixel_rows = get_text_rgb_cmyk_row;
772
134
    else
773
134
      ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
774
804
    need_iobuffer = FALSE;
775
804
    break;
776
777
8.49k
  case '5':                     /* it's a raw-format PGM file */
778
8.49k
    if (cinfo->in_color_space == JCS_UNKNOWN ||
779
8.49k
        cinfo->in_color_space == JCS_RGB)
780
0
      cinfo->in_color_space = JCS_GRAYSCALE;
781
8.49k
    TRACEMS3(cinfo, 1, JTRC_PGM, w, h, maxval);
782
8.49k
    if (maxval > 255) {
783
558
      if (cinfo->in_color_space == JCS_GRAYSCALE)
784
93
        source->pub.get_pixel_rows = get_word_gray_row;
785
465
      else if (IsExtRGB(cinfo->in_color_space))
786
465
        source->pub.get_pixel_rows = get_word_gray_rgb_row;
787
0
      else if (cinfo->in_color_space == JCS_CMYK)
788
0
        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
7.93k
    } else if (maxval <= _MAXJSAMPLE &&
793
7.93k
               maxval == ((1U << cinfo->data_precision) - 1U) &&
794
564
               cinfo->in_color_space == JCS_GRAYSCALE) {
795
94
      source->pub.get_pixel_rows = get_raw_row;
796
94
      use_raw_buffer = TRUE;
797
94
      need_rescale = FALSE;
798
#endif
799
7.84k
    } else {
800
7.84k
      if (cinfo->in_color_space == JCS_GRAYSCALE)
801
1.22k
        source->pub.get_pixel_rows = get_scaled_gray_row;
802
6.61k
      else if (IsExtRGB(cinfo->in_color_space))
803
6.61k
        source->pub.get_pixel_rows = get_gray_rgb_row;
804
0
      else if (cinfo->in_color_space == JCS_CMYK)
805
0
        source->pub.get_pixel_rows = get_gray_cmyk_row;
806
0
      else
807
0
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
808
7.84k
    }
809
8.49k
    break;
810
811
2.01k
  case '6':                     /* it's a raw-format PPM file */
812
2.01k
    if (cinfo->in_color_space == JCS_UNKNOWN)
813
0
      cinfo->in_color_space = JCS_EXT_RGB;
814
2.01k
    TRACEMS3(cinfo, 1, JTRC_PPM, w, h, maxval);
815
2.01k
    if (maxval > 255) {
816
666
      if (IsExtRGB(cinfo->in_color_space))
817
555
        source->pub.get_pixel_rows = get_word_rgb_row;
818
111
      else if (cinfo->in_color_space == JCS_CMYK)
819
0
        source->pub.get_pixel_rows = get_word_rgb_cmyk_row;
820
111
      else
821
111
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
822
#if BITS_IN_JSAMPLE == 8
823
1.34k
    } else if (maxval <= _MAXJSAMPLE &&
824
1.34k
               maxval == ((1U << cinfo->data_precision) - 1U) &&
825
234
#if RGB_RED == 0 && RGB_GREEN == 1 && RGB_BLUE == 2 && RGB_PIXELSIZE == 3
826
234
               (cinfo->in_color_space == JCS_EXT_RGB ||
827
195
                cinfo->in_color_space == JCS_RGB)) {
828
#else
829
               cinfo->in_color_space == JCS_EXT_RGB) {
830
#endif
831
39
      source->pub.get_pixel_rows = get_raw_row;
832
39
      use_raw_buffer = TRUE;
833
39
      need_rescale = FALSE;
834
#endif
835
1.30k
    } else {
836
1.30k
      if (IsExtRGB(cinfo->in_color_space))
837
1.08k
        source->pub.get_pixel_rows = get_rgb_row;
838
224
      else if (cinfo->in_color_space == JCS_CMYK)
839
0
        source->pub.get_pixel_rows = get_rgb_cmyk_row;
840
224
      else
841
224
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
842
1.30k
    }
843
2.01k
    break;
844
13.3k
  }
845
846
11.6k
  if (IsExtRGB(cinfo->in_color_space))
847
10.0k
    cinfo->input_components = rgb_pixelsize[cinfo->in_color_space];
848
1.54k
  else if (cinfo->in_color_space == JCS_GRAYSCALE)
849
1.54k
    cinfo->input_components = 1;
850
0
  else if (cinfo->in_color_space == JCS_CMYK)
851
0
    cinfo->input_components = 4;
852
853
  /* Allocate space for I/O buffer: 1 or 3 bytes or words/pixel. */
854
11.6k
  if (need_iobuffer) {
855
10.1k
    if (c == '6')
856
1.67k
      source->buffer_width = (size_t)w * 3 * (maxval <= 255 ? 1 : 2);
857
8.49k
    else
858
8.49k
      source->buffer_width = (size_t)w * (maxval <= 255 ? 1 : 2);
859
10.1k
    source->iobuffer = (unsigned char *)
860
10.1k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
861
10.1k
                                  source->buffer_width);
862
10.1k
  }
863
864
  /* Create compressor input buffer. */
865
11.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
133
    source->pixrow = (_JSAMPROW)source->iobuffer;
869
133
    source->pub._buffer = &source->pixrow;
870
133
    source->pub.buffer_height = 1;
871
11.4k
  } else {
872
    /* Need to translate anyway, so make a separate sample buffer. */
873
11.4k
    source->pub._buffer = (_JSAMPARRAY)(*cinfo->mem->alloc_sarray)
874
11.4k
      ((j_common_ptr)cinfo, JPOOL_IMAGE,
875
11.4k
       (JDIMENSION)w * cinfo->input_components, (JDIMENSION)1);
876
11.4k
    source->pub.buffer_height = 1;
877
11.4k
  }
878
879
  /* Compute the rescaling array if required. */
880
11.6k
  if (need_rescale) {
881
11.4k
    size_t val, half_maxval;
882
883
    /* On 16-bit-int machines we have to be careful of maxval = 65535 */
884
11.4k
    source->rescale = (_JSAMPLE *)
885
11.4k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
886
11.4k
                                  (MAX(maxval, 255) + 1L) * sizeof(_JSAMPLE));
887
11.4k
    memset(source->rescale, 0, (MAX(maxval, 255) + 1L) * sizeof(_JSAMPLE));
888
11.4k
    half_maxval = (size_t)maxval / 2;
889
16.8M
    for (val = 0; val <= (size_t)maxval; val++) {
890
      /* The multiplication here must be done in 32 bits to avoid overflow */
891
16.8M
      source->rescale[val] =
892
16.8M
        (_JSAMPLE)((val * ((1 << cinfo->data_precision) - 1) + half_maxval) /
893
16.8M
                   maxval);
894
16.8M
    }
895
11.4k
  }
896
11.6k
}
rdppm-8.c:start_input_ppm
Line
Count
Source
703
13.4k
{
704
13.4k
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
705
13.4k
  int c;
706
13.4k
  unsigned int w, h, maxval;
707
13.4k
  boolean need_iobuffer, use_raw_buffer, need_rescale;
708
709
13.4k
  if (getc(source->pub.input_file) != 'P')
710
0
    ERREXIT(cinfo, JERR_PPM_NOT);
711
712
13.4k
  c = getc(source->pub.input_file); /* subformat discriminator character */
713
714
  /* detect unsupported variants (ie, PBM) before trying to read header */
715
13.4k
  switch (c) {
716
1.14k
  case '2':                     /* it's a text-format PGM file */
717
2.16k
  case '3':                     /* it's a text-format PPM file */
718
11.0k
  case '5':                     /* it's a raw-format PGM file */
719
13.3k
  case '6':                     /* it's a raw-format PPM file */
720
13.3k
    break;
721
48
  default:
722
48
    ERREXIT(cinfo, JERR_PPM_NOT);
723
48
    break;
724
13.4k
  }
725
726
  /* fetch the remaining header info */
727
13.3k
  w = read_pbm_integer(cinfo, source->pub.input_file, 65535);
728
13.3k
  h = read_pbm_integer(cinfo, source->pub.input_file, 65535);
729
13.3k
  maxval = read_pbm_integer(cinfo, source->pub.input_file, 65535);
730
731
13.3k
  if (w <= 0 || h <= 0 || maxval <= 0) /* error check */
732
18
    ERREXIT(cinfo, JERR_PPM_NOT);
733
13.3k
  if (w > JPEG_MAX_DIMENSION || h > JPEG_MAX_DIMENSION)
734
12
    ERREXIT1(cinfo, JERR_IMAGE_TOO_BIG, JPEG_MAX_DIMENSION);
735
13.3k
  if (sinfo->max_pixels && (unsigned long long)w * h > sinfo->max_pixels)
736
222
    ERREXIT1(cinfo, JERR_IMAGE_TOO_BIG, sinfo->max_pixels);
737
738
13.3k
  cinfo->image_width = (JDIMENSION)w;
739
13.3k
  cinfo->image_height = (JDIMENSION)h;
740
13.3k
  source->maxval = maxval;
741
742
  /* initialize flags to most common settings */
743
13.3k
  need_iobuffer = TRUE;         /* do we need an I/O buffer? */
744
13.3k
  use_raw_buffer = FALSE;       /* do we map input buffer onto I/O buffer? */
745
13.3k
  need_rescale = TRUE;          /* do we need a rescale array? */
746
747
13.3k
  switch (c) {
748
774
  case '2':                     /* it's a text-format PGM file */
749
774
    if (cinfo->in_color_space == JCS_UNKNOWN ||
750
774
        cinfo->in_color_space == JCS_RGB)
751
0
      cinfo->in_color_space = JCS_GRAYSCALE;
752
774
    TRACEMS3(cinfo, 1, JTRC_PGM_TEXT, w, h, maxval);
753
774
    if (cinfo->in_color_space == JCS_GRAYSCALE)
754
129
      source->pub.get_pixel_rows = get_text_gray_row;
755
645
    else if (IsExtRGB(cinfo->in_color_space))
756
645
      source->pub.get_pixel_rows = get_text_gray_rgb_row;
757
0
    else if (cinfo->in_color_space == JCS_CMYK)
758
0
      source->pub.get_pixel_rows = get_text_gray_cmyk_row;
759
0
    else
760
0
      ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
761
774
    need_iobuffer = FALSE;
762
774
    break;
763
764
804
  case '3':                     /* it's a text-format PPM file */
765
804
    if (cinfo->in_color_space == JCS_UNKNOWN)
766
0
      cinfo->in_color_space = JCS_EXT_RGB;
767
804
    TRACEMS3(cinfo, 1, JTRC_PPM_TEXT, w, h, maxval);
768
804
    if (IsExtRGB(cinfo->in_color_space))
769
670
      source->pub.get_pixel_rows = get_text_rgb_row;
770
134
    else if (cinfo->in_color_space == JCS_CMYK)
771
0
      source->pub.get_pixel_rows = get_text_rgb_cmyk_row;
772
134
    else
773
134
      ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
774
804
    need_iobuffer = FALSE;
775
804
    break;
776
777
8.49k
  case '5':                     /* it's a raw-format PGM file */
778
8.49k
    if (cinfo->in_color_space == JCS_UNKNOWN ||
779
8.49k
        cinfo->in_color_space == JCS_RGB)
780
0
      cinfo->in_color_space = JCS_GRAYSCALE;
781
8.49k
    TRACEMS3(cinfo, 1, JTRC_PGM, w, h, maxval);
782
8.49k
    if (maxval > 255) {
783
558
      if (cinfo->in_color_space == JCS_GRAYSCALE)
784
93
        source->pub.get_pixel_rows = get_word_gray_row;
785
465
      else if (IsExtRGB(cinfo->in_color_space))
786
465
        source->pub.get_pixel_rows = get_word_gray_rgb_row;
787
0
      else if (cinfo->in_color_space == JCS_CMYK)
788
0
        source->pub.get_pixel_rows = get_word_gray_cmyk_row;
789
0
      else
790
0
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
791
558
#if BITS_IN_JSAMPLE == 8
792
7.93k
    } else if (maxval <= _MAXJSAMPLE &&
793
7.93k
               maxval == ((1U << cinfo->data_precision) - 1U) &&
794
564
               cinfo->in_color_space == JCS_GRAYSCALE) {
795
94
      source->pub.get_pixel_rows = get_raw_row;
796
94
      use_raw_buffer = TRUE;
797
94
      need_rescale = FALSE;
798
94
#endif
799
7.84k
    } else {
800
7.84k
      if (cinfo->in_color_space == JCS_GRAYSCALE)
801
1.22k
        source->pub.get_pixel_rows = get_scaled_gray_row;
802
6.61k
      else if (IsExtRGB(cinfo->in_color_space))
803
6.61k
        source->pub.get_pixel_rows = get_gray_rgb_row;
804
0
      else if (cinfo->in_color_space == JCS_CMYK)
805
0
        source->pub.get_pixel_rows = get_gray_cmyk_row;
806
0
      else
807
0
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
808
7.84k
    }
809
8.49k
    break;
810
811
2.01k
  case '6':                     /* it's a raw-format PPM file */
812
2.01k
    if (cinfo->in_color_space == JCS_UNKNOWN)
813
0
      cinfo->in_color_space = JCS_EXT_RGB;
814
2.01k
    TRACEMS3(cinfo, 1, JTRC_PPM, w, h, maxval);
815
2.01k
    if (maxval > 255) {
816
666
      if (IsExtRGB(cinfo->in_color_space))
817
555
        source->pub.get_pixel_rows = get_word_rgb_row;
818
111
      else if (cinfo->in_color_space == JCS_CMYK)
819
0
        source->pub.get_pixel_rows = get_word_rgb_cmyk_row;
820
111
      else
821
111
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
822
666
#if BITS_IN_JSAMPLE == 8
823
1.34k
    } else if (maxval <= _MAXJSAMPLE &&
824
1.34k
               maxval == ((1U << cinfo->data_precision) - 1U) &&
825
234
#if RGB_RED == 0 && RGB_GREEN == 1 && RGB_BLUE == 2 && RGB_PIXELSIZE == 3
826
234
               (cinfo->in_color_space == JCS_EXT_RGB ||
827
195
                cinfo->in_color_space == JCS_RGB)) {
828
#else
829
               cinfo->in_color_space == JCS_EXT_RGB) {
830
#endif
831
39
      source->pub.get_pixel_rows = get_raw_row;
832
39
      use_raw_buffer = TRUE;
833
39
      need_rescale = FALSE;
834
39
#endif
835
1.30k
    } else {
836
1.30k
      if (IsExtRGB(cinfo->in_color_space))
837
1.08k
        source->pub.get_pixel_rows = get_rgb_row;
838
224
      else if (cinfo->in_color_space == JCS_CMYK)
839
0
        source->pub.get_pixel_rows = get_rgb_cmyk_row;
840
224
      else
841
224
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
842
1.30k
    }
843
2.01k
    break;
844
13.3k
  }
845
846
11.6k
  if (IsExtRGB(cinfo->in_color_space))
847
10.0k
    cinfo->input_components = rgb_pixelsize[cinfo->in_color_space];
848
1.54k
  else if (cinfo->in_color_space == JCS_GRAYSCALE)
849
1.54k
    cinfo->input_components = 1;
850
0
  else if (cinfo->in_color_space == JCS_CMYK)
851
0
    cinfo->input_components = 4;
852
853
  /* Allocate space for I/O buffer: 1 or 3 bytes or words/pixel. */
854
11.6k
  if (need_iobuffer) {
855
10.1k
    if (c == '6')
856
1.67k
      source->buffer_width = (size_t)w * 3 * (maxval <= 255 ? 1 : 2);
857
8.49k
    else
858
8.49k
      source->buffer_width = (size_t)w * (maxval <= 255 ? 1 : 2);
859
10.1k
    source->iobuffer = (unsigned char *)
860
10.1k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
861
10.1k
                                  source->buffer_width);
862
10.1k
  }
863
864
  /* Create compressor input buffer. */
865
11.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
133
    source->pixrow = (_JSAMPROW)source->iobuffer;
869
133
    source->pub._buffer = &source->pixrow;
870
133
    source->pub.buffer_height = 1;
871
11.4k
  } else {
872
    /* Need to translate anyway, so make a separate sample buffer. */
873
11.4k
    source->pub._buffer = (_JSAMPARRAY)(*cinfo->mem->alloc_sarray)
874
11.4k
      ((j_common_ptr)cinfo, JPOOL_IMAGE,
875
11.4k
       (JDIMENSION)w * cinfo->input_components, (JDIMENSION)1);
876
11.4k
    source->pub.buffer_height = 1;
877
11.4k
  }
878
879
  /* Compute the rescaling array if required. */
880
11.6k
  if (need_rescale) {
881
11.4k
    size_t val, half_maxval;
882
883
    /* On 16-bit-int machines we have to be careful of maxval = 65535 */
884
11.4k
    source->rescale = (_JSAMPLE *)
885
11.4k
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
886
11.4k
                                  (MAX(maxval, 255) + 1L) * sizeof(_JSAMPLE));
887
11.4k
    memset(source->rescale, 0, (MAX(maxval, 255) + 1L) * sizeof(_JSAMPLE));
888
11.4k
    half_maxval = (size_t)maxval / 2;
889
16.8M
    for (val = 0; val <= (size_t)maxval; val++) {
890
      /* The multiplication here must be done in 32 bits to avoid overflow */
891
16.8M
      source->rescale[val] =
892
16.8M
        (_JSAMPLE)((val * ((1 << cinfo->data_precision) - 1) + half_maxval) /
893
16.8M
                   maxval);
894
16.8M
    }
895
11.4k
  }
896
11.6k
}
Unexecuted instantiation: rdppm-12.c:start_input_ppm
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
13.4k
{
914
  /* no work */
915
13.4k
}
rdppm-8.c:finish_input_ppm
Line
Count
Source
913
13.4k
{
914
  /* no work */
915
13.4k
}
Unexecuted instantiation: rdppm-12.c:finish_input_ppm
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
13.4k
{
925
13.4k
  ppm_source_ptr source;
926
927
#if BITS_IN_JSAMPLE == 8
928
13.4k
  if (cinfo->data_precision > BITS_IN_JSAMPLE || cinfo->data_precision < 2)
929
#else
930
0
  if (cinfo->data_precision > BITS_IN_JSAMPLE ||
931
0
      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
13.4k
  source = (ppm_source_ptr)
937
13.4k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
938
13.4k
                                sizeof(ppm_source_struct));
939
  /* Fill in method ptrs, except get_pixel_rows which start_input sets */
940
13.4k
  source->pub.start_input = start_input_ppm;
941
13.4k
  source->pub.read_icc_profile = read_icc_profile_ppm;
942
13.4k
  source->pub.finish_input = finish_input_ppm;
943
13.4k
  source->pub.max_pixels = 0;
944
945
13.4k
  return (cjpeg_source_ptr)source;
946
13.4k
}
jinit_read_ppm
Line
Count
Source
924
13.4k
{
925
13.4k
  ppm_source_ptr source;
926
927
13.4k
#if BITS_IN_JSAMPLE == 8
928
13.4k
  if (cinfo->data_precision > BITS_IN_JSAMPLE || cinfo->data_precision < 2)
929
#else
930
  if (cinfo->data_precision > BITS_IN_JSAMPLE ||
931
      cinfo->data_precision < BITS_IN_JSAMPLE - 3)
932
#endif
933
0
    ERREXIT1(cinfo, JERR_BAD_PRECISION, cinfo->data_precision);
934
935
  /* Create module interface object */
936
13.4k
  source = (ppm_source_ptr)
937
13.4k
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
938
13.4k
                                sizeof(ppm_source_struct));
939
  /* Fill in method ptrs, except get_pixel_rows which start_input sets */
940
13.4k
  source->pub.start_input = start_input_ppm;
941
13.4k
  source->pub.read_icc_profile = read_icc_profile_ppm;
942
13.4k
  source->pub.finish_input = finish_input_ppm;
943
13.4k
  source->pub.max_pixels = 0;
944
945
13.4k
  return (cjpeg_source_ptr)source;
946
13.4k
}
Unexecuted instantiation: j12init_read_ppm
Unexecuted instantiation: j16init_read_ppm
947
948
#endif /* defined(PPM_SUPPORTED) &&
949
          (BITS_IN_JSAMPLE != 16 || defined(C_LOSSLESS_SUPPORTED)) */