2 /* pngget.c - retrieval of values from info struct
4 * Last changed in libpng 1.6.1 [March 28, 2013]
5 * Copyright (c) 1998-2013 Glenn Randers-Pehrson
6 * (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
7 * (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
9 * This code is released under the libpng license.
10 * For conditions of distribution and use, see the disclaimer
11 * and license in png.h
17 #if defined(PNG_READ_SUPPORTED) || defined(PNG_WRITE_SUPPORTED)
20 png_get_valid(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
23 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
24 return(info_ptr
->valid
& flag
);
30 png_get_rowbytes(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
32 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
33 return(info_ptr
->rowbytes
);
38 #ifdef PNG_INFO_IMAGE_SUPPORTED
40 png_get_rows(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
42 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
43 return(info_ptr
->row_pointers
);
49 #ifdef PNG_EASY_ACCESS_SUPPORTED
50 /* Easy access to info, added in libpng-0.99 */
52 png_get_image_width(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
54 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
55 return info_ptr
->width
;
61 png_get_image_height(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
63 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
64 return info_ptr
->height
;
70 png_get_bit_depth(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
72 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
73 return info_ptr
->bit_depth
;
79 png_get_color_type(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
81 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
82 return info_ptr
->color_type
;
88 png_get_filter_type(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
90 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
91 return info_ptr
->filter_type
;
97 png_get_interlace_type(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
99 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
100 return info_ptr
->interlace_type
;
106 png_get_compression_type(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
108 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
109 return info_ptr
->compression_type
;
115 png_get_x_pixels_per_meter(png_const_structrp png_ptr
, png_const_inforp
118 #ifdef PNG_pHYs_SUPPORTED
119 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_pHYs
))
121 png_debug1(1, "in %s retrieval function",
122 "png_get_x_pixels_per_meter");
124 if (info_ptr
->phys_unit_type
== PNG_RESOLUTION_METER
)
125 return (info_ptr
->x_pixels_per_unit
);
133 png_get_y_pixels_per_meter(png_const_structrp png_ptr
, png_const_inforp
136 #ifdef PNG_pHYs_SUPPORTED
137 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_pHYs
))
139 png_debug1(1, "in %s retrieval function",
140 "png_get_y_pixels_per_meter");
142 if (info_ptr
->phys_unit_type
== PNG_RESOLUTION_METER
)
143 return (info_ptr
->y_pixels_per_unit
);
151 png_get_pixels_per_meter(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
153 #ifdef PNG_pHYs_SUPPORTED
154 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_pHYs
))
156 png_debug1(1, "in %s retrieval function", "png_get_pixels_per_meter");
158 if (info_ptr
->phys_unit_type
== PNG_RESOLUTION_METER
&&
159 info_ptr
->x_pixels_per_unit
== info_ptr
->y_pixels_per_unit
)
160 return (info_ptr
->x_pixels_per_unit
);
167 #ifdef PNG_FLOATING_POINT_SUPPORTED
169 png_get_pixel_aspect_ratio(png_const_structrp png_ptr
, png_const_inforp
172 #ifdef PNG_READ_pHYs_SUPPORTED
173 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_pHYs
))
175 png_debug1(1, "in %s retrieval function", "png_get_aspect_ratio");
177 if (info_ptr
->x_pixels_per_unit
!= 0)
178 return ((float)((float)info_ptr
->y_pixels_per_unit
179 /(float)info_ptr
->x_pixels_per_unit
));
190 #ifdef PNG_FIXED_POINT_SUPPORTED
191 png_fixed_point PNGAPI
192 png_get_pixel_aspect_ratio_fixed(png_const_structrp png_ptr
,
193 png_const_inforp info_ptr
)
195 #ifdef PNG_READ_pHYs_SUPPORTED
196 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_pHYs
)
197 && info_ptr
->x_pixels_per_unit
> 0 && info_ptr
->y_pixels_per_unit
> 0
198 && info_ptr
->x_pixels_per_unit
<= PNG_UINT_31_MAX
199 && info_ptr
->y_pixels_per_unit
<= PNG_UINT_31_MAX
)
203 png_debug1(1, "in %s retrieval function", "png_get_aspect_ratio_fixed");
205 /* The following casts work because a PNG 4 byte integer only has a valid
206 * range of 0..2^31-1; otherwise the cast might overflow.
208 if (png_muldiv(&res
, (png_int_32
)info_ptr
->y_pixels_per_unit
, PNG_FP_1
,
209 (png_int_32
)info_ptr
->x_pixels_per_unit
))
222 png_get_x_offset_microns(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
224 #ifdef PNG_oFFs_SUPPORTED
225 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_oFFs
))
227 png_debug1(1, "in %s retrieval function", "png_get_x_offset_microns");
229 if (info_ptr
->offset_unit_type
== PNG_OFFSET_MICROMETER
)
230 return (info_ptr
->x_offset
);
238 png_get_y_offset_microns(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
240 #ifdef PNG_oFFs_SUPPORTED
241 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_oFFs
))
243 png_debug1(1, "in %s retrieval function", "png_get_y_offset_microns");
245 if (info_ptr
->offset_unit_type
== PNG_OFFSET_MICROMETER
)
246 return (info_ptr
->y_offset
);
254 png_get_x_offset_pixels(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
256 #ifdef PNG_oFFs_SUPPORTED
257 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_oFFs
))
259 png_debug1(1, "in %s retrieval function", "png_get_x_offset_pixels");
261 if (info_ptr
->offset_unit_type
== PNG_OFFSET_PIXEL
)
262 return (info_ptr
->x_offset
);
270 png_get_y_offset_pixels(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
272 #ifdef PNG_oFFs_SUPPORTED
273 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_oFFs
))
275 png_debug1(1, "in %s retrieval function", "png_get_y_offset_pixels");
277 if (info_ptr
->offset_unit_type
== PNG_OFFSET_PIXEL
)
278 return (info_ptr
->y_offset
);
285 #ifdef PNG_INCH_CONVERSIONS_SUPPORTED
287 ppi_from_ppm(png_uint_32 ppm
)
290 /* The conversion is *(2.54/100), in binary (32 digits):
291 * .00000110100000001001110101001001
293 png_uint_32 t1001
, t1101
;
295 t1001
= ppm
+ (ppm
>> 3); /* .1001 */
296 t1101
= t1001
+ (ppm
>> 1); /* .1101 */
297 ppm
>>= 20; /* .000000000000000000001 */
298 t1101
+= t1101
>> 15; /* .1101000000000001101 */
299 t1001
>>= 11; /* .000000000001001 */
300 t1001
+= t1001
>> 12; /* .000000000001001000000001001 */
301 ppm
+= t1001
; /* .000000000001001000001001001 */
302 ppm
+= t1101
; /* .110100000001001110101001001 */
303 return (ppm
+ 16) >> 5;/* .00000110100000001001110101001001 */
305 /* The argument is a PNG unsigned integer, so it is not permitted
306 * to be bigger than 2^31.
308 png_fixed_point result
;
309 if (ppm
<= PNG_UINT_31_MAX
&& png_muldiv(&result
, (png_int_32
)ppm
, 127,
319 png_get_pixels_per_inch(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
321 return ppi_from_ppm(png_get_pixels_per_meter(png_ptr
, info_ptr
));
325 png_get_x_pixels_per_inch(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
327 return ppi_from_ppm(png_get_x_pixels_per_meter(png_ptr
, info_ptr
));
331 png_get_y_pixels_per_inch(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
333 return ppi_from_ppm(png_get_y_pixels_per_meter(png_ptr
, info_ptr
));
336 #ifdef PNG_FIXED_POINT_SUPPORTED
337 static png_fixed_point
338 png_fixed_inches_from_microns(png_const_structrp png_ptr
, png_int_32 microns
)
340 /* Convert from metres * 1,000,000 to inches * 100,000, meters to
341 * inches is simply *(100/2.54), so we want *(10/2.54) == 500/127.
342 * Notice that this can overflow - a warning is output and 0 is
345 return png_muldiv_warn(png_ptr
, microns
, 500, 127);
348 png_fixed_point PNGAPI
349 png_get_x_offset_inches_fixed(png_const_structrp png_ptr
,
350 png_const_inforp info_ptr
)
352 return png_fixed_inches_from_microns(png_ptr
,
353 png_get_x_offset_microns(png_ptr
, info_ptr
));
357 #ifdef PNG_FIXED_POINT_SUPPORTED
358 png_fixed_point PNGAPI
359 png_get_y_offset_inches_fixed(png_const_structrp png_ptr
,
360 png_const_inforp info_ptr
)
362 return png_fixed_inches_from_microns(png_ptr
,
363 png_get_y_offset_microns(png_ptr
, info_ptr
));
367 #ifdef PNG_FLOATING_POINT_SUPPORTED
369 png_get_x_offset_inches(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
371 /* To avoid the overflow do the conversion directly in floating
374 return (float)(png_get_x_offset_microns(png_ptr
, info_ptr
) * .00003937);
378 #ifdef PNG_FLOATING_POINT_SUPPORTED
380 png_get_y_offset_inches(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
382 /* To avoid the overflow do the conversion directly in floating
385 return (float)(png_get_y_offset_microns(png_ptr
, info_ptr
) * .00003937);
389 #ifdef PNG_pHYs_SUPPORTED
391 png_get_pHYs_dpi(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
392 png_uint_32
*res_x
, png_uint_32
*res_y
, int *unit_type
)
394 png_uint_32 retval
= 0;
396 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_pHYs
))
398 png_debug1(1, "in %s retrieval function", "pHYs");
402 *res_x
= info_ptr
->x_pixels_per_unit
;
403 retval
|= PNG_INFO_pHYs
;
408 *res_y
= info_ptr
->y_pixels_per_unit
;
409 retval
|= PNG_INFO_pHYs
;
412 if (unit_type
!= NULL
)
414 *unit_type
= (int)info_ptr
->phys_unit_type
;
415 retval
|= PNG_INFO_pHYs
;
419 if (res_x
!= NULL
) *res_x
= (png_uint_32
)(*res_x
* .0254 + .50);
420 if (res_y
!= NULL
) *res_y
= (png_uint_32
)(*res_y
* .0254 + .50);
427 #endif /* PNG_pHYs_SUPPORTED */
428 #endif /* PNG_INCH_CONVERSIONS_SUPPORTED */
430 /* png_get_channels really belongs in here, too, but it's been around longer */
432 #endif /* PNG_EASY_ACCESS_SUPPORTED */
436 png_get_channels(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
438 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
439 return(info_ptr
->channels
);
444 #ifdef PNG_READ_SUPPORTED
445 png_const_bytep PNGAPI
446 png_get_signature(png_const_structrp png_ptr
, png_const_inforp info_ptr
)
448 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
449 return(info_ptr
->signature
);
455 #ifdef PNG_bKGD_SUPPORTED
457 png_get_bKGD(png_const_structrp png_ptr
, png_inforp info_ptr
,
458 png_color_16p
*background
)
460 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_bKGD
)
461 && background
!= NULL
)
463 png_debug1(1, "in %s retrieval function", "bKGD");
465 *background
= &(info_ptr
->background
);
466 return (PNG_INFO_bKGD
);
473 #ifdef PNG_cHRM_SUPPORTED
474 /* The XYZ APIs were added in 1.5.5 to take advantage of the code added at the
475 * same time to correct the rgb grayscale coefficient defaults obtained from the
476 * cHRM chunk in 1.5.4
478 # ifdef PNG_FLOATING_POINT_SUPPORTED
480 png_get_cHRM(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
481 double *white_x
, double *white_y
, double *red_x
, double *red_y
,
482 double *green_x
, double *green_y
, double *blue_x
, double *blue_y
)
484 /* Quiet API change: this code used to only return the end points if a cHRM
485 * chunk was present, but the end points can also come from iCCP or sRGB
486 * chunks, so in 1.6.0 the png_get_ APIs return the end points regardless and
487 * the png_set_ APIs merely check that set end points are mutually
490 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&&
491 (info_ptr
->colorspace
.flags
& PNG_COLORSPACE_HAVE_ENDPOINTS
))
493 png_debug1(1, "in %s retrieval function", "cHRM");
496 *white_x
= png_float(png_ptr
,
497 info_ptr
->colorspace
.end_points_xy
.whitex
, "cHRM white X");
499 *white_y
= png_float(png_ptr
,
500 info_ptr
->colorspace
.end_points_xy
.whitey
, "cHRM white Y");
502 *red_x
= png_float(png_ptr
, info_ptr
->colorspace
.end_points_xy
.redx
,
505 *red_y
= png_float(png_ptr
, info_ptr
->colorspace
.end_points_xy
.redy
,
508 *green_x
= png_float(png_ptr
,
509 info_ptr
->colorspace
.end_points_xy
.greenx
, "cHRM green X");
511 *green_y
= png_float(png_ptr
,
512 info_ptr
->colorspace
.end_points_xy
.greeny
, "cHRM green Y");
514 *blue_x
= png_float(png_ptr
, info_ptr
->colorspace
.end_points_xy
.bluex
,
517 *blue_y
= png_float(png_ptr
, info_ptr
->colorspace
.end_points_xy
.bluey
,
519 return (PNG_INFO_cHRM
);
526 png_get_cHRM_XYZ(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
527 double *red_X
, double *red_Y
, double *red_Z
, double *green_X
,
528 double *green_Y
, double *green_Z
, double *blue_X
, double *blue_Y
,
531 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&&
532 (info_ptr
->colorspace
.flags
& PNG_COLORSPACE_HAVE_ENDPOINTS
))
534 png_debug1(1, "in %s retrieval function", "cHRM_XYZ(float)");
537 *red_X
= png_float(png_ptr
, info_ptr
->colorspace
.end_points_XYZ
.red_X
,
540 *red_Y
= png_float(png_ptr
, info_ptr
->colorspace
.end_points_XYZ
.red_Y
,
543 *red_Z
= png_float(png_ptr
, info_ptr
->colorspace
.end_points_XYZ
.red_Z
,
546 *green_X
= png_float(png_ptr
,
547 info_ptr
->colorspace
.end_points_XYZ
.green_X
, "cHRM green X");
549 *green_Y
= png_float(png_ptr
,
550 info_ptr
->colorspace
.end_points_XYZ
.green_Y
, "cHRM green Y");
552 *green_Z
= png_float(png_ptr
,
553 info_ptr
->colorspace
.end_points_XYZ
.green_Z
, "cHRM green Z");
555 *blue_X
= png_float(png_ptr
,
556 info_ptr
->colorspace
.end_points_XYZ
.blue_X
, "cHRM blue X");
558 *blue_Y
= png_float(png_ptr
,
559 info_ptr
->colorspace
.end_points_XYZ
.blue_Y
, "cHRM blue Y");
561 *blue_Z
= png_float(png_ptr
,
562 info_ptr
->colorspace
.end_points_XYZ
.blue_Z
, "cHRM blue Z");
563 return (PNG_INFO_cHRM
);
570 # ifdef PNG_FIXED_POINT_SUPPORTED
572 png_get_cHRM_XYZ_fixed(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
573 png_fixed_point
*int_red_X
, png_fixed_point
*int_red_Y
,
574 png_fixed_point
*int_red_Z
, png_fixed_point
*int_green_X
,
575 png_fixed_point
*int_green_Y
, png_fixed_point
*int_green_Z
,
576 png_fixed_point
*int_blue_X
, png_fixed_point
*int_blue_Y
,
577 png_fixed_point
*int_blue_Z
)
579 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&&
580 (info_ptr
->colorspace
.flags
& PNG_COLORSPACE_HAVE_ENDPOINTS
))
582 png_debug1(1, "in %s retrieval function", "cHRM_XYZ");
584 if (int_red_X
!= NULL
)
585 *int_red_X
= info_ptr
->colorspace
.end_points_XYZ
.red_X
;
586 if (int_red_Y
!= NULL
)
587 *int_red_Y
= info_ptr
->colorspace
.end_points_XYZ
.red_Y
;
588 if (int_red_Z
!= NULL
)
589 *int_red_Z
= info_ptr
->colorspace
.end_points_XYZ
.red_Z
;
590 if (int_green_X
!= NULL
)
591 *int_green_X
= info_ptr
->colorspace
.end_points_XYZ
.green_X
;
592 if (int_green_Y
!= NULL
)
593 *int_green_Y
= info_ptr
->colorspace
.end_points_XYZ
.green_Y
;
594 if (int_green_Z
!= NULL
)
595 *int_green_Z
= info_ptr
->colorspace
.end_points_XYZ
.green_Z
;
596 if (int_blue_X
!= NULL
)
597 *int_blue_X
= info_ptr
->colorspace
.end_points_XYZ
.blue_X
;
598 if (int_blue_Y
!= NULL
)
599 *int_blue_Y
= info_ptr
->colorspace
.end_points_XYZ
.blue_Y
;
600 if (int_blue_Z
!= NULL
)
601 *int_blue_Z
= info_ptr
->colorspace
.end_points_XYZ
.blue_Z
;
602 return (PNG_INFO_cHRM
);
609 png_get_cHRM_fixed(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
610 png_fixed_point
*white_x
, png_fixed_point
*white_y
, png_fixed_point
*red_x
,
611 png_fixed_point
*red_y
, png_fixed_point
*green_x
, png_fixed_point
*green_y
,
612 png_fixed_point
*blue_x
, png_fixed_point
*blue_y
)
614 png_debug1(1, "in %s retrieval function", "cHRM");
616 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&&
617 (info_ptr
->colorspace
.flags
& PNG_COLORSPACE_HAVE_ENDPOINTS
))
620 *white_x
= info_ptr
->colorspace
.end_points_xy
.whitex
;
622 *white_y
= info_ptr
->colorspace
.end_points_xy
.whitey
;
624 *red_x
= info_ptr
->colorspace
.end_points_xy
.redx
;
626 *red_y
= info_ptr
->colorspace
.end_points_xy
.redy
;
628 *green_x
= info_ptr
->colorspace
.end_points_xy
.greenx
;
630 *green_y
= info_ptr
->colorspace
.end_points_xy
.greeny
;
632 *blue_x
= info_ptr
->colorspace
.end_points_xy
.bluex
;
634 *blue_y
= info_ptr
->colorspace
.end_points_xy
.bluey
;
635 return (PNG_INFO_cHRM
);
643 #ifdef PNG_gAMA_SUPPORTED
644 # ifdef PNG_FIXED_POINT_SUPPORTED
646 png_get_gAMA_fixed(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
647 png_fixed_point
*file_gamma
)
649 png_debug1(1, "in %s retrieval function", "gAMA");
651 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&&
652 (info_ptr
->colorspace
.flags
& PNG_COLORSPACE_HAVE_GAMMA
) &&
655 *file_gamma
= info_ptr
->colorspace
.gamma
;
656 return (PNG_INFO_gAMA
);
663 # ifdef PNG_FLOATING_POINT_SUPPORTED
665 png_get_gAMA(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
668 png_debug1(1, "in %s retrieval function", "gAMA(float)");
670 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&&
671 (info_ptr
->colorspace
.flags
& PNG_COLORSPACE_HAVE_GAMMA
) &&
674 *file_gamma
= png_float(png_ptr
, info_ptr
->colorspace
.gamma
,
676 return (PNG_INFO_gAMA
);
684 #ifdef PNG_sRGB_SUPPORTED
686 png_get_sRGB(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
687 int *file_srgb_intent
)
689 png_debug1(1, "in %s retrieval function", "sRGB");
691 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_sRGB
)
692 && file_srgb_intent
!= NULL
)
694 *file_srgb_intent
= info_ptr
->colorspace
.rendering_intent
;
695 return (PNG_INFO_sRGB
);
702 #ifdef PNG_iCCP_SUPPORTED
704 png_get_iCCP(png_const_structrp png_ptr
, png_inforp info_ptr
,
705 png_charpp name
, int *compression_type
,
706 png_bytepp profile
, png_uint_32
*proflen
)
708 png_debug1(1, "in %s retrieval function", "iCCP");
710 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_iCCP
)
711 && name
!= NULL
&& compression_type
!= NULL
&& profile
!= NULL
&&
714 *name
= info_ptr
->iccp_name
;
715 *profile
= info_ptr
->iccp_profile
;
716 *proflen
= png_get_uint_32(info_ptr
->iccp_profile
);
717 /* This is somewhat irrelevant since the profile data returned has
718 * actually been uncompressed.
720 *compression_type
= PNG_COMPRESSION_TYPE_BASE
;
721 return (PNG_INFO_iCCP
);
728 #ifdef PNG_sPLT_SUPPORTED
730 png_get_sPLT(png_const_structrp png_ptr
, png_inforp info_ptr
,
731 png_sPLT_tpp spalettes
)
733 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& spalettes
!= NULL
)
735 *spalettes
= info_ptr
->splt_palettes
;
736 return info_ptr
->splt_palettes_num
;
743 #ifdef PNG_hIST_SUPPORTED
745 png_get_hIST(png_const_structrp png_ptr
, png_inforp info_ptr
,
748 png_debug1(1, "in %s retrieval function", "hIST");
750 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_hIST
)
753 *hist
= info_ptr
->hist
;
754 return (PNG_INFO_hIST
);
762 png_get_IHDR(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
763 png_uint_32
*width
, png_uint_32
*height
, int *bit_depth
,
764 int *color_type
, int *interlace_type
, int *compression_type
,
767 png_debug1(1, "in %s retrieval function", "IHDR");
769 if (png_ptr
== NULL
|| info_ptr
== NULL
|| width
== NULL
||
770 height
== NULL
|| bit_depth
== NULL
|| color_type
== NULL
)
773 *width
= info_ptr
->width
;
774 *height
= info_ptr
->height
;
775 *bit_depth
= info_ptr
->bit_depth
;
776 *color_type
= info_ptr
->color_type
;
778 if (compression_type
!= NULL
)
779 *compression_type
= info_ptr
->compression_type
;
781 if (filter_type
!= NULL
)
782 *filter_type
= info_ptr
->filter_type
;
784 if (interlace_type
!= NULL
)
785 *interlace_type
= info_ptr
->interlace_type
;
787 /* This is redundant if we can be sure that the info_ptr values were all
788 * assigned in png_set_IHDR(). We do the check anyhow in case an
789 * application has ignored our advice not to mess with the members
790 * of info_ptr directly.
792 png_check_IHDR(png_ptr
, info_ptr
->width
, info_ptr
->height
,
793 info_ptr
->bit_depth
, info_ptr
->color_type
, info_ptr
->interlace_type
,
794 info_ptr
->compression_type
, info_ptr
->filter_type
);
799 #ifdef PNG_oFFs_SUPPORTED
801 png_get_oFFs(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
802 png_int_32
*offset_x
, png_int_32
*offset_y
, int *unit_type
)
804 png_debug1(1, "in %s retrieval function", "oFFs");
806 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_oFFs
)
807 && offset_x
!= NULL
&& offset_y
!= NULL
&& unit_type
!= NULL
)
809 *offset_x
= info_ptr
->x_offset
;
810 *offset_y
= info_ptr
->y_offset
;
811 *unit_type
= (int)info_ptr
->offset_unit_type
;
812 return (PNG_INFO_oFFs
);
819 #ifdef PNG_pCAL_SUPPORTED
821 png_get_pCAL(png_const_structrp png_ptr
, png_inforp info_ptr
,
822 png_charp
*purpose
, png_int_32
*X0
, png_int_32
*X1
, int *type
, int *nparams
,
823 png_charp
*units
, png_charpp
*params
)
825 png_debug1(1, "in %s retrieval function", "pCAL");
827 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_pCAL
)
828 && purpose
!= NULL
&& X0
!= NULL
&& X1
!= NULL
&& type
!= NULL
&&
829 nparams
!= NULL
&& units
!= NULL
&& params
!= NULL
)
831 *purpose
= info_ptr
->pcal_purpose
;
832 *X0
= info_ptr
->pcal_X0
;
833 *X1
= info_ptr
->pcal_X1
;
834 *type
= (int)info_ptr
->pcal_type
;
835 *nparams
= (int)info_ptr
->pcal_nparams
;
836 *units
= info_ptr
->pcal_units
;
837 *params
= info_ptr
->pcal_params
;
838 return (PNG_INFO_pCAL
);
845 #ifdef PNG_sCAL_SUPPORTED
846 # ifdef PNG_FIXED_POINT_SUPPORTED
847 # if defined(PNG_FLOATING_ARITHMETIC_SUPPORTED) || \
848 defined(PNG_FLOATING_POINT_SUPPORTED)
850 png_get_sCAL_fixed(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
851 int *unit
, png_fixed_point
*width
, png_fixed_point
*height
)
853 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&&
854 (info_ptr
->valid
& PNG_INFO_sCAL
))
856 *unit
= info_ptr
->scal_unit
;
857 /*TODO: make this work without FP support; the API is currently eliminated
858 * if neither floating point APIs nor internal floating point arithmetic
861 *width
= png_fixed(png_ptr
, atof(info_ptr
->scal_s_width
), "sCAL width");
862 *height
= png_fixed(png_ptr
, atof(info_ptr
->scal_s_height
),
864 return (PNG_INFO_sCAL
);
869 # endif /* FLOATING_ARITHMETIC */
870 # endif /* FIXED_POINT */
871 # ifdef PNG_FLOATING_POINT_SUPPORTED
873 png_get_sCAL(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
874 int *unit
, double *width
, double *height
)
876 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&&
877 (info_ptr
->valid
& PNG_INFO_sCAL
))
879 *unit
= info_ptr
->scal_unit
;
880 *width
= atof(info_ptr
->scal_s_width
);
881 *height
= atof(info_ptr
->scal_s_height
);
882 return (PNG_INFO_sCAL
);
887 # endif /* FLOATING POINT */
889 png_get_sCAL_s(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
890 int *unit
, png_charpp width
, png_charpp height
)
892 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&&
893 (info_ptr
->valid
& PNG_INFO_sCAL
))
895 *unit
= info_ptr
->scal_unit
;
896 *width
= info_ptr
->scal_s_width
;
897 *height
= info_ptr
->scal_s_height
;
898 return (PNG_INFO_sCAL
);
905 #ifdef PNG_pHYs_SUPPORTED
907 png_get_pHYs(png_const_structrp png_ptr
, png_const_inforp info_ptr
,
908 png_uint_32
*res_x
, png_uint_32
*res_y
, int *unit_type
)
910 png_uint_32 retval
= 0;
912 png_debug1(1, "in %s retrieval function", "pHYs");
914 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&&
915 (info_ptr
->valid
& PNG_INFO_pHYs
))
919 *res_x
= info_ptr
->x_pixels_per_unit
;
920 retval
|= PNG_INFO_pHYs
;
925 *res_y
= info_ptr
->y_pixels_per_unit
;
926 retval
|= PNG_INFO_pHYs
;
929 if (unit_type
!= NULL
)
931 *unit_type
= (int)info_ptr
->phys_unit_type
;
932 retval
|= PNG_INFO_pHYs
;
941 png_get_PLTE(png_const_structrp png_ptr
, png_inforp info_ptr
,
942 png_colorp
*palette
, int *num_palette
)
944 png_debug1(1, "in %s retrieval function", "PLTE");
946 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_PLTE
)
949 *palette
= info_ptr
->palette
;
950 *num_palette
= info_ptr
->num_palette
;
951 png_debug1(3, "num_palette = %d", *num_palette
);
952 return (PNG_INFO_PLTE
);
958 #ifdef PNG_sBIT_SUPPORTED
960 png_get_sBIT(png_const_structrp png_ptr
, png_inforp info_ptr
,
961 png_color_8p
*sig_bit
)
963 png_debug1(1, "in %s retrieval function", "sBIT");
965 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_sBIT
)
968 *sig_bit
= &(info_ptr
->sig_bit
);
969 return (PNG_INFO_sBIT
);
976 #ifdef PNG_TEXT_SUPPORTED
978 png_get_text(png_const_structrp png_ptr
, png_inforp info_ptr
,
979 png_textp
*text_ptr
, int *num_text
)
981 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& info_ptr
->num_text
> 0)
983 png_debug1(1, "in 0x%lx retrieval function",
984 (unsigned long)png_ptr
->chunk_name
);
986 if (text_ptr
!= NULL
)
987 *text_ptr
= info_ptr
->text
;
989 if (num_text
!= NULL
)
990 *num_text
= info_ptr
->num_text
;
992 return info_ptr
->num_text
;
995 if (num_text
!= NULL
)
1002 #ifdef PNG_tIME_SUPPORTED
1004 png_get_tIME(png_const_structrp png_ptr
, png_inforp info_ptr
,
1005 png_timep
*mod_time
)
1007 png_debug1(1, "in %s retrieval function", "tIME");
1009 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_tIME
)
1010 && mod_time
!= NULL
)
1012 *mod_time
= &(info_ptr
->mod_time
);
1013 return (PNG_INFO_tIME
);
1020 #ifdef PNG_tRNS_SUPPORTED
1022 png_get_tRNS(png_const_structrp png_ptr
, png_inforp info_ptr
,
1023 png_bytep
*trans_alpha
, int *num_trans
, png_color_16p
*trans_color
)
1025 png_uint_32 retval
= 0;
1026 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& (info_ptr
->valid
& PNG_INFO_tRNS
))
1028 png_debug1(1, "in %s retrieval function", "tRNS");
1030 if (info_ptr
->color_type
== PNG_COLOR_TYPE_PALETTE
)
1032 if (trans_alpha
!= NULL
)
1034 *trans_alpha
= info_ptr
->trans_alpha
;
1035 retval
|= PNG_INFO_tRNS
;
1038 if (trans_color
!= NULL
)
1039 *trans_color
= &(info_ptr
->trans_color
);
1042 else /* if (info_ptr->color_type != PNG_COLOR_TYPE_PALETTE) */
1044 if (trans_color
!= NULL
)
1046 *trans_color
= &(info_ptr
->trans_color
);
1047 retval
|= PNG_INFO_tRNS
;
1050 if (trans_alpha
!= NULL
)
1051 *trans_alpha
= NULL
;
1054 if (num_trans
!= NULL
)
1056 *num_trans
= info_ptr
->num_trans
;
1057 retval
|= PNG_INFO_tRNS
;
1065 #ifdef PNG_STORE_UNKNOWN_CHUNKS_SUPPORTED
1067 png_get_unknown_chunks(png_const_structrp png_ptr
, png_inforp info_ptr
,
1068 png_unknown_chunkpp unknowns
)
1070 if (png_ptr
!= NULL
&& info_ptr
!= NULL
&& unknowns
!= NULL
)
1072 *unknowns
= info_ptr
->unknown_chunks
;
1073 return info_ptr
->unknown_chunks_num
;
1080 #ifdef PNG_READ_RGB_TO_GRAY_SUPPORTED
1082 png_get_rgb_to_gray_status (png_const_structrp png_ptr
)
1084 return (png_byte
)(png_ptr
? png_ptr
->rgb_to_gray_status
: 0);
1088 #ifdef PNG_USER_CHUNKS_SUPPORTED
1090 png_get_user_chunk_ptr(png_const_structrp png_ptr
)
1092 return (png_ptr
? png_ptr
->user_chunk_ptr
: NULL
);
1097 png_get_compression_buffer_size(png_const_structrp png_ptr
)
1099 if (png_ptr
== NULL
)
1102 # ifdef PNG_WRITE_SUPPORTED
1103 if (png_ptr
->mode
& PNG_IS_READ_STRUCT
)
1106 # ifdef PNG_SEQUENTIAL_READ_SUPPORTED
1107 return png_ptr
->IDAT_read_size
;
1109 return PNG_IDAT_READ_SIZE
;
1113 # ifdef PNG_WRITE_SUPPORTED
1115 return png_ptr
->zbuffer_size
;
1119 #ifdef PNG_SET_USER_LIMITS_SUPPORTED
1120 /* These functions were added to libpng 1.2.6 and were enabled
1121 * by default in libpng-1.4.0 */
1123 png_get_user_width_max (png_const_structrp png_ptr
)
1125 return (png_ptr
? png_ptr
->user_width_max
: 0);
1129 png_get_user_height_max (png_const_structrp png_ptr
)
1131 return (png_ptr
? png_ptr
->user_height_max
: 0);
1134 /* This function was added to libpng 1.4.0 */
1136 png_get_chunk_cache_max (png_const_structrp png_ptr
)
1138 return (png_ptr
? png_ptr
->user_chunk_cache_max
: 0);
1141 /* This function was added to libpng 1.4.1 */
1142 png_alloc_size_t PNGAPI
1143 png_get_chunk_malloc_max (png_const_structrp png_ptr
)
1145 return (png_ptr
? png_ptr
->user_chunk_malloc_max
: 0);
1147 #endif /* ?PNG_SET_USER_LIMITS_SUPPORTED */
1149 /* These functions were added to libpng 1.4.0 */
1150 #ifdef PNG_IO_STATE_SUPPORTED
1152 png_get_io_state (png_const_structrp png_ptr
)
1154 return png_ptr
->io_state
;
1158 png_get_io_chunk_type (png_const_structrp png_ptr
)
1160 return png_ptr
->chunk_name
;
1162 #endif /* ?PNG_IO_STATE_SUPPORTED */
1164 #ifdef PNG_CHECK_FOR_INVALID_INDEX_SUPPORTED
1165 # ifdef PNG_GET_PALETTE_MAX_SUPPORTED
1167 png_get_palette_max(png_const_structp png_ptr
, png_const_infop info_ptr
)
1169 if (png_ptr
!= NULL
&& info_ptr
!= NULL
)
1170 return png_ptr
->num_palette_max
;
1177 #endif /* PNG_READ_SUPPORTED || PNG_WRITE_SUPPORTED */