Coverage Report

Created: 2025-10-12 07:48

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libpng/pngget.c
Line
Count
Source
1
/* pngget.c - retrieval of values from info struct
2
 *
3
 * Copyright (c) 2018-2025 Cosmin Truta
4
 * Copyright (c) 1998-2002,2004,2006-2018 Glenn Randers-Pehrson
5
 * Copyright (c) 1996-1997 Andreas Dilger
6
 * Copyright (c) 1995-1996 Guy Eric Schalnat, Group 42, Inc.
7
 *
8
 * This code is released under the libpng license.
9
 * For conditions of distribution and use, see the disclaimer
10
 * and license in png.h
11
 *
12
 */
13
14
#include "pngpriv.h"
15
16
#if defined(PNG_READ_SUPPORTED) || defined(PNG_WRITE_SUPPORTED)
17
18
png_uint_32
19
png_get_valid(png_const_structrp png_ptr, png_const_inforp info_ptr,
20
    png_uint_32 flag)
21
938k
{
22
938k
   if (png_ptr != NULL && info_ptr != NULL)
23
938k
   {
24
938k
#ifdef PNG_READ_tRNS_SUPPORTED
25
      /* png_handle_PLTE() may have canceled a valid tRNS chunk but left the
26
       * 'valid' flag for the detection of duplicate chunks. Do not report a
27
       * valid tRNS chunk in this case.
28
       */
29
938k
      if (flag == PNG_INFO_tRNS && png_ptr->num_trans == 0)
30
158k
         return 0;
31
779k
#endif
32
33
779k
      return info_ptr->valid & flag;
34
938k
   }
35
36
0
   return 0;
37
938k
}
38
39
size_t
40
png_get_rowbytes(png_const_structrp png_ptr, png_const_inforp info_ptr)
41
46.5k
{
42
46.5k
   if (png_ptr != NULL && info_ptr != NULL)
43
46.5k
      return info_ptr->rowbytes;
44
45
0
   return 0;
46
46.5k
}
47
48
#ifdef PNG_INFO_IMAGE_SUPPORTED
49
png_bytepp
50
png_get_rows(png_const_structrp png_ptr, png_const_inforp info_ptr)
51
0
{
52
0
   if (png_ptr != NULL && info_ptr != NULL)
53
0
      return info_ptr->row_pointers;
54
55
0
   return 0;
56
0
}
57
#endif
58
59
#ifdef PNG_EASY_ACCESS_SUPPORTED
60
/* Easy access to info, added in libpng-0.99 */
61
png_uint_32
62
png_get_image_width(png_const_structrp png_ptr, png_const_inforp info_ptr)
63
0
{
64
0
   if (png_ptr != NULL && info_ptr != NULL)
65
0
      return info_ptr->width;
66
67
0
   return 0;
68
0
}
69
70
png_uint_32
71
png_get_image_height(png_const_structrp png_ptr, png_const_inforp info_ptr)
72
0
{
73
0
   if (png_ptr != NULL && info_ptr != NULL)
74
0
      return info_ptr->height;
75
76
0
   return 0;
77
0
}
78
79
png_byte
80
png_get_bit_depth(png_const_structrp png_ptr, png_const_inforp info_ptr)
81
0
{
82
0
   if (png_ptr != NULL && info_ptr != NULL)
83
0
      return info_ptr->bit_depth;
84
85
0
   return 0;
86
0
}
87
88
png_byte
89
png_get_color_type(png_const_structrp png_ptr, png_const_inforp info_ptr)
90
0
{
91
0
   if (png_ptr != NULL && info_ptr != NULL)
92
0
      return info_ptr->color_type;
93
94
0
   return 0;
95
0
}
96
97
png_byte
98
png_get_filter_type(png_const_structrp png_ptr, png_const_inforp info_ptr)
99
0
{
100
0
   if (png_ptr != NULL && info_ptr != NULL)
101
0
      return info_ptr->filter_type;
102
103
0
   return 0;
104
0
}
105
106
png_byte
107
png_get_interlace_type(png_const_structrp png_ptr, png_const_inforp info_ptr)
108
0
{
109
0
   if (png_ptr != NULL && info_ptr != NULL)
110
0
      return info_ptr->interlace_type;
111
112
0
   return 0;
113
0
}
114
115
png_byte
116
png_get_compression_type(png_const_structrp png_ptr, png_const_inforp info_ptr)
117
0
{
118
0
   if (png_ptr != NULL && info_ptr != NULL)
119
0
      return info_ptr->compression_type;
120
121
0
   return 0;
122
0
}
123
124
png_uint_32
125
png_get_x_pixels_per_meter(png_const_structrp png_ptr, png_const_inforp
126
   info_ptr)
127
0
{
128
0
#ifdef PNG_pHYs_SUPPORTED
129
0
   png_debug(1, "in png_get_x_pixels_per_meter");
130
131
0
   if (png_ptr != NULL && info_ptr != NULL &&
132
0
       (info_ptr->valid & PNG_INFO_pHYs) != 0)
133
0
   {
134
0
      if (info_ptr->phys_unit_type == PNG_RESOLUTION_METER)
135
0
         return info_ptr->x_pixels_per_unit;
136
0
   }
137
#else
138
   PNG_UNUSED(png_ptr)
139
   PNG_UNUSED(info_ptr)
140
#endif
141
142
0
   return 0;
143
0
}
144
145
png_uint_32
146
png_get_y_pixels_per_meter(png_const_structrp png_ptr, png_const_inforp
147
    info_ptr)
148
0
{
149
0
#ifdef PNG_pHYs_SUPPORTED
150
0
   png_debug(1, "in png_get_y_pixels_per_meter");
151
152
0
   if (png_ptr != NULL && info_ptr != NULL &&
153
0
       (info_ptr->valid & PNG_INFO_pHYs) != 0)
154
0
   {
155
0
      if (info_ptr->phys_unit_type == PNG_RESOLUTION_METER)
156
0
         return info_ptr->y_pixels_per_unit;
157
0
   }
158
#else
159
   PNG_UNUSED(png_ptr)
160
   PNG_UNUSED(info_ptr)
161
#endif
162
163
0
   return 0;
164
0
}
165
166
png_uint_32
167
png_get_pixels_per_meter(png_const_structrp png_ptr, png_const_inforp info_ptr)
168
0
{
169
0
#ifdef PNG_pHYs_SUPPORTED
170
0
   png_debug(1, "in png_get_pixels_per_meter");
171
172
0
   if (png_ptr != NULL && info_ptr != NULL &&
173
0
       (info_ptr->valid & PNG_INFO_pHYs) != 0)
174
0
   {
175
0
      if (info_ptr->phys_unit_type == PNG_RESOLUTION_METER &&
176
0
          info_ptr->x_pixels_per_unit == info_ptr->y_pixels_per_unit)
177
0
         return info_ptr->x_pixels_per_unit;
178
0
   }
179
#else
180
   PNG_UNUSED(png_ptr)
181
   PNG_UNUSED(info_ptr)
182
#endif
183
184
0
   return 0;
185
0
}
186
187
#ifdef PNG_FLOATING_POINT_SUPPORTED
188
float
189
png_get_pixel_aspect_ratio(png_const_structrp png_ptr, png_const_inforp
190
   info_ptr)
191
0
{
192
0
#ifdef PNG_READ_pHYs_SUPPORTED
193
0
   png_debug(1, "in png_get_pixel_aspect_ratio");
194
195
0
   if (png_ptr != NULL && info_ptr != NULL &&
196
0
       (info_ptr->valid & PNG_INFO_pHYs) != 0)
197
0
   {
198
0
      if (info_ptr->x_pixels_per_unit != 0)
199
0
         return (float)info_ptr->y_pixels_per_unit
200
0
              / (float)info_ptr->x_pixels_per_unit;
201
0
   }
202
#else
203
   PNG_UNUSED(png_ptr)
204
   PNG_UNUSED(info_ptr)
205
#endif
206
207
0
   return (float)0.0;
208
0
}
209
#endif
210
211
#ifdef PNG_FIXED_POINT_SUPPORTED
212
png_fixed_point
213
png_get_pixel_aspect_ratio_fixed(png_const_structrp png_ptr,
214
    png_const_inforp info_ptr)
