vrshoot

annotate libs/libpng/pngtrans.c @ 0:b2f14e535253

initial commit
author John Tsiombikas <nuclear@member.fsf.org>
date Sat, 01 Feb 2014 19:58:19 +0200 (2014-02-01)
parents
children
rev   line source
nuclear@0 1
nuclear@0 2 /* pngtrans.c - transforms the data in a row (used by both readers and writers)
nuclear@0 3 *
nuclear@0 4 * Last changed in libpng 1.2.30 [August 15, 2008]
nuclear@0 5 * For conditions of distribution and use, see copyright notice in png.h
nuclear@0 6 * Copyright (c) 1998-2008 Glenn Randers-Pehrson
nuclear@0 7 * (Version 0.96 Copyright (c) 1996, 1997 Andreas Dilger)
nuclear@0 8 * (Version 0.88 Copyright (c) 1995, 1996 Guy Eric Schalnat, Group 42, Inc.)
nuclear@0 9 */
nuclear@0 10
nuclear@0 11 #define PNG_INTERNAL
nuclear@0 12 #include "png.h"
nuclear@0 13 #if defined(PNG_READ_SUPPORTED) || defined(PNG_WRITE_SUPPORTED)
nuclear@0 14
nuclear@0 15 #if defined(PNG_READ_BGR_SUPPORTED) || defined(PNG_WRITE_BGR_SUPPORTED)
nuclear@0 16 /* turn on BGR-to-RGB mapping */
nuclear@0 17 void PNGAPI
nuclear@0 18 png_set_bgr(png_structp png_ptr)
nuclear@0 19 {
nuclear@0 20 png_debug(1, "in png_set_bgr\n");
nuclear@0 21 if (png_ptr == NULL) return;
nuclear@0 22 png_ptr->transformations |= PNG_BGR;
nuclear@0 23 }
nuclear@0 24 #endif
nuclear@0 25
nuclear@0 26 #if defined(PNG_READ_SWAP_SUPPORTED) || defined(PNG_WRITE_SWAP_SUPPORTED)
nuclear@0 27 /* turn on 16 bit byte swapping */
nuclear@0 28 void PNGAPI
nuclear@0 29 png_set_swap(png_structp png_ptr)
nuclear@0 30 {
nuclear@0 31 png_debug(1, "in png_set_swap\n");
nuclear@0 32 if (png_ptr == NULL) return;
nuclear@0 33 if (png_ptr->bit_depth == 16)
nuclear@0 34 png_ptr->transformations |= PNG_SWAP_BYTES;
nuclear@0 35 }
nuclear@0 36 #endif
nuclear@0 37
nuclear@0 38 #if defined(PNG_READ_PACK_SUPPORTED) || defined(PNG_WRITE_PACK_SUPPORTED)
nuclear@0 39 /* turn on pixel packing */
nuclear@0 40 void PNGAPI
nuclear@0 41 png_set_packing(png_structp png_ptr)
nuclear@0 42 {
nuclear@0 43 png_debug(1, "in png_set_packing\n");
nuclear@0 44 if (png_ptr == NULL) return;
nuclear@0 45 if (png_ptr->bit_depth < 8)
nuclear@0 46 {
nuclear@0 47 png_ptr->transformations |= PNG_PACK;
nuclear@0 48 png_ptr->usr_bit_depth = 8;
nuclear@0 49 }
nuclear@0 50 }
nuclear@0 51 #endif
nuclear@0 52
nuclear@0 53 #if defined(PNG_READ_PACKSWAP_SUPPORTED)||defined(PNG_WRITE_PACKSWAP_SUPPORTED)
nuclear@0 54 /* turn on packed pixel swapping */
nuclear@0 55 void PNGAPI
nuclear@0 56 png_set_packswap(png_structp png_ptr)
nuclear@0 57 {
nuclear@0 58 png_debug(1, "in png_set_packswap\n");
nuclear@0 59 if (png_ptr == NULL) return;
nuclear@0 60 if (png_ptr->bit_depth < 8)
nuclear@0 61 png_ptr->transformations |= PNG_PACKSWAP;
nuclear@0 62 }
nuclear@0 63 #endif
nuclear@0 64
nuclear@0 65 #if defined(PNG_READ_SHIFT_SUPPORTED) || defined(PNG_WRITE_SHIFT_SUPPORTED)
nuclear@0 66 void PNGAPI
nuclear@0 67 png_set_shift(png_structp png_ptr, png_color_8p true_bits)
nuclear@0 68 {
nuclear@0 69 png_debug(1, "in png_set_shift\n");
nuclear@0 70 if (png_ptr == NULL) return;
nuclear@0 71 png_ptr->transformations |= PNG_SHIFT;
nuclear@0 72 png_ptr->shift = *true_bits;
nuclear@0 73 }
nuclear@0 74 #endif
nuclear@0 75
nuclear@0 76 #if defined(PNG_READ_INTERLACING_SUPPORTED) || \
nuclear@0 77 defined(PNG_WRITE_INTERLACING_SUPPORTED)
nuclear@0 78 int PNGAPI
nuclear@0 79 png_set_interlace_handling(png_structp png_ptr)
nuclear@0 80 {
nuclear@0 81 png_debug(1, "in png_set_interlace handling\n");
nuclear@0 82 if (png_ptr && png_ptr->interlaced)
nuclear@0 83 {
nuclear@0 84 png_ptr->transformations |= PNG_INTERLACE;
nuclear@0 85 return (7);
nuclear@0 86 }
nuclear@0 87
nuclear@0 88 return (1);
nuclear@0 89 }
nuclear@0 90 #endif
nuclear@0 91
nuclear@0 92 #if defined(PNG_READ_FILLER_SUPPORTED) || defined(PNG_WRITE_FILLER_SUPPORTED)
nuclear@0 93 /* Add a filler byte on read, or remove a filler or alpha byte on write.
nuclear@0 94 * The filler type has changed in v0.95 to allow future 2-byte fillers
nuclear@0 95 * for 48-bit input data, as well as to avoid problems with some compilers
nuclear@0 96 * that don't like bytes as parameters.
nuclear@0 97 */
nuclear@0 98 void PNGAPI
nuclear@0 99 png_set_filler(png_structp png_ptr, png_uint_32 filler, int filler_loc)
nuclear@0 100 {
nuclear@0 101 png_debug(1, "in png_set_filler\n");
nuclear@0 102 if (png_ptr == NULL) return;
nuclear@0 103 png_ptr->transformations |= PNG_FILLER;
nuclear@0 104 png_ptr->filler = (png_byte)filler;
nuclear@0 105 if (filler_loc == PNG_FILLER_AFTER)
nuclear@0 106 png_ptr->flags |= PNG_FLAG_FILLER_AFTER;
nuclear@0 107 else
nuclear@0 108 png_ptr->flags &= ~PNG_FLAG_FILLER_AFTER;
nuclear@0 109
nuclear@0 110 /* This should probably go in the "do_read_filler" routine.
nuclear@0 111 * I attempted to do that in libpng-1.0.1a but that caused problems
nuclear@0 112 * so I restored it in libpng-1.0.2a
nuclear@0 113 */
nuclear@0 114
nuclear@0 115 if (png_ptr->color_type == PNG_COLOR_TYPE_RGB)
nuclear@0 116 {
nuclear@0 117 png_ptr->usr_channels = 4;
nuclear@0 118 }
nuclear@0 119
nuclear@0 120 /* Also I added this in libpng-1.0.2a (what happens when we expand
nuclear@0 121 * a less-than-8-bit grayscale to GA? */
nuclear@0 122
nuclear@0 123 if (png_ptr->color_type == PNG_COLOR_TYPE_GRAY && png_ptr->bit_depth >= 8)
nuclear@0 124 {
nuclear@0 125 png_ptr->usr_channels = 2;
nuclear@0 126 }
nuclear@0 127 }
nuclear@0 128
nuclear@0 129 #if !defined(PNG_1_0_X)
nuclear@0 130 /* Added to libpng-1.2.7 */
nuclear@0 131 void PNGAPI
nuclear@0 132 png_set_add_alpha(png_structp png_ptr, png_uint_32 filler, int filler_loc)
nuclear@0 133 {
nuclear@0 134 png_debug(1, "in png_set_add_alpha\n");
nuclear@0 135 if (png_ptr == NULL) return;
nuclear@0 136 png_set_filler(png_ptr, filler, filler_loc);
nuclear@0 137 png_ptr->transformations |= PNG_ADD_ALPHA;
nuclear@0 138 }
nuclear@0 139 #endif
nuclear@0 140
nuclear@0 141 #endif
nuclear@0 142
nuclear@0 143 #if defined(PNG_READ_SWAP_ALPHA_SUPPORTED) || \
nuclear@0 144 defined(PNG_WRITE_SWAP_ALPHA_SUPPORTED)
nuclear@0 145 void PNGAPI
nuclear@0 146 png_set_swap_alpha(png_structp png_ptr)
nuclear@0 147 {
nuclear@0 148 png_debug(1, "in png_set_swap_alpha\n");
nuclear@0 149 if (png_ptr == NULL) return;
nuclear@0 150 png_ptr->transformations |= PNG_SWAP_ALPHA;
nuclear@0 151 }
nuclear@0 152 #endif
nuclear@0 153
nuclear@0 154 #if defined(PNG_READ_INVERT_ALPHA_SUPPORTED) || \
nuclear@0 155 defined(PNG_WRITE_INVERT_ALPHA_SUPPORTED)
nuclear@0 156 void PNGAPI
nuclear@0 157 png_set_invert_alpha(png_structp png_ptr)
nuclear@0 158 {
nuclear@0 159 png_debug(1, "in png_set_invert_alpha\n");
nuclear@0 160 if (png_ptr == NULL) return;
nuclear@0 161 png_ptr->transformations |= PNG_INVERT_ALPHA;
nuclear@0 162 }
nuclear@0 163 #endif
nuclear@0 164
nuclear@0 165 #if defined(PNG_READ_INVERT_SUPPORTED) || defined(PNG_WRITE_INVERT_SUPPORTED)
nuclear@0 166 void PNGAPI
nuclear@0 167 png_set_invert_mono(png_structp png_ptr)
nuclear@0 168 {
nuclear@0 169 png_debug(1, "in png_set_invert_mono\n");
nuclear@0 170 if (png_ptr == NULL) return;
nuclear@0 171 png_ptr->transformations |= PNG_INVERT_MONO;
nuclear@0 172 }
nuclear@0 173
nuclear@0 174 /* invert monochrome grayscale data */
nuclear@0 175 void /* PRIVATE */
nuclear@0 176 png_do_invert(png_row_infop row_info, png_bytep row)
nuclear@0 177 {
nuclear@0 178 png_debug(1, "in png_do_invert\n");
nuclear@0 179 /* This test removed from libpng version 1.0.13 and 1.2.0:
nuclear@0 180 * if (row_info->bit_depth == 1 &&
nuclear@0 181 */
nuclear@0 182 #if defined(PNG_USELESS_TESTS_SUPPORTED)
nuclear@0 183 if (row == NULL || row_info == NULL)
nuclear@0 184 return;
nuclear@0 185 #endif
nuclear@0 186 if (row_info->color_type == PNG_COLOR_TYPE_GRAY)
nuclear@0 187 {
nuclear@0 188 png_bytep rp = row;
nuclear@0 189 png_uint_32 i;
nuclear@0 190 png_uint_32 istop = row_info->rowbytes;
nuclear@0 191
nuclear@0 192 for (i = 0; i < istop; i++)
nuclear@0 193 {
nuclear@0 194 *rp = (png_byte)(~(*rp));
nuclear@0 195 rp++;
nuclear@0 196 }
nuclear@0 197 }
nuclear@0 198 else if (row_info->color_type == PNG_COLOR_TYPE_GRAY_ALPHA &&
nuclear@0 199 row_info->bit_depth == 8)
nuclear@0 200 {
nuclear@0 201 png_bytep rp = row;
nuclear@0 202 png_uint_32 i;
nuclear@0 203 png_uint_32 istop = row_info->rowbytes;
nuclear@0 204
nuclear@0 205 for (i = 0; i < istop; i+=2)
nuclear@0 206 {
nuclear@0 207 *rp = (png_byte)(~(*rp));
nuclear@0 208 rp+=2;
nuclear@0 209 }
nuclear@0 210 }
nuclear@0 211 else if (row_info->color_type == PNG_COLOR_TYPE_GRAY_ALPHA &&
nuclear@0 212 row_info->bit_depth == 16)
nuclear@0 213 {
nuclear@0 214 png_bytep rp = row;
nuclear@0 215 png_uint_32 i;
nuclear@0 216 png_uint_32 istop = row_info->rowbytes;
nuclear@0 217
nuclear@0 218 for (i = 0; i < istop; i+=4)
nuclear@0 219 {
nuclear@0 220 *rp = (png_byte)(~(*rp));
nuclear@0 221 *(rp+1) = (png_byte)(~(*(rp+1)));
nuclear@0 222 rp+=4;
nuclear@0 223 }
nuclear@0 224 }
nuclear@0 225 }
nuclear@0 226 #endif
nuclear@0 227
nuclear@0 228 #if defined(PNG_READ_SWAP_SUPPORTED) || defined(PNG_WRITE_SWAP_SUPPORTED)
nuclear@0 229 /* swaps byte order on 16 bit depth images */
nuclear@0 230 void /* PRIVATE */
nuclear@0 231 png_do_swap(png_row_infop row_info, png_bytep row)
nuclear@0 232 {
nuclear@0 233 png_debug(1, "in png_do_swap\n");
nuclear@0 234 if (
nuclear@0 235 #if defined(PNG_USELESS_TESTS_SUPPORTED)
nuclear@0 236 row != NULL && row_info != NULL &&
nuclear@0 237 #endif
nuclear@0 238 row_info->bit_depth == 16)
nuclear@0 239 {
nuclear@0 240 png_bytep rp = row;
nuclear@0 241 png_uint_32 i;
nuclear@0 242 png_uint_32 istop= row_info->width * row_info->channels;
nuclear@0 243
nuclear@0 244 for (i = 0; i < istop; i++, rp += 2)
nuclear@0 245 {
nuclear@0 246 png_byte t = *rp;
nuclear@0 247 *rp = *(rp + 1);
nuclear@0 248 *(rp + 1) = t;
nuclear@0 249 }
nuclear@0 250 }
nuclear@0 251 }
nuclear@0 252 #endif
nuclear@0 253
nuclear@0 254 #if defined(PNG_READ_PACKSWAP_SUPPORTED)||defined(PNG_WRITE_PACKSWAP_SUPPORTED)
nuclear@0 255 static PNG_CONST png_byte onebppswaptable[256] = {
nuclear@0 256 0x00, 0x80, 0x40, 0xC0, 0x20, 0xA0, 0x60, 0xE0,
nuclear@0 257 0x10, 0x90, 0x50, 0xD0, 0x30, 0xB0, 0x70, 0xF0,
nuclear@0 258 0x08, 0x88, 0x48, 0xC8, 0x28, 0xA8, 0x68, 0xE8,
nuclear@0 259 0x18, 0x98, 0x58, 0xD8, 0x38, 0xB8, 0x78, 0xF8,
nuclear@0 260 0x04, 0x84, 0x44, 0xC4, 0x24, 0xA4, 0x64, 0xE4,
nuclear@0 261 0x14, 0x94, 0x54, 0xD4, 0x34, 0xB4, 0x74, 0xF4,
nuclear@0 262 0x0C, 0x8C, 0x4C, 0xCC, 0x2C, 0xAC, 0x6C, 0xEC,
nuclear@0 263 0x1C, 0x9C, 0x5C, 0xDC, 0x3C, 0xBC, 0x7C, 0xFC,
nuclear@0 264 0x02, 0x82, 0x42, 0xC2, 0x22, 0xA2, 0x62, 0xE2,
nuclear@0 265 0x12, 0x92, 0x52, 0xD2, 0x32, 0xB2, 0x72, 0xF2,
nuclear@0 266 0x0A, 0x8A, 0x4A, 0xCA, 0x2A, 0xAA, 0x6A, 0xEA,
nuclear@0 267 0x1A, 0x9A, 0x5A, 0xDA, 0x3A, 0xBA, 0x7A, 0xFA,
nuclear@0 268 0x06, 0x86, 0x46, 0xC6, 0x26, 0xA6, 0x66, 0xE6,
nuclear@0 269 0x16, 0x96, 0x56, 0xD6, 0x36, 0xB6, 0x76, 0xF6,
nuclear@0 270 0x0E, 0x8E, 0x4E, 0xCE, 0x2E, 0xAE, 0x6E, 0xEE,
nuclear@0 271 0x1E, 0x9E, 0x5E, 0xDE, 0x3E, 0xBE, 0x7E, 0xFE,
nuclear@0 272 0x01, 0x81, 0x41, 0xC1, 0x21, 0xA1, 0x61, 0xE1,
nuclear@0 273 0x11, 0x91, 0x51, 0xD1, 0x31, 0xB1, 0x71, 0xF1,
nuclear@0 274 0x09, 0x89, 0x49, 0xC9, 0x29, 0xA9, 0x69, 0xE9,
nuclear@0 275 0x19, 0x99, 0x59, 0xD9, 0x39, 0xB9, 0x79, 0xF9,
nuclear@0 276 0x05, 0x85, 0x45, 0xC5, 0x25, 0xA5, 0x65, 0xE5,
nuclear@0 277 0x15, 0x95, 0x55, 0xD5, 0x35, 0xB5, 0x75, 0xF5,
nuclear@0 278 0x0D, 0x8D, 0x4D, 0xCD, 0x2D, 0xAD, 0x6D, 0xED,
nuclear@0 279 0x1D, 0x9D, 0x5D, 0xDD, 0x3D, 0xBD, 0x7D, 0xFD,
nuclear@0 280 0x03, 0x83, 0x43, 0xC3, 0x23, 0xA3, 0x63, 0xE3,
nuclear@0 281 0x13, 0x93, 0x53, 0xD3, 0x33, 0xB3, 0x73, 0xF3,
nuclear@0 282 0x0B, 0x8B, 0x4B, 0xCB, 0x2B, 0xAB, 0x6B, 0xEB,
nuclear@0 283 0x1B, 0x9B, 0x5B, 0xDB, 0x3B, 0xBB, 0x7B, 0xFB,
nuclear@0 284 0x07, 0x87, 0x47, 0xC7, 0x27, 0xA7, 0x67, 0xE7,
nuclear@0 285 0x17, 0x97, 0x57, 0xD7, 0x37, 0xB7, 0x77, 0xF7,
nuclear@0 286 0x0F, 0x8F, 0x4F, 0xCF, 0x2F, 0xAF, 0x6F, 0xEF,
nuclear@0 287 0x1F, 0x9F, 0x5F, 0xDF, 0x3F, 0xBF, 0x7F, 0xFF
nuclear@0 288 };
nuclear@0 289
nuclear@0 290 static PNG_CONST png_byte twobppswaptable[256] = {
nuclear@0 291 0x00, 0x40, 0x80, 0xC0, 0x10, 0x50, 0x90, 0xD0,
nuclear@0 292 0x20, 0x60, 0xA0, 0xE0, 0x30, 0x70, 0xB0, 0xF0,
nuclear@0 293 0x04, 0x44, 0x84, 0xC4, 0x14, 0x54, 0x94, 0xD4,
nuclear@0 294 0x24, 0x64, 0xA4, 0xE4, 0x34, 0x74, 0xB4, 0xF4,
nuclear@0 295 0x08, 0x48, 0x88, 0xC8, 0x18, 0x58, 0x98, 0xD8,
nuclear@0 296 0x28, 0x68, 0xA8, 0xE8, 0x38, 0x78, 0xB8, 0xF8,
nuclear@0 297 0x0C, 0x4C, 0x8C, 0xCC, 0x1C, 0x5C, 0x9C, 0xDC,
nuclear@0 298 0x2C, 0x6C, 0xAC, 0xEC, 0x3C, 0x7C, 0xBC, 0xFC,
nuclear@0 299 0x01, 0x41, 0x81, 0xC1, 0x11, 0x51, 0x91, 0xD1,
nuclear@0 300 0x21, 0x61, 0xA1, 0xE1, 0x31, 0x71, 0xB1, 0xF1,
nuclear@0 301 0x05, 0x45, 0x85, 0xC5, 0x15, 0x55, 0x95, 0xD5,
nuclear@0 302 0x25, 0x65, 0xA5, 0xE5, 0x35, 0x75, 0xB5, 0xF5,
nuclear@0 303 0x09, 0x49, 0x89, 0xC9, 0x19, 0x59, 0x99, 0xD9,
nuclear@0 304 0x29, 0x69, 0xA9, 0xE9, 0x39, 0x79, 0xB9, 0xF9,
nuclear@0 305 0x0D, 0x4D, 0x8D, 0xCD, 0x1D, 0x5D, 0x9D, 0xDD,
nuclear@0 306 0x2D, 0x6D, 0xAD, 0xED, 0x3D, 0x7D, 0xBD, 0xFD,
nuclear@0 307 0x02, 0x42, 0x82, 0xC2, 0x12, 0x52, 0x92, 0xD2,
nuclear@0 308 0x22, 0x62, 0xA2, 0xE2, 0x32, 0x72, 0xB2, 0xF2,
nuclear@0 309 0x06, 0x46, 0x86, 0xC6, 0x16, 0x56, 0x96, 0xD6,
nuclear@0 310 0x26, 0x66, 0xA6, 0xE6, 0x36, 0x76, 0xB6, 0xF6,
nuclear@0 311 0x0A, 0x4A, 0x8A, 0xCA, 0x1A, 0x5A, 0x9A, 0xDA,
nuclear@0 312 0x2A, 0x6A, 0xAA, 0xEA, 0x3A, 0x7A, 0xBA, 0xFA,
nuclear@0 313 0x0E, 0x4E, 0x8E, 0xCE, 0x1E, 0x5E, 0x9E, 0xDE,
nuclear@0 314 0x2E, 0x6E, 0xAE, 0xEE, 0x3E, 0x7E, 0xBE, 0xFE,
nuclear@0 315 0x03, 0x43, 0x83, 0xC3, 0x13, 0x53, 0x93, 0xD3,
nuclear@0 316 0x23, 0x63, 0xA3, 0xE3, 0x33, 0x73, 0xB3, 0xF3,
nuclear@0 317 0x07, 0x47, 0x87, 0xC7, 0x17, 0x57, 0x97, 0xD7,
nuclear@0 318 0x27, 0x67, 0xA7, 0xE7, 0x37, 0x77, 0xB7, 0xF7,
nuclear@0 319 0x0B, 0x4B, 0x8B, 0xCB, 0x1B, 0x5B, 0x9B, 0xDB,
nuclear@0 320 0x2B, 0x6B, 0xAB, 0xEB, 0x3B, 0x7B, 0xBB, 0xFB,
nuclear@0 321 0x0F, 0x4F, 0x8F, 0xCF, 0x1F, 0x5F, 0x9F, 0xDF,
nuclear@0 322 0x2F, 0x6F, 0xAF, 0xEF, 0x3F, 0x7F, 0xBF, 0xFF
nuclear@0 323 };
nuclear@0 324
nuclear@0 325 static PNG_CONST png_byte fourbppswaptable[256] = {
nuclear@0 326 0x00, 0x10, 0x20, 0x30, 0x40, 0x50, 0x60, 0x70,
nuclear@0 327 0x80, 0x90, 0xA0, 0xB0, 0xC0, 0xD0, 0xE0, 0xF0,
nuclear@0 328 0x01, 0x11, 0x21, 0x31, 0x41, 0x51, 0x61, 0x71,
nuclear@0 329 0x81, 0x91, 0xA1, 0xB1, 0xC1, 0xD1, 0xE1, 0xF1,
nuclear@0 330 0x02, 0x12, 0x22, 0x32, 0x42, 0x52, 0x62, 0x72,
nuclear@0 331 0x82, 0x92, 0xA2, 0xB2, 0xC2, 0xD2, 0xE2, 0xF2,
nuclear@0 332 0x03, 0x13, 0x23, 0x33, 0x43, 0x53, 0x63, 0x73,
nuclear@0 333 0x83, 0x93, 0xA3, 0xB3, 0xC3, 0xD3, 0xE3, 0xF3,
nuclear@0 334 0x04, 0x14, 0x24, 0x34, 0x44, 0x54, 0x64, 0x74,
nuclear@0 335 0x84, 0x94, 0xA4, 0xB4, 0xC4, 0xD4, 0xE4, 0xF4,
nuclear@0 336 0x05, 0x15, 0x25, 0x35, 0x45, 0x55, 0x65, 0x75,
nuclear@0 337 0x85, 0x95, 0xA5, 0xB5, 0xC5, 0xD5, 0xE5, 0xF5,
nuclear@0 338 0x06, 0x16, 0x26, 0x36, 0x46, 0x56, 0x66, 0x76,
nuclear@0 339 0x86, 0x96, 0xA6, 0xB6, 0xC6, 0xD6, 0xE6, 0xF6,
nuclear@0 340 0x07, 0x17, 0x27, 0x37, 0x47, 0x57, 0x67, 0x77,
nuclear@0 341 0x87, 0x97, 0xA7, 0xB7, 0xC7, 0xD7, 0xE7, 0xF7,
nuclear@0 342 0x08, 0x18, 0x28, 0x38, 0x48, 0x58, 0x68, 0x78,
nuclear@0 343 0x88, 0x98, 0xA8, 0xB8, 0xC8, 0xD8, 0xE8, 0xF8,
nuclear@0 344 0x09, 0x19, 0x29, 0x39, 0x49, 0x59, 0x69, 0x79,
nuclear@0 345 0x89, 0x99, 0xA9, 0xB9, 0xC9, 0xD9, 0xE9, 0xF9,
nuclear@0 346 0x0A, 0x1A, 0x2A, 0x3A, 0x4A, 0x5A, 0x6A, 0x7A,
nuclear@0 347 0x8A, 0x9A, 0xAA, 0xBA, 0xCA, 0xDA, 0xEA, 0xFA,
nuclear@0 348 0x0B, 0x1B, 0x2B, 0x3B, 0x4B, 0x5B, 0x6B, 0x7B,
nuclear@0 349 0x8B, 0x9B, 0xAB, 0xBB, 0xCB, 0xDB, 0xEB, 0xFB,
nuclear@0 350 0x0C, 0x1C, 0x2C, 0x3C, 0x4C, 0x5C, 0x6C, 0x7C,
nuclear@0 351 0x8C, 0x9C, 0xAC, 0xBC, 0xCC, 0xDC, 0xEC, 0xFC,
nuclear@0 352 0x0D, 0x1D, 0x2D, 0x3D, 0x4D, 0x5D, 0x6D, 0x7D,
nuclear@0 353 0x8D, 0x9D, 0xAD, 0xBD, 0xCD, 0xDD, 0xED, 0xFD,
nuclear@0 354 0x0E, 0x1E, 0x2E, 0x3E, 0x4E, 0x5E, 0x6E, 0x7E,
nuclear@0 355 0x8E, 0x9E, 0xAE, 0xBE, 0xCE, 0xDE, 0xEE, 0xFE,
nuclear@0 356 0x0F, 0x1F, 0x2F, 0x3F, 0x4F, 0x5F, 0x6F, 0x7F,
nuclear@0 357 0x8F, 0x9F, 0xAF, 0xBF, 0xCF, 0xDF, 0xEF, 0xFF
nuclear@0 358 };
nuclear@0 359
nuclear@0 360 /* swaps pixel packing order within bytes */
nuclear@0 361 void /* PRIVATE */
nuclear@0 362 png_do_packswap(png_row_infop row_info, png_bytep row)
nuclear@0 363 {
nuclear@0 364 png_debug(1, "in png_do_packswap\n");
nuclear@0 365 if (
nuclear@0 366 #if defined(PNG_USELESS_TESTS_SUPPORTED)
nuclear@0 367 row != NULL && row_info != NULL &&
nuclear@0 368 #endif
nuclear@0 369 row_info->bit_depth < 8)
nuclear@0 370 {
nuclear@0 371 png_bytep rp, end, table;
nuclear@0 372
nuclear@0 373 end = row + row_info->rowbytes;
nuclear@0 374
nuclear@0 375 if (row_info->bit_depth == 1)
nuclear@0 376 table = (png_bytep)onebppswaptable;
nuclear@0 377 else if (row_info->bit_depth == 2)
nuclear@0 378 table = (png_bytep)twobppswaptable;
nuclear@0 379 else if (row_info->bit_depth == 4)
nuclear@0 380 table = (png_bytep)fourbppswaptable;
nuclear@0 381 else
nuclear@0 382 return;
nuclear@0 383
nuclear@0 384 for (rp = row; rp < end; rp++)
nuclear@0 385 *rp = table[*rp];
nuclear@0 386 }
nuclear@0 387 }
nuclear@0 388 #endif /* PNG_READ_PACKSWAP_SUPPORTED or PNG_WRITE_PACKSWAP_SUPPORTED */
nuclear@0 389
nuclear@0 390 #if defined(PNG_WRITE_FILLER_SUPPORTED) || \
nuclear@0 391 defined(PNG_READ_STRIP_ALPHA_SUPPORTED)
nuclear@0 392 /* remove filler or alpha byte(s) */
nuclear@0 393 void /* PRIVATE */
nuclear@0 394 png_do_strip_filler(png_row_infop row_info, png_bytep row, png_uint_32 flags)
nuclear@0 395 {
nuclear@0 396 png_debug(1, "in png_do_strip_filler\n");
nuclear@0 397 #if defined(PNG_USELESS_TESTS_SUPPORTED)
nuclear@0 398 if (row != NULL && row_info != NULL)
nuclear@0 399 #endif
nuclear@0 400 {
nuclear@0 401 png_bytep sp=row;
nuclear@0 402 png_bytep dp=row;
nuclear@0 403 png_uint_32 row_width=row_info->width;
nuclear@0 404 png_uint_32 i;
nuclear@0 405
nuclear@0 406 if ((row_info->color_type == PNG_COLOR_TYPE_RGB ||
nuclear@0 407 (row_info->color_type == PNG_COLOR_TYPE_RGB_ALPHA &&
nuclear@0 408 (flags & PNG_FLAG_STRIP_ALPHA))) &&
nuclear@0 409 row_info->channels == 4)
nuclear@0 410 {
nuclear@0 411 if (row_info->bit_depth == 8)
nuclear@0 412 {
nuclear@0 413 /* This converts from RGBX or RGBA to RGB */
nuclear@0 414 if (flags & PNG_FLAG_FILLER_AFTER)
nuclear@0 415 {
nuclear@0 416 dp+=3; sp+=4;
nuclear@0 417 for (i = 1; i < row_width; i++)
nuclear@0 418 {
nuclear@0 419 *dp++ = *sp++;
nuclear@0 420 *dp++ = *sp++;
nuclear@0 421 *dp++ = *sp++;
nuclear@0 422 sp++;
nuclear@0 423 }
nuclear@0 424 }
nuclear@0 425 /* This converts from XRGB or ARGB to RGB */
nuclear@0 426 else
nuclear@0 427 {
nuclear@0 428 for (i = 0; i < row_width; i++)
nuclear@0 429 {
nuclear@0 430 sp++;
nuclear@0 431 *dp++ = *sp++;
nuclear@0 432 *dp++ = *sp++;
nuclear@0 433 *dp++ = *sp++;
nuclear@0 434 }
nuclear@0 435 }
nuclear@0 436 row_info->pixel_depth = 24;
nuclear@0 437 row_info->rowbytes = row_width * 3;
nuclear@0 438 }
nuclear@0 439 else /* if (row_info->bit_depth == 16) */
nuclear@0 440 {
nuclear@0 441 if (flags & PNG_FLAG_FILLER_AFTER)
nuclear@0 442 {
nuclear@0 443 /* This converts from RRGGBBXX or RRGGBBAA to RRGGBB */
nuclear@0 444 sp += 8; dp += 6;
nuclear@0 445 for (i = 1; i < row_width; i++)
nuclear@0 446 {
nuclear@0 447 /* This could be (although png_memcpy is probably slower):
nuclear@0 448 png_memcpy(dp, sp, 6);
nuclear@0 449 sp += 8;
nuclear@0 450 dp += 6;
nuclear@0 451 */
nuclear@0 452
nuclear@0 453 *dp++ = *sp++;
nuclear@0 454 *dp++ = *sp++;
nuclear@0 455 *dp++ = *sp++;
nuclear@0 456 *dp++ = *sp++;
nuclear@0 457 *dp++ = *sp++;
nuclear@0 458 *dp++ = *sp++;
nuclear@0 459 sp += 2;
nuclear@0 460 }
nuclear@0 461 }
nuclear@0 462 else
nuclear@0 463 {
nuclear@0 464 /* This converts from XXRRGGBB or AARRGGBB to RRGGBB */
nuclear@0 465 for (i = 0; i < row_width; i++)
nuclear@0 466 {
nuclear@0 467 /* This could be (although png_memcpy is probably slower):
nuclear@0 468 png_memcpy(dp, sp, 6);
nuclear@0 469 sp += 8;
nuclear@0 470 dp += 6;
nuclear@0 471 */
nuclear@0 472
nuclear@0 473 sp+=2;
nuclear@0 474 *dp++ = *sp++;
nuclear@0 475 *dp++ = *sp++;
nuclear@0 476 *dp++ = *sp++;
nuclear@0 477 *dp++ = *sp++;
nuclear@0 478 *dp++ = *sp++;
nuclear@0 479 *dp++ = *sp++;
nuclear@0 480 }
nuclear@0 481 }
nuclear@0 482 row_info->pixel_depth = 48;
nuclear@0 483 row_info->rowbytes = row_width * 6;
nuclear@0 484 }
nuclear@0 485 row_info->channels = 3;
nuclear@0 486 }
nuclear@0 487 else if ((row_info->color_type == PNG_COLOR_TYPE_GRAY ||
nuclear@0 488 (row_info->color_type == PNG_COLOR_TYPE_GRAY_ALPHA &&
nuclear@0 489 (flags & PNG_FLAG_STRIP_ALPHA))) &&
nuclear@0 490 row_info->channels == 2)
nuclear@0 491 {
nuclear@0 492 if (row_info->bit_depth == 8)
nuclear@0 493 {
nuclear@0 494 /* This converts from GX or GA to G */
nuclear@0 495 if (flags & PNG_FLAG_FILLER_AFTER)
nuclear@0 496 {
nuclear@0 497 for (i = 0; i < row_width; i++)
nuclear@0 498 {
nuclear@0 499 *dp++ = *sp++;
nuclear@0 500 sp++;
nuclear@0 501 }
nuclear@0 502 }
nuclear@0 503 /* This converts from XG or AG to G */
nuclear@0 504 else
nuclear@0 505 {
nuclear@0 506 for (i = 0; i < row_width; i++)
nuclear@0 507 {
nuclear@0 508 sp++;
nuclear@0 509 *dp++ = *sp++;
nuclear@0 510 }
nuclear@0 511 }
nuclear@0 512 row_info->pixel_depth = 8;
nuclear@0 513 row_info->rowbytes = row_width;
nuclear@0 514 }
nuclear@0 515 else /* if (row_info->bit_depth == 16) */
nuclear@0 516 {
nuclear@0 517 if (flags & PNG_FLAG_FILLER_AFTER)
nuclear@0 518 {
nuclear@0 519 /* This converts from GGXX or GGAA to GG */
nuclear@0 520 sp += 4; dp += 2;
nuclear@0 521 for (i = 1; i < row_width; i++)
nuclear@0 522 {
nuclear@0 523 *dp++ = *sp++;
nuclear@0 524 *dp++ = *sp++;
nuclear@0 525 sp += 2;
nuclear@0 526 }
nuclear@0 527 }
nuclear@0 528 else
nuclear@0 529 {
nuclear@0 530 /* This converts from XXGG or AAGG to GG */
nuclear@0 531 for (i = 0; i < row_width; i++)
nuclear@0 532 {
nuclear@0 533 sp += 2;
nuclear@0 534 *dp++ = *sp++;
nuclear@0 535 *dp++ = *sp++;
nuclear@0 536 }
nuclear@0 537 }
nuclear@0 538 row_info->pixel_depth = 16;
nuclear@0 539 row_info->rowbytes = row_width * 2;
nuclear@0 540 }
nuclear@0 541 row_info->channels = 1;
nuclear@0 542 }
nuclear@0 543 if (flags & PNG_FLAG_STRIP_ALPHA)
nuclear@0 544 row_info->color_type &= ~PNG_COLOR_MASK_ALPHA;
nuclear@0 545 }
nuclear@0 546 }
nuclear@0 547 #endif
nuclear@0 548
nuclear@0 549 #if defined(PNG_READ_BGR_SUPPORTED) || defined(PNG_WRITE_BGR_SUPPORTED)
nuclear@0 550 /* swaps red and blue bytes within a pixel */
nuclear@0 551 void /* PRIVATE */
nuclear@0 552 png_do_bgr(png_row_infop row_info, png_bytep row)
nuclear@0 553 {
nuclear@0 554 png_debug(1, "in png_do_bgr\n");
nuclear@0 555 if (
nuclear@0 556 #if defined(PNG_USELESS_TESTS_SUPPORTED)
nuclear@0 557 row != NULL && row_info != NULL &&
nuclear@0 558 #endif
nuclear@0 559 (row_info->color_type & PNG_COLOR_MASK_COLOR))
nuclear@0 560 {
nuclear@0 561 png_uint_32 row_width = row_info->width;
nuclear@0 562 if (row_info->bit_depth == 8)
nuclear@0 563 {
nuclear@0 564 if (row_info->color_type == PNG_COLOR_TYPE_RGB)
nuclear@0 565 {
nuclear@0 566 png_bytep rp;
nuclear@0 567 png_uint_32 i;
nuclear@0 568
nuclear@0 569 for (i = 0, rp = row; i < row_width; i++, rp += 3)
nuclear@0 570 {
nuclear@0 571 png_byte save = *rp;
nuclear@0 572 *rp = *(rp + 2);
nuclear@0 573 *(rp + 2) = save;
nuclear@0 574 }
nuclear@0 575 }
nuclear@0 576 else if (row_info->color_type == PNG_COLOR_TYPE_RGB_ALPHA)
nuclear@0 577 {
nuclear@0 578 png_bytep rp;
nuclear@0 579 png_uint_32 i;
nuclear@0 580
nuclear@0 581 for (i = 0, rp = row; i < row_width; i++, rp += 4)
nuclear@0 582 {
nuclear@0 583 png_byte save = *rp;
nuclear@0 584 *rp = *(rp + 2);
nuclear@0 585 *(rp + 2) = save;
nuclear@0 586 }
nuclear@0 587 }
nuclear@0 588 }
nuclear@0 589 else if (row_info->bit_depth == 16)
nuclear@0 590 {
nuclear@0 591 if (row_info->color_type == PNG_COLOR_TYPE_RGB)
nuclear@0 592 {
nuclear@0 593 png_bytep rp;
nuclear@0 594 png_uint_32 i;
nuclear@0 595
nuclear@0 596 for (i = 0, rp = row; i < row_width; i++, rp += 6)
nuclear@0 597 {
nuclear@0 598 png_byte save = *rp;
nuclear@0 599 *rp = *(rp + 4);
nuclear@0 600 *(rp + 4) = save;
nuclear@0 601 save = *(rp + 1);
nuclear@0 602 *(rp + 1) = *(rp + 5);
nuclear@0 603 *(rp + 5) = save;
nuclear@0 604 }
nuclear@0 605 }
nuclear@0 606 else if (row_info->color_type == PNG_COLOR_TYPE_RGB_ALPHA)
nuclear@0 607 {
nuclear@0 608 png_bytep rp;
nuclear@0 609 png_uint_32 i;
nuclear@0 610
nuclear@0 611 for (i = 0, rp = row; i < row_width; i++, rp += 8)
nuclear@0 612 {
nuclear@0 613 png_byte save = *rp;
nuclear@0 614 *rp = *(rp + 4);
nuclear@0 615 *(rp + 4) = save;
nuclear@0 616 save = *(rp + 1);
nuclear@0 617 *(rp + 1) = *(rp + 5);
nuclear@0 618 *(rp + 5) = save;
nuclear@0 619 }
nuclear@0 620 }
nuclear@0 621 }
nuclear@0 622 }
nuclear@0 623 }
nuclear@0 624 #endif /* PNG_READ_BGR_SUPPORTED or PNG_WRITE_BGR_SUPPORTED */
nuclear@0 625
nuclear@0 626 #if defined(PNG_READ_USER_TRANSFORM_SUPPORTED) || \
nuclear@0 627 defined(PNG_WRITE_USER_TRANSFORM_SUPPORTED) || \
nuclear@0 628 defined(PNG_LEGACY_SUPPORTED)
nuclear@0 629 void PNGAPI
nuclear@0 630 png_set_user_transform_info(png_structp png_ptr, png_voidp
nuclear@0 631 user_transform_ptr, int user_transform_depth, int user_transform_channels)
nuclear@0 632 {
nuclear@0 633 png_debug(1, "in png_set_user_transform_info\n");
nuclear@0 634 if (png_ptr == NULL) return;
nuclear@0 635 #if defined(PNG_USER_TRANSFORM_PTR_SUPPORTED)
nuclear@0 636 png_ptr->user_transform_ptr = user_transform_ptr;
nuclear@0 637 png_ptr->user_transform_depth = (png_byte)user_transform_depth;
nuclear@0 638 png_ptr->user_transform_channels = (png_byte)user_transform_channels;
nuclear@0 639 #else
nuclear@0 640 if (user_transform_ptr || user_transform_depth || user_transform_channels)
nuclear@0 641 png_warning(png_ptr,
nuclear@0 642 "This version of libpng does not support user transform info");
nuclear@0 643 #endif
nuclear@0 644 }
nuclear@0 645 #endif
nuclear@0 646
nuclear@0 647 /* This function returns a pointer to the user_transform_ptr associated with
nuclear@0 648 * the user transform functions. The application should free any memory
nuclear@0 649 * associated with this pointer before png_write_destroy and png_read_destroy
nuclear@0 650 * are called.
nuclear@0 651 */
nuclear@0 652 png_voidp PNGAPI
nuclear@0 653 png_get_user_transform_ptr(png_structp png_ptr)
nuclear@0 654 {
nuclear@0 655 if (png_ptr == NULL) return (NULL);
nuclear@0 656 #if defined(PNG_USER_TRANSFORM_PTR_SUPPORTED)
nuclear@0 657 return ((png_voidp)png_ptr->user_transform_ptr);
nuclear@0 658 #else
nuclear@0 659 return (NULL);
nuclear@0 660 #endif
nuclear@0 661 }
nuclear@0 662 #endif /* PNG_READ_SUPPORTED || PNG_WRITE_SUPPORTED */