Coverage Report

Created: 2026-04-12 06:04

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
0
  (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
0
{
74
0
  register int ch;
75
76
0
  ch = getc(infile);
77
0
  if (ch == '#') {
78
0
    do {
79
0
      ch = getc(infile);
80
0
    } while (ch != '\n' && ch != EOF);
81
0
  }
82
0
  return ch;
83
0
}
Unexecuted instantiation: rdppm-8.c:pbm_getc
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
0
{
93
0
  register int ch;
94
0
  register unsigned int val;
95
96
  /* Skip any leading whitespace */
97
0
  do {
98
0
    ch = pbm_getc(infile);
99
0
    if (ch == EOF)
100
0
      ERREXIT(cinfo, JERR_INPUT_EOF);
101
0
  } while (ch == ' ' || ch == '\t' || ch == '\n' || ch == '\r');
102
103
0
  if (ch < '0' || ch > '9')
104
0
    ERREXIT(cinfo, JERR_PPM_NONNUMERIC);
105
106
0
  val = ch - '0';
107
0
  while ((ch = pbm_getc(infile)) >= '0' && ch <= '9') {
108
0
    val *= 10;
109
0
    val += ch - '0';
110
0
    if (val > maxval)
111
0
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
112
0
  }
113
114
0
  return val;
115
0
}
Unexecuted instantiation: rdppm-8.c:read_pbm_integer
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
0
{
134
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
135
0
  FILE *infile = source->pub.input_file;
136
0
  register _JSAMPROW ptr;
137
0
  register _JSAMPLE *rescale = source->rescale;
138
0
  JDIMENSION col;
139
0
  unsigned int maxval = source->maxval;
140
141
0
  ptr = source->pub._buffer[0];
142
0
  for (col = cinfo->image_width; col > 0; col--) {
143
0
    *ptr++ = rescale[read_pbm_integer(cinfo, infile, maxval)];
144
0
  }
145
0
  return 1;
146
0
}
Unexecuted instantiation: rdppm-8.c:get_text_gray_row
Unexecuted instantiation: rdppm-12.c:get_text_gray_row
Unexecuted instantiation: rdppm-16.c:get_text_gray_row
147
148
149
0
#define GRAY_RGB_READ_LOOP(read_op, alpha_set_op) { \
150
0
  for (col = cinfo->image_width; col > 0; col--) { \
151
0
    ptr[rindex] = ptr[gindex] = ptr[bindex] = read_op; \
152
0
    alpha_set_op \
153
0
    ptr += ps; \
154
0
  } \
155
0
}
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
0
{
162
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
163
0
  FILE *infile = source->pub.input_file;
164
0
  register _JSAMPROW ptr;
165
0
  register _JSAMPLE *rescale = source->rescale;
166
0
  JDIMENSION col;
167
0
  unsigned int maxval = source->maxval;
168
0
  register int rindex = rgb_red[cinfo->in_color_space];
169
0
  register int gindex = rgb_green[cinfo->in_color_space];
170
0
  register int bindex = rgb_blue[cinfo->in_color_space];
171
0
  register int aindex = alpha_index[cinfo->in_color_space];
172
0
  register int ps = rgb_pixelsize[cinfo->in_color_space];
173
174
0
  ptr = source->pub._buffer[0];
175
0
  if (maxval == (1U << cinfo->data_precision) - 1U) {
176
0
    if (aindex >= 0)
177
0
      GRAY_RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval),
178
0
                         ptr[aindex] = (_JSAMPLE)maxval;)
179
0
    else
180
0
      GRAY_RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval), {})
181
0
  } else {
182
0
    if (aindex >= 0)
183
0
      GRAY_RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)],
184
0
                         ptr[aindex] = (1 << cinfo->data_precision) - 1;)
185
0
    else
186
0
      GRAY_RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)], {})
187
0
  }
188
0
  return 1;
189
0
}
Unexecuted instantiation: rdppm-8.c:get_text_gray_rgb_row
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
0
#define RGB_READ_LOOP(read_op, alpha_set_op) { \
224
0
  for (col = cinfo->image_width; col > 0; col--) { \
225
0
    ptr[rindex] = read_op; \
226
0
    ptr[gindex] = read_op; \
227
0
    ptr[bindex] = read_op; \
228
0
    alpha_set_op \
229
0
    ptr += ps; \
230
0
  } \