215
0
{
216
0
#ifdef PNG_READ_pHYs_SUPPORTED
217
0
   png_debug(1, "in png_get_pixel_aspect_ratio_fixed");
218
219
0
   if (png_ptr != NULL && info_ptr != NULL &&
220
0
       (info_ptr->valid & PNG_INFO_pHYs) != 0 &&
221
0
       info_ptr->x_pixels_per_unit > 0 && info_ptr->y_pixels_per_unit > 0 &&
222
0
       info_ptr->x_pixels_per_unit <= PNG_UINT_31_MAX &&
223
0
       info_ptr->y_pixels_per_unit <= PNG_UINT_31_MAX)
224
0
   {
225
0
      png_fixed_point res;
226
227
      /* The following casts work because a PNG 4 byte integer only has a valid
228
       * range of 0..2^31-1; otherwise the cast might overflow.
229
       */
230
0
      if (png_muldiv(&res, (png_int_32)info_ptr->y_pixels_per_unit, PNG_FP_1,
231
0
          (png_int_32)info_ptr->x_pixels_per_unit) != 0)
232
0
         return res;
233
0
   }
234
#else
235
   PNG_UNUSED(png_ptr)
236
   PNG_UNUSED(info_ptr)
237
#endif
238
239
0
   return 0;
240
0
}
241
#endif
242
243
png_int_32
244
png_get_x_offset_microns(png_const_structrp png_ptr, png_const_inforp info_ptr)
245
0
{
246
0
#ifdef PNG_oFFs_SUPPORTED
247
0
   png_debug(1, "in png_get_x_offset_microns");
248
249
0
   if (png_ptr != NULL && info_ptr != NULL &&
250
0
       (info_ptr->valid & PNG_INFO_oFFs) != 0)
251
0
   {
252
0
      if (info_ptr->offset_unit_type == PNG_OFFSET_MICROMETER)
253
0
         return info_ptr->x_offset;
254
0
   }
255
#else
256
   PNG_UNUSED(png_ptr)
257
   PNG_UNUSED(info_ptr)
258
#endif
259
260
0
   return 0;
261
0
}
262
263
png_int_32
264
png_get_y_offset_microns(png_const_structrp png_ptr, png_const_inforp info_ptr)
265
0
{
266
0
#ifdef PNG_oFFs_SUPPORTED
267
0
   png_debug(1, "in png_get_y_offset_microns");
268
269
0
   if (png_ptr != NULL && info_ptr != NULL &&
270
0
       (info_ptr->valid & PNG_INFO_oFFs) != 0)
271
0
   {
272
0
      if (info_ptr->offset_unit_type == PNG_OFFSET_MICROMETER)
273
0
         return info_ptr->y_offset;
274
0
   }
275
#else
276
   PNG_UNUSED(png_ptr)
277
   PNG_UNUSED(info_ptr)
278
#endif
279
280
0
   return 0;
281
0
}
282
283
png_int_32
284
png_get_x_offset_pixels(png_const_structrp png_ptr, png_const_inforp info_ptr)
285
49
{
286
49
#ifdef PNG_oFFs_SUPPORTED
287
49
   png_debug(1, "in png_get_x_offset_pixels");
288
289
49
   if (png_ptr != NULL && info_ptr != NULL &&
290
49
       (info_ptr->valid & PNG_INFO_oFFs) != 0)
291
49
   {
292
49
      if (info_ptr->offset_unit_type == PNG_OFFSET_PIXEL)
293
10
         return info_ptr->x_offset;
294
49
   }
295
#else
296
   PNG_UNUSED(png_ptr)
297
   PNG_UNUSED(info_ptr)
298
#endif
299
300
39
   return 0;
301
49
}
302
303
png_int_32
304
png_get_y_offset_pixels(png_const_structrp png_ptr, png_const_inforp info_ptr)
305
49
{
306
49
#ifdef PNG_oFFs_SUPPORTED
307
49
   png_debug(1, "in png_get_y_offset_pixels");
308
309
49
   if (png_ptr != NULL && info_ptr != NULL &&
310
49
       (info_ptr->valid & PNG_INFO_oFFs) != 0)
311
49
   {
312
49
      if (info_ptr->offset_unit_type == PNG_OFFSET_PIXEL)
313
10
         return info_ptr->y_offset;
314
49
   }
315
#else
316
   PNG_UNUSED(png_ptr)
317
   PNG_UNUSED(info_ptr)
318
#endif
319
320
39
   return 0;
321
49
}
322
323
#ifdef PNG_INCH_CONVERSIONS_SUPPORTED
324
static png_uint_32
325
ppi_from_ppm(png_uint_32 ppm)
326
0
{
327
#if 0
328
   /* The conversion is *(2.54/100), in binary (32 digits):
329
    * .00000110100000001001110101001001
330
    */
331
   png_uint_32 t1001, t1101;
332
   ppm >>= 1;                  /* .1 */
333
   t1001 = ppm + (ppm >> 3);   /* .1001 */
334
   t1101 = t1001 + (ppm >> 1); /* .1101 */
335
   ppm >>= 20;                 /* .000000000000000000001 */
336
   t1101 += t1101 >> 15;       /* .1101000000000001101 */
337
   t1001 >>= 11;               /* .000000000001001 */
338
   t1001 += t1001 >> 12;       /* .000000000001001000000001001 */
339
   ppm += t1001;               /* .000000000001001000001001001 */
340
   ppm += t1101;               /* .110100000001001110101001001 */
341
   return (ppm + 16) >> 5;/* .00000110100000001001110101001001 */
342
#else
343
   /* The argument is a PNG unsigned integer, so it is not permitted
344
    * to be bigger than 2^31.
345
    */
346
0
   png_fixed_point result;
347
0
   if (ppm <= PNG_UINT_31_MAX && png_muldiv(&result, (png_int_32)ppm, 127,
348
0
       5000) != 0)
349
0
      return (png_uint_32)result;
350
351
   /* Overflow. */
352
0
   return 0;
353
0
#endif
354
0
}
355
356
png_uint_32
357
png_get_pixels_per_inch(png_const_structrp png_ptr, png_const_inforp info_ptr)
358
0
{
359
0
   return ppi_from_ppm(png_get_pixels_per_meter(png_ptr, info_ptr));
360
0
}
361
362
png_uint_32
363
png_get_x_pixels_per_inch(png_const_structrp png_ptr, png_const_inforp info_ptr)
364
0
{
365
0
   return ppi_from_ppm(png_get_x_pixels_per_meter(png_ptr, info_ptr));
366
0
}
367
368
png_uint_32
369
png_get_y_pixels_per_inch(png_const_structrp png_ptr, png_const_inforp info_ptr)
370
0
{
371
0
   return ppi_from_ppm(png_get_y_pixels_per_meter(png_ptr, info_ptr));
372
0
}
373
374
#ifdef PNG_FIXED_POINT_SUPPORTED
375
static png_fixed_point
376
png_fixed_inches_from_microns(png_const_structrp png_ptr, png_int_32 microns)
377
0
{
378
   /* Convert from meters * 1,000,000 to inches * 100,000, meters to
379
    * inches is simply *(100/2.54), so we want *(10/2.54) == 500/127.
380
    * Notice that this can overflow - a warning is output and 0 is
381
    * returned.
382
    */
383
0
   png_fixed_point result;
384
385
0
   if (png_muldiv(&result, microns, 500, 127) != 0)
386
0
      return result;
387
388
0
   png_warning(png_ptr, "fixed point overflow ignored");
389
0
   return 0;
390
0
}
391
392
png_fixed_point
393
png_get_x_offset_inches_fixed(png_const_structrp png_ptr,
394
    png_const_inforp info_ptr)
395
0
{
396
0
   return png_fixed_inches_from_microns(png_ptr,
397
0
       png_get_x_offset_microns(png_ptr, info_ptr));
398
0
}
399
#endif /* FIXED_POINT */
400
401
#ifdef PNG_FIXED_POINT_SUPPORTED
402
png_fixed_point
403
png_get_y_offset_inches_fixed(png_const_structrp png_ptr,
404
    png_const_inforp info_ptr)
