blob: 660cb61289edb1634913c778478386747e3f0131 [file] [log] [blame]
Andreas Dilger47a0c421997-05-16 02:46:07 -05001
2/* pngset.c - storage of image information into info struct
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -06003 *
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -06004 * libpng 1.0.5s - February 18, 2000
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -06005 * For conditions of distribution and use, see copyright notice in png.h
6 * Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.
7 * Copyright (c) 1996, 1997 Andreas Dilger
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -06008 * Copyright (c) 1998, 1999, 2000 Glenn Randers-Pehrson
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -06009 *
10 * The functions here are used during reads to store data from the file
11 * into the info struct, and during writes to store application data
12 * into the info struct for writing into the file. This abstracts the
13 * info struct and allows us to change the structure in the future.
14 */
Andreas Dilger47a0c421997-05-16 02:46:07 -050015
16#define PNG_INTERNAL
17#include "png.h"
18
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -060019#if defined(PNG_bKGD_SUPPORTED)
Andreas Dilger47a0c421997-05-16 02:46:07 -050020void
21png_set_bKGD(png_structp png_ptr, png_infop info_ptr, png_color_16p background)
22{
23 png_debug1(1, "in %s storage function\n", "bKGD");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -060024 if (png_ptr == NULL || info_ptr == NULL)
Andreas Dilger47a0c421997-05-16 02:46:07 -050025 return;
26
27 png_memcpy(&(info_ptr->background), background, sizeof(png_color_16));
28 info_ptr->valid |= PNG_INFO_bKGD;
29}
30#endif
31
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -060032#if defined(PNG_cHRM_SUPPORTED)
33#ifdef PNG_FLOATING_POINT_SUPPORTED
Andreas Dilger47a0c421997-05-16 02:46:07 -050034void
35png_set_cHRM(png_structp png_ptr, png_infop info_ptr,
36 double white_x, double white_y, double red_x, double red_y,
37 double green_x, double green_y, double blue_x, double blue_y)
38{
39 png_debug1(1, "in %s storage function\n", "cHRM");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -060040 if (png_ptr == NULL || info_ptr == NULL)
Andreas Dilger47a0c421997-05-16 02:46:07 -050041 return;
42
43 info_ptr->x_white = (float)white_x;
44 info_ptr->y_white = (float)white_y;
45 info_ptr->x_red = (float)red_x;
46 info_ptr->y_red = (float)red_y;
47 info_ptr->x_green = (float)green_x;
48 info_ptr->y_green = (float)green_y;
49 info_ptr->x_blue = (float)blue_x;
50 info_ptr->y_blue = (float)blue_y;
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -060051#ifdef PNG_FIXED_POINT_SUPPORTED
52 info_ptr->int_x_white = (png_fixed_point)(white_x*100000.+0.5);
53 info_ptr->int_y_white = (png_fixed_point)(white_y*100000.+0.5);
54 info_ptr->int_x_red = (png_fixed_point)(red_x*100000.+0.5);
55 info_ptr->int_y_red = (png_fixed_point)(red_y*100000.+0.5);
56 info_ptr->int_x_green = (png_fixed_point)(green_x*100000.+0.5);
57 info_ptr->int_y_green = (png_fixed_point)(green_y*100000.+0.5);
58 info_ptr->int_x_blue = (png_fixed_point)(blue_x*100000.+0.5);
59 info_ptr->int_y_blue = (png_fixed_point)(blue_y*100000.+0.5);
60#endif
Andreas Dilger47a0c421997-05-16 02:46:07 -050061 info_ptr->valid |= PNG_INFO_cHRM;
62}
63#endif
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -060064#ifdef PNG_FIXED_POINT_SUPPORTED
65void
66png_set_cHRM_fixed(png_structp png_ptr, png_infop info_ptr,
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -060067 png_fixed_point white_x, png_fixed_point white_y, png_fixed_point red_x,
68 png_fixed_point red_y, png_fixed_point green_x, png_fixed_point green_y,
69 png_fixed_point blue_x, png_fixed_point blue_y)
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -060070{
71 png_debug1(1, "in %s storage function\n", "cHRM");
72 if (png_ptr == NULL || info_ptr == NULL)
73 return;
Andreas Dilger47a0c421997-05-16 02:46:07 -050074
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -060075 info_ptr->int_x_white = white_x;
76 info_ptr->int_y_white = white_y;
77 info_ptr->int_x_red = red_x;
78 info_ptr->int_y_red = red_y;
79 info_ptr->int_x_green = green_x;
80 info_ptr->int_y_green = green_y;
81 info_ptr->int_x_blue = blue_x;
82 info_ptr->int_y_blue = blue_y;
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -060083#ifdef PNG_FLOATING_POINT_SUPPORTED
84 info_ptr->x_white = (float)(white_x/100000.);
85 info_ptr->y_white = (float)(white_y/100000.);
86 info_ptr->x_red = (float)(red_x/100000.);
87 info_ptr->y_red = (float)(red_y/100000.);
88 info_ptr->x_green = (float)(green_x/100000.);
89 info_ptr->y_green = (float)(green_y/100000.);
90 info_ptr->x_blue = (float)(blue_x/100000.);
91 info_ptr->y_blue = (float)(blue_y/100000.);
92#endif
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -060093 info_ptr->valid |= PNG_INFO_cHRM;
94}
95#endif
96#endif
97
98#if defined(PNG_gAMA_SUPPORTED)
99#ifdef PNG_FLOATING_POINT_SUPPORTED
Andreas Dilger47a0c421997-05-16 02:46:07 -0500100void
101png_set_gAMA(png_structp png_ptr, png_infop info_ptr, double file_gamma)
102{
103 png_debug1(1, "in %s storage function\n", "gAMA");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600104 if (png_ptr == NULL || info_ptr == NULL)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500105 return;
106
107 info_ptr->gamma = (float)file_gamma;
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600108#ifdef PNG_FIXED_POINT_SUPPORTED
109 info_ptr->int_gamma = (int)(file_gamma*100000.+.5);
110#endif
111 info_ptr->valid |= PNG_INFO_gAMA;
112}
113#endif
114#endif
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600115void
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600116png_set_gAMA_fixed(png_structp png_ptr, png_infop info_ptr, png_fixed_point
117 int_gamma)
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600118{
119 png_debug1(1, "in %s storage function\n", "gAMA");
120 if (png_ptr == NULL || info_ptr == NULL)
121 return;
122
123#ifdef PNG_FLOATING_POINT_SUPPORTED
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600124 info_ptr->gamma = (float)(int_gamma/100000.);
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600125#endif
126 info_ptr->int_gamma = int_gamma;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500127 info_ptr->valid |= PNG_INFO_gAMA;
128}
Andreas Dilger47a0c421997-05-16 02:46:07 -0500129
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600130#if defined(PNG_hIST_SUPPORTED)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500131void
132png_set_hIST(png_structp png_ptr, png_infop info_ptr, png_uint_16p hist)
133{
134 png_debug1(1, "in %s storage function\n", "hIST");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600135 if (png_ptr == NULL || info_ptr == NULL)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500136 return;
137
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600138 info_ptr->hist = hist;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500139 info_ptr->valid |= PNG_INFO_hIST;
140}
141#endif
142
143void
144png_set_IHDR(png_structp png_ptr, png_infop info_ptr,
145 png_uint_32 width, png_uint_32 height, int bit_depth,
146 int color_type, int interlace_type, int compression_type,
147 int filter_type)
148{
Glenn Randers-Pehrson0f881d61998-02-07 10:20:57 -0600149 int rowbytes_per_pixel;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500150 png_debug1(1, "in %s storage function\n", "IHDR");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600151 if (png_ptr == NULL || info_ptr == NULL)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500152 return;
153
154 info_ptr->width = width;
155 info_ptr->height = height;
156 info_ptr->bit_depth = (png_byte)bit_depth;
157 info_ptr->color_type =(png_byte) color_type;
158 info_ptr->compression_type = (png_byte)compression_type;
159 info_ptr->filter_type = (png_byte)filter_type;
160 info_ptr->interlace_type = (png_byte)interlace_type;
161 if (info_ptr->color_type == PNG_COLOR_TYPE_PALETTE)
162 info_ptr->channels = 1;
163 else if (info_ptr->color_type & PNG_COLOR_MASK_COLOR)
164 info_ptr->channels = 3;
165 else
166 info_ptr->channels = 1;
167 if (info_ptr->color_type & PNG_COLOR_MASK_ALPHA)
168 info_ptr->channels++;
169 info_ptr->pixel_depth = (png_byte)(info_ptr->channels * info_ptr->bit_depth);
Glenn Randers-Pehrson0f881d61998-02-07 10:20:57 -0600170
171 /* check for overflow */
172 rowbytes_per_pixel = (info_ptr->pixel_depth + 7) >> 3;
Glenn Randers-Pehrson4393a9a1999-09-17 12:27:26 -0500173 if (( width > PNG_MAX_UINT/rowbytes_per_pixel))
Glenn Randers-Pehrson0f881d61998-02-07 10:20:57 -0600174 {
175 png_warning(png_ptr,
176 "Width too large to process image data; rowbytes will overflow.");
177 info_ptr->rowbytes = (png_size_t)0;
178 }
Glenn Randers-Pehrson896239b1998-04-21 15:03:57 -0500179 else
180 info_ptr->rowbytes = (info_ptr->width * info_ptr->pixel_depth + 7) >> 3;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500181}
182
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600183#if defined(PNG_oFFs_SUPPORTED)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500184void
185png_set_oFFs(png_structp png_ptr, png_infop info_ptr,
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600186 png_int_32 offset_x, png_int_32 offset_y, int unit_type)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500187{
188 png_debug1(1, "in %s storage function\n", "oFFs");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600189 if (png_ptr == NULL || info_ptr == NULL)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500190 return;
191
192 info_ptr->x_offset = offset_x;
193 info_ptr->y_offset = offset_y;
194 info_ptr->offset_unit_type = (png_byte)unit_type;
195 info_ptr->valid |= PNG_INFO_oFFs;
196}
197#endif
198
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600199#if defined(PNG_pCAL_SUPPORTED)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500200void
201png_set_pCAL(png_structp png_ptr, png_infop info_ptr,
202 png_charp purpose, png_int_32 X0, png_int_32 X1, int type, int nparams,
203 png_charp units, png_charpp params)
204{
Glenn Randers-Pehrson0f881d61998-02-07 10:20:57 -0600205 png_uint_32 length;
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600206 int i;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500207
208 png_debug1(1, "in %s storage function\n", "pCAL");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600209 if (png_ptr == NULL || info_ptr == NULL)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500210 return;
211
212 length = png_strlen(purpose) + 1;
213 png_debug1(3, "allocating purpose for info (%d bytes)\n", length);
214 info_ptr->pcal_purpose = (png_charp)png_malloc(png_ptr, length);
Glenn Randers-Pehrson0f881d61998-02-07 10:20:57 -0600215 png_memcpy(info_ptr->pcal_purpose, purpose, (png_size_t)length);
Andreas Dilger47a0c421997-05-16 02:46:07 -0500216
217 png_debug(3, "storing X0, X1, type, and nparams in info\n");
218 info_ptr->pcal_X0 = X0;
219 info_ptr->pcal_X1 = X1;
220 info_ptr->pcal_type = (png_byte)type;
221 info_ptr->pcal_nparams = (png_byte)nparams;
222
223 length = png_strlen(units) + 1;
224 png_debug1(3, "allocating units for info (%d bytes)\n", length);
225 info_ptr->pcal_units = (png_charp)png_malloc(png_ptr, length);
Glenn Randers-Pehrson0f881d61998-02-07 10:20:57 -0600226 png_memcpy(info_ptr->pcal_units, units, (png_size_t)length);
Andreas Dilger47a0c421997-05-16 02:46:07 -0500227
228 info_ptr->pcal_params = (png_charpp)png_malloc(png_ptr,
Glenn Randers-Pehrson0f881d61998-02-07 10:20:57 -0600229 (png_uint_32)((nparams + 1) * sizeof(png_charp)));
Andreas Dilger47a0c421997-05-16 02:46:07 -0500230 info_ptr->pcal_params[nparams] = NULL;
231
232 for (i = 0; i < nparams; i++)
233 {
234 length = png_strlen(params[i]) + 1;
235 png_debug2(3, "allocating parameter %d for info (%d bytes)\n", i, length);
236 info_ptr->pcal_params[i] = (png_charp)png_malloc(png_ptr, length);
Glenn Randers-Pehrson0f881d61998-02-07 10:20:57 -0600237 png_memcpy(info_ptr->pcal_params[i], params[i], (png_size_t)length);
Andreas Dilger47a0c421997-05-16 02:46:07 -0500238 }
239
240 info_ptr->valid |= PNG_INFO_pCAL;
241}
242#endif
243
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600244#if defined(PNG_READ_sCAL_SUPPORTED) || defined(PNG_WRITE_sCAL_SUPPORTED)
245#ifdef PNG_FLOATING_POINT_SUPPORTED
246void
247png_set_sCAL(png_structp png_ptr, png_infop info_ptr,
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600248 int unit, double width, double height)
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600249{
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600250 png_debug1(1, "in %s storage function\n", "sCAL");
251 if (png_ptr == NULL || info_ptr == NULL)
252 return;
253
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600254 info_ptr->scal_unit = (png_byte)unit;
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600255 info_ptr->scal_pixel_width = width;
256 info_ptr->scal_pixel_height = height;
257
258 info_ptr->valid |= PNG_INFO_sCAL;
259}
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600260#else
261#ifdef PNG_FIXED_POINT_SUPPORTED
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600262void
263png_set_sCAL_s(png_structp png_ptr, png_infop info_ptr,
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600264 int unit, png_charp swidth, png_charp sheight)
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600265{
266 png_uint_32 length;
267
268 png_debug1(1, "in %s storage function\n", "sCAL");
269 if (png_ptr == NULL || info_ptr == NULL)
270 return;
271
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600272 info_ptr->scal_unit = (png_byte)unit;
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600273
274 length = png_strlen(swidth) + 1;
275 png_debug1(3, "allocating unit for info (%d bytes)\n", length);
276 info_ptr->scal_s_width = (png_charp)png_malloc(png_ptr, length);
277 png_memcpy(info_ptr->scal_s_width, swidth, (png_size_t)length);
278
279 length = png_strlen(sheight) + 1;
280 png_debug1(3, "allocating unit for info (%d bytes)\n", length);
281 info_ptr->scal_s_width = (png_charp)png_malloc(png_ptr, length);
282 png_memcpy(info_ptr->scal_s_height, sheight, (png_size_t)length);
283
284 info_ptr->valid |= PNG_INFO_sCAL;
285}
286#endif
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600287#endif
288#endif
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600289
290#if defined(PNG_pHYs_SUPPORTED)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500291void
292png_set_pHYs(png_structp png_ptr, png_infop info_ptr,
293 png_uint_32 res_x, png_uint_32 res_y, int unit_type)
294{
295 png_debug1(1, "in %s storage function\n", "pHYs");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600296 if (png_ptr == NULL || info_ptr == NULL)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500297 return;
298
299 info_ptr->x_pixels_per_unit = res_x;
300 info_ptr->y_pixels_per_unit = res_y;
301 info_ptr->phys_unit_type = (png_byte)unit_type;
302 info_ptr->valid |= PNG_INFO_pHYs;
303}
304#endif
305
306void
307png_set_PLTE(png_structp png_ptr, png_infop info_ptr,
308 png_colorp palette, int num_palette)
309{
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600310
Andreas Dilger47a0c421997-05-16 02:46:07 -0500311 png_debug1(1, "in %s storage function\n", "PLTE");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600312 if (png_ptr == NULL || info_ptr == NULL)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500313 return;
314
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600315 png_debug1(3, "allocating PLTE for info (%d bytes)\n", length);
316
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600317 info_ptr->palette = palette;
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600318
Andreas Dilger47a0c421997-05-16 02:46:07 -0500319 info_ptr->num_palette = (png_uint_16)num_palette;
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600320 info_ptr->valid |= PNG_INFO_PLTE;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500321}
322
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600323#if defined(PNG_sBIT_SUPPORTED)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500324void
325png_set_sBIT(png_structp png_ptr, png_infop info_ptr,
326 png_color_8p sig_bit)
327{
328 png_debug1(1, "in %s storage function\n", "sBIT");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600329 if (png_ptr == NULL || info_ptr == NULL)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500330 return;
331
332 png_memcpy(&(info_ptr->sig_bit), sig_bit, sizeof (png_color_8));
333 info_ptr->valid |= PNG_INFO_sBIT;
334}
335#endif
336
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600337#if defined(PNG_sRGB_SUPPORTED)
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600338void
Glenn Randers-Pehrsonc4a2ae61998-01-16 22:06:18 -0600339png_set_sRGB(png_structp png_ptr, png_infop info_ptr, int intent)
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600340{
341 png_debug1(1, "in %s storage function\n", "sRGB");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600342 if (png_ptr == NULL || info_ptr == NULL)
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600343 return;
344
Glenn Randers-Pehrsonc4a2ae61998-01-16 22:06:18 -0600345 info_ptr->srgb_intent = (png_byte)intent;
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600346 info_ptr->valid |= PNG_INFO_sRGB;
347}
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600348
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600349void
350png_set_sRGB_gAMA_and_cHRM(png_structp png_ptr, png_infop info_ptr,
Glenn Randers-Pehrsonc4a2ae61998-01-16 22:06:18 -0600351 int intent)
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600352{
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600353#if defined(PNG_gAMA_SUPPORTED)
354#ifdef PNG_FLOATING_POINT_SUPPORTED
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600355 float file_gamma;
356#endif
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600357#ifdef PNG_FIXED_POINT_SUPPORTED
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600358 png_fixed_point int_file_gamma;
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600359#endif
360#endif
361#if defined(PNG_cHRM_SUPPORTED)
362#ifdef PNG_FLOATING_POINT_SUPPORTED
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600363 float white_x, white_y, red_x, red_y, green_x, green_y, blue_x, blue_y;
364#endif
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600365#ifdef PNG_FIXED_POINT_SUPPORTED
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600366 png_fixed_point int_white_x, int_white_y, int_red_x, int_red_y, int_green_x,
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600367 int_green_y, int_blue_x, int_blue_y;
368#endif
369#endif
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600370 png_debug1(1, "in %s storage function\n", "sRGB_gAMA_and_cHRM");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600371 if (png_ptr == NULL || info_ptr == NULL)
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600372 return;
373
374 png_set_sRGB(png_ptr, info_ptr, intent);
375
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600376#if defined(PNG_gAMA_SUPPORTED)
377#ifdef PNG_FLOATING_POINT_SUPPORTED
Glenn Randers-Pehrsonab1e5831999-10-06 04:57:42 -0500378 file_gamma = (float).45455;
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600379 png_set_gAMA(png_ptr, info_ptr, file_gamma);
380#endif
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600381#ifdef PNG_FIXED_POINT_SUPPORTED
382 int_file_gamma = 45455L;
383 png_set_gAMA_fixed(png_ptr, info_ptr, int_file_gamma);
384#endif
385#endif
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600386
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600387#if defined(PNG_cHRM_SUPPORTED)
388#ifdef PNG_FIXED_POINT_SUPPORTED
389 int_white_x = 31270L;
390 int_white_y = 32900L;
391 int_red_x = 64000L;
392 int_red_y = 33000L;
393 int_green_x = 30000L;
394 int_green_y = 60000L;
395 int_blue_x = 15000L;
396 int_blue_y = 6000L;
397
398 png_set_cHRM_fixed(png_ptr, info_ptr,
399 int_white_x, int_white_y, int_red_x, int_red_y, int_green_x, int_green_y,
400 int_blue_x, int_blue_y);
401#endif
402#ifdef PNG_FLOATING_POINT_SUPPORTED
Glenn Randers-Pehrson70e3f541998-01-03 22:40:55 -0600403 white_x = (float).3127;
404 white_y = (float).3290;
405 red_x = (float).64;
406 red_y = (float).33;
407 green_x = (float).30;
408 green_y = (float).60;
409 blue_x = (float).15;
410 blue_y = (float).06;
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600411
412 png_set_cHRM(png_ptr, info_ptr,
413 white_x, white_y, red_x, red_y, green_x, green_y, blue_x, blue_y);
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600414#endif
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600415#endif
416}
417#endif
418
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600419
420#if defined(PNG_iCCP_SUPPORTED)
421void
422png_set_iCCP(png_structp png_ptr, png_infop info_ptr,
423 png_charp name, int compression_type,
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600424 png_charp profile, png_uint_32 proflen)
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600425{
426 png_debug1(1, "in %s storage function\n", "iCCP");
427 if (png_ptr == NULL || info_ptr == NULL || name == NULL || profile == NULL)
428 return;
429
430 info_ptr->iccp_name = png_malloc(png_ptr, png_strlen(name)+1);
431 strcpy(info_ptr->iccp_name, name);
432 info_ptr->iccp_profile = png_malloc(png_ptr, proflen);
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600433 png_memcpy(info_ptr->iccp_profile, profile, (png_size_t)proflen);
434 info_ptr->iccp_proflen = proflen;
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600435 /* Compression is always zero but is here so the API and info structure
436 * does not have to change * if we introduce multiple compression types */
437 info_ptr->iccp_compression = (png_byte)compression_type;
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600438 info_ptr->free_me |= PNG_FREE_ICCP;
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600439 info_ptr->valid |= PNG_INFO_iCCP;
440}
441#endif
442
443#if defined(PNG_TEXT_SUPPORTED)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500444void
445png_set_text(png_structp png_ptr, png_infop info_ptr, png_textp text_ptr,
446 int num_text)
447{
448 int i;
449
450 png_debug1(1, "in %s storage function\n", (png_ptr->chunk_name[0] == '\0' ?
Glenn Randers-Pehrsonc4a2ae61998-01-16 22:06:18 -0600451 "text" : (png_const_charp)png_ptr->chunk_name));
Andreas Dilger47a0c421997-05-16 02:46:07 -0500452
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600453 if (png_ptr == NULL || info_ptr == NULL || num_text == 0)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500454 return;
455
456 /* Make sure we have enough space in the "text" array in info_struct
457 * to hold all of the incoming text_ptr objects.
458 */
459 if (info_ptr->num_text + num_text > info_ptr->max_text)
460 {
461 if (info_ptr->text != NULL)
462 {
463 png_textp old_text;
464 int old_max;
465
466 old_max = info_ptr->max_text;
467 info_ptr->max_text = info_ptr->num_text + num_text + 8;
468 old_text = info_ptr->text;
469 info_ptr->text = (png_textp)png_malloc(png_ptr,
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600470 (png_uint_32)(info_ptr->max_text * sizeof (png_text)));
Glenn Randers-Pehrson0f881d61998-02-07 10:20:57 -0600471 png_memcpy(info_ptr->text, old_text, (png_size_t)(old_max *
472 sizeof(png_text)));
Andreas Dilger47a0c421997-05-16 02:46:07 -0500473 png_free(png_ptr, old_text);
474 }
475 else
476 {
477 info_ptr->max_text = num_text + 8;
478 info_ptr->num_text = 0;
479 info_ptr->text = (png_textp)png_malloc(png_ptr,
Glenn Randers-Pehrson0f881d61998-02-07 10:20:57 -0600480 (png_uint_32)(info_ptr->max_text * sizeof (png_text)));
Andreas Dilger47a0c421997-05-16 02:46:07 -0500481 }
482 png_debug1(3, "allocated %d entries for info_ptr->text\n",
483 info_ptr->max_text);
484 }
485
486 for (i = 0; i < num_text; i++)
487 {
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600488 png_size_t text_length,key_len,lang_len,lang_key_len;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500489 png_textp textp = &(info_ptr->text[info_ptr->num_text]);
490
Glenn Randers-Pehrson6d8f3b01999-10-23 08:39:18 -0500491 if (text_ptr[i].key == (png_charp)NULL)
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600492 continue;
493
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600494 key_len = png_strlen(text_ptr[i].key);
495
496 if(text_ptr[i].compression > 0)
497 {
498 /* set iTXt data */
499 lang_len = png_strlen(text_ptr[i].lang);
500 lang_key_len = png_strlen(text_ptr[i].lang_key);
501 }
502 else
503 {
504 lang_len = 0;
505 lang_key_len = 0;
506 }
Andreas Dilger47a0c421997-05-16 02:46:07 -0500507
508 if (text_ptr[i].text[0] == '\0')
509 {
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600510 text_length = 0;
511 if(text_ptr[i].compression > 0)
512 textp->compression = PNG_ITXT_COMPRESSION_NONE;
513 else
514 textp->compression = PNG_TEXT_COMPRESSION_NONE;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500515 }
516 else
517 {
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600518 text_length = png_strlen(text_ptr[i].text);
Andreas Dilger47a0c421997-05-16 02:46:07 -0500519 textp->compression = text_ptr[i].compression;
520 }
Glenn Randers-Pehrson6d8f3b01999-10-23 08:39:18 -0500521
522 textp->key = (png_charp)png_malloc(png_ptr,
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600523 (png_uint_32)(key_len + lang_len + lang_key_len + text_length + 4));
Glenn Randers-Pehrson6d8f3b01999-10-23 08:39:18 -0500524 png_debug2(2, "Allocated %d bytes at %x in png_set_text\n",
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600525 key_len + lang_len + lang_key_len + text_length + 4, textp->key);
Glenn Randers-Pehrson6d8f3b01999-10-23 08:39:18 -0500526
527 png_memcpy(textp->key, text_ptr[i].key,
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600528 (png_size_t)(key_len));
529 *(textp->key+key_len) = '\0';
530 if (text_ptr[i].compression > 0)
531 {
532 textp->lang=textp->key + key_len + 1;
533 png_memcpy(textp->lang, text_ptr[i].lang, lang_len);
534 *(textp->lang+lang_len) = '\0';
535 textp->lang_key=textp->lang + lang_len + 1;
536 png_memcpy(textp->lang_key, text_ptr[i].lang_key, lang_key_len);
537 *(textp->lang_key+lang_key_len) = '\0';
538 textp->text=textp->lang_key + lang_key_len + 1;
539 }
540 else
541 {
542 textp->lang=NULL;
543 textp->lang_key=NULL;
544 textp->text=textp->key + key_len + 1;
545 }
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600546
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600547 if(text_length)
Glenn Randers-Pehrson6d8f3b01999-10-23 08:39:18 -0500548 {
549 png_memcpy(textp->text, text_ptr[i].text,
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600550 (png_size_t)(text_length));
551 *(textp->text+text_length) = '\0';
Glenn Randers-Pehrson6d8f3b01999-10-23 08:39:18 -0500552 }
553 else
554 textp->text--;
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600555
556 if(textp->compression > 0)
557 {
558 textp->text_length = 0;
559 textp->itxt_length = text_length;
560 }
561 else
562 {
563 textp->text_length = text_length;
564 textp->itxt_length = 0;
565 }
566
Glenn Randers-Pehrson6d8f3b01999-10-23 08:39:18 -0500567 info_ptr->text[info_ptr->num_text]= *textp;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500568 info_ptr->num_text++;
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600569 info_ptr->free_me |= PNG_FREE_TEXT;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500570 png_debug1(3, "transferred text chunk %d\n", info_ptr->num_text);
571 }
572}
573#endif
574
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600575#if defined(PNG_tIME_SUPPORTED)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500576void
577png_set_tIME(png_structp png_ptr, png_infop info_ptr, png_timep mod_time)
578{
579 png_debug1(1, "in %s storage function\n", "tIME");
Glenn Randers-Pehrson4393a9a1999-09-17 12:27:26 -0500580 if (png_ptr == NULL || info_ptr == NULL ||
Glenn Randers-Pehrson5379b241999-11-27 10:22:33 -0600581 (png_ptr->mode & PNG_WROTE_tIME))
Andreas Dilger47a0c421997-05-16 02:46:07 -0500582 return;
583
584 png_memcpy(&(info_ptr->mod_time), mod_time, sizeof (png_time));
585 info_ptr->valid |= PNG_INFO_tIME;
586}
587#endif
588
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600589#if defined(PNG_tRNS_SUPPORTED)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500590void
591png_set_tRNS(png_structp png_ptr, png_infop info_ptr,
592 png_bytep trans, int num_trans, png_color_16p trans_values)
593{
594 png_debug1(1, "in %s storage function\n", "tRNS");
Glenn Randers-Pehrsona357b991998-02-08 20:56:40 -0600595 if (png_ptr == NULL || info_ptr == NULL)
Andreas Dilger47a0c421997-05-16 02:46:07 -0500596 return;
597
598 if (trans != NULL)
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600599 info_ptr->trans = trans;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500600
601 if (trans_values != NULL)
602 {
603 png_memcpy(&(info_ptr->trans_values), trans_values,
604 sizeof(png_color_16));
Glenn Randers-Pehrsonb6ce43d1998-01-01 07:13:13 -0600605 if (num_trans == 0)
606 num_trans = 1;
Andreas Dilger47a0c421997-05-16 02:46:07 -0500607 }
608 info_ptr->num_trans = (png_uint_16)num_trans;
609 info_ptr->valid |= PNG_INFO_tRNS;
610}
611#endif
612
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600613#if defined(PNG_sPLT_SUPPORTED)
614void
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600615png_set_sPLT(png_structp png_ptr,
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600616 png_infop info_ptr, png_spalette_p entries, int nentries)
617{
618 png_spalette_p np;
619 int i;
620
621 np = (png_spalette_p)png_malloc(png_ptr,
622 (info_ptr->splt_palettes_num + nentries) * sizeof(png_spalette));
623
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600624 png_memcpy(np, info_ptr->splt_palettes,
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600625 info_ptr->splt_palettes_num * sizeof(png_spalette));
626 png_free(png_ptr, info_ptr->splt_palettes);
627
628 for (i = 0; i < nentries; i++)
629 {
630 png_spalette_p to = np + info_ptr->splt_palettes_num + i;
631 png_spalette_p from = entries + i;
632
633 to->name = (png_charp)png_malloc(png_ptr,
634 png_strlen(from->name) + 1);
635 png_strcpy(to->name, from->name);
636 to->entries = (png_spalette_entryp)png_malloc(png_ptr,
637 from->nentries * sizeof(png_spalette));
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600638 png_memcpy(to->entries, from->entries,
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600639 from->nentries * sizeof(png_spalette));
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600640 to->nentries = from->nentries;
641 to->depth = from->depth;
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600642 }
643
644 info_ptr->splt_palettes = np;
645 info_ptr->splt_palettes_num += nentries;
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600646 info_ptr->valid |= PNG_INFO_sPLT;
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600647 info_ptr->free_me |= PNG_FREE_SPLT;
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600648}
649#endif /* PNG_sPLT_SUPPORTED */
650
651#if defined(PNG_WRITE_UNKNOWN_CHUNKS_SUPPORTED)
652void
653png_set_unknown_chunks(png_structp png_ptr,
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600654 png_infop info_ptr, png_unknown_chunkp unknowns, int num_unknowns)
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600655{
656 png_unknown_chunkp np;
657 int i;
658
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600659 if (png_ptr == NULL || info_ptr == NULL || num_unknowns == 0)
660 return;
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600661
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600662 np = (png_unknown_chunkp)png_malloc(png_ptr,
663 (info_ptr->unknown_chunks_num + num_unknowns) *
664 sizeof(png_unknown_chunk));
665
666 png_memcpy(np, info_ptr->unknown_chunks,
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600667 info_ptr->unknown_chunks_num * sizeof(png_unknown_chunk));
668 png_free(png_ptr, info_ptr->unknown_chunks);
669
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600670 for (i = 0; i < num_unknowns; i++)
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600671 {
672 png_unknown_chunkp to = np + info_ptr->unknown_chunks_num + i;
673 png_unknown_chunkp from = unknowns + i;
674
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600675 png_strcpy((png_charp)to->name, (png_charp)from->name);
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600676 to->data = (png_bytep)png_malloc(png_ptr, from->size);
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600677 png_memcpy(to->data, from->data, from->size);
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600678 to->size = from->size;
679
680 /* note our location in the read or write sequence */
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600681 to->location = (png_byte)(png_ptr->mode & 0xff);
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600682 }
683
684 info_ptr->unknown_chunks = np;
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600685 info_ptr->unknown_chunks_num += num_unknowns;
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600686 info_ptr->free_me |= PNG_FREE_UNKN;
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600687}
688#endif
689
Glenn Randers-Pehrson4393a9a1999-09-17 12:27:26 -0500690#if defined(PNG_READ_EMPTY_PLTE_SUPPORTED)
691void
692png_permit_empty_plte (png_structp png_ptr, int empty_plte_permitted)
693{
694 png_debug1(1, "in png_permit_empty_plte\n", "");
695 if (png_ptr == NULL)
696 return;
697 png_ptr->empty_plte_permitted=(png_byte)empty_plte_permitted;
698}
699#endif
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600700
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600701#if defined(PNG_UNKNOWN_CHUNKS_SUPPORTED)
702void
703png_set_keep_unknown_chunks(png_structp png_ptr, int keep, png_bytep
704 chunk_list, int num_chunks)
705{
706 png_bytep new_list, p;
707 int i, old_num_chunks;
708 if (num_chunks == 0)
709 {
710 if(keep == HANDLE_CHUNK_ALWAYS || keep == HANDLE_CHUNK_IF_SAFE)
711 png_ptr->flags |= PNG_FLAG_KEEP_UNKNOWN_CHUNKS;
712 else
713 png_ptr->flags &= ~PNG_FLAG_KEEP_UNKNOWN_CHUNKS;
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600714
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600715 if(keep == HANDLE_CHUNK_ALWAYS)
716 png_ptr->flags |= PNG_FLAG_KEEP_UNSAFE_CHUNKS;
717 else
718 png_ptr->flags &= ~PNG_FLAG_KEEP_UNSAFE_CHUNKS;
719 return;
720 }
721 if (chunk_list == NULL)
722 return;
723 old_num_chunks=png_ptr->num_chunk_list;
724 new_list=png_malloc(png_ptr,5*(num_chunks+old_num_chunks));
725 if(png_ptr->chunk_list != (png_bytep)NULL)
726 {
727 png_memcpy(new_list, png_ptr->chunk_list, 5*old_num_chunks);
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600728 png_free(png_ptr, png_ptr->chunk_list);
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600729 }
730 png_memcpy(new_list+5*old_num_chunks, chunk_list, 5*num_chunks);
731 for (p=new_list+5*old_num_chunks+4, i=0; i<num_chunks; i++, p+=5)
732 *p=(png_byte)keep;
733 png_ptr->num_chunk_list=old_num_chunks+num_chunks;
734 png_ptr->chunk_list=new_list;
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600735 png_ptr->free_me |= PNG_FREE_LIST;
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600736}
737#endif
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600738
Glenn Randers-Pehrson61c32d92000-02-04 23:40:16 -0600739#if defined(PNG_READ_USER_CHUNKS_SUPPORTED)
740void
741png_set_read_user_chunk_fn(png_structp png_ptr, png_voidp user_chunk_ptr,
742 png_user_chunk_ptr read_user_chunk_fn)
743{
744 png_debug(1, "in png_set_read_user_chunk_fn\n");
745 png_ptr->read_user_chunk_fn = read_user_chunk_fn;
746 png_ptr->user_chunk_ptr = user_chunk_ptr;
747}
748#endif
Glenn Randers-Pehrson166c5a31999-12-10 09:43:02 -0600749
Glenn Randers-Pehrsona77ef622000-02-18 13:48:52 -0600750#if defined(PNG_INFO_IMAGE_SUPPORTED)
751void
752png_set_rows(png_structp png_ptr, png_infop info_ptr, png_bytepp row_pointers)
753{
754 png_debug1(1, "in %s storage function\n", "rows");
755 if (png_ptr == NULL || info_ptr == NULL)
756 return;
757
758 info_ptr->row_pointers = row_pointers;
759 info_ptr->free_me |= PNG_FREE_ROWS;
760}
761#endif
762