231
0
}
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
0
{
237
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
238
0
  FILE *infile = source->pub.input_file;
239
0
  register _JSAMPROW ptr;
240
0
  register _JSAMPLE *rescale = source->rescale;
241
0
  JDIMENSION col;
242
0
  unsigned int maxval = source->maxval;
243
0
  register int rindex = rgb_red[cinfo->in_color_space];
244
0
  register int gindex = rgb_green[cinfo->in_color_space];
245
0
  register int bindex = rgb_blue[cinfo->in_color_space];
246
0
  register int aindex = alpha_index[cinfo->in_color_space];
247
0
  register int ps = rgb_pixelsize[cinfo->in_color_space];
248
249
0
  ptr = source->pub._buffer[0];
250
0
  if (maxval == (1U << cinfo->data_precision) - 1U) {
251
0
    if (aindex >= 0)
252
0
      RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval),
253
0
                    ptr[aindex] = (_JSAMPLE)maxval;)
254
0
    else
255
0
      RGB_READ_LOOP((_JSAMPLE)read_pbm_integer(cinfo, infile, maxval), {})
256
0
  } else {
257
0
    if (aindex >= 0)
258
0
      RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)],
259
0
                    ptr[aindex] = (1 << cinfo->data_precision) - 1;)
260
0
    else
261
0
      RGB_READ_LOOP(rescale[read_pbm_integer(cinfo, infile, maxval)], {})
262
0
  }
263
0
  return 1;
264
0
}
Unexecuted instantiation: rdppm-8.c:get_text_rgb_row
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
0
{
306
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
307
0
  register _JSAMPROW ptr;
308
0
  register unsigned char *bufferptr;
309
0
  register _JSAMPLE *rescale = source->rescale;
310
0
  JDIMENSION col;
311
312
0
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
313
0
    ERREXIT(cinfo, JERR_INPUT_EOF);
314
0
  ptr = source->pub._buffer[0];
315
0
  bufferptr = source->iobuffer;
316
0
  for (col = cinfo->image_width; col > 0; col--) {
317
0
    *ptr++ = rescale[*bufferptr++];
318
0
  }
319
0
  return 1;
320
0
}
Unexecuted instantiation: rdppm-8.c:get_scaled_gray_row
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
0
{
328
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
329
0
  register _JSAMPROW ptr;
330
0
  register unsigned char *bufferptr;
331
0
  register _JSAMPLE *rescale = source->rescale;
332
0
  JDIMENSION col;
333
0
  unsigned int maxval = source->maxval;
334
0
  register int rindex = rgb_red[cinfo->in_color_space];
335
0
  register int gindex = rgb_green[cinfo->in_color_space];
336
0
  register int bindex = rgb_blue[cinfo->in_color_space];
337
0
  register int aindex = alpha_index[cinfo->in_color_space];
338
0
  register int ps = rgb_pixelsize[cinfo->in_color_space];
339
340
0
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
341
0
    ERREXIT(cinfo, JERR_INPUT_EOF);
342
0
  ptr = source->pub._buffer[0];
343
0
  bufferptr = source->iobuffer;
344
0
  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
0
  } else {
350
0
    if (aindex >= 0)
351
0
      GRAY_RGB_READ_LOOP(rescale[*bufferptr++],
352
0
                         ptr[aindex] = (1 << cinfo->data_precision) - 1;)
353
0
    else
354
0
      GRAY_RGB_READ_LOOP(rescale[*bufferptr++], {})
355
0
  }
356
0
  return 1;
357
0
}
Unexecuted instantiation: rdppm-8.c:get_gray_rgb_row
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
0
{
398
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
399
0
  register _JSAMPROW ptr;
400
0
  register unsigned char *bufferptr;
401
0
  register _JSAMPLE *rescale = source->rescale;
402
0
  JDIMENSION col;
403
0
  unsigned int maxval = source->maxval;
404
0
  register int rindex = rgb_red[cinfo->in_color_space];
405
0
  register int gindex = rgb_green[cinfo->in_color_space];
406
0
  register int bindex = rgb_blue[cinfo->in_color_space];
407
0
  register int aindex = alpha_index[cinfo->in_color_space];
408
0
  register int ps = rgb_pixelsize[cinfo->in_color_space];
409
410
0
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
411
0
    ERREXIT(cinfo, JERR_INPUT_EOF);
412
0
  ptr = source->pub._buffer[0];
413
0
  bufferptr = source->iobuffer;
414
0
  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
0
  } else {
420
0
    if (aindex >= 0)
421
0
      RGB_READ_LOOP(rescale[*bufferptr++],
422
0
                    ptr[aindex] = (1 << cinfo->data_precision) - 1;)
423
0
    else
424
0
      RGB_READ_LOOP(rescale[*bufferptr++], {})
425
0
  }