405
0
{
406
0
   return png_fixed_inches_from_microns(png_ptr,
407
0
       png_get_y_offset_microns(png_ptr, info_ptr));
408
0
}
409
#endif
410
411
#ifdef PNG_FLOATING_POINT_SUPPORTED
412
float
413
png_get_x_offset_inches(png_const_structrp png_ptr, png_const_inforp info_ptr)
414
0
{
415
   /* To avoid the overflow do the conversion directly in floating
416
    * point.
417
    */
418
0
   return (float)(png_get_x_offset_microns(png_ptr, info_ptr) * .00003937);
419
0
}
420
#endif
421
422
#ifdef PNG_FLOATING_POINT_SUPPORTED
423
float
424
png_get_y_offset_inches(png_const_structrp png_ptr, png_const_inforp info_ptr)
425
0
{
426
   /* To avoid the overflow do the conversion directly in floating
427
    * point.
428
    */
429
0
   return (float)(png_get_y_offset_microns(png_ptr, info_ptr) * .00003937);
430
0
}
431
#endif
432
433
#ifdef PNG_pHYs_SUPPORTED
434
png_uint_32
435
png_get_pHYs_dpi(png_const_structrp png_ptr, png_const_inforp info_ptr,
436
    png_uint_32 *res_x, png_uint_32 *res_y, int *unit_type)
437
0
{
438
0
   png_uint_32 retval = 0;
439
440
0
   png_debug1(1, "in %s retrieval function", "pHYs");
441
442
0
   if (png_ptr != NULL && info_ptr != NULL &&
443
0
       (info_ptr->valid & PNG_INFO_pHYs) != 0)
444
0
   {
445
0
      if (res_x != NULL)
446
0
      {
447
0
         *res_x = info_ptr->x_pixels_per_unit;
448
0
         retval |= PNG_INFO_pHYs;
449
0
      }
450
451
0
      if (res_y != NULL)
452
0
      {
453
0
         *res_y = info_ptr->y_pixels_per_unit;
454
0
         retval |= PNG_INFO_pHYs;
455
0
      }
456
457
0
      if (unit_type != NULL)
458
0
      {
459
0
         *unit_type = (int)info_ptr->phys_unit_type;
460
0
         retval |= PNG_INFO_pHYs;
461
462
0
         if (*unit_type == 1)
463
0
         {
464
0
            if (res_x != NULL) *res_x = (png_uint_32)(*res_x * .0254 + .50);
465
0
            if (res_y != NULL) *res_y = (png_uint_32)(*res_y * .0254 + .50);
466
0
         }
467
0
      }
468
0
   }
469
470
0
   return retval;
471
0
}
472
#endif /* pHYs */
473
#endif /* INCH_CONVERSIONS */
474
475
/* png_get_channels really belongs in here, too, but it's been around longer */
476
477
#endif /* EASY_ACCESS */
478
479
480
png_byte
481
png_get_channels(png_const_structrp png_ptr, png_const_inforp info_ptr)
482
0
{
483
0
   if (png_ptr != NULL && info_ptr != NULL)
484
0
      return info_ptr->channels;
485
486
0
   return 0;
487
0
}
488
489
#ifdef PNG_READ_SUPPORTED
490
png_const_bytep
491
png_get_signature(png_const_structrp png_ptr, png_const_inforp info_ptr)
492
0
{
493
0
   if (png_ptr != NULL && info_ptr != NULL)
494
0
      return info_ptr->signature;
495
496
0
   return NULL;
497
0
}
498
#endif
499
500
#ifdef PNG_bKGD_SUPPORTED
501
png_uint_32
502
png_get_bKGD(png_const_structrp png_ptr, png_inforp info_ptr,
503
    png_color_16p *background)
504
46.5k
{
505
46.5k
   png_debug1(1, "in %s retrieval function", "bKGD");
506
507
46.5k
   if (png_ptr != NULL && info_ptr != NULL &&
508
46.5k
       (info_ptr->valid & PNG_INFO_bKGD) != 0 &&
509
231
       background != NULL)
510
231
   {
511
231
      *background = &(info_ptr->background);
512
231
      return PNG_INFO_bKGD;
513
231
   }
514
515
46.3k
   return 0;
516
46.5k
}
517
#endif
518
519
#ifdef PNG_cHRM_SUPPORTED
520
/* The XYZ APIs were added in 1.5.5 to take advantage of the code added at the
521
 * same time to correct the rgb grayscale coefficient defaults obtained from the
522
 * cHRM chunk in 1.5.4
523
 */
524
#  ifdef PNG_FLOATING_POINT_SUPPORTED
525
png_uint_32
526
png_get_cHRM(png_const_structrp png_ptr, png_const_inforp info_ptr,
527
    double *whitex, double *whitey, double *redx, double *redy,
528
    double *greenx, double *greeny, double *bluex, double *bluey)
529
119
{
530
119
   png_debug1(1, "in %s retrieval function", "cHRM");
531
532
   /* PNGv3: this just returns the values store from the cHRM, if any. */
533
119
   if (png_ptr != NULL && info_ptr != NULL &&
534
119
       (info_ptr->valid & PNG_INFO_cHRM) != 0)
535
119
   {
536
119
      if (whitex != NULL)
537
119
         *whitex = png_float(png_ptr, info_ptr->cHRM.whitex, "cHRM wx");
538
119
      if (whitey != NULL)
539
119
         *whitey = png_float(png_ptr, info_ptr->cHRM.whitey, "cHRM wy");
540
119
      if (redx   != NULL)
541
119
         *redx   = png_float(png_ptr, info_ptr->cHRM.redx,   "cHRM rx");
542
119
      if (redy   != NULL)
543
119
         *redy   = png_float(png_ptr, info_ptr->cHRM.redy,   "cHRM ry");
544
119
      if (greenx != NULL)
545
119
         *greenx = png_float(png_ptr, info_ptr->cHRM.greenx, "cHRM gx");
546
119
      if (greeny != NULL)
547
119
         *greeny = png_float(png_ptr, info_ptr->cHRM.greeny, "cHRM gy");
548
119
      if (bluex  != NULL)
549
119
         *bluex  = png_float(png_ptr, info_ptr->cHRM.bluex,  "cHRM bx");
550
119
      if (bluey  != NULL)
551
119
         *bluey  = png_float(png_ptr, info_ptr->cHRM.bluey,  "cHRM by");
552
119
      return PNG_INFO_cHRM;
553
119
   }
554
555
0
   return 0;
556
119
}
557
558
png_uint_32
559
png_get_cHRM_XYZ(png_const_structrp png_ptr, png_const_inforp info_ptr,
560
    double *red_X, double *red_Y, double *red_Z, double *green_X,
561
    double *green_Y, double *green_Z, double *blue_X, double *blue_Y,
562
    double *blue_Z)
563
0
{
564
0
   png_XYZ XYZ;
565
0
   png_debug1(1, "in %s retrieval function", "cHRM_XYZ(float)");
566
567
0
   if (png_ptr != NULL && info_ptr != NULL &&
568
0
       (info_ptr->valid & PNG_INFO_cHRM) != 0 &&
569
0
       png_XYZ_from_xy(&XYZ, &info_ptr->cHRM) == 0)
570
0
   {
571
0
      if (red_X != NULL)
572
0
         *red_X = png_float(png_ptr, XYZ.red_X, "cHRM red X");
573
0
      if (red_Y != NULL)
574
0
         *red_Y = png_float(png_ptr, XYZ.red_Y, "cHRM red Y");
575
0
      if (red_Z != NULL)
576
0
         *red_Z = png_float(png_ptr, XYZ.red_Z, "cHRM red Z");
577
0
      if (green_X != NULL)
578
0
         *green_X = png_float(png_ptr, XYZ.green_X, "cHRM green X");
579
0
      if (green_Y != NULL)
580
0
         *green_Y = png_float(png_ptr, XYZ.green_Y, "cHRM green Y");
581
0
      if (green_Z != NULL)
582
0
         *green_Z = png_float(png_ptr, XYZ.green_Z, "cHRM green Z");
583
0
      if (blue_X != NULL)
584
0
         *blue_X = png_float(png_ptr, XYZ.blue_X, "cHRM blue X");
585
0
      if (blue_Y != NULL)
586
0
         *blue_Y = png_float(png_ptr, XYZ.blue_Y, "cHRM blue Y");
587
0
      if (blue_Z != NULL)
588
0
         *blue_Z = png_float(png_ptr, XYZ.blue_Z, "cHRM blue Z");
589
0
      return PNG_INFO_cHRM;
590
0
   }
591
592
0
   return 0;
593
0
}
594
#  endif
595
596
#  ifdef PNG_FIXED_POINT_SUPPORTED
597
png_uint_32
598
png_get_cHRM_XYZ_fixed(png_const_structrp png_ptr, png_const_inforp info_ptr,
599
    png_fixed_point *int_red_X, png_fixed_point *int_red_Y,
600
    png_fixed_point *int_red_Z, png_fixed_point *int_green_X,
601
    png_fixed_point *int_green_Y, png_fixed_point *int_green_Z,
602
    png_fixed_point *int_blue_X, png_fixed_point *int_blue_Y,
603
    png_fixed_point *int_blue_Z)
604
0
{
605
0
   png_XYZ XYZ;
606
0
   png_debug1(1, "in %s retrieval function", "cHRM_XYZ");
607
608
0
   if (png_ptr != NULL && info_ptr != NULL &&
609
0
       (info_ptr->valid & PNG_INFO_cHRM) != 0U &&
610
0
       png_XYZ_from_xy(&XYZ, &info_ptr->cHRM) == 0)
611
0
   {
612
0
      if (int_red_X != NULL) *int_red_X = XYZ.red_X;
613
0
      if (int_red_Y != NULL) *int_red_Y = XYZ.red_Y;
614
0
      if (int_red_Z != NULL) *int_red_Z = XYZ.red_Z;
615
0
      if (int_green_X != NULL) *int_green_X = XYZ.green_X;
616
0
      if (int_green_Y != NULL) *int_green_Y = XYZ.green_Y;
617
0
      if (int_green_Z != NULL) *int_green_Z = XYZ.green_Z;
618
0
      if (int_blue_X != NULL) *int_blue_X = XYZ.blue_X;
619
0
      if (int_blue_Y != NULL) *int_blue_Y = XYZ.blue_Y;
620
0
      if (int_blue_Z != NULL) *int_blue_Z = XYZ.blue_Z;
621
0
      return PNG_INFO_cHRM;
622
0
   }
623
624
0
   return 0;
625
0
}
626
627
png_uint_32
628
png_get_cHRM_fixed(png_const_structrp png_ptr, png_const_inforp info_ptr,
629
    png_fixed_point *whitex, png_fixed_point *whitey, png_fixed_point *redx,
630
    png_fixed_point *redy, png_fixed_point *greenx, png_fixed_point *greeny,
631
    png_fixed_point *bluex, png_fixed_point *bluey)
632
0
{
633
0
   png_debug1(1, "in %s retrieval function", "cHRM");
634
635
   /* PNGv3: this just returns the values store from the cHRM, if any. */
636
0
   if (png_ptr != NULL && info_ptr != NULL &&
637
0
       (info_ptr->valid & PNG_INFO_cHRM) != 0)
638
0
   {
639
0
      if (whitex != NULL) *whitex = info_ptr->cHRM.whitex;
640
0
      if (whitey != NULL) *whitey = info_ptr->cHRM.whitey;
641
0
      if (redx   != NULL) *redx   = info_ptr->cHRM.redx;
642
0
      if (redy   != NULL) *redy   = info_ptr->cHRM.redy;
643
0
      if (greenx != NULL) *greenx = info_ptr->cHRM.greenx;
644
0
      if (greeny != NULL) *greeny = info_ptr->cHRM.greeny;
645
0
      if (bluex  != NULL) *bluex  = info_ptr->cHRM.bluex;
646
0
      if (bluey  != NULL) *bluey  = info_ptr->cHRM.bluey;
647
0
      return PNG_INFO_cHRM;
648
0
   }
649
650
0
   return 0;
651
0
}
652
#  endif
653
#endif
654
655
#ifdef PNG_gAMA_SUPPORTED
656
#  ifdef PNG_FIXED_POINT_SUPPORTED
657
png_uint_32
658
png_get_gAMA_fixed(png_const_structrp png_ptr, png_const_inforp info_ptr,
659
    png_fixed_point *file_gamma)
660
0
{
661
0
   png_debug1(1, "in %s retrieval function", "gAMA");
662
663
   /* PNGv3 compatibility: only report gAMA if it is really present. */
664
0
   if (png_ptr != NULL && info_ptr != NULL &&
665
0
       (info_ptr->valid & PNG_INFO_gAMA) != 0)
666
0
   {
667
0
      if (file_gamma != NULL) *file_gamma = info_ptr->gamma;
668
0
      return PNG_INFO_gAMA;
669
0
   }
670
671
0
   return 0;
672
0
}
673
#  endif
674
675
#  ifdef PNG_FLOATING_POINT_SUPPORTED
676
png_uint_32
677
png_get_gAMA(png_const_structrp png_ptr, png_const_inforp info_ptr,
678
    double *file_gamma)
679
93.0k
{
680
93.0k
   png_debug1(1, "in %s retrieval function", "gAMA(float)");
681
682
   /* PNGv3 compatibility: only report gAMA if it is really present. */
683
93.0k
   if (png_ptr != NULL && info_ptr != NULL &&
684
93.0k
       (info_ptr->valid & PNG_INFO_gAMA) != 0)
685
1.37k
   {
686
1.37k
      if (file_gamma != NULL)
687
1.37k
         *file_gamma = png_float(png_ptr, info_ptr->gamma, "gAMA");
688
689
1.37k
      return PNG_INFO_gAMA;
690
1.37k
   }
691
692
91.7k
   return 0;
693
93.0k
}
694
#  endif
695
#endif
696
697
#ifdef PNG_sRGB_SUPPORTED
698
png_uint_32
699
png_get_sRGB(png_const_structrp png_ptr, png_const_inforp info_ptr,
700
    int *file_srgb_intent)
701
161
{
702
161
   png_debug1(1, "in %s retrieval function", "sRGB");
703
704
161
   if (png_ptr != NULL && info_ptr != NULL &&
705
161
      (info_ptr->valid & PNG_INFO_sRGB) != 0)
706
161
   {
707
161
      if (file_srgb_intent != NULL)
708
161
         *file_srgb_intent = info_ptr->rendering_intent;
709
161
      return PNG_INFO_sRGB;
710
161
   }
711
712
0
   return 0;
713
161
}
714
#endif
715
716
#ifdef PNG_iCCP_SUPPORTED
717
png_uint_32
718
png_get_iCCP(png_const_structrp png_ptr, png_inforp info_ptr,
719
    png_charpp name, int *compression_type,
720
    png_bytepp profile, png_uint_32 *proflen)
721
3.34k
{
722
3.34k
   png_debug1(1, "in %s retrieval function", "iCCP");
723
724
3.34k
   if (png_ptr != NULL && info_ptr != NULL &&
725
3.34k
       (info_ptr->valid & PNG_INFO_iCCP) != 0 &&
726
3.34k
       name != NULL && profile != NULL && proflen != NULL)
727
3.34k
   {
728
3.34k
      *name = info_ptr->iccp_name;
729
3.34k
      *profile = info_ptr->iccp_profile;
730
3.34k
      *proflen = png_get_uint_32(info_ptr->iccp_profile);
731
      /* This is somewhat irrelevant since the profile data returned has
732
       * actually been uncompressed.
733
       */
734
3.34k
      if (compression_type != NULL)
735
3.34k
         *compression_type = PNG_COMPRESSION_TYPE_BASE;
736
3.34k
      return PNG_INFO_iCCP;
737
3.34k
   }
738
739
0
   return 0;
740
741
3.34k
}
742
#endif
743
744
#ifdef PNG_sPLT_SUPPORTED
745
int
746
png_get_sPLT(png_const_structrp png_ptr, png_inforp info_ptr,
747
    png_sPLT_tpp spalettes)
748
0
{
749
0
   png_debug1(1, "in %s retrieval function", "sPLT");
750
751
0
   if (png_ptr != NULL && info_ptr != NULL && spalettes != NULL)
752
0
   {
753
0
      *spalettes = info_ptr->splt_palettes;
754
0
      return info_ptr->splt_palettes_num;
755
0
   }
756
757
0
   return 0;
758
0
}
759
#endif
760
761
#ifdef PNG_cICP_SUPPORTED
762
png_uint_32
763
png_get_cICP(png_const_structrp png_ptr,
764
             png_const_inforp info_ptr, png_bytep colour_primaries,
765
             png_bytep transfer_function, png_bytep matrix_coefficients,
766
             png_bytep video_full_range_flag)