426
0
  return 1;
427
0
}
Unexecuted instantiation: rdppm-8.c:get_rgb_row
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
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
0
{
492
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
493
0
  register _JSAMPROW ptr;
494
0
  register unsigned char *bufferptr;
495
0
  register _JSAMPLE *rescale = source->rescale;
496
0
  JDIMENSION col;
497
0
  unsigned int maxval = source->maxval;
498
499
0
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
500
0
    ERREXIT(cinfo, JERR_INPUT_EOF);
501
0
  ptr = source->pub._buffer[0];
502
0
  bufferptr = source->iobuffer;
503
0
  for (col = cinfo->image_width; col > 0; col--) {
504
0
    register unsigned int temp;
505
0
    temp  = (*bufferptr++) << 8;
506
0
    temp |= (*bufferptr++);
507
0
    if (temp > maxval)
508
0
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
509
0
    *ptr++ = rescale[temp];
510
0
  }
511
0
  return 1;
512
0
}
Unexecuted instantiation: rdppm-8.c:get_word_gray_row
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
0
{
519
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
520
0
  register _JSAMPROW ptr;
521
0
  register unsigned char *bufferptr;
522
0
  register _JSAMPLE *rescale = source->rescale;
523
0
  JDIMENSION col;
524
0
  unsigned int maxval = source->maxval;
525
0
  register int rindex = rgb_red[cinfo->in_color_space];
526
0
  register int gindex = rgb_green[cinfo->in_color_space];
527
0
  register int bindex = rgb_blue[cinfo->in_color_space];
528
0
  register int aindex = alpha_index[cinfo->in_color_space];
529
0
  register int ps = rgb_pixelsize[cinfo->in_color_space];
530
531
0
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
532
0
    ERREXIT(cinfo, JERR_INPUT_EOF);
533
0
  ptr = source->pub._buffer[0];
534
0
  bufferptr = source->iobuffer;
535
0
  for (col = cinfo->image_width; col > 0; col--) {
536
0
    register unsigned int temp;
537
0
    temp  = (*bufferptr++) << 8;
538
0
    temp |= (*bufferptr++);
539
0
    if (temp > maxval)
540
0
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
541
0
    ptr[rindex] = ptr[gindex] = ptr[bindex] = rescale[temp];
542
0
    if (aindex >= 0)
543
0
      ptr[aindex] = (1 << cinfo->data_precision) - 1;
544
0
    ptr += ps;
545
0
  }
546
0
  return 1;
547
0
}
Unexecuted instantiation: rdppm-8.c:get_word_gray_rgb_row
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
0
{
598
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
599
0
  register _JSAMPROW ptr;
600
0
  register unsigned char *bufferptr;
601
0
  register _JSAMPLE *rescale = source->rescale;
602
0
  JDIMENSION col;
603
0
  unsigned int maxval = source->maxval;
604
0
  register int rindex = rgb_red[cinfo->in_color_space];
605
0
  register int gindex = rgb_green[cinfo->in_color_space];
606
0
  register int bindex = rgb_blue[cinfo->in_color_space];
607
0
  register int aindex = alpha_index[cinfo->in_color_space];
608
0
  register int ps = rgb_pixelsize[cinfo->in_color_space];
609
610
0
  if (!ReadOK(source->pub.input_file, source->iobuffer, source->buffer_width))
611
0
    ERREXIT(cinfo, JERR_INPUT_EOF);
612
0
  ptr = source->pub._buffer[0];
613
0
  bufferptr = source->iobuffer;
614
0
  for (col = cinfo->image_width; col > 0; col--) {
615
0
    register unsigned int temp;
616
0
    temp  = (*bufferptr++) << 8;
617
0
    temp |= (*bufferptr++);
618
0
    if (temp > maxval)
619
0
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
620
0
    ptr[rindex] = rescale[temp];
621
0
    temp  = (*bufferptr++) << 8;
622
0
    temp |= (*bufferptr++);
623
0
    if (temp > maxval)
624
0
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
625
0
    ptr[gindex] = rescale[temp];
626
0
    temp  = (*bufferptr++) << 8;
627
0
    temp |= (*bufferptr++);
628
0
    if (temp > maxval)
629
0
      ERREXIT(cinfo, JERR_PPM_OUTOFRANGE);
630
0
    ptr[bindex] = rescale[temp];
631
0
    if (aindex >= 0)
632
0
      ptr[aindex] = (1 << cinfo->data_precision) - 1;
633
0
    ptr += ps;
634
0
  }
635
0
  return 1;
636
0
}
Unexecuted instantiation: rdppm-8.c:get_word_rgb_row
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
0
{
704
0
  ppm_source_ptr source = (ppm_source_ptr)sinfo;
705
0
  int c;
706
0
  unsigned int w, h, maxval;
707
0
  boolean need_iobuffer, use_raw_buffer, need_rescale;
708
709
0
  if (getc(source->pub.input_file) != 'P')
710
0
    ERREXIT(cinfo, JERR_PPM_NOT);
711
712
0
  c = getc(source->pub.input_file); /* subformat discriminator character */
713
714
  /* detect unsupported variants (ie, PBM) before trying to read header */
715
0
  switch (c) {
716
0
  case '2':                     /* it's a text-format PGM file */
717
0
  case '3':                     /* it's a text-format PPM file */
718
0
  case '5':                     /* it's a raw-format PGM file */
719
0
  case '6':                     /* it's a raw-format PPM file */
720
0
    break;
721
0
  default:
722
0
    ERREXIT(cinfo, JERR_PPM_NOT);
723
0
    break;
724
0
  }
725
726
  /* fetch the remaining header info */
727
0
  w = read_pbm_integer(cinfo, source->pub.input_file, 65535);
728
0
  h = read_pbm_integer(cinfo, source->pub.input_file, 65535);
729
0
  maxval = read_pbm_integer(cinfo, source->pub.input_file, 65535);
730
731
0
  if (w <= 0 || h <= 0 || maxval <= 0) /* error check */
732
0
    ERREXIT(cinfo, JERR_PPM_NOT);
733
0
  if (w > JPEG_MAX_DIMENSION || h > JPEG_MAX_DIMENSION)
734
0
    ERREXIT1(cinfo, JERR_IMAGE_TOO_BIG, JPEG_MAX_DIMENSION);
735
0
  if (sinfo->max_pixels && (unsigned long long)w * h > sinfo->max_pixels)
736
0
    ERREXIT1(cinfo, JERR_IMAGE_TOO_BIG, sinfo->max_pixels);
737
738
0
  cinfo->image_width = (JDIMENSION)w;
739
0
  cinfo->image_height = (JDIMENSION)h;
740
0
  source->maxval = maxval;
741
742
  /* initialize flags to most common settings */
743
0
  need_iobuffer = TRUE;         /* do we need an I/O buffer? */
744
0
  use_raw_buffer = FALSE;       /* do we map input buffer onto I/O buffer? */
745
0
  need_rescale = TRUE;          /* do we need a rescale array? */
746
747
0
  switch (c) {
748
0
  case '2':                     /* it's a text-format PGM file */
749
0
    if (cinfo->in_color_space == JCS_UNKNOWN ||
750
0
        cinfo->in_color_space == JCS_RGB)
751
0
      cinfo->in_color_space = JCS_GRAYSCALE;
752
0
    TRACEMS3(cinfo, 1, JTRC_PGM_TEXT, w, h, maxval);
753
0
    if (cinfo->in_color_space == JCS_GRAYSCALE)
754
0
      source->pub.get_pixel_rows = get_text_gray_row;
755
0
    else if (IsExtRGB(cinfo->in_color_space))
756
0
      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
0
    need_iobuffer = FALSE;
762
0
    break;
763
764
0
  case '3':                     /* it's a text-format PPM file */
765
0
    if (cinfo->in_color_space == JCS_UNKNOWN)
766
0
      cinfo->in_color_space = JCS_EXT_RGB;
767
0
    TRACEMS3(cinfo, 1, JTRC_PPM_TEXT, w, h, maxval);
768
0
    if (IsExtRGB(cinfo->in_color_space))
769
0
      source->pub.get_pixel_rows = get_text_rgb_row;
770
0
    else if (cinfo->in_color_space == JCS_CMYK)
771
0
      source->pub.get_pixel_rows = get_text_rgb_cmyk_row;
772
0
    else
773
0
      ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
774
0
    need_iobuffer = FALSE;
775
0
    break;
776
777
0
  case '5':                     /* it's a raw-format PGM file */
778
0
    if (cinfo->in_color_space == JCS_UNKNOWN ||
779
0
        cinfo->in_color_space == JCS_RGB)
780
0
      cinfo->in_color_space = JCS_GRAYSCALE;
781
0
    TRACEMS3(cinfo, 1, JTRC_PGM, w, h, maxval);
782
0
    if (maxval > 255) {
783
0
      if (cinfo->in_color_space == JCS_GRAYSCALE)
784
0
        source->pub.get_pixel_rows = get_word_gray_row;
785
0
      else if (IsExtRGB(cinfo->in_color_space))
786
0
        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
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
0
    } else {
800
0
      if (cinfo->in_color_space == JCS_GRAYSCALE)
801
0
        source->pub.get_pixel_rows = get_scaled_gray_row;
802
0
      else if (IsExtRGB(cinfo->in_color_space))
803
0
        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
0
    }
809
0
    break;
810
811
0
  case '6':                     /* it's a raw-format PPM file */
812
0
    if (cinfo->in_color_space == JCS_UNKNOWN)
813
0
      cinfo->in_color_space = JCS_EXT_RGB;
814
0
    TRACEMS3(cinfo, 1, JTRC_PPM, w, h, maxval);
815
0
    if (maxval > 255) {
816
0
      if (IsExtRGB(cinfo->in_color_space))
817
0
        source->pub.get_pixel_rows = get_word_rgb_row;
818
0
      else if (cinfo->in_color_space == JCS_CMYK)
819
0
        source->pub.get_pixel_rows = get_word_rgb_cmyk_row;
820
0
      else
821
0
        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
0
    } else {
836
0
      if (IsExtRGB(cinfo->in_color_space))
837
0
        source->pub.get_pixel_rows = get_rgb_row;
838
0
      else if (cinfo->in_color_space == JCS_CMYK)
839
0
        source->pub.get_pixel_rows = get_rgb_cmyk_row;
840
0
      else
841
0
        ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
842
0
    }
843
0
    break;
844
0
  }
845
846
0
  if (IsExtRGB(cinfo->in_color_space))
847
0
    cinfo->input_components = rgb_pixelsize[cinfo->in_color_space];
848
0
  else if (cinfo->in_color_space == JCS_GRAYSCALE)
849
0
    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
0
  if (need_iobuffer) {
855
0
    if (c == '6')
856
0
      source->buffer_width = (size_t)w * 3 * (maxval <= 255 ? 1 : 2);
857
0
    else
858
0
      source->buffer_width = (size_t)w * (maxval <= 255 ? 1 : 2);
859
0
    source->iobuffer = (unsigned char *)
860
0
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
861
0
                                  source->buffer_width);
862
0
  }