767
0
{
768
0
    png_debug1(1, "in %s retrieval function", "cICP");
769
770
0
    if (png_ptr != NULL && info_ptr != NULL &&
771
0
        (info_ptr->valid & PNG_INFO_cICP) != 0 &&
772
0
        colour_primaries != NULL && transfer_function != NULL &&
773
0
        matrix_coefficients != NULL && video_full_range_flag != NULL)
774
0
    {
775
0
        *colour_primaries = info_ptr->cicp_colour_primaries;
776
0
        *transfer_function = info_ptr->cicp_transfer_function;
777
0
        *matrix_coefficients = info_ptr->cicp_matrix_coefficients;
778
0
        *video_full_range_flag = info_ptr->cicp_video_full_range_flag;
779
0
        return (PNG_INFO_cICP);
780
0
    }
781
782
0
    return 0;
783
0
}
784
#endif
785
786
#ifdef PNG_cLLI_SUPPORTED
787
#  ifdef PNG_FIXED_POINT_SUPPORTED
788
png_uint_32
789
png_get_cLLI_fixed(png_const_structrp png_ptr, png_const_inforp info_ptr,
790
    png_uint_32p maxCLL,
791
    png_uint_32p maxFALL)
792
0
{
793
0
   png_debug1(1, "in %s retrieval function", "cLLI");
794
795
0
   if (png_ptr != NULL && info_ptr != NULL &&
796
0
       (info_ptr->valid & PNG_INFO_cLLI) != 0)
797
0
   {
798
0
      if (maxCLL != NULL) *maxCLL = info_ptr->maxCLL;
799
0
      if (maxFALL != NULL) *maxFALL = info_ptr->maxFALL;
800
0
      return PNG_INFO_cLLI;
801
0
   }
802
803
0
   return 0;
804
0
}
805
#  endif
806
807
#  ifdef PNG_FLOATING_POINT_SUPPORTED
808
png_uint_32
809
png_get_cLLI(png_const_structrp png_ptr, png_const_inforp info_ptr,
810
      double *maxCLL, double *maxFALL)
811
0
{
812
0
   png_debug1(1, "in %s retrieval function", "cLLI(float)");
813
814
0
   if (png_ptr != NULL && info_ptr != NULL &&
815
0
       (info_ptr->valid & PNG_INFO_cLLI) != 0)
816
0
   {
817
0
      if (maxCLL != NULL) *maxCLL = info_ptr->maxCLL * .0001;
818
0
      if (maxFALL != NULL) *maxFALL = info_ptr->maxFALL * .0001;
819
0
      return PNG_INFO_cLLI;
820
0
   }
821
822
0
   return 0;
823
0
}
824
#  endif
825
#endif /* cLLI */
826
827
#ifdef PNG_mDCV_SUPPORTED
828
#  ifdef PNG_FIXED_POINT_SUPPORTED
829
png_uint_32
830
png_get_mDCV_fixed(png_const_structrp png_ptr, png_const_inforp info_ptr,
831
    png_fixed_point *white_x, png_fixed_point *white_y,
832
    png_fixed_point *red_x, png_fixed_point *red_y,
833
    png_fixed_point *green_x, png_fixed_point *green_y,
834
    png_fixed_point *blue_x, png_fixed_point *blue_y,
835
    png_uint_32p mastering_maxDL, png_uint_32p mastering_minDL)
836
0
{
837
0
   png_debug1(1, "in %s retrieval function", "mDCV");
838
839
0
   if (png_ptr != NULL && info_ptr != NULL &&
840
0
       (info_ptr->valid & PNG_INFO_mDCV) != 0)
841
0
   {
842
0
      if (white_x != NULL) *white_x = info_ptr->mastering_white_x * 2;
843
0
      if (white_y != NULL) *white_y = info_ptr->mastering_white_y * 2;
844
0
      if (red_x != NULL) *red_x = info_ptr->mastering_red_x * 2;
845
0
      if (red_y != NULL) *red_y = info_ptr->mastering_red_y * 2;
846
0
      if (green_x != NULL) *green_x = info_ptr->mastering_green_x * 2;
847
0
      if (green_y != NULL) *green_y = info_ptr->mastering_green_y * 2;
848
0
      if (blue_x != NULL) *blue_x = info_ptr->mastering_blue_x * 2;
849
0
      if (blue_y != NULL) *blue_y = info_ptr->mastering_blue_y * 2;
850
0
      if (mastering_maxDL != NULL) *mastering_maxDL = info_ptr->mastering_maxDL;
851
0
      if (mastering_minDL != NULL) *mastering_minDL = info_ptr->mastering_minDL;
852
0
      return PNG_INFO_mDCV;
853
0
   }
854
855
0
   return 0;
856
0
}
857
#  endif
858
859
#  ifdef PNG_FLOATING_POINT_SUPPORTED
860
png_uint_32
861
png_get_mDCV(png_const_structrp png_ptr, png_const_inforp info_ptr,
862
    double *white_x, double *white_y, double *red_x, double *red_y,
863
    double *green_x, double *green_y, double *blue_x, double *blue_y,
864
    double *mastering_maxDL, double *mastering_minDL)
865
0
{
866
0
   png_debug1(1, "in %s retrieval function", "mDCV(float)");
867
868
0
   if (png_ptr != NULL && info_ptr != NULL &&
869
0
       (info_ptr->valid & PNG_INFO_mDCV) != 0)
870
0
   {
871
0
      if (white_x != NULL) *white_x = info_ptr->mastering_white_x * .00002;
872
0
      if (white_y != NULL) *white_y = info_ptr->mastering_white_y * .00002;
873
0
      if (red_x != NULL) *red_x = info_ptr->mastering_red_x * .00002;
874
0
      if (red_y != NULL) *red_y = info_ptr->mastering_red_y * .00002;
875
0
      if (green_x != NULL) *green_x = info_ptr->mastering_green_x * .00002;
876
0
      if (green_y != NULL) *green_y = info_ptr->mastering_green_y * .00002;
877
0
      if (blue_x != NULL) *blue_x = info_ptr->mastering_blue_x * .00002;
878
0
      if (blue_y != NULL) *blue_y = info_ptr->mastering_blue_y * .00002;
879
0
      if (mastering_maxDL != NULL)
880
0
         *mastering_maxDL = info_ptr->mastering_maxDL * .0001;
881
0
      if (mastering_minDL != NULL)
882
0
         *mastering_minDL = info_ptr->mastering_minDL * .0001;
883
0
      return PNG_INFO_mDCV;
884
0
   }
885
886
0
   return 0;
887
0
}
888
#  endif /* FLOATING_POINT */
889
#endif /* mDCV */
890
891
#ifdef PNG_eXIf_SUPPORTED
892
png_uint_32
893
png_get_eXIf_1(png_const_structrp png_ptr, png_const_inforp info_ptr,
894
    png_uint_32 *num_exif, png_bytep *exif)
895
80.0k
{
896
80.0k
   png_debug1(1, "in %s retrieval function", "eXIf");
897
898
80.0k
   if (png_ptr != NULL && info_ptr != NULL &&
899
80.0k
       (info_ptr->valid & PNG_INFO_eXIf) != 0 && exif != NULL)
900
6
   {
901
6
      *num_exif = info_ptr->num_exif;
902
6
      *exif = info_ptr->exif;
903
6
      return PNG_INFO_eXIf;
904
6
   }
905
906
80.0k
   return 0;
907
80.0k
}
908
#endif
909
910
#ifdef PNG_hIST_SUPPORTED
911
png_uint_32
912
png_get_hIST(png_const_structrp png_ptr, png_inforp info_ptr,
913
    png_uint_16p *hist)
914
0
{
915
0
   png_debug1(1, "in %s retrieval function", "hIST");
916
917
0
   if (png_ptr != NULL && info_ptr != NULL &&
918
0
       (info_ptr->valid & PNG_INFO_hIST) != 0 && hist != NULL)
919
0
   {
920
0
      *hist = info_ptr->hist;
921
0
      return PNG_INFO_hIST;
922
0
   }
923
924
0
   return 0;
925
0
}
926
#endif
927
928
png_uint_32
929
png_get_IHDR(png_const_structrp png_ptr, png_const_inforp info_ptr,
930
    png_uint_32 *width, png_uint_32 *height, int *bit_depth,
931
    int *color_type, int *interlace_type, int *compression_type,
932
    int *filter_type)
933
46.5k
{
934
46.5k
   png_debug1(1, "in %s retrieval function", "IHDR");
935
936
46.5k
   if (png_ptr == NULL || info_ptr == NULL)
937
0
      return 0;
938
939
46.5k
   if (width != NULL)
940
46.5k
       *width = info_ptr->width;
941
942
46.5k
   if (height != NULL)
943
46.5k
       *height = info_ptr->height;
944
945
46.5k
   if (bit_depth != NULL)
946
46.5k
       *bit_depth = info_ptr->bit_depth;
947
948
46.5k
   if (color_type != NULL)
949
46.5k
       *color_type = info_ptr->color_type;
950
951
46.5k
   if (compression_type != NULL)
952
46.5k
      *compression_type = info_ptr->compression_type;
953
954
46.5k
   if (filter_type != NULL)
955
46.5k
      *filter_type = info_ptr->filter_type;
956
957
46.5k
   if (interlace_type != NULL)
958
46.5k
      *interlace_type = info_ptr->interlace_type;
959
960
   /* This is redundant if we can be sure that the info_ptr values were all
961
    * assigned in png_set_IHDR().  We do the check anyhow in case an
962
    * application has ignored our advice not to mess with the members
963
    * of info_ptr directly.
964
    */
965
46.5k
   png_check_IHDR(png_ptr, info_ptr->width, info_ptr->height,
966
46.5k
       info_ptr->bit_depth, info_ptr->color_type, info_ptr->interlace_type,
967
46.5k
       info_ptr->compression_type, info_ptr->filter_type);
968
969
46.5k
   return 1;
970
46.5k
}
971
972
#ifdef PNG_oFFs_SUPPORTED
973
png_uint_32
974
png_get_oFFs(png_const_structrp png_ptr, png_const_inforp info_ptr,
975
    png_int_32 *offset_x, png_int_32 *offset_y, int *unit_type)
976
0
{
977
0
   png_debug1(1, "in %s retrieval function", "oFFs");
978
979
0
   if (png_ptr != NULL && info_ptr != NULL &&
980
0
       (info_ptr->valid & PNG_INFO_oFFs) != 0 &&
981
0
       offset_x != NULL && offset_y != NULL && unit_type != NULL)
982
0
   {
983
0
      *offset_x = info_ptr->x_offset;
984
0
      *offset_y = info_ptr->y_offset;
985
0
      *unit_type = (int)info_ptr->offset_unit_type;
986
0
      return PNG_INFO_oFFs;
987
0
   }
988
989
0
   return 0;
990
0
}
991
#endif
992
993
#ifdef PNG_pCAL_SUPPORTED
994
png_uint_32
995
png_get_pCAL(png_const_structrp png_ptr, png_inforp info_ptr,
996
    png_charp *purpose, png_int_32 *X0, png_int_32 *X1, int *type, int *nparams,
997
    png_charp *units, png_charpp *params)
998
0
{
999
0
   png_debug1(1, "in %s retrieval function", "pCAL");
1000
1001
0
   if (png_ptr != NULL && info_ptr != NULL &&
1002
0
       (info_ptr->valid & PNG_INFO_pCAL) != 0 &&
1003
0
       purpose != NULL && X0 != NULL && X1 != NULL && type != NULL &&
1004
0
       nparams != NULL && units != NULL && params != NULL)
1005
0
   {
1006
0
      *purpose = info_ptr->pcal_purpose;
1007
0
      *X0 = info_ptr->pcal_X0;
1008
0
      *X1 = info_ptr->pcal_X1;
1009
0
      *type = (int)info_ptr->pcal_type;
1010
0
      *nparams = (int)info_ptr->pcal_nparams;
1011
0
      *units = info_ptr->pcal_units;
1012
0
      *params = info_ptr->pcal_params;
1013
0
      return PNG_INFO_pCAL;
1014
0
   }
1015
1016
0
   return 0;
1017
0
}
1018
#endif
1019
1020
#ifdef PNG_sCAL_SUPPORTED
1021
#  ifdef PNG_FIXED_POINT_SUPPORTED
1022
#    if defined(PNG_FLOATING_ARITHMETIC_SUPPORTED) || \
1023
         defined(PNG_FLOATING_POINT_SUPPORTED)
1024
png_uint_32
1025
png_get_sCAL_fixed(png_const_structrp png_ptr, png_const_inforp info_ptr,
1026
    int *unit, png_fixed_point *width, png_fixed_point *height)
1027
0
{
1028
0
   png_debug1(1, "in %s retrieval function", "sCAL");
1029
1030
0
   if (png_ptr != NULL && info_ptr != NULL &&
1031
0
       (info_ptr->valid & PNG_INFO_sCAL) != 0)
1032
0
   {
1033
0
      *unit = info_ptr->scal_unit;
1034
      /*TODO: make this work without FP support; the API is currently eliminated
1035
       * if neither floating point APIs nor internal floating point arithmetic
1036
       * are enabled.
1037
       */
1038
0
      *width = png_fixed(png_ptr, atof(info_ptr->scal_s_width), "sCAL width");
1039
0
      *height = png_fixed(png_ptr, atof(info_ptr->scal_s_height),
1040
0
          "sCAL height");
1041
0
      return PNG_INFO_sCAL;
1042
0
   }
1043
1044
0
   return 0;
1045
0
}
1046
#    endif /* FLOATING_ARITHMETIC */
1047
#  endif /* FIXED_POINT */
1048
#  ifdef PNG_FLOATING_POINT_SUPPORTED
1049
png_uint_32
1050
png_get_sCAL(png_const_structrp png_ptr, png_const_inforp info_ptr,
1051
    int *unit, double *width, double *height)
1052
0
{
1053
0
   png_debug1(1, "in %s retrieval function", "sCAL(float)");
1054
1055
0
   if (png_ptr != NULL && info_ptr != NULL &&
1056
0
       (info_ptr->valid & PNG_INFO_sCAL) != 0)
1057
0
   {
1058
0
      *unit = info_ptr->scal_unit;
1059
0
      *width = atof(info_ptr->scal_s_width);
1060
0
      *height = atof(info_ptr->scal_s_height);
1061
0
      return PNG_INFO_sCAL;
1062
0
   }
1063
1064
0
   return 0;
1065
0
}
1066
#  endif /* FLOATING POINT */
1067
png_uint_32
1068
png_get_sCAL_s(png_const_structrp png_ptr, png_const_inforp info_ptr,
1069
    int *unit, png_charpp width, png_charpp height)
1070
0
{
1071
0
   png_debug1(1, "in %s retrieval function", "sCAL(str)");
1072
1073
0
   if (png_ptr != NULL && info_ptr != NULL &&
1074
0
       (info_ptr->valid & PNG_INFO_sCAL) != 0)
1075
0
   {
1076
0
      *unit = info_ptr->scal_unit;
1077
0
      *width = info_ptr->scal_s_width;
1078
0
      *height = info_ptr->scal_s_height;
1079
0
      return PNG_INFO_sCAL;
1080
0
   }
1081
1082
0
   return 0;
1083
0
}
1084
#endif /* sCAL */
1085
1086
#ifdef PNG_pHYs_SUPPORTED
1087
png_uint_32
1088
png_get_pHYs(png_const_structrp png_ptr, png_const_inforp info_ptr,
1089
    png_uint_32 *res_x, png_uint_32 *res_y, int *unit_type)
1090
316
{
1091
316
   png_uint_32 retval = 0;
1092
1093
316
   png_debug1(1, "in %s retrieval function", "pHYs");
1094
1095
316
   if (png_ptr != NULL && info_ptr != NULL &&
1096
316
       (info_ptr->valid & PNG_INFO_pHYs) != 0)
1097
316
   {
1098
316
      if (res_x != NULL)
1099
316
      {
1100
316
         *res_x = info_ptr->x_pixels_per_unit;
1101
316
         retval |= PNG_INFO_pHYs;
1102
316
      }
1103
1104
316
      if (res_y != NULL)
1105
316
      {
1106
316
         *res_y = info_ptr->y_pixels_per_unit;
1107
316
         retval |= PNG_INFO_pHYs;
1108
316
      }
1109
1110
316
      if (unit_type != NULL)
1111
316
      {
1112
316
         *unit_type = (int)info_ptr->phys_unit_type;
1113
316
         retval |= PNG_INFO_pHYs;
1114
316
      }
1115
316
   }
1116
1117
316
   return retval;
1118
316
}
1119
#endif /* pHYs */
1120
1121
png_uint_32
1122
png_get_PLTE(png_const_structrp png_ptr, png_inforp info_ptr,
1123
    png_colorp *palette, int *num_palette)