863
864
  /* Create compressor input buffer. */
865
0
  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
0
  } else {
872
    /* Need to translate anyway, so make a separate sample buffer. */
873
0
    source->pub._buffer = (_JSAMPARRAY)(*cinfo->mem->alloc_sarray)
874
0
      ((j_common_ptr)cinfo, JPOOL_IMAGE,
875
0
       (JDIMENSION)w * cinfo->input_components, (JDIMENSION)1);
876
0
    source->pub.buffer_height = 1;
877
0
  }
878
879
  /* Compute the rescaling array if required. */
880
0
  if (need_rescale) {
881
0
    size_t val, half_maxval;
882
883
    /* On 16-bit-int machines we have to be careful of maxval = 65535 */
884
0
    source->rescale = (_JSAMPLE *)
885
0
      (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
886
0
                                  (MAX(maxval, 255) + 1L) * sizeof(_JSAMPLE));
887
0
    memset(source->rescale, 0, (MAX(maxval, 255) + 1L) * sizeof(_JSAMPLE));
888
0
    half_maxval = (size_t)maxval / 2;
889
0
    for (val = 0; val <= (size_t)maxval; val++) {
890
      /* The multiplication here must be done in 32 bits to avoid overflow */
891
0
      source->rescale[val] =
892
0
        (_JSAMPLE)((val * ((1 << cinfo->data_precision) - 1) + half_maxval) /
893
0
                   maxval);
894
0
    }
895
0
  }
896
0
}
Unexecuted instantiation: rdppm-8.c:start_input_ppm
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
0
{
914
  /* no work */
915
0
}
Unexecuted instantiation: rdppm-8.c:finish_input_ppm
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
0
{
925
0
  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
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
0
  source = (ppm_source_ptr)
937
0
    (*cinfo->mem->alloc_small) ((j_common_ptr)cinfo, JPOOL_IMAGE,
938
0
                                sizeof(ppm_source_struct));
939
  /* Fill in method ptrs, except get_pixel_rows which start_input sets */
940
0
  source->pub.start_input = start_input_ppm;
941
0
  source->pub.read_icc_profile = read_icc_profile_ppm;
942
0
  source->pub.finish_input = finish_input_ppm;
943
0
  source->pub.max_pixels = 0;
944
945
0
  return (cjpeg_source_ptr)source;
946
0
}
Unexecuted instantiation: jinit_read_ppm
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)) */