1124
4.54k
{
1125
4.54k
   png_debug1(1, "in %s retrieval function", "PLTE");
1126
1127
4.54k
   if (png_ptr != NULL && info_ptr != NULL &&
1128
4.54k
       (info_ptr->valid & PNG_INFO_PLTE) != 0 && palette != NULL)
1129
4.54k
   {
1130
4.54k
      *palette = info_ptr->palette;
1131
4.54k
      *num_palette = info_ptr->num_palette;
1132
4.54k
      png_debug1(3, "num_palette = %d", *num_palette);
1133
4.54k
      return PNG_INFO_PLTE;
1134
4.54k
   }
1135
1136
0
   return 0;
1137
4.54k
}
1138
1139
#ifdef PNG_sBIT_SUPPORTED
1140
png_uint_32
1141
png_get_sBIT(png_const_structrp png_ptr, png_inforp info_ptr,
1142
    png_color_8p *sig_bit)
1143
0
{
1144
0
   png_debug1(1, "in %s retrieval function", "sBIT");
1145
1146
0
   if (png_ptr != NULL && info_ptr != NULL &&
1147
0
       (info_ptr->valid & PNG_INFO_sBIT) != 0 && sig_bit != NULL)
1148
0
   {
1149
0
      *sig_bit = &(info_ptr->sig_bit);
1150
0
      return PNG_INFO_sBIT;
1151
0
   }
1152
1153
0
   return 0;
1154
0
}
1155
#endif
1156
1157
#ifdef PNG_TEXT_SUPPORTED
1158
int
1159
png_get_text(png_const_structrp png_ptr, png_inforp info_ptr,
1160
    png_textp *text_ptr, int *num_text)
1161
67.1k
{
1162
67.1k
   if (png_ptr != NULL && info_ptr != NULL && info_ptr->num_text > 0)
1163
1.25k
   {
1164
1.25k
      png_debug1(1, "in text retrieval function, chunk typeid = 0x%lx",
1165
1.25k
         (unsigned long)png_ptr->chunk_name);
1166
1167
1.25k
      if (text_ptr != NULL)
1168
1.25k
         *text_ptr = info_ptr->text;
1169
1170
1.25k
      if (num_text != NULL)
1171
1.25k
         *num_text = info_ptr->num_text;
1172
1173
1.25k
      return info_ptr->num_text;
1174
1.25k
   }
1175
1176
65.8k
   if (num_text != NULL)
1177
65.8k
      *num_text = 0;
1178
1179
65.8k
   return 0;
1180
67.1k
}
1181
#endif
1182
1183
#ifdef PNG_tIME_SUPPORTED
1184
png_uint_32
1185
png_get_tIME(png_const_structrp png_ptr, png_inforp info_ptr,
1186
    png_timep *mod_time)
1187
80.0k
{
1188
80.0k
   png_debug1(1, "in %s retrieval function", "tIME");
1189
1190
80.0k
   if (png_ptr != NULL && info_ptr != NULL &&
1191
80.0k
       (info_ptr->valid & PNG_INFO_tIME) != 0 && mod_time != NULL)
1192
61
   {
1193
61
      *mod_time = &(info_ptr->mod_time);
1194
61
      return PNG_INFO_tIME;
1195
61
   }
1196
1197
80.0k
   return 0;
1198
80.0k
}
1199
#endif
1200
1201
#ifdef PNG_tRNS_SUPPORTED
1202
png_uint_32
1203
png_get_tRNS(png_const_structrp png_ptr, png_inforp info_ptr,
1204
    png_bytep *trans_alpha, int *num_trans, png_color_16p *trans_color)
1205
46.5k
{
1206
46.5k
   png_uint_32 retval = 0;
1207
1208
46.5k
   png_debug1(1, "in %s retrieval function", "tRNS");
1209
1210
46.5k
   if (png_ptr != NULL && info_ptr != NULL &&
1211
46.5k
       (info_ptr->valid & PNG_INFO_tRNS) != 0)
1212
1.31k
   {
1213
1.31k
      if (info_ptr->color_type == PNG_COLOR_TYPE_PALETTE)
1214
256
      {
1215
256
         if (trans_alpha != NULL)
1216
256
         {
1217
256
            *trans_alpha = info_ptr->trans_alpha;
1218
256
            retval |= PNG_INFO_tRNS;
1219
256
         }
1220
1221
256
         if (trans_color != NULL)
1222
256
            *trans_color = &(info_ptr->trans_color);
1223
256
      }
1224
1225
1.05k
      else /* if (info_ptr->color_type != PNG_COLOR_TYPE_PALETTE) */
1226
1.05k
      {
1227
1.05k
         if (trans_color != NULL)
1228
1.05k
         {
1229
1.05k
            *trans_color = &(info_ptr->trans_color);
1230
1.05k
            retval |= PNG_INFO_tRNS;
1231
1.05k
         }
1232
1233
1.05k
         if (trans_alpha != NULL)
1234
1.05k
            *trans_alpha = NULL;
1235
1.05k
      }
1236
1237
1.31k
      if (num_trans != NULL)
1238
1.31k
      {
1239
1.31k
         *num_trans = info_ptr->num_trans;
1240
1.31k
         retval |= PNG_INFO_tRNS;
1241
1.31k
      }
1242
1.31k
   }
1243
1244
46.5k
   return retval;
1245
46.5k
}
1246
#endif
1247
1248
#ifdef PNG_STORE_UNKNOWN_CHUNKS_SUPPORTED
1249
int
1250
png_get_unknown_chunks(png_const_structrp png_ptr, png_inforp info_ptr,
1251
    png_unknown_chunkpp unknowns)
1252
0
{
1253
0
   if (png_ptr != NULL && info_ptr != NULL && unknowns != NULL)
1254
0
   {
1255
0
      *unknowns = info_ptr->unknown_chunks;
1256
0
      return info_ptr->unknown_chunks_num;
1257
0
   }
1258
1259
0
   return 0;
1260
0
}
1261
#endif
1262
1263
#ifdef PNG_READ_RGB_TO_GRAY_SUPPORTED
1264
png_byte
1265
png_get_rgb_to_gray_status(png_const_structrp png_ptr)
1266
0
{
1267
0
   return (png_byte)(png_ptr ? png_ptr->rgb_to_gray_status : 0);
1268
0
}
1269
#endif
1270
1271
#ifdef PNG_USER_CHUNKS_SUPPORTED
1272
png_voidp
1273
png_get_user_chunk_ptr(png_const_structrp png_ptr)
1274
230k
{
1275
230k
   return (png_ptr ? png_ptr->user_chunk_ptr : NULL);
1276
230k
}
1277
#endif
1278
1279
size_t
1280
png_get_compression_buffer_size(png_const_structrp png_ptr)
1281
0
{
1282
0
   if (png_ptr == NULL)
1283
0
      return 0;
1284
1285
0
#ifdef PNG_WRITE_SUPPORTED
1286
0
   if ((png_ptr->mode & PNG_IS_READ_STRUCT) != 0)
1287
0
#endif
1288
0
   {
1289
0
#ifdef PNG_SEQUENTIAL_READ_SUPPORTED
1290
0
      return png_ptr->IDAT_read_size;
1291
#else
1292
      return PNG_IDAT_READ_SIZE;
1293
#endif
1294
0
   }
1295
1296
0
#ifdef PNG_WRITE_SUPPORTED
1297
0
   else
1298
0
      return png_ptr->zbuffer_size;
1299
0
#endif
1300
0
}
1301
1302
#ifdef PNG_SET_USER_LIMITS_SUPPORTED
1303
/* These functions were added to libpng 1.2.6 and were enabled
1304
 * by default in libpng-1.4.0 */
1305
png_uint_32
1306
png_get_user_width_max(png_const_structrp png_ptr)
1307
0
{
1308
0
   return (png_ptr ? png_ptr->user_width_max : 0);
1309
0
}
1310
1311
png_uint_32
1312
png_get_user_height_max(png_const_structrp png_ptr)
1313
0
{
1314
0
   return (png_ptr ? png_ptr->user_height_max : 0);
1315
0
}
1316
1317
/* This function was added to libpng 1.4.0 */
1318
png_uint_32
1319
png_get_chunk_cache_max(png_const_structrp png_ptr)
1320
0
{
1321
0
   return (png_ptr ? png_ptr->user_chunk_cache_max : 0);
1322
0
}
1323
1324
/* This function was added to libpng 1.4.1 */
1325
png_alloc_size_t
1326
png_get_chunk_malloc_max(png_const_structrp png_ptr)
1327
0
{
1328
0
   return (png_ptr ? png_ptr->user_chunk_malloc_max : 0);
1329
0
}
1330
#endif /* SET_USER_LIMITS */
1331
1332
/* These functions were added to libpng 1.4.0 */
1333
#ifdef PNG_IO_STATE_SUPPORTED
1334
png_uint_32
1335
png_get_io_state(png_const_structrp png_ptr)
1336
0
{
1337
0
   return png_ptr->io_state;
1338
0
}
1339
1340
png_uint_32
1341
png_get_io_chunk_type(png_const_structrp png_ptr)
1342
0
{
1343
0
   return png_ptr->chunk_name;
1344
0
}
1345
#endif /* IO_STATE */
1346
1347
#ifdef PNG_CHECK_FOR_INVALID_INDEX_SUPPORTED
1348
#  ifdef PNG_GET_PALETTE_MAX_SUPPORTED
1349
int
1350
png_get_palette_max(png_const_structp png_ptr, png_const_infop info_ptr)
1351
0
{
1352
0
   if (png_ptr != NULL && info_ptr != NULL)
1353
0
      return png_ptr->num_palette_max;
1354
1355
0
   return -1;
1356
0
}
1357
#  endif
1358
#endif
1359
1360
#ifdef PNG_APNG_SUPPORTED
1361
png_uint_32 PNGAPI
1362
png_get_acTL(png_structp png_ptr, png_infop info_ptr,
1363
             png_uint_32 *num_frames, png_uint_32 *num_plays)
1364
0
{
1365
0
   png_debug1(1, "in %s retrieval function", "acTL");
1366
1367
0
   if (png_ptr != NULL && info_ptr != NULL &&
1368
0
       (info_ptr->valid & PNG_INFO_acTL) &&
1369
0
       num_frames != NULL && num_plays != NULL)
1370
0
   {
1371
0
      *num_frames = info_ptr->num_frames;
1372
0
      *num_plays = info_ptr->num_plays;
1373
0
      return 1;
1374
0
   }
1375
1376
0
   return 0;
1377
0
}
1378
1379
png_uint_32 PNGAPI
1380
png_get_num_frames(png_structp png_ptr, png_infop info_ptr)
1381
0
{
1382
0
   png_debug(1, "in png_get_num_frames");
1383
1384
0
   if (png_ptr != NULL && info_ptr != NULL)
1385
0
      return info_ptr->num_frames;
1386
0
   return 0;
1387
0
}
1388
1389
png_uint_32 PNGAPI
1390
png_get_num_plays(png_structp png_ptr, png_infop info_ptr)
1391
0
{
1392
0
   png_debug(1, "in png_get_num_plays");
1393
1394
0
   if (png_ptr != NULL && info_ptr != NULL)
1395
0
      return info_ptr->num_plays;
1396
0
   return 0;
1397
0
}
1398
1399
png_uint_32 PNGAPI
1400
png_get_next_frame_fcTL(png_structp png_ptr, png_infop info_ptr,
1401
                        png_uint_32 *width, png_uint_32 *height,
1402
                        png_uint_32 *x_offset, png_uint_32 *y_offset,
1403
                        png_uint_16 *delay_num, png_uint_16 *delay_den,
1404
                        png_byte *dispose_op, png_byte *blend_op)
1405
0
{
1406
0
   png_debug1(1, "in %s retrieval function", "fcTL");
1407
1408
0
   if (png_ptr != NULL && info_ptr != NULL &&
1409
0
       (info_ptr->valid & PNG_INFO_fcTL) &&
1410
0
       width != NULL && height != NULL &&
1411
0
       x_offset != NULL && y_offset != NULL &&
1412
0
       delay_num != NULL && delay_den != NULL &&
1413
0
       dispose_op != NULL && blend_op != NULL)
1414
0
   {
1415
0
      *width = info_ptr->next_frame_width;
1416
0
      *height = info_ptr->next_frame_height;
1417
0
      *x_offset = info_ptr->next_frame_x_offset;
1418
0
      *y_offset = info_ptr->next_frame_y_offset;
1419
0
      *delay_num = info_ptr->next_frame_delay_num;
1420
0
      *delay_den = info_ptr->next_frame_delay_den;
1421
0
      *dispose_op = info_ptr->next_frame_dispose_op;
1422
0
      *blend_op = info_ptr->next_frame_blend_op;
1423
0
      return 1;
1424
0
   }
1425
1426
0
   return 0;
1427
0
}
1428
1429
png_uint_32 PNGAPI
1430
png_get_next_frame_width(png_structp png_ptr, png_infop info_ptr)
1431
0
{
1432
0
   png_debug(1, "in png_get_next_frame_width");
1433
1434
0
   if (png_ptr != NULL && info_ptr != NULL)
1435
0
      return info_ptr->next_frame_width;
1436
0
   return 0;
1437
0
}
1438
1439
png_uint_32 PNGAPI
1440
png_get_next_frame_height(png_structp png_ptr, png_infop info_ptr)
1441
0
{
1442
0
   png_debug(1, "in png_get_next_frame_height");
1443
1444
0
   if (png_ptr != NULL && info_ptr != NULL)
1445
0
      return info_ptr->next_frame_height;
1446
0
   return 0;
1447
0
}
1448
1449
png_uint_32 PNGAPI
1450
png_get_next_frame_x_offset(png_structp png_ptr, png_infop info_ptr)
1451
0
{
1452
0
   png_debug(1, "in png_get_next_frame_x_offset");
1453
1454
0
   if (png_ptr != NULL && info_ptr != NULL)
1455
0
      return info_ptr->next_frame_x_offset;
1456
0
   return 0;
1457
0
}
1458
1459
png_uint_32 PNGAPI
1460
png_get_next_frame_y_offset(png_structp png_ptr, png_infop info_ptr)
1461
0
{
1462
0
   png_debug(1, "in png_get_next_frame_y_offset");
1463
1464
0
   if (png_ptr != NULL && info_ptr != NULL)
1465
0
      return info_ptr->next_frame_y_offset;
1466
0
   return 0;
1467
0
}
1468
1469
png_uint_16 PNGAPI
1470
png_get_next_frame_delay_num(png_structp png_ptr, png_infop info_ptr)
1471
0
{
1472
0
   png_debug(1, "in png_get_next_frame_delay_num");
1473
1474
0
   if (png_ptr != NULL && info_ptr != NULL)
1475
0
      return info_ptr->next_frame_delay_num;
1476
0
   return 0;
1477
0
}
1478
1479
png_uint_16 PNGAPI
1480
png_get_next_frame_delay_den(png_structp png_ptr, png_infop info_ptr)
1481
0
{
1482
0
   png_debug(1, "in png_get_next_frame_delay_den");
1483
1484
0
   if (png_ptr != NULL && info_ptr != NULL)
1485
0
      return info_ptr->next_frame_delay_den;
1486
0
   return 0;
1487
0
}
1488
1489
png_byte PNGAPI
1490
png_get_next_frame_dispose_op(png_structp png_ptr, png_infop info_ptr)
1491
0
{
1492
0
   png_debug(1, "in png_get_next_frame_dispose_op");
1493
1494
0
   if (png_ptr != NULL && info_ptr != NULL)
1495
0
      return info_ptr->next_frame_dispose_op;
1496
0
   return 0;
1497
0
}
1498
1499
png_byte PNGAPI
1500
png_get_next_frame_blend_op(png_structp png_ptr, png_infop info_ptr)
1501
0
{
1502
0
   png_debug(1, "in png_get_next_frame_blend_op");
1503
1504
0
   if (png_ptr != NULL && info_ptr != NULL)
1505
0
      return info_ptr->next_frame_blend_op;
1506
0
   return 0;
1507
0
}
1508
1509
png_byte PNGAPI
1510
png_get_first_frame_is_hidden(png_structp png_ptr, png_infop info_ptr)
1511
0
{
1512
0
   png_debug(1, "in png_first_frame_is_hidden");
1513
1514
0
   if (png_ptr != NULL)
1515
0
      return (png_byte)(png_ptr->apng_flags & PNG_FIRST_FRAME_HIDDEN);
1516
1517
0
   PNG_UNUSED(info_ptr)
1518
1519
0
   return 0;
1520
0
}
1521
#endif /* PNG_APNG_SUPPORTED */
1522
#endif /* READ || WRITE */