From 6873aa19d37bdd44337d0447e0be253dc4aecdd3 Mon Sep 17 00:00:00 2001 From: Hartmut Seichter Date: Tue, 23 Sep 2025 23:01:17 +0200 Subject: [PATCH 1/2] update stb_image with fixes --- src/lib/src/vendor/stb/stb_image.h | 12438 ++++++++++++++------------- 1 file changed, 6643 insertions(+), 5795 deletions(-) diff --git a/src/lib/src/vendor/stb/stb_image.h b/src/lib/src/vendor/stb/stb_image.h index 1f44c87..70af74b 100644 --- a/src/lib/src/vendor/stb/stb_image.h +++ b/src/lib/src/vendor/stb/stb_image.h @@ -1,9 +1,10 @@ -/* stb_image - v2.28 - public domain image loader - http://nothings.org/stb +/* stb_image - v2.30 - public domain image loader - http://nothings.org/stb no warranty implied; use at your own risk Do this: #define STB_IMAGE_IMPLEMENTATION - before you include this file in *one* C or C++ file to create the implementation. + before you include this file in *one* C or C++ file to create the +implementation. // i.e. it should look like this: #include ... @@ -13,15 +14,16 @@ #include "stb_image.h" You can #define STBI_ASSERT(x) before the #include to avoid using assert.h. - And #define STBI_MALLOC, STBI_REALLOC, and STBI_FREE to avoid using malloc,realloc,free + And #define STBI_MALLOC, STBI_REALLOC, and STBI_FREE to avoid using +malloc,realloc,free QUICK NOTES: Primarily of interest to game developers and other people who can avoid problematic images and only need the trivial interface - JPEG baseline & progressive (12 bpc/arithmetic not supported, same as stock IJG lib) - PNG 1/2/4/8/16-bit-per-channel + JPEG baseline & progressive (12 bpc/arithmetic not supported, same as +stock IJG lib) PNG 1/2/4/8/16-bit-per-channel TGA (not sure what subset, if a subset) BMP non-1bpp, non-RLE @@ -48,24 +50,22 @@ LICENSE RECENT REVISION HISTORY: + 2.30 (2024-05-31) avoid erroneous gcc warning + 2.29 (2023-05-xx) optimizations 2.28 (2023-01-29) many error fixes, security errors, just tons of stuff - 2.27 (2021-07-11) document stbi_info better, 16-bit PNM support, bug fixes - 2.26 (2020-07-13) many minor fixes - 2.25 (2020-02-02) fix warnings - 2.24 (2020-02-02) fix warnings; thread-local failure_reason and flip_vertically - 2.23 (2019-08-11) fix clang static analysis warning - 2.22 (2019-03-04) gif fixes, fix warnings - 2.21 (2019-02-25) fix typo in comment - 2.20 (2019-02-07) support utf8 filenames in Windows; fix warnings and platform ifdefs - 2.19 (2018-02-11) fix warning - 2.18 (2018-01-30) fix warnings - 2.17 (2018-01-29) bugfix, 1-bit BMP, 16-bitness query, fix warnings - 2.16 (2017-07-23) all functions have 16-bit variants; optimizations; bugfixes - 2.15 (2017-03-18) fix png-1,2,4; all Imagenet JPGs; no runtime SSE detection on GCC - 2.14 (2017-03-03) remove deprecated STBI_JPEG_OLD; fixes for Imagenet JPGs - 2.13 (2016-12-04) experimental 16-bit API, only for PNG so far; fixes - 2.12 (2016-04-02) fix typo in 2.11 PSD fix that caused crashes - 2.11 (2016-04-02) 16-bit PNGS; enable SSE2 in non-gcc x64 + 2.27 (2021-07-11) document stbi_info better, 16-bit PNM support, bug +fixes 2.26 (2020-07-13) many minor fixes 2.25 (2020-02-02) fix warnings 2.24 +(2020-02-02) fix warnings; thread-local failure_reason and flip_vertically 2.23 +(2019-08-11) fix clang static analysis warning 2.22 (2019-03-04) gif fixes, fix +warnings 2.21 (2019-02-25) fix typo in comment 2.20 (2019-02-07) support utf8 +filenames in Windows; fix warnings and platform ifdefs 2.19 (2018-02-11) fix +warning 2.18 (2018-01-30) fix warnings 2.17 (2018-01-29) bugfix, 1-bit BMP, +16-bitness query, fix warnings 2.16 (2017-07-23) all functions have 16-bit +variants; optimizations; bugfixes 2.15 (2017-03-18) fix png-1,2,4; all Imagenet +JPGs; no runtime SSE detection on GCC 2.14 (2017-03-03) remove deprecated +STBI_JPEG_OLD; fixes for Imagenet JPGs 2.13 (2016-12-04) experimental 16-bit +API, only for PNG so far; fixes 2.12 (2016-04-02) fix typo in 2.11 PSD fix that +caused crashes 2.11 (2016-04-02) 16-bit PNGS; enable SSE2 in non-gcc x64 RGB-format JPEG; remove white matting in PSD; allocate large structures on the stack; correct channel count for PNG & BMP @@ -88,40 +88,39 @@ RECENT REVISION HISTORY: github:urraka (animated gif) Junggon Kim (PNM comments) Christopher Forseth (animated gif) Daniel Gibson (16-bit TGA) socks-the-fox (16-bit PNG) - Jeremy Sawicki (handle all ImageNet JPGs) - Optimizations & bugfixes Mikhail Morozov (1-bit BMP) + Jeremy Sawicki (handle all ImageNet +JPGs) Optimizations & bugfixes Mikhail Morozov (1-bit BMP) Fabian "ryg" Giesen Anael Seghezzi (is-16-bit query) Arseny Kapoulkine Simon Breuss (16-bit PNM) John-Mark Allen Carmelo J Fdez-Aguera Bug & warning fixes - Marc LeBlanc David Woo Guillaume George Martins Mozeiko - Christpher Lloyd Jerry Jansson Joseph Thomson Blazej Dariusz Roszkowski - Phil Jordan Dave Moore Roy Eltham - Hayaki Saito Nathan Reed Won Chun - Luke Graham Johan Duparc Nick Verigakis the Horde3D community - Thomas Ruf Ronny Chevalier github:rlyeh - Janez Zemva John Bartholomew Michal Cichon github:romigrou - Jonathan Blow Ken Hamada Tero Hanninen github:svdijk - Eugene Golushkov Laurent Gomila Cort Stratton github:snagar - Aruelien Pocheville Sergio Gonzalez Thibault Reuille github:Zelex - Cass Everitt Ryamond Barbiero github:grim210 - Paul Du Bois Engin Manap Aldo Culquicondor github:sammyhw - Philipp Wiesemann Dale Weiler Oriol Ferrer Mesia github:phprus - Josh Tobin Neil Bickford Matthew Gregan github:poppolopoppo - Julian Raschke Gregory Mullen Christian Floisand github:darealshinji - Baldur Karlsson Kevin Schmidt JR Smith github:Michaelangel007 - Brad Weinberger Matvey Cherevko github:mosra - Luca Sas Alexander Veselov Zack Middleton [reserved] - Ryan C. Gordon [reserved] [reserved] - DO NOT ADD YOUR NAME HERE + Marc LeBlanc David Woo Guillaume George Martins +Mozeiko Christpher Lloyd Jerry Jansson Joseph Thomson Blazej +Dariusz Roszkowski Phil Jordan Dave Moore Roy +Eltham Hayaki Saito Nathan Reed Won Chun Luke Graham Johan +Duparc Nick Verigakis the Horde3D community Thomas Ruf Ronny +Chevalier github:rlyeh Janez Zemva John +Bartholomew Michal Cichon github:romigrou Jonathan Blow Ken +Hamada Tero Hanninen github:svdijk Eugene Golushkov Laurent +Gomila Cort Stratton github:snagar Aruelien Pocheville Sergio +Gonzalez Thibault Reuille github:Zelex Cass Everitt Ryamond +Barbiero github:grim210 Paul Du Bois Engin +Manap Aldo Culquicondor github:sammyhw Philipp Wiesemann Dale +Weiler Oriol Ferrer Mesia github:phprus Josh Tobin Neil +Bickford Matthew Gregan github:poppolopoppo Julian Raschke Gregory +Mullen Christian Floisand github:darealshinji Baldur Karlsson Kevin +Schmidt JR Smith github:Michaelangel007 Brad Weinberger Matvey +Cherevko github:mosra Luca Sas Alexander Veselov Zack +Middleton [reserved] Ryan C. Gordon [reserved] [reserved] DO NOT +ADD YOUR NAME HERE Jacko Dirks - To add your name to the credits, pick a random blank space in the middle and fill it. - 80% of merge conflicts on stb PRs are due to people adding their name at the end - of the credits. + To add your name to the credits, pick a random blank space in the middle and +fill it. 80% of merge conflicts on stb PRs are due to people adding their name +at the end of the credits. */ #ifndef STBI_INCLUDE_STB_IMAGE_H @@ -140,14 +139,15 @@ RECENT REVISION HISTORY: // // ... process data if not NULL ... // // ... x = width, y = height, n = # 8-bit components per pixel ... // // ... replace '0' with '1'..'4' to force that many components per pixel -// // ... but 'n' will always be the number that it would have been if you said 0 -// stbi_image_free(data); +// // ... but 'n' will always be the number that it would have been if you +// said 0 stbi_image_free(data); // // Standard parameters: // int *x -- outputs image width in pixels // int *y -- outputs image height in pixels // int *channels_in_file -- outputs # of image components in image file -// int desired_channels -- if non-zero, # of image components requested in result +// int desired_channels -- if non-zero, # of image components requested in +// result // // The return value from an image loader is an 'unsigned char *' which points // to the pixel data, or NULL on an allocation failure or if the image is @@ -175,8 +175,8 @@ RECENT REVISION HISTORY: // and *x, *y, *channels_in_file will be unchanged. The function // stbi_failure_reason() can be queried for an extremely brief, end-user // unfriendly explanation of why the load failed. Define STBI_NO_FAILURE_STRINGS -// to avoid compiling these strings at all, and STBI_FAILURE_USERMSG to get slightly -// more user-friendly ones. +// to avoid compiling these strings at all, and STBI_FAILURE_USERMSG to get +// slightly more user-friendly ones. // // Paletted PNG, BMP, GIF, and PIC images are automatically depalettized. // @@ -226,11 +226,12 @@ RECENT REVISION HISTORY: // 2. easy to maintain // 3. good performance // -// Sometimes I let "good performance" creep up in priority over "easy to maintain", -// and for best performance I may provide less-easy-to-use APIs that give higher -// performance, in addition to the easy-to-use ones. Nevertheless, it's important -// to keep in mind that from the standpoint of you, a client of this library, -// all you care about is #1 and #3, and stb libraries DO NOT emphasize #3 above all. +// Sometimes I let "good performance" creep up in priority over "easy to +// maintain", and for best performance I may provide less-easy-to-use APIs that +// give higher performance, in addition to the easy-to-use ones. Nevertheless, +// it's important to keep in mind that from the standpoint of you, a client of +// this library, all you care about is #1 and #3, and stb libraries DO NOT +// emphasize #3 above all. // // Some secondary priorities arise directly from the first two, some of which // provide more explicit reasons why performance can't be emphasized. @@ -249,7 +250,8 @@ RECENT REVISION HISTORY: // overhead. // // The three functions you must define are "read" (reads some bytes of data), -// "skip" (skips some bytes of data), "eof" (reports if the stream is at the end). +// "skip" (skips some bytes of data), "eof" (reports if the stream is at the +// end). // // =========================================================================== // @@ -277,10 +279,11 @@ RECENT REVISION HISTORY: // HDR image support (disable by defining STBI_NO_HDR) // // stb_image supports loading HDR images in general, and currently the Radiance -// .HDR file format specifically. You can still load any file through the existing -// interface; if you attempt to load an HDR file, it will be automatically remapped -// to LDR, assuming gamma 2.2 and an arbitrary scale factor defaulting to 1; -// both of these constants can be reconfigured through this interface: +// .HDR file format specifically. You can still load any file through the +// existing interface; if you attempt to load an HDR file, it will be +// automatically remapped to LDR, assuming gamma 2.2 and an arbitrary scale +// factor defaulting to 1; both of these constants can be reconfigured through +// this interface: // // stbi_hdr_to_ldr_gamma(2.2f); // stbi_hdr_to_ldr_scale(1.0f); @@ -371,14 +374,13 @@ RECENT REVISION HISTORY: #define STBI_VERSION 1 -enum -{ - STBI_default = 0, // only used for desired_channels +enum { + STBI_default = 0, // only used for desired_channels - STBI_grey = 1, - STBI_grey_alpha = 2, - STBI_rgb = 3, - STBI_rgb_alpha = 4 + STBI_grey = 1, + STBI_grey_alpha = 2, + STBI_rgb = 3, + STBI_rgb_alpha = 4 }; #include @@ -406,11 +408,13 @@ extern "C" { // load image by filename, open file, or memory buffer // -typedef struct -{ - int (*read) (void *user,char *data,int size); // fill 'data' with 'size' bytes. return number of bytes actually read - void (*skip) (void *user,int n); // skip the next 'n' bytes, or 'unget' the last -n bytes if negative - int (*eof) (void *user); // returns nonzero if we are at end of file/data +typedef struct { + int (*read)(void* user, char* data, + int size); // fill 'data' with 'size' bytes. return number of + // bytes actually read + void (*skip)(void* user, int n); // skip the next 'n' bytes, or 'unget' the + // last -n bytes if negative + int (*eof)(void* user); // returns nonzero if we are at end of file/data } stbi_io_callbacks; //////////////////////////////////// @@ -418,21 +422,33 @@ typedef struct // 8-bits-per-channel interface // -STBIDEF stbi_uc *stbi_load_from_memory (stbi_uc const *buffer, int len , int *x, int *y, int *channels_in_file, int desired_channels); -STBIDEF stbi_uc *stbi_load_from_callbacks(stbi_io_callbacks const *clbk , void *user, int *x, int *y, int *channels_in_file, int desired_channels); +STBIDEF stbi_uc* stbi_load_from_memory(stbi_uc const* buffer, int len, int* x, + int* y, int* channels_in_file, + int desired_channels); +STBIDEF stbi_uc* stbi_load_from_callbacks(stbi_io_callbacks const* clbk, + void* user, int* x, int* y, + int* channels_in_file, + int desired_channels); #ifndef STBI_NO_STDIO -STBIDEF stbi_uc *stbi_load (char const *filename, int *x, int *y, int *channels_in_file, int desired_channels); -STBIDEF stbi_uc *stbi_load_from_file (FILE *f, int *x, int *y, int *channels_in_file, int desired_channels); -// for stbi_load_from_file, file pointer is left pointing immediately after image +STBIDEF stbi_uc* stbi_load(char const* filename, int* x, int* y, + int* channels_in_file, int desired_channels); +STBIDEF stbi_uc* stbi_load_from_file(FILE* f, int* x, int* y, + int* channels_in_file, + int desired_channels); +// for stbi_load_from_file, file pointer is left pointing immediately after +// image #endif #ifndef STBI_NO_GIF -STBIDEF stbi_uc *stbi_load_gif_from_memory(stbi_uc const *buffer, int len, int **delays, int *x, int *y, int *z, int *comp, int req_comp); +STBIDEF stbi_uc* stbi_load_gif_from_memory(stbi_uc const* buffer, int len, + int** delays, int* x, int* y, int* z, + int* comp, int req_comp); #endif #ifdef STBI_WINDOWS_UTF8 -STBIDEF int stbi_convert_wchar_to_utf8(char *buffer, size_t bufferlen, const wchar_t* input); +STBIDEF int stbi_convert_wchar_to_utf8(char* buffer, size_t bufferlen, + const wchar_t* input); #endif //////////////////////////////////// @@ -440,12 +456,20 @@ STBIDEF int stbi_convert_wchar_to_utf8(char *buffer, size_t bufferlen, const wch // 16-bits-per-channel interface // -STBIDEF stbi_us *stbi_load_16_from_memory (stbi_uc const *buffer, int len, int *x, int *y, int *channels_in_file, int desired_channels); -STBIDEF stbi_us *stbi_load_16_from_callbacks(stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *channels_in_file, int desired_channels); +STBIDEF stbi_us* stbi_load_16_from_memory(stbi_uc const* buffer, int len, + int* x, int* y, int* channels_in_file, + int desired_channels); +STBIDEF stbi_us* stbi_load_16_from_callbacks(stbi_io_callbacks const* clbk, + void* user, int* x, int* y, + int* channels_in_file, + int desired_channels); #ifndef STBI_NO_STDIO -STBIDEF stbi_us *stbi_load_16 (char const *filename, int *x, int *y, int *channels_in_file, int desired_channels); -STBIDEF stbi_us *stbi_load_from_file_16(FILE *f, int *x, int *y, int *channels_in_file, int desired_channels); +STBIDEF stbi_us* stbi_load_16(char const* filename, int* x, int* y, + int* channels_in_file, int desired_channels); +STBIDEF stbi_us* stbi_load_from_file_16(FILE* f, int* x, int* y, + int* channels_in_file, + int desired_channels); #endif //////////////////////////////////// @@ -453,85 +477,106 @@ STBIDEF stbi_us *stbi_load_from_file_16(FILE *f, int *x, int *y, int *channels_i // float-per-channel interface // #ifndef STBI_NO_LINEAR - STBIDEF float *stbi_loadf_from_memory (stbi_uc const *buffer, int len, int *x, int *y, int *channels_in_file, int desired_channels); - STBIDEF float *stbi_loadf_from_callbacks (stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *channels_in_file, int desired_channels); +STBIDEF float* stbi_loadf_from_memory(stbi_uc const* buffer, int len, int* x, + int* y, int* channels_in_file, + int desired_channels); +STBIDEF float* stbi_loadf_from_callbacks(stbi_io_callbacks const* clbk, + void* user, int* x, int* y, + int* channels_in_file, + int desired_channels); - #ifndef STBI_NO_STDIO - STBIDEF float *stbi_loadf (char const *filename, int *x, int *y, int *channels_in_file, int desired_channels); - STBIDEF float *stbi_loadf_from_file (FILE *f, int *x, int *y, int *channels_in_file, int desired_channels); - #endif +#ifndef STBI_NO_STDIO +STBIDEF float* stbi_loadf(char const* filename, int* x, int* y, + int* channels_in_file, int desired_channels); +STBIDEF float* stbi_loadf_from_file(FILE* f, int* x, int* y, + int* channels_in_file, + int desired_channels); +#endif #endif #ifndef STBI_NO_HDR - STBIDEF void stbi_hdr_to_ldr_gamma(float gamma); - STBIDEF void stbi_hdr_to_ldr_scale(float scale); +STBIDEF void stbi_hdr_to_ldr_gamma(float gamma); +STBIDEF void stbi_hdr_to_ldr_scale(float scale); #endif // STBI_NO_HDR #ifndef STBI_NO_LINEAR - STBIDEF void stbi_ldr_to_hdr_gamma(float gamma); - STBIDEF void stbi_ldr_to_hdr_scale(float scale); +STBIDEF void stbi_ldr_to_hdr_gamma(float gamma); +STBIDEF void stbi_ldr_to_hdr_scale(float scale); #endif // STBI_NO_LINEAR // stbi_is_hdr is always defined, but always returns false if STBI_NO_HDR -STBIDEF int stbi_is_hdr_from_callbacks(stbi_io_callbacks const *clbk, void *user); -STBIDEF int stbi_is_hdr_from_memory(stbi_uc const *buffer, int len); +STBIDEF int stbi_is_hdr_from_callbacks(stbi_io_callbacks const* clbk, + void* user); +STBIDEF int stbi_is_hdr_from_memory(stbi_uc const* buffer, int len); #ifndef STBI_NO_STDIO -STBIDEF int stbi_is_hdr (char const *filename); -STBIDEF int stbi_is_hdr_from_file(FILE *f); +STBIDEF int stbi_is_hdr(char const* filename); +STBIDEF int stbi_is_hdr_from_file(FILE* f); #endif // STBI_NO_STDIO - // get a VERY brief reason for failure // on most compilers (and ALL modern mainstream compilers) this is threadsafe -STBIDEF const char *stbi_failure_reason (void); +STBIDEF const char* stbi_failure_reason(void); // free the loaded image -- this is just free() -STBIDEF void stbi_image_free (void *retval_from_stbi_load); +STBIDEF void stbi_image_free(void* retval_from_stbi_load); // get image dimensions & components without fully decoding -STBIDEF int stbi_info_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp); -STBIDEF int stbi_info_from_callbacks(stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp); -STBIDEF int stbi_is_16_bit_from_memory(stbi_uc const *buffer, int len); -STBIDEF int stbi_is_16_bit_from_callbacks(stbi_io_callbacks const *clbk, void *user); +STBIDEF int stbi_info_from_memory(stbi_uc const* buffer, int len, int* x, + int* y, int* comp); +STBIDEF int stbi_info_from_callbacks(stbi_io_callbacks const* clbk, void* user, + int* x, int* y, int* comp); +STBIDEF int stbi_is_16_bit_from_memory(stbi_uc const* buffer, int len); +STBIDEF int stbi_is_16_bit_from_callbacks(stbi_io_callbacks const* clbk, + void* user); #ifndef STBI_NO_STDIO -STBIDEF int stbi_info (char const *filename, int *x, int *y, int *comp); -STBIDEF int stbi_info_from_file (FILE *f, int *x, int *y, int *comp); -STBIDEF int stbi_is_16_bit (char const *filename); -STBIDEF int stbi_is_16_bit_from_file(FILE *f); +STBIDEF int stbi_info(char const* filename, int* x, int* y, int* comp); +STBIDEF int stbi_info_from_file(FILE* f, int* x, int* y, int* comp); +STBIDEF int stbi_is_16_bit(char const* filename); +STBIDEF int stbi_is_16_bit_from_file(FILE* f); #endif - - // for image formats that explicitly notate that they have premultiplied alpha, // we just return the colors as stored in the file. set this flag to force // unpremultiplication. results are undefined if the unpremultiply overflow. -STBIDEF void stbi_set_unpremultiply_on_load(int flag_true_if_should_unpremultiply); +STBIDEF void +stbi_set_unpremultiply_on_load(int flag_true_if_should_unpremultiply); // indicate whether we should process iphone images back to canonical format, // or just pass them through "as-is" STBIDEF void stbi_convert_iphone_png_to_rgb(int flag_true_if_should_convert); -// flip the image vertically, so the first pixel in the output array is the bottom left +// flip the image vertically, so the first pixel in the output array is the +// bottom left STBIDEF void stbi_set_flip_vertically_on_load(int flag_true_if_should_flip); -// as above, but only applies to images loaded on the thread that calls the function -// this function is only available if your compiler supports thread-local variables; -// calling it will fail to link if your compiler doesn't -STBIDEF void stbi_set_unpremultiply_on_load_thread(int flag_true_if_should_unpremultiply); -STBIDEF void stbi_convert_iphone_png_to_rgb_thread(int flag_true_if_should_convert); -STBIDEF void stbi_set_flip_vertically_on_load_thread(int flag_true_if_should_flip); +// as above, but only applies to images loaded on the thread that calls the +// function this function is only available if your compiler supports +// thread-local variables; calling it will fail to link if your compiler doesn't +STBIDEF void +stbi_set_unpremultiply_on_load_thread(int flag_true_if_should_unpremultiply); +STBIDEF void +stbi_convert_iphone_png_to_rgb_thread(int flag_true_if_should_convert); +STBIDEF void +stbi_set_flip_vertically_on_load_thread(int flag_true_if_should_flip); // ZLIB client - used by PNG, available for other purposes -STBIDEF char *stbi_zlib_decode_malloc_guesssize(const char *buffer, int len, int initial_size, int *outlen); -STBIDEF char *stbi_zlib_decode_malloc_guesssize_headerflag(const char *buffer, int len, int initial_size, int *outlen, int parse_header); -STBIDEF char *stbi_zlib_decode_malloc(const char *buffer, int len, int *outlen); -STBIDEF int stbi_zlib_decode_buffer(char *obuffer, int olen, const char *ibuffer, int ilen); - -STBIDEF char *stbi_zlib_decode_noheader_malloc(const char *buffer, int len, int *outlen); -STBIDEF int stbi_zlib_decode_noheader_buffer(char *obuffer, int olen, const char *ibuffer, int ilen); +STBIDEF char* stbi_zlib_decode_malloc_guesssize(const char* buffer, int len, + int initial_size, int* outlen); +STBIDEF char* stbi_zlib_decode_malloc_guesssize_headerflag(const char* buffer, + int len, + int initial_size, + int* outlen, + int parse_header); +STBIDEF char* stbi_zlib_decode_malloc(const char* buffer, int len, int* outlen); +STBIDEF int stbi_zlib_decode_buffer(char* obuffer, int olen, + const char* ibuffer, int ilen); +STBIDEF char* stbi_zlib_decode_noheader_malloc(const char* buffer, int len, + int* outlen); +STBIDEF int stbi_zlib_decode_noheader_buffer(char* obuffer, int olen, + const char* ibuffer, int ilen); #ifdef __cplusplus } @@ -544,52 +589,53 @@ STBIDEF int stbi_zlib_decode_noheader_buffer(char *obuffer, int olen, const ch #ifdef STB_IMAGE_IMPLEMENTATION -#if defined(STBI_ONLY_JPEG) || defined(STBI_ONLY_PNG) || defined(STBI_ONLY_BMP) \ - || defined(STBI_ONLY_TGA) || defined(STBI_ONLY_GIF) || defined(STBI_ONLY_PSD) \ - || defined(STBI_ONLY_HDR) || defined(STBI_ONLY_PIC) || defined(STBI_ONLY_PNM) \ - || defined(STBI_ONLY_ZLIB) - #ifndef STBI_ONLY_JPEG - #define STBI_NO_JPEG - #endif - #ifndef STBI_ONLY_PNG - #define STBI_NO_PNG - #endif - #ifndef STBI_ONLY_BMP - #define STBI_NO_BMP - #endif - #ifndef STBI_ONLY_PSD - #define STBI_NO_PSD - #endif - #ifndef STBI_ONLY_TGA - #define STBI_NO_TGA - #endif - #ifndef STBI_ONLY_GIF - #define STBI_NO_GIF - #endif - #ifndef STBI_ONLY_HDR - #define STBI_NO_HDR - #endif - #ifndef STBI_ONLY_PIC - #define STBI_NO_PIC - #endif - #ifndef STBI_ONLY_PNM - #define STBI_NO_PNM - #endif +#if defined(STBI_ONLY_JPEG) || defined(STBI_ONLY_PNG) || \ + defined(STBI_ONLY_BMP) || defined(STBI_ONLY_TGA) || \ + defined(STBI_ONLY_GIF) || defined(STBI_ONLY_PSD) || \ + defined(STBI_ONLY_HDR) || defined(STBI_ONLY_PIC) || \ + defined(STBI_ONLY_PNM) || defined(STBI_ONLY_ZLIB) +#ifndef STBI_ONLY_JPEG +#define STBI_NO_JPEG +#endif +#ifndef STBI_ONLY_PNG +#define STBI_NO_PNG +#endif +#ifndef STBI_ONLY_BMP +#define STBI_NO_BMP +#endif +#ifndef STBI_ONLY_PSD +#define STBI_NO_PSD +#endif +#ifndef STBI_ONLY_TGA +#define STBI_NO_TGA +#endif +#ifndef STBI_ONLY_GIF +#define STBI_NO_GIF +#endif +#ifndef STBI_ONLY_HDR +#define STBI_NO_HDR +#endif +#ifndef STBI_ONLY_PIC +#define STBI_NO_PIC +#endif +#ifndef STBI_ONLY_PNM +#define STBI_NO_PNM +#endif #endif -#if defined(STBI_NO_PNG) && !defined(STBI_SUPPORT_ZLIB) && !defined(STBI_NO_ZLIB) +#if defined(STBI_NO_PNG) && !defined(STBI_SUPPORT_ZLIB) && \ + !defined(STBI_NO_ZLIB) #define STBI_NO_ZLIB #endif - +#include #include #include // ptrdiff_t on osx #include #include -#include #if !defined(STBI_NO_LINEAR) || !defined(STBI_NO_HDR) -#include // ldexp, pow +#include // ldexp, pow #endif #ifndef STBI_NO_STDIO @@ -607,55 +653,55 @@ STBIDEF int stbi_zlib_decode_noheader_buffer(char *obuffer, int olen, const ch #define STBI_EXTERN extern #endif - #ifndef _MSC_VER - #ifdef __cplusplus - #define stbi_inline inline - #else - #define stbi_inline - #endif +#ifdef __cplusplus +#define stbi_inline inline #else - #define stbi_inline __forceinline +#define stbi_inline +#endif +#else +#define stbi_inline __forceinline #endif #ifndef STBI_NO_THREAD_LOCALS - #if defined(__cplusplus) && __cplusplus >= 201103L - #define STBI_THREAD_LOCAL thread_local - #elif defined(__GNUC__) && __GNUC__ < 5 - #define STBI_THREAD_LOCAL __thread - #elif defined(_MSC_VER) - #define STBI_THREAD_LOCAL __declspec(thread) - #elif defined (__STDC_VERSION__) && __STDC_VERSION__ >= 201112L && !defined(__STDC_NO_THREADS__) - #define STBI_THREAD_LOCAL _Thread_local - #endif +#if defined(__cplusplus) && __cplusplus >= 201103L +#define STBI_THREAD_LOCAL thread_local +#elif defined(__GNUC__) && __GNUC__ < 5 +#define STBI_THREAD_LOCAL __thread +#elif defined(_MSC_VER) +#define STBI_THREAD_LOCAL __declspec(thread) +#elif defined(__STDC_VERSION__) && __STDC_VERSION__ >= 201112L && \ + !defined(__STDC_NO_THREADS__) +#define STBI_THREAD_LOCAL _Thread_local +#endif - #ifndef STBI_THREAD_LOCAL - #if defined(__GNUC__) - #define STBI_THREAD_LOCAL __thread - #endif - #endif +#ifndef STBI_THREAD_LOCAL +#if defined(__GNUC__) +#define STBI_THREAD_LOCAL __thread +#endif +#endif #endif #if defined(_MSC_VER) || defined(__SYMBIAN32__) typedef unsigned short stbi__uint16; -typedef signed short stbi__int16; -typedef unsigned int stbi__uint32; -typedef signed int stbi__int32; +typedef signed short stbi__int16; +typedef unsigned int stbi__uint32; +typedef signed int stbi__int32; #else #include typedef uint16_t stbi__uint16; -typedef int16_t stbi__int16; +typedef int16_t stbi__int16; typedef uint32_t stbi__uint32; -typedef int32_t stbi__int32; +typedef int32_t stbi__int32; #endif // should produce compiler error if size is wrong -typedef unsigned char validate_uint32[sizeof(stbi__uint32)==4 ? 1 : -1]; +typedef unsigned char validate_uint32[sizeof(stbi__uint32) == 4 ? 1 : -1]; #ifdef _MSC_VER -#define STBI_NOTUSED(v) (void)(v) +#define STBI_NOTUSED(v) (void)(v) #else -#define STBI_NOTUSED(v) (void)sizeof(v) +#define STBI_NOTUSED(v) (void)sizeof(v) #endif #ifdef _MSC_VER @@ -663,27 +709,30 @@ typedef unsigned char validate_uint32[sizeof(stbi__uint32)==4 ? 1 : -1]; #endif #ifdef STBI_HAS_LROTL - #define stbi_lrot(x,y) _lrotl(x,y) +#define stbi_lrot(x, y) _lrotl(x, y) #else - #define stbi_lrot(x,y) (((x) << (y)) | ((x) >> (-(y) & 31))) +#define stbi_lrot(x, y) (((x) << (y)) | ((x) >> (-(y) & 31))) #endif -#if defined(STBI_MALLOC) && defined(STBI_FREE) && (defined(STBI_REALLOC) || defined(STBI_REALLOC_SIZED)) +#if defined(STBI_MALLOC) && defined(STBI_FREE) && \ + (defined(STBI_REALLOC) || defined(STBI_REALLOC_SIZED)) // ok -#elif !defined(STBI_MALLOC) && !defined(STBI_FREE) && !defined(STBI_REALLOC) && !defined(STBI_REALLOC_SIZED) +#elif !defined(STBI_MALLOC) && !defined(STBI_FREE) && \ + !defined(STBI_REALLOC) && !defined(STBI_REALLOC_SIZED) // ok #else -#error "Must define all or none of STBI_MALLOC, STBI_FREE, and STBI_REALLOC (or STBI_REALLOC_SIZED)." +#error \ + "Must define all or none of STBI_MALLOC, STBI_FREE, and STBI_REALLOC (or STBI_REALLOC_SIZED)." #endif #ifndef STBI_MALLOC -#define STBI_MALLOC(sz) malloc(sz) -#define STBI_REALLOC(p,newsz) realloc(p,newsz) -#define STBI_FREE(p) free(p) +#define STBI_MALLOC(sz) malloc(sz) +#define STBI_REALLOC(p, newsz) realloc(p, newsz) +#define STBI_FREE(p) free(p) #endif #ifndef STBI_REALLOC_SIZED -#define STBI_REALLOC_SIZED(p,oldsz,newsz) STBI_REALLOC(p,newsz) +#define STBI_REALLOC_SIZED(p, oldsz, newsz) STBI_REALLOC(p, newsz) #endif // x86/x64 detection @@ -693,7 +742,8 @@ typedef unsigned char validate_uint32[sizeof(stbi__uint32)==4 ? 1 : -1]; #define STBI__X86_TARGET #endif -#if defined(__GNUC__) && defined(STBI__X86_TARGET) && !defined(__SSE2__) && !defined(STBI_NO_SIMD) +#if defined(__GNUC__) && defined(STBI__X86_TARGET) && !defined(__SSE2__) && \ + !defined(STBI_NO_SIMD) // gcc doesn't support sse2 intrinsics unless you compile with -msse2, // which in turn means it gets to use SSE2 everywhere. This is unfortunate, // but previous attempts to provide the SSE2 functions with runtime @@ -704,8 +754,10 @@ typedef unsigned char validate_uint32[sizeof(stbi__uint32)==4 ? 1 : -1]; #define STBI_NO_SIMD #endif -#if defined(__MINGW32__) && defined(STBI__X86_TARGET) && !defined(STBI_MINGW_ENABLE_SSE2) && !defined(STBI_NO_SIMD) -// Note that __MINGW32__ doesn't actually mean 32-bit, so we have to avoid STBI__X64_TARGET +#if defined(__MINGW32__) && defined(STBI__X86_TARGET) && \ + !defined(STBI_MINGW_ENABLE_SSE2) && !defined(STBI_NO_SIMD) +// Note that __MINGW32__ doesn't actually mean 32-bit, so we have to avoid +// STBI__X64_TARGET // // 32-bit MinGW wants ESP to be 16-byte aligned, but this is not in the // Windows ABI and VC++ as well as Windows DLLs don't maintain that invariant. @@ -715,44 +767,43 @@ typedef unsigned char validate_uint32[sizeof(stbi__uint32)==4 ? 1 : -1]; // See https://github.com/nothings/stb/issues/81 for more information. // // So default to no SSE2 on 32-bit MinGW. If you've read this far and added -// -mstackrealign to your build settings, feel free to #define STBI_MINGW_ENABLE_SSE2. +// -mstackrealign to your build settings, feel free to #define +// STBI_MINGW_ENABLE_SSE2. #define STBI_NO_SIMD #endif -#if !defined(STBI_NO_SIMD) && (defined(STBI__X86_TARGET) || defined(STBI__X64_TARGET)) +#if !defined(STBI_NO_SIMD) && \ + (defined(STBI__X86_TARGET) || defined(STBI__X64_TARGET)) #define STBI_SSE2 #include #ifdef _MSC_VER -#if _MSC_VER >= 1400 // not VC6 -#include // __cpuid -static int stbi__cpuid3(void) -{ - int info[4]; - __cpuid(info,1); - return info[3]; +#if _MSC_VER >= 1400 // not VC6 +#include // __cpuid +static int stbi__cpuid3(void) { + int info[4]; + __cpuid(info, 1); + return info[3]; } #else -static int stbi__cpuid3(void) -{ - int res; - __asm { +static int stbi__cpuid3(void) { + int res; + __asm { mov eax,1 cpuid mov res,edx - } - return res; + } + return res; } #endif #define STBI_SIMD_ALIGN(type, name) __declspec(align(16)) type name #if !defined(STBI_NO_JPEG) && defined(STBI_SSE2) -static int stbi__sse2_available(void) -{ - int info3 = stbi__cpuid3(); - return ((info3 >> 26) & 1) != 0; +static int stbi__sse2_available(void) { + int info3 = stbi__cpuid3(); + return ((info3 >> 26) & 1) != 0; } #endif @@ -760,12 +811,11 @@ static int stbi__sse2_available(void) #define STBI_SIMD_ALIGN(type, name) type name __attribute__((aligned(16))) #if !defined(STBI_NO_JPEG) && defined(STBI_SSE2) -static int stbi__sse2_available(void) -{ - // If we're even attempting to compile this on GCC/Clang, that means - // -msse2 is on, which means the compiler is allowed to use SSE2 - // instructions at will, and so are we. - return 1; +static int stbi__sse2_available(void) { + // If we're even attempting to compile this on GCC/Clang, that means + // -msse2 is on, which means the compiler is allowed to use SSE2 + // instructions at will, and so are we. + return 1; } #endif @@ -800,190 +850,180 @@ static int stbi__sse2_available(void) // stbi__context structure is our basic context used by all images, so it // contains all the IO context, plus some basic image information -typedef struct -{ - stbi__uint32 img_x, img_y; - int img_n, img_out_n; +typedef struct { + stbi__uint32 img_x, img_y; + int img_n, img_out_n; - stbi_io_callbacks io; - void *io_user_data; + stbi_io_callbacks io; + void* io_user_data; - int read_from_callbacks; - int buflen; - stbi_uc buffer_start[128]; - int callback_already_read; + int read_from_callbacks; + int buflen; + stbi_uc buffer_start[128]; + int callback_already_read; - stbi_uc *img_buffer, *img_buffer_end; - stbi_uc *img_buffer_original, *img_buffer_original_end; + stbi_uc *img_buffer, *img_buffer_end; + stbi_uc *img_buffer_original, *img_buffer_original_end; } stbi__context; - -static void stbi__refill_buffer(stbi__context *s); +static void stbi__refill_buffer(stbi__context* s); // initialize a memory-decode context -static void stbi__start_mem(stbi__context *s, stbi_uc const *buffer, int len) -{ - s->io.read = NULL; - s->read_from_callbacks = 0; - s->callback_already_read = 0; - s->img_buffer = s->img_buffer_original = (stbi_uc *) buffer; - s->img_buffer_end = s->img_buffer_original_end = (stbi_uc *) buffer+len; +static void stbi__start_mem(stbi__context* s, stbi_uc const* buffer, int len) { + s->io.read = NULL; + s->read_from_callbacks = 0; + s->callback_already_read = 0; + s->img_buffer = s->img_buffer_original = (stbi_uc*)buffer; + s->img_buffer_end = s->img_buffer_original_end = (stbi_uc*)buffer + len; } // initialize a callback-based context -static void stbi__start_callbacks(stbi__context *s, stbi_io_callbacks *c, void *user) -{ - s->io = *c; - s->io_user_data = user; - s->buflen = sizeof(s->buffer_start); - s->read_from_callbacks = 1; - s->callback_already_read = 0; - s->img_buffer = s->img_buffer_original = s->buffer_start; - stbi__refill_buffer(s); - s->img_buffer_original_end = s->img_buffer_end; +static void stbi__start_callbacks(stbi__context* s, stbi_io_callbacks* c, + void* user) { + s->io = *c; + s->io_user_data = user; + s->buflen = sizeof(s->buffer_start); + s->read_from_callbacks = 1; + s->callback_already_read = 0; + s->img_buffer = s->img_buffer_original = s->buffer_start; + stbi__refill_buffer(s); + s->img_buffer_original_end = s->img_buffer_end; } #ifndef STBI_NO_STDIO -static int stbi__stdio_read(void *user, char *data, int size) -{ - return (int) fread(data,1,size,(FILE*) user); +static int stbi__stdio_read(void* user, char* data, int size) { + return (int)fread(data, 1, size, (FILE*)user); } -static void stbi__stdio_skip(void *user, int n) -{ - int ch; - fseek((FILE*) user, n, SEEK_CUR); - ch = fgetc((FILE*) user); /* have to read a byte to reset feof()'s flag */ - if (ch != EOF) { - ungetc(ch, (FILE *) user); /* push byte back onto stream if valid. */ - } +static void stbi__stdio_skip(void* user, int n) { + int ch; + fseek((FILE*)user, n, SEEK_CUR); + ch = fgetc((FILE*)user); /* have to read a byte to reset feof()'s flag */ + if (ch != EOF) { + ungetc(ch, (FILE*)user); /* push byte back onto stream if valid. */ + } } -static int stbi__stdio_eof(void *user) -{ - return feof((FILE*) user) || ferror((FILE *) user); +static int stbi__stdio_eof(void* user) { + return feof((FILE*)user) || ferror((FILE*)user); } -static stbi_io_callbacks stbi__stdio_callbacks = -{ - stbi__stdio_read, - stbi__stdio_skip, - stbi__stdio_eof, +static stbi_io_callbacks stbi__stdio_callbacks = { + stbi__stdio_read, + stbi__stdio_skip, + stbi__stdio_eof, }; -static void stbi__start_file(stbi__context *s, FILE *f) -{ - stbi__start_callbacks(s, &stbi__stdio_callbacks, (void *) f); +static void stbi__start_file(stbi__context* s, FILE* f) { + stbi__start_callbacks(s, &stbi__stdio_callbacks, (void*)f); } -//static void stop_file(stbi__context *s) { } +// static void stop_file(stbi__context *s) { } #endif // !STBI_NO_STDIO -static void stbi__rewind(stbi__context *s) -{ - // conceptually rewind SHOULD rewind to the beginning of the stream, - // but we just rewind to the beginning of the initial buffer, because - // we only use it after doing 'test', which only ever looks at at most 92 bytes - s->img_buffer = s->img_buffer_original; - s->img_buffer_end = s->img_buffer_original_end; +static void stbi__rewind(stbi__context* s) { + // conceptually rewind SHOULD rewind to the beginning of the stream, + // but we just rewind to the beginning of the initial buffer, because + // we only use it after doing 'test', which only ever looks at at most 92 + // bytes + s->img_buffer = s->img_buffer_original; + s->img_buffer_end = s->img_buffer_original_end; } -enum -{ - STBI_ORDER_RGB, - STBI_ORDER_BGR -}; +enum { STBI_ORDER_RGB, STBI_ORDER_BGR }; -typedef struct -{ - int bits_per_channel; - int num_channels; - int channel_order; +typedef struct { + int bits_per_channel; + int num_channels; + int channel_order; } stbi__result_info; #ifndef STBI_NO_JPEG -static int stbi__jpeg_test(stbi__context *s); -static void *stbi__jpeg_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri); -static int stbi__jpeg_info(stbi__context *s, int *x, int *y, int *comp); +static int stbi__jpeg_test(stbi__context* s); +static void* stbi__jpeg_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri); +static int stbi__jpeg_info(stbi__context* s, int* x, int* y, int* comp); #endif #ifndef STBI_NO_PNG -static int stbi__png_test(stbi__context *s); -static void *stbi__png_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri); -static int stbi__png_info(stbi__context *s, int *x, int *y, int *comp); -static int stbi__png_is16(stbi__context *s); +static int stbi__png_test(stbi__context* s); +static void* stbi__png_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri); +static int stbi__png_info(stbi__context* s, int* x, int* y, int* comp); +static int stbi__png_is16(stbi__context* s); #endif #ifndef STBI_NO_BMP -static int stbi__bmp_test(stbi__context *s); -static void *stbi__bmp_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri); -static int stbi__bmp_info(stbi__context *s, int *x, int *y, int *comp); +static int stbi__bmp_test(stbi__context* s); +static void* stbi__bmp_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri); +static int stbi__bmp_info(stbi__context* s, int* x, int* y, int* comp); #endif #ifndef STBI_NO_TGA -static int stbi__tga_test(stbi__context *s); -static void *stbi__tga_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri); -static int stbi__tga_info(stbi__context *s, int *x, int *y, int *comp); +static int stbi__tga_test(stbi__context* s); +static void* stbi__tga_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri); +static int stbi__tga_info(stbi__context* s, int* x, int* y, int* comp); #endif #ifndef STBI_NO_PSD -static int stbi__psd_test(stbi__context *s); -static void *stbi__psd_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri, int bpc); -static int stbi__psd_info(stbi__context *s, int *x, int *y, int *comp); -static int stbi__psd_is16(stbi__context *s); +static int stbi__psd_test(stbi__context* s); +static void* stbi__psd_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri, int bpc); +static int stbi__psd_info(stbi__context* s, int* x, int* y, int* comp); +static int stbi__psd_is16(stbi__context* s); #endif #ifndef STBI_NO_HDR -static int stbi__hdr_test(stbi__context *s); -static float *stbi__hdr_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri); -static int stbi__hdr_info(stbi__context *s, int *x, int *y, int *comp); +static int stbi__hdr_test(stbi__context* s); +static float* stbi__hdr_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri); +static int stbi__hdr_info(stbi__context* s, int* x, int* y, int* comp); #endif #ifndef STBI_NO_PIC -static int stbi__pic_test(stbi__context *s); -static void *stbi__pic_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri); -static int stbi__pic_info(stbi__context *s, int *x, int *y, int *comp); +static int stbi__pic_test(stbi__context* s); +static void* stbi__pic_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri); +static int stbi__pic_info(stbi__context* s, int* x, int* y, int* comp); #endif #ifndef STBI_NO_GIF -static int stbi__gif_test(stbi__context *s); -static void *stbi__gif_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri); -static void *stbi__load_gif_main(stbi__context *s, int **delays, int *x, int *y, int *z, int *comp, int req_comp); -static int stbi__gif_info(stbi__context *s, int *x, int *y, int *comp); +static int stbi__gif_test(stbi__context* s); +static void* stbi__gif_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri); +static void* stbi__load_gif_main(stbi__context* s, int** delays, int* x, int* y, + int* z, int* comp, int req_comp); +static int stbi__gif_info(stbi__context* s, int* x, int* y, int* comp); #endif #ifndef STBI_NO_PNM -static int stbi__pnm_test(stbi__context *s); -static void *stbi__pnm_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri); -static int stbi__pnm_info(stbi__context *s, int *x, int *y, int *comp); -static int stbi__pnm_is16(stbi__context *s); +static int stbi__pnm_test(stbi__context* s); +static void* stbi__pnm_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri); +static int stbi__pnm_info(stbi__context* s, int* x, int* y, int* comp); +static int stbi__pnm_is16(stbi__context* s); #endif static #ifdef STBI_THREAD_LOCAL -STBI_THREAD_LOCAL + STBI_THREAD_LOCAL #endif -const char *stbi__g_failure_reason; + const char* stbi__g_failure_reason; -STBIDEF const char *stbi_failure_reason(void) -{ - return stbi__g_failure_reason; -} +STBIDEF const char* stbi_failure_reason(void) { return stbi__g_failure_reason; } #ifndef STBI_NO_FAILURE_STRINGS -static int stbi__err(const char *str) -{ - stbi__g_failure_reason = str; - return 0; +static int stbi__err(const char* str) { + stbi__g_failure_reason = str; + return 0; } #endif -static void *stbi__malloc(size_t size) -{ - return STBI_MALLOC(size); -} +static void* stbi__malloc(size_t size) { return STBI_MALLOC(size); } // stb_image uses ints pervasively, including for offset calculations. // therefore the largest decoded image size we can support with the @@ -997,88 +1037,97 @@ static void *stbi__malloc(size_t size) // return 1 if the sum is valid, 0 on overflow. // negative terms are considered invalid. -static int stbi__addsizes_valid(int a, int b) -{ - if (b < 0) return 0; - // now 0 <= b <= INT_MAX, hence also - // 0 <= INT_MAX - b <= INTMAX. - // And "a + b <= INT_MAX" (which might overflow) is the - // same as a <= INT_MAX - b (no overflow) - return a <= INT_MAX - b; +static int stbi__addsizes_valid(int a, int b) { + if (b < 0) + return 0; + // now 0 <= b <= INT_MAX, hence also + // 0 <= INT_MAX - b <= INTMAX. + // And "a + b <= INT_MAX" (which might overflow) is the + // same as a <= INT_MAX - b (no overflow) + return a <= INT_MAX - b; } // returns 1 if the product is valid, 0 on overflow. // negative factors are considered invalid. -static int stbi__mul2sizes_valid(int a, int b) -{ - if (a < 0 || b < 0) return 0; - if (b == 0) return 1; // mul-by-0 is always safe - // portable way to check for no overflows in a*b - return a <= INT_MAX/b; +static int stbi__mul2sizes_valid(int a, int b) { + if (a < 0 || b < 0) + return 0; + if (b == 0) + return 1; // mul-by-0 is always safe + // portable way to check for no overflows in a*b + return a <= INT_MAX / b; } -#if !defined(STBI_NO_JPEG) || !defined(STBI_NO_PNG) || !defined(STBI_NO_TGA) || !defined(STBI_NO_HDR) +#if !defined(STBI_NO_JPEG) || !defined(STBI_NO_PNG) || \ + !defined(STBI_NO_TGA) || !defined(STBI_NO_HDR) // returns 1 if "a*b + add" has no negative terms/factors and doesn't overflow -static int stbi__mad2sizes_valid(int a, int b, int add) -{ - return stbi__mul2sizes_valid(a, b) && stbi__addsizes_valid(a*b, add); +static int stbi__mad2sizes_valid(int a, int b, int add) { + return stbi__mul2sizes_valid(a, b) && stbi__addsizes_valid(a * b, add); } #endif // returns 1 if "a*b*c + add" has no negative terms/factors and doesn't overflow -static int stbi__mad3sizes_valid(int a, int b, int c, int add) -{ - return stbi__mul2sizes_valid(a, b) && stbi__mul2sizes_valid(a*b, c) && - stbi__addsizes_valid(a*b*c, add); +static int stbi__mad3sizes_valid(int a, int b, int c, int add) { + return stbi__mul2sizes_valid(a, b) && stbi__mul2sizes_valid(a * b, c) && + stbi__addsizes_valid(a * b * c, add); } -// returns 1 if "a*b*c*d + add" has no negative terms/factors and doesn't overflow +// returns 1 if "a*b*c*d + add" has no negative terms/factors and doesn't +// overflow #if !defined(STBI_NO_LINEAR) || !defined(STBI_NO_HDR) || !defined(STBI_NO_PNM) -static int stbi__mad4sizes_valid(int a, int b, int c, int d, int add) -{ - return stbi__mul2sizes_valid(a, b) && stbi__mul2sizes_valid(a*b, c) && - stbi__mul2sizes_valid(a*b*c, d) && stbi__addsizes_valid(a*b*c*d, add); +static int stbi__mad4sizes_valid(int a, int b, int c, int d, int add) { + return stbi__mul2sizes_valid(a, b) && stbi__mul2sizes_valid(a * b, c) && + stbi__mul2sizes_valid(a * b * c, d) && + stbi__addsizes_valid(a * b * c * d, add); } #endif -#if !defined(STBI_NO_JPEG) || !defined(STBI_NO_PNG) || !defined(STBI_NO_TGA) || !defined(STBI_NO_HDR) +#if !defined(STBI_NO_JPEG) || !defined(STBI_NO_PNG) || \ + !defined(STBI_NO_TGA) || !defined(STBI_NO_HDR) // mallocs with size overflow checking -static void *stbi__malloc_mad2(int a, int b, int add) -{ - if (!stbi__mad2sizes_valid(a, b, add)) return NULL; - return stbi__malloc(a*b + add); +static void* stbi__malloc_mad2(int a, int b, int add) { + if (!stbi__mad2sizes_valid(a, b, add)) + return NULL; + return stbi__malloc(a * b + add); } #endif -static void *stbi__malloc_mad3(int a, int b, int c, int add) -{ - if (!stbi__mad3sizes_valid(a, b, c, add)) return NULL; - return stbi__malloc(a*b*c + add); +static void* stbi__malloc_mad3(int a, int b, int c, int add) { + if (!stbi__mad3sizes_valid(a, b, c, add)) + return NULL; + return stbi__malloc(a * b * c + add); } #if !defined(STBI_NO_LINEAR) || !defined(STBI_NO_HDR) || !defined(STBI_NO_PNM) -static void *stbi__malloc_mad4(int a, int b, int c, int d, int add) -{ - if (!stbi__mad4sizes_valid(a, b, c, d, add)) return NULL; - return stbi__malloc(a*b*c*d + add); +static void* stbi__malloc_mad4(int a, int b, int c, int d, int add) { + if (!stbi__mad4sizes_valid(a, b, c, d, add)) + return NULL; + return stbi__malloc(a * b * c * d + add); } #endif -// returns 1 if the sum of two signed ints is valid (between -2^31 and 2^31-1 inclusive), 0 on overflow. -static int stbi__addints_valid(int a, int b) -{ - if ((a >= 0) != (b >= 0)) return 1; // a and b have different signs, so no overflow - if (a < 0 && b < 0) return a >= INT_MIN - b; // same as a + b >= INT_MIN; INT_MIN - b cannot overflow since b < 0. - return a <= INT_MAX - b; +// returns 1 if the sum of two signed ints is valid (between -2^31 and 2^31-1 +// inclusive), 0 on overflow. +static int stbi__addints_valid(int a, int b) { + if ((a >= 0) != (b >= 0)) + return 1; // a and b have different signs, so no overflow + if (a < 0 && b < 0) + return a >= INT_MIN - b; // same as a + b >= INT_MIN; INT_MIN - b cannot + // overflow since b < 0. + return a <= INT_MAX - b; } -// returns 1 if the product of two signed shorts is valid, 0 on overflow. -static int stbi__mul2shorts_valid(short a, short b) -{ - if (b == 0 || b == -1) return 1; // multiplication by 0 is always 0; check for -1 so SHRT_MIN/b doesn't overflow - if ((a >= 0) == (b >= 0)) return a <= SHRT_MAX/b; // product is positive, so similar to mul2sizes_valid - if (b < 0) return a <= SHRT_MIN / b; // same as a * b >= SHRT_MIN - return a >= SHRT_MIN / b; +// returns 1 if the product of two ints fits in a signed short, 0 on overflow. +static int stbi__mul2shorts_valid(int a, int b) { + if (b == 0 || b == -1) + return 1; // multiplication by 0 is always 0; check for -1 so SHRT_MIN/b + // doesn't overflow + if ((a >= 0) == (b >= 0)) + return a <= SHRT_MAX / + b; // product is positive, so similar to mul2sizes_valid + if (b < 0) + return a <= SHRT_MIN / b; // same as a * b >= SHRT_MIN + return a >= SHRT_MIN / b; } // stbi__err - error @@ -1086,423 +1135,466 @@ static int stbi__mul2shorts_valid(short a, short b) // stbi__errpuc - error returning pointer to unsigned char #ifdef STBI_NO_FAILURE_STRINGS - #define stbi__err(x,y) 0 +#define stbi__err(x, y) 0 #elif defined(STBI_FAILURE_USERMSG) - #define stbi__err(x,y) stbi__err(y) +#define stbi__err(x, y) stbi__err(y) #else - #define stbi__err(x,y) stbi__err(x) +#define stbi__err(x, y) stbi__err(x) #endif -#define stbi__errpf(x,y) ((float *)(size_t) (stbi__err(x,y)?NULL:NULL)) -#define stbi__errpuc(x,y) ((unsigned char *)(size_t) (stbi__err(x,y)?NULL:NULL)) +#define stbi__errpf(x, y) ((float*)(size_t)(stbi__err(x, y) ? NULL : NULL)) +#define stbi__errpuc(x, y) \ + ((unsigned char*)(size_t)(stbi__err(x, y) ? NULL : NULL)) -STBIDEF void stbi_image_free(void *retval_from_stbi_load) -{ - STBI_FREE(retval_from_stbi_load); +STBIDEF void stbi_image_free(void* retval_from_stbi_load) { + STBI_FREE(retval_from_stbi_load); } #ifndef STBI_NO_LINEAR -static float *stbi__ldr_to_hdr(stbi_uc *data, int x, int y, int comp); +static float* stbi__ldr_to_hdr(stbi_uc* data, int x, int y, int comp); #endif #ifndef STBI_NO_HDR -static stbi_uc *stbi__hdr_to_ldr(float *data, int x, int y, int comp); +static stbi_uc* stbi__hdr_to_ldr(float* data, int x, int y, int comp); #endif static int stbi__vertically_flip_on_load_global = 0; -STBIDEF void stbi_set_flip_vertically_on_load(int flag_true_if_should_flip) -{ - stbi__vertically_flip_on_load_global = flag_true_if_should_flip; +STBIDEF void stbi_set_flip_vertically_on_load(int flag_true_if_should_flip) { + stbi__vertically_flip_on_load_global = flag_true_if_should_flip; } #ifndef STBI_THREAD_LOCAL -#define stbi__vertically_flip_on_load stbi__vertically_flip_on_load_global +#define stbi__vertically_flip_on_load stbi__vertically_flip_on_load_global #else -static STBI_THREAD_LOCAL int stbi__vertically_flip_on_load_local, stbi__vertically_flip_on_load_set; +static STBI_THREAD_LOCAL int stbi__vertically_flip_on_load_local, + stbi__vertically_flip_on_load_set; -STBIDEF void stbi_set_flip_vertically_on_load_thread(int flag_true_if_should_flip) -{ - stbi__vertically_flip_on_load_local = flag_true_if_should_flip; - stbi__vertically_flip_on_load_set = 1; +STBIDEF void +stbi_set_flip_vertically_on_load_thread(int flag_true_if_should_flip) { + stbi__vertically_flip_on_load_local = flag_true_if_should_flip; + stbi__vertically_flip_on_load_set = 1; } -#define stbi__vertically_flip_on_load (stbi__vertically_flip_on_load_set \ - ? stbi__vertically_flip_on_load_local \ - : stbi__vertically_flip_on_load_global) +#define stbi__vertically_flip_on_load \ + (stbi__vertically_flip_on_load_set ? stbi__vertically_flip_on_load_local \ + : stbi__vertically_flip_on_load_global) #endif // STBI_THREAD_LOCAL -static void *stbi__load_main(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri, int bpc) -{ - memset(ri, 0, sizeof(*ri)); // make sure it's initialized if we add new fields - ri->bits_per_channel = 8; // default is 8 so most paths don't have to be changed - ri->channel_order = STBI_ORDER_RGB; // all current input & output are this, but this is here so we can add BGR order - ri->num_channels = 0; +static void* stbi__load_main(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri, int bpc) { + memset(ri, 0, + sizeof(*ri)); // make sure it's initialized if we add new fields + ri->bits_per_channel = + 8; // default is 8 so most paths don't have to be changed + ri->channel_order = + STBI_ORDER_RGB; // all current input & output are this, but this is here + // so we can add BGR order + ri->num_channels = 0; - // test the formats with a very explicit header first (at least a FOURCC - // or distinctive magic number first) - #ifndef STBI_NO_PNG - if (stbi__png_test(s)) return stbi__png_load(s,x,y,comp,req_comp, ri); - #endif - #ifndef STBI_NO_BMP - if (stbi__bmp_test(s)) return stbi__bmp_load(s,x,y,comp,req_comp, ri); - #endif - #ifndef STBI_NO_GIF - if (stbi__gif_test(s)) return stbi__gif_load(s,x,y,comp,req_comp, ri); - #endif - #ifndef STBI_NO_PSD - if (stbi__psd_test(s)) return stbi__psd_load(s,x,y,comp,req_comp, ri, bpc); - #else - STBI_NOTUSED(bpc); - #endif - #ifndef STBI_NO_PIC - if (stbi__pic_test(s)) return stbi__pic_load(s,x,y,comp,req_comp, ri); - #endif +// test the formats with a very explicit header first (at least a FOURCC +// or distinctive magic number first) +#ifndef STBI_NO_PNG + if (stbi__png_test(s)) + return stbi__png_load(s, x, y, comp, req_comp, ri); +#endif +#ifndef STBI_NO_BMP + if (stbi__bmp_test(s)) + return stbi__bmp_load(s, x, y, comp, req_comp, ri); +#endif +#ifndef STBI_NO_GIF + if (stbi__gif_test(s)) + return stbi__gif_load(s, x, y, comp, req_comp, ri); +#endif +#ifndef STBI_NO_PSD + if (stbi__psd_test(s)) + return stbi__psd_load(s, x, y, comp, req_comp, ri, bpc); +#else + STBI_NOTUSED(bpc); +#endif +#ifndef STBI_NO_PIC + if (stbi__pic_test(s)) + return stbi__pic_load(s, x, y, comp, req_comp, ri); +#endif - // then the formats that can end up attempting to load with just 1 or 2 - // bytes matching expectations; these are prone to false positives, so - // try them later - #ifndef STBI_NO_JPEG - if (stbi__jpeg_test(s)) return stbi__jpeg_load(s,x,y,comp,req_comp, ri); - #endif - #ifndef STBI_NO_PNM - if (stbi__pnm_test(s)) return stbi__pnm_load(s,x,y,comp,req_comp, ri); - #endif +// then the formats that can end up attempting to load with just 1 or 2 +// bytes matching expectations; these are prone to false positives, so +// try them later +#ifndef STBI_NO_JPEG + if (stbi__jpeg_test(s)) + return stbi__jpeg_load(s, x, y, comp, req_comp, ri); +#endif +#ifndef STBI_NO_PNM + if (stbi__pnm_test(s)) + return stbi__pnm_load(s, x, y, comp, req_comp, ri); +#endif - #ifndef STBI_NO_HDR - if (stbi__hdr_test(s)) { - float *hdr = stbi__hdr_load(s, x,y,comp,req_comp, ri); - return stbi__hdr_to_ldr(hdr, *x, *y, req_comp ? req_comp : *comp); - } - #endif +#ifndef STBI_NO_HDR + if (stbi__hdr_test(s)) { + float* hdr = stbi__hdr_load(s, x, y, comp, req_comp, ri); + return stbi__hdr_to_ldr(hdr, *x, *y, req_comp ? req_comp : *comp); + } +#endif - #ifndef STBI_NO_TGA - // test tga last because it's a crappy test! - if (stbi__tga_test(s)) - return stbi__tga_load(s,x,y,comp,req_comp, ri); - #endif +#ifndef STBI_NO_TGA + // test tga last because it's a crappy test! + if (stbi__tga_test(s)) + return stbi__tga_load(s, x, y, comp, req_comp, ri); +#endif - return stbi__errpuc("unknown image type", "Image not of any known type, or corrupt"); + return stbi__errpuc("unknown image type", + "Image not of any known type, or corrupt"); } -static stbi_uc *stbi__convert_16_to_8(stbi__uint16 *orig, int w, int h, int channels) -{ - int i; - int img_len = w * h * channels; - stbi_uc *reduced; +static stbi_uc* stbi__convert_16_to_8(stbi__uint16* orig, int w, int h, + int channels) { + int i; + int img_len = w * h * channels; + stbi_uc* reduced; - reduced = (stbi_uc *) stbi__malloc(img_len); - if (reduced == NULL) return stbi__errpuc("outofmem", "Out of memory"); + reduced = (stbi_uc*)stbi__malloc(img_len); + if (reduced == NULL) + return stbi__errpuc("outofmem", "Out of memory"); - for (i = 0; i < img_len; ++i) - reduced[i] = (stbi_uc)((orig[i] >> 8) & 0xFF); // top half of each byte is sufficient approx of 16->8 bit scaling + for (i = 0; i < img_len; ++i) + reduced[i] = (stbi_uc)((orig[i] >> 8) & + 0xFF); // top half of each byte is sufficient + // approx of 16->8 bit scaling - STBI_FREE(orig); - return reduced; + STBI_FREE(orig); + return reduced; } -static stbi__uint16 *stbi__convert_8_to_16(stbi_uc *orig, int w, int h, int channels) -{ - int i; - int img_len = w * h * channels; - stbi__uint16 *enlarged; +static stbi__uint16* stbi__convert_8_to_16(stbi_uc* orig, int w, int h, + int channels) { + int i; + int img_len = w * h * channels; + stbi__uint16* enlarged; - enlarged = (stbi__uint16 *) stbi__malloc(img_len*2); - if (enlarged == NULL) return (stbi__uint16 *) stbi__errpuc("outofmem", "Out of memory"); + enlarged = (stbi__uint16*)stbi__malloc(img_len * 2); + if (enlarged == NULL) + return (stbi__uint16*)stbi__errpuc("outofmem", "Out of memory"); - for (i = 0; i < img_len; ++i) - enlarged[i] = (stbi__uint16)((orig[i] << 8) + orig[i]); // replicate to high and low byte, maps 0->0, 255->0xffff + for (i = 0; i < img_len; ++i) + enlarged[i] = (stbi__uint16)((orig[i] << 8) + + orig[i]); // replicate to high and low + // byte, maps 0->0, 255->0xffff - STBI_FREE(orig); - return enlarged; + STBI_FREE(orig); + return enlarged; } -static void stbi__vertical_flip(void *image, int w, int h, int bytes_per_pixel) -{ - int row; - size_t bytes_per_row = (size_t)w * bytes_per_pixel; - stbi_uc temp[2048]; - stbi_uc *bytes = (stbi_uc *)image; +static void stbi__vertical_flip(void* image, int w, int h, + int bytes_per_pixel) { + int row; + size_t bytes_per_row = (size_t)w * bytes_per_pixel; + stbi_uc temp[2048]; + stbi_uc* bytes = (stbi_uc*)image; - for (row = 0; row < (h>>1); row++) { - stbi_uc *row0 = bytes + row*bytes_per_row; - stbi_uc *row1 = bytes + (h - row - 1)*bytes_per_row; - // swap row0 with row1 - size_t bytes_left = bytes_per_row; - while (bytes_left) { - size_t bytes_copy = (bytes_left < sizeof(temp)) ? bytes_left : sizeof(temp); - memcpy(temp, row0, bytes_copy); - memcpy(row0, row1, bytes_copy); - memcpy(row1, temp, bytes_copy); - row0 += bytes_copy; - row1 += bytes_copy; - bytes_left -= bytes_copy; - } - } + for (row = 0; row < (h >> 1); row++) { + stbi_uc* row0 = bytes + row * bytes_per_row; + stbi_uc* row1 = bytes + (h - row - 1) * bytes_per_row; + // swap row0 with row1 + size_t bytes_left = bytes_per_row; + while (bytes_left) { + size_t bytes_copy = + (bytes_left < sizeof(temp)) ? bytes_left : sizeof(temp); + memcpy(temp, row0, bytes_copy); + memcpy(row0, row1, bytes_copy); + memcpy(row1, temp, bytes_copy); + row0 += bytes_copy; + row1 += bytes_copy; + bytes_left -= bytes_copy; + } + } } #ifndef STBI_NO_GIF -static void stbi__vertical_flip_slices(void *image, int w, int h, int z, int bytes_per_pixel) -{ - int slice; - int slice_size = w * h * bytes_per_pixel; +static void stbi__vertical_flip_slices(void* image, int w, int h, int z, + int bytes_per_pixel) { + int slice; + int slice_size = w * h * bytes_per_pixel; - stbi_uc *bytes = (stbi_uc *)image; - for (slice = 0; slice < z; ++slice) { - stbi__vertical_flip(bytes, w, h, bytes_per_pixel); - bytes += slice_size; - } + stbi_uc* bytes = (stbi_uc*)image; + for (slice = 0; slice < z; ++slice) { + stbi__vertical_flip(bytes, w, h, bytes_per_pixel); + bytes += slice_size; + } } #endif -static unsigned char *stbi__load_and_postprocess_8bit(stbi__context *s, int *x, int *y, int *comp, int req_comp) -{ - stbi__result_info ri; - void *result = stbi__load_main(s, x, y, comp, req_comp, &ri, 8); +static unsigned char* stbi__load_and_postprocess_8bit(stbi__context* s, int* x, + int* y, int* comp, + int req_comp) { + stbi__result_info ri; + void* result = stbi__load_main(s, x, y, comp, req_comp, &ri, 8); - if (result == NULL) - return NULL; + if (result == NULL) + return NULL; - // it is the responsibility of the loaders to make sure we get either 8 or 16 bit. - STBI_ASSERT(ri.bits_per_channel == 8 || ri.bits_per_channel == 16); + // it is the responsibility of the loaders to make sure we get either 8 or + // 16 bit. + STBI_ASSERT(ri.bits_per_channel == 8 || ri.bits_per_channel == 16); - if (ri.bits_per_channel != 8) { - result = stbi__convert_16_to_8((stbi__uint16 *) result, *x, *y, req_comp == 0 ? *comp : req_comp); - ri.bits_per_channel = 8; - } + if (ri.bits_per_channel != 8) { + result = stbi__convert_16_to_8((stbi__uint16*)result, *x, *y, + req_comp == 0 ? *comp : req_comp); + ri.bits_per_channel = 8; + } - // @TODO: move stbi__convert_format to here + // @TODO: move stbi__convert_format to here - if (stbi__vertically_flip_on_load) { - int channels = req_comp ? req_comp : *comp; - stbi__vertical_flip(result, *x, *y, channels * sizeof(stbi_uc)); - } + if (stbi__vertically_flip_on_load) { + int channels = req_comp ? req_comp : *comp; + stbi__vertical_flip(result, *x, *y, channels * sizeof(stbi_uc)); + } - return (unsigned char *) result; + return (unsigned char*)result; } -static stbi__uint16 *stbi__load_and_postprocess_16bit(stbi__context *s, int *x, int *y, int *comp, int req_comp) -{ - stbi__result_info ri; - void *result = stbi__load_main(s, x, y, comp, req_comp, &ri, 16); +static stbi__uint16* stbi__load_and_postprocess_16bit(stbi__context* s, int* x, + int* y, int* comp, + int req_comp) { + stbi__result_info ri; + void* result = stbi__load_main(s, x, y, comp, req_comp, &ri, 16); - if (result == NULL) - return NULL; + if (result == NULL) + return NULL; - // it is the responsibility of the loaders to make sure we get either 8 or 16 bit. - STBI_ASSERT(ri.bits_per_channel == 8 || ri.bits_per_channel == 16); + // it is the responsibility of the loaders to make sure we get either 8 or + // 16 bit. + STBI_ASSERT(ri.bits_per_channel == 8 || ri.bits_per_channel == 16); - if (ri.bits_per_channel != 16) { - result = stbi__convert_8_to_16((stbi_uc *) result, *x, *y, req_comp == 0 ? *comp : req_comp); - ri.bits_per_channel = 16; - } + if (ri.bits_per_channel != 16) { + result = stbi__convert_8_to_16((stbi_uc*)result, *x, *y, + req_comp == 0 ? *comp : req_comp); + ri.bits_per_channel = 16; + } - // @TODO: move stbi__convert_format16 to here - // @TODO: special case RGB-to-Y (and RGBA-to-YA) for 8-bit-to-16-bit case to keep more precision + // @TODO: move stbi__convert_format16 to here + // @TODO: special case RGB-to-Y (and RGBA-to-YA) for 8-bit-to-16-bit case to + // keep more precision - if (stbi__vertically_flip_on_load) { - int channels = req_comp ? req_comp : *comp; - stbi__vertical_flip(result, *x, *y, channels * sizeof(stbi__uint16)); - } + if (stbi__vertically_flip_on_load) { + int channels = req_comp ? req_comp : *comp; + stbi__vertical_flip(result, *x, *y, channels * sizeof(stbi__uint16)); + } - return (stbi__uint16 *) result; + return (stbi__uint16*)result; } #if !defined(STBI_NO_HDR) && !defined(STBI_NO_LINEAR) -static void stbi__float_postprocess(float *result, int *x, int *y, int *comp, int req_comp) -{ - if (stbi__vertically_flip_on_load && result != NULL) { - int channels = req_comp ? req_comp : *comp; - stbi__vertical_flip(result, *x, *y, channels * sizeof(float)); - } +static void stbi__float_postprocess(float* result, int* x, int* y, int* comp, + int req_comp) { + if (stbi__vertically_flip_on_load && result != NULL) { + int channels = req_comp ? req_comp : *comp; + stbi__vertical_flip(result, *x, *y, channels * sizeof(float)); + } } #endif #ifndef STBI_NO_STDIO #if defined(_WIN32) && defined(STBI_WINDOWS_UTF8) -STBI_EXTERN __declspec(dllimport) int __stdcall MultiByteToWideChar(unsigned int cp, unsigned long flags, const char *str, int cbmb, wchar_t *widestr, int cchwide); -STBI_EXTERN __declspec(dllimport) int __stdcall WideCharToMultiByte(unsigned int cp, unsigned long flags, const wchar_t *widestr, int cchwide, char *str, int cbmb, const char *defchar, int *used_default); +STBI_EXTERN __declspec(dllimport) int __stdcall MultiByteToWideChar( + unsigned int cp, unsigned long flags, const char* str, int cbmb, + wchar_t* widestr, int cchwide); +STBI_EXTERN __declspec(dllimport) int __stdcall WideCharToMultiByte( + unsigned int cp, unsigned long flags, const wchar_t* widestr, int cchwide, + char* str, int cbmb, const char* defchar, int* used_default); #endif #if defined(_WIN32) && defined(STBI_WINDOWS_UTF8) -STBIDEF int stbi_convert_wchar_to_utf8(char *buffer, size_t bufferlen, const wchar_t* input) -{ - return WideCharToMultiByte(65001 /* UTF8 */, 0, input, -1, buffer, (int) bufferlen, NULL, NULL); +STBIDEF int stbi_convert_wchar_to_utf8(char* buffer, size_t bufferlen, + const wchar_t* input) { + return WideCharToMultiByte(65001 /* UTF8 */, 0, input, -1, buffer, + (int)bufferlen, NULL, NULL); } #endif -static FILE *stbi__fopen(char const *filename, char const *mode) -{ - FILE *f; +static FILE* stbi__fopen(char const* filename, char const* mode) { + FILE* f; #if defined(_WIN32) && defined(STBI_WINDOWS_UTF8) - wchar_t wMode[64]; - wchar_t wFilename[1024]; - if (0 == MultiByteToWideChar(65001 /* UTF8 */, 0, filename, -1, wFilename, sizeof(wFilename)/sizeof(*wFilename))) - return 0; + wchar_t wMode[64]; + wchar_t wFilename[1024]; + if (0 == MultiByteToWideChar(65001 /* UTF8 */, 0, filename, -1, wFilename, + sizeof(wFilename) / sizeof(*wFilename))) + return 0; - if (0 == MultiByteToWideChar(65001 /* UTF8 */, 0, mode, -1, wMode, sizeof(wMode)/sizeof(*wMode))) - return 0; + if (0 == MultiByteToWideChar(65001 /* UTF8 */, 0, mode, -1, wMode, + sizeof(wMode) / sizeof(*wMode))) + return 0; #if defined(_MSC_VER) && _MSC_VER >= 1400 - if (0 != _wfopen_s(&f, wFilename, wMode)) - f = 0; + if (0 != _wfopen_s(&f, wFilename, wMode)) + f = 0; #else - f = _wfopen(wFilename, wMode); + f = _wfopen(wFilename, wMode); #endif #elif defined(_MSC_VER) && _MSC_VER >= 1400 - if (0 != fopen_s(&f, filename, mode)) - f=0; + if (0 != fopen_s(&f, filename, mode)) + f = 0; #else - f = fopen(filename, mode); + f = fopen(filename, mode); #endif - return f; + return f; } - -STBIDEF stbi_uc *stbi_load(char const *filename, int *x, int *y, int *comp, int req_comp) -{ - FILE *f = stbi__fopen(filename, "rb"); - unsigned char *result; - if (!f) return stbi__errpuc("can't fopen", "Unable to open file"); - result = stbi_load_from_file(f,x,y,comp,req_comp); - fclose(f); - return result; +STBIDEF stbi_uc* stbi_load(char const* filename, int* x, int* y, int* comp, + int req_comp) { + FILE* f = stbi__fopen(filename, "rb"); + unsigned char* result; + if (!f) + return stbi__errpuc("can't fopen", "Unable to open file"); + result = stbi_load_from_file(f, x, y, comp, req_comp); + fclose(f); + return result; } -STBIDEF stbi_uc *stbi_load_from_file(FILE *f, int *x, int *y, int *comp, int req_comp) -{ - unsigned char *result; - stbi__context s; - stbi__start_file(&s,f); - result = stbi__load_and_postprocess_8bit(&s,x,y,comp,req_comp); - if (result) { - // need to 'unget' all the characters in the IO buffer - fseek(f, - (int) (s.img_buffer_end - s.img_buffer), SEEK_CUR); - } - return result; +STBIDEF stbi_uc* stbi_load_from_file(FILE* f, int* x, int* y, int* comp, + int req_comp) { + unsigned char* result; + stbi__context s; + stbi__start_file(&s, f); + result = stbi__load_and_postprocess_8bit(&s, x, y, comp, req_comp); + if (result) { + // need to 'unget' all the characters in the IO buffer + fseek(f, -(int)(s.img_buffer_end - s.img_buffer), SEEK_CUR); + } + return result; } -STBIDEF stbi__uint16 *stbi_load_from_file_16(FILE *f, int *x, int *y, int *comp, int req_comp) -{ - stbi__uint16 *result; - stbi__context s; - stbi__start_file(&s,f); - result = stbi__load_and_postprocess_16bit(&s,x,y,comp,req_comp); - if (result) { - // need to 'unget' all the characters in the IO buffer - fseek(f, - (int) (s.img_buffer_end - s.img_buffer), SEEK_CUR); - } - return result; +STBIDEF stbi__uint16* stbi_load_from_file_16(FILE* f, int* x, int* y, int* comp, + int req_comp) { + stbi__uint16* result; + stbi__context s; + stbi__start_file(&s, f); + result = stbi__load_and_postprocess_16bit(&s, x, y, comp, req_comp); + if (result) { + // need to 'unget' all the characters in the IO buffer + fseek(f, -(int)(s.img_buffer_end - s.img_buffer), SEEK_CUR); + } + return result; } -STBIDEF stbi_us *stbi_load_16(char const *filename, int *x, int *y, int *comp, int req_comp) -{ - FILE *f = stbi__fopen(filename, "rb"); - stbi__uint16 *result; - if (!f) return (stbi_us *) stbi__errpuc("can't fopen", "Unable to open file"); - result = stbi_load_from_file_16(f,x,y,comp,req_comp); - fclose(f); - return result; +STBIDEF stbi_us* stbi_load_16(char const* filename, int* x, int* y, int* comp, + int req_comp) { + FILE* f = stbi__fopen(filename, "rb"); + stbi__uint16* result; + if (!f) + return (stbi_us*)stbi__errpuc("can't fopen", "Unable to open file"); + result = stbi_load_from_file_16(f, x, y, comp, req_comp); + fclose(f); + return result; } +#endif //! STBI_NO_STDIO -#endif //!STBI_NO_STDIO - -STBIDEF stbi_us *stbi_load_16_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *channels_in_file, int desired_channels) -{ - stbi__context s; - stbi__start_mem(&s,buffer,len); - return stbi__load_and_postprocess_16bit(&s,x,y,channels_in_file,desired_channels); +STBIDEF stbi_us* stbi_load_16_from_memory(stbi_uc const* buffer, int len, + int* x, int* y, int* channels_in_file, + int desired_channels) { + stbi__context s; + stbi__start_mem(&s, buffer, len); + return stbi__load_and_postprocess_16bit(&s, x, y, channels_in_file, + desired_channels); } -STBIDEF stbi_us *stbi_load_16_from_callbacks(stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *channels_in_file, int desired_channels) -{ - stbi__context s; - stbi__start_callbacks(&s, (stbi_io_callbacks *)clbk, user); - return stbi__load_and_postprocess_16bit(&s,x,y,channels_in_file,desired_channels); +STBIDEF stbi_us* stbi_load_16_from_callbacks(stbi_io_callbacks const* clbk, + void* user, int* x, int* y, + int* channels_in_file, + int desired_channels) { + stbi__context s; + stbi__start_callbacks(&s, (stbi_io_callbacks*)clbk, user); + return stbi__load_and_postprocess_16bit(&s, x, y, channels_in_file, + desired_channels); } -STBIDEF stbi_uc *stbi_load_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp, int req_comp) -{ - stbi__context s; - stbi__start_mem(&s,buffer,len); - return stbi__load_and_postprocess_8bit(&s,x,y,comp,req_comp); +STBIDEF stbi_uc* stbi_load_from_memory(stbi_uc const* buffer, int len, int* x, + int* y, int* comp, int req_comp) { + stbi__context s; + stbi__start_mem(&s, buffer, len); + return stbi__load_and_postprocess_8bit(&s, x, y, comp, req_comp); } -STBIDEF stbi_uc *stbi_load_from_callbacks(stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp, int req_comp) -{ - stbi__context s; - stbi__start_callbacks(&s, (stbi_io_callbacks *) clbk, user); - return stbi__load_and_postprocess_8bit(&s,x,y,comp,req_comp); +STBIDEF stbi_uc* stbi_load_from_callbacks(stbi_io_callbacks const* clbk, + void* user, int* x, int* y, int* comp, + int req_comp) { + stbi__context s; + stbi__start_callbacks(&s, (stbi_io_callbacks*)clbk, user); + return stbi__load_and_postprocess_8bit(&s, x, y, comp, req_comp); } #ifndef STBI_NO_GIF -STBIDEF stbi_uc *stbi_load_gif_from_memory(stbi_uc const *buffer, int len, int **delays, int *x, int *y, int *z, int *comp, int req_comp) -{ - unsigned char *result; - stbi__context s; - stbi__start_mem(&s,buffer,len); +STBIDEF stbi_uc* stbi_load_gif_from_memory(stbi_uc const* buffer, int len, + int** delays, int* x, int* y, int* z, + int* comp, int req_comp) { + unsigned char* result; + stbi__context s; + stbi__start_mem(&s, buffer, len); - result = (unsigned char*) stbi__load_gif_main(&s, delays, x, y, z, comp, req_comp); - if (stbi__vertically_flip_on_load) { - stbi__vertical_flip_slices( result, *x, *y, *z, *comp ); - } + result = (unsigned char*)stbi__load_gif_main(&s, delays, x, y, z, comp, + req_comp); + if (stbi__vertically_flip_on_load) { + stbi__vertical_flip_slices(result, *x, *y, *z, *comp); + } - return result; + return result; } #endif #ifndef STBI_NO_LINEAR -static float *stbi__loadf_main(stbi__context *s, int *x, int *y, int *comp, int req_comp) -{ - unsigned char *data; - #ifndef STBI_NO_HDR - if (stbi__hdr_test(s)) { - stbi__result_info ri; - float *hdr_data = stbi__hdr_load(s,x,y,comp,req_comp, &ri); - if (hdr_data) - stbi__float_postprocess(hdr_data,x,y,comp,req_comp); - return hdr_data; - } - #endif - data = stbi__load_and_postprocess_8bit(s, x, y, comp, req_comp); - if (data) - return stbi__ldr_to_hdr(data, *x, *y, req_comp ? req_comp : *comp); - return stbi__errpf("unknown image type", "Image not of any known type, or corrupt"); +static float* stbi__loadf_main(stbi__context* s, int* x, int* y, int* comp, + int req_comp) { + unsigned char* data; +#ifndef STBI_NO_HDR + if (stbi__hdr_test(s)) { + stbi__result_info ri; + float* hdr_data = stbi__hdr_load(s, x, y, comp, req_comp, &ri); + if (hdr_data) + stbi__float_postprocess(hdr_data, x, y, comp, req_comp); + return hdr_data; + } +#endif + data = stbi__load_and_postprocess_8bit(s, x, y, comp, req_comp); + if (data) + return stbi__ldr_to_hdr(data, *x, *y, req_comp ? req_comp : *comp); + return stbi__errpf("unknown image type", + "Image not of any known type, or corrupt"); } -STBIDEF float *stbi_loadf_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp, int req_comp) -{ - stbi__context s; - stbi__start_mem(&s,buffer,len); - return stbi__loadf_main(&s,x,y,comp,req_comp); +STBIDEF float* stbi_loadf_from_memory(stbi_uc const* buffer, int len, int* x, + int* y, int* comp, int req_comp) { + stbi__context s; + stbi__start_mem(&s, buffer, len); + return stbi__loadf_main(&s, x, y, comp, req_comp); } -STBIDEF float *stbi_loadf_from_callbacks(stbi_io_callbacks const *clbk, void *user, int *x, int *y, int *comp, int req_comp) -{ - stbi__context s; - stbi__start_callbacks(&s, (stbi_io_callbacks *) clbk, user); - return stbi__loadf_main(&s,x,y,comp,req_comp); +STBIDEF float* stbi_loadf_from_callbacks(stbi_io_callbacks const* clbk, + void* user, int* x, int* y, int* comp, + int req_comp) { + stbi__context s; + stbi__start_callbacks(&s, (stbi_io_callbacks*)clbk, user); + return stbi__loadf_main(&s, x, y, comp, req_comp); } #ifndef STBI_NO_STDIO -STBIDEF float *stbi_loadf(char const *filename, int *x, int *y, int *comp, int req_comp) -{ - float *result; - FILE *f = stbi__fopen(filename, "rb"); - if (!f) return stbi__errpf("can't fopen", "Unable to open file"); - result = stbi_loadf_from_file(f,x,y,comp,req_comp); - fclose(f); - return result; +STBIDEF float* stbi_loadf(char const* filename, int* x, int* y, int* comp, + int req_comp) { + float* result; + FILE* f = stbi__fopen(filename, "rb"); + if (!f) + return stbi__errpf("can't fopen", "Unable to open file"); + result = stbi_loadf_from_file(f, x, y, comp, req_comp); + fclose(f); + return result; } -STBIDEF float *stbi_loadf_from_file(FILE *f, int *x, int *y, int *comp, int req_comp) -{ - stbi__context s; - stbi__start_file(&s,f); - return stbi__loadf_main(&s,x,y,comp,req_comp); +STBIDEF float* stbi_loadf_from_file(FILE* f, int* x, int* y, int* comp, + int req_comp) { + stbi__context s; + stbi__start_file(&s, f); + return stbi__loadf_main(&s, x, y, comp, req_comp); } #endif // !STBI_NO_STDIO @@ -1512,222 +1604,220 @@ STBIDEF float *stbi_loadf_from_file(FILE *f, int *x, int *y, int *comp, int req_ // defined, for API simplicity; if STBI_NO_LINEAR is defined, it always // reports false! -STBIDEF int stbi_is_hdr_from_memory(stbi_uc const *buffer, int len) -{ - #ifndef STBI_NO_HDR - stbi__context s; - stbi__start_mem(&s,buffer,len); - return stbi__hdr_test(&s); - #else - STBI_NOTUSED(buffer); - STBI_NOTUSED(len); - return 0; - #endif +STBIDEF int stbi_is_hdr_from_memory(stbi_uc const* buffer, int len) { +#ifndef STBI_NO_HDR + stbi__context s; + stbi__start_mem(&s, buffer, len); + return stbi__hdr_test(&s); +#else + STBI_NOTUSED(buffer); + STBI_NOTUSED(len); + return 0; +#endif } #ifndef STBI_NO_STDIO -STBIDEF int stbi_is_hdr (char const *filename) -{ - FILE *f = stbi__fopen(filename, "rb"); - int result=0; - if (f) { - result = stbi_is_hdr_from_file(f); - fclose(f); - } - return result; +STBIDEF int stbi_is_hdr(char const* filename) { + FILE* f = stbi__fopen(filename, "rb"); + int result = 0; + if (f) { + result = stbi_is_hdr_from_file(f); + fclose(f); + } + return result; } -STBIDEF int stbi_is_hdr_from_file(FILE *f) -{ - #ifndef STBI_NO_HDR - long pos = ftell(f); - int res; - stbi__context s; - stbi__start_file(&s,f); - res = stbi__hdr_test(&s); - fseek(f, pos, SEEK_SET); - return res; - #else - STBI_NOTUSED(f); - return 0; - #endif +STBIDEF int stbi_is_hdr_from_file(FILE* f) { +#ifndef STBI_NO_HDR + long pos = ftell(f); + int res; + stbi__context s; + stbi__start_file(&s, f); + res = stbi__hdr_test(&s); + fseek(f, pos, SEEK_SET); + return res; +#else + STBI_NOTUSED(f); + return 0; +#endif } #endif // !STBI_NO_STDIO -STBIDEF int stbi_is_hdr_from_callbacks(stbi_io_callbacks const *clbk, void *user) -{ - #ifndef STBI_NO_HDR - stbi__context s; - stbi__start_callbacks(&s, (stbi_io_callbacks *) clbk, user); - return stbi__hdr_test(&s); - #else - STBI_NOTUSED(clbk); - STBI_NOTUSED(user); - return 0; - #endif +STBIDEF int stbi_is_hdr_from_callbacks(stbi_io_callbacks const* clbk, + void* user) { +#ifndef STBI_NO_HDR + stbi__context s; + stbi__start_callbacks(&s, (stbi_io_callbacks*)clbk, user); + return stbi__hdr_test(&s); +#else + STBI_NOTUSED(clbk); + STBI_NOTUSED(user); + return 0; +#endif } #ifndef STBI_NO_LINEAR -static float stbi__l2h_gamma=2.2f, stbi__l2h_scale=1.0f; +static float stbi__l2h_gamma = 2.2f, stbi__l2h_scale = 1.0f; -STBIDEF void stbi_ldr_to_hdr_gamma(float gamma) { stbi__l2h_gamma = gamma; } -STBIDEF void stbi_ldr_to_hdr_scale(float scale) { stbi__l2h_scale = scale; } +STBIDEF void stbi_ldr_to_hdr_gamma(float gamma) { stbi__l2h_gamma = gamma; } +STBIDEF void stbi_ldr_to_hdr_scale(float scale) { stbi__l2h_scale = scale; } #endif -static float stbi__h2l_gamma_i=1.0f/2.2f, stbi__h2l_scale_i=1.0f; - -STBIDEF void stbi_hdr_to_ldr_gamma(float gamma) { stbi__h2l_gamma_i = 1/gamma; } -STBIDEF void stbi_hdr_to_ldr_scale(float scale) { stbi__h2l_scale_i = 1/scale; } +static float stbi__h2l_gamma_i = 1.0f / 2.2f, stbi__h2l_scale_i = 1.0f; +STBIDEF void stbi_hdr_to_ldr_gamma(float gamma) { + stbi__h2l_gamma_i = 1 / gamma; +} +STBIDEF void stbi_hdr_to_ldr_scale(float scale) { + stbi__h2l_scale_i = 1 / scale; +} ////////////////////////////////////////////////////////////////////////////// // // Common code used by all image loaders // -enum -{ - STBI__SCAN_load=0, - STBI__SCAN_type, - STBI__SCAN_header -}; +enum { STBI__SCAN_load = 0, STBI__SCAN_type, STBI__SCAN_header }; -static void stbi__refill_buffer(stbi__context *s) -{ - int n = (s->io.read)(s->io_user_data,(char*)s->buffer_start,s->buflen); - s->callback_already_read += (int) (s->img_buffer - s->img_buffer_original); - if (n == 0) { - // at end of file, treat same as if from memory, but need to handle case - // where s->img_buffer isn't pointing to safe memory, e.g. 0-byte file - s->read_from_callbacks = 0; - s->img_buffer = s->buffer_start; - s->img_buffer_end = s->buffer_start+1; - *s->img_buffer = 0; - } else { - s->img_buffer = s->buffer_start; - s->img_buffer_end = s->buffer_start + n; - } +static void stbi__refill_buffer(stbi__context* s) { + int n = (s->io.read)(s->io_user_data, (char*)s->buffer_start, s->buflen); + s->callback_already_read += (int)(s->img_buffer - s->img_buffer_original); + if (n == 0) { + // at end of file, treat same as if from memory, but need to handle case + // where s->img_buffer isn't pointing to safe memory, e.g. 0-byte file + s->read_from_callbacks = 0; + s->img_buffer = s->buffer_start; + s->img_buffer_end = s->buffer_start + 1; + *s->img_buffer = 0; + } else { + s->img_buffer = s->buffer_start; + s->img_buffer_end = s->buffer_start + n; + } } -stbi_inline static stbi_uc stbi__get8(stbi__context *s) -{ - if (s->img_buffer < s->img_buffer_end) - return *s->img_buffer++; - if (s->read_from_callbacks) { - stbi__refill_buffer(s); - return *s->img_buffer++; - } - return 0; +stbi_inline static stbi_uc stbi__get8(stbi__context* s) { + if (s->img_buffer < s->img_buffer_end) + return *s->img_buffer++; + if (s->read_from_callbacks) { + stbi__refill_buffer(s); + return *s->img_buffer++; + } + return 0; } -#if defined(STBI_NO_JPEG) && defined(STBI_NO_HDR) && defined(STBI_NO_PIC) && defined(STBI_NO_PNM) +#if defined(STBI_NO_JPEG) && defined(STBI_NO_HDR) && defined(STBI_NO_PIC) && \ + defined(STBI_NO_PNM) // nothing #else -stbi_inline static int stbi__at_eof(stbi__context *s) -{ - if (s->io.read) { - if (!(s->io.eof)(s->io_user_data)) return 0; - // if feof() is true, check if buffer = end - // special case: we've only got the special 0 character at the end - if (s->read_from_callbacks == 0) return 1; - } +stbi_inline static int stbi__at_eof(stbi__context* s) { + if (s->io.read) { + if (!(s->io.eof)(s->io_user_data)) + return 0; + // if feof() is true, check if buffer = end + // special case: we've only got the special 0 character at the end + if (s->read_from_callbacks == 0) + return 1; + } - return s->img_buffer >= s->img_buffer_end; + return s->img_buffer >= s->img_buffer_end; } #endif -#if defined(STBI_NO_JPEG) && defined(STBI_NO_PNG) && defined(STBI_NO_BMP) && defined(STBI_NO_PSD) && defined(STBI_NO_TGA) && defined(STBI_NO_GIF) && defined(STBI_NO_PIC) +#if defined(STBI_NO_JPEG) && defined(STBI_NO_PNG) && defined(STBI_NO_BMP) && \ + defined(STBI_NO_PSD) && defined(STBI_NO_TGA) && defined(STBI_NO_GIF) && \ + defined(STBI_NO_PIC) // nothing #else -static void stbi__skip(stbi__context *s, int n) -{ - if (n == 0) return; // already there! - if (n < 0) { - s->img_buffer = s->img_buffer_end; - return; - } - if (s->io.read) { - int blen = (int) (s->img_buffer_end - s->img_buffer); - if (blen < n) { - s->img_buffer = s->img_buffer_end; - (s->io.skip)(s->io_user_data, n - blen); - return; - } - } - s->img_buffer += n; +static void stbi__skip(stbi__context* s, int n) { + if (n == 0) + return; // already there! + if (n < 0) { + s->img_buffer = s->img_buffer_end; + return; + } + if (s->io.read) { + int blen = (int)(s->img_buffer_end - s->img_buffer); + if (blen < n) { + s->img_buffer = s->img_buffer_end; + (s->io.skip)(s->io_user_data, n - blen); + return; + } + } + s->img_buffer += n; } #endif -#if defined(STBI_NO_PNG) && defined(STBI_NO_TGA) && defined(STBI_NO_HDR) && defined(STBI_NO_PNM) +#if defined(STBI_NO_PNG) && defined(STBI_NO_TGA) && defined(STBI_NO_HDR) && \ + defined(STBI_NO_PNM) // nothing #else -static int stbi__getn(stbi__context *s, stbi_uc *buffer, int n) -{ - if (s->io.read) { - int blen = (int) (s->img_buffer_end - s->img_buffer); - if (blen < n) { - int res, count; +static int stbi__getn(stbi__context* s, stbi_uc* buffer, int n) { + if (s->io.read) { + int blen = (int)(s->img_buffer_end - s->img_buffer); + if (blen < n) { + int res, count; - memcpy(buffer, s->img_buffer, blen); + memcpy(buffer, s->img_buffer, blen); - count = (s->io.read)(s->io_user_data, (char*) buffer + blen, n - blen); - res = (count == (n-blen)); - s->img_buffer = s->img_buffer_end; - return res; - } - } + count = + (s->io.read)(s->io_user_data, (char*)buffer + blen, n - blen); + res = (count == (n - blen)); + s->img_buffer = s->img_buffer_end; + return res; + } + } - if (s->img_buffer+n <= s->img_buffer_end) { - memcpy(buffer, s->img_buffer, n); - s->img_buffer += n; - return 1; - } else - return 0; + if (s->img_buffer + n <= s->img_buffer_end) { + memcpy(buffer, s->img_buffer, n); + s->img_buffer += n; + return 1; + } else + return 0; } #endif -#if defined(STBI_NO_JPEG) && defined(STBI_NO_PNG) && defined(STBI_NO_PSD) && defined(STBI_NO_PIC) +#if defined(STBI_NO_JPEG) && defined(STBI_NO_PNG) && defined(STBI_NO_PSD) && \ + defined(STBI_NO_PIC) // nothing #else -static int stbi__get16be(stbi__context *s) -{ - int z = stbi__get8(s); - return (z << 8) + stbi__get8(s); +static int stbi__get16be(stbi__context* s) { + int z = stbi__get8(s); + return (z << 8) + stbi__get8(s); } #endif #if defined(STBI_NO_PNG) && defined(STBI_NO_PSD) && defined(STBI_NO_PIC) // nothing #else -static stbi__uint32 stbi__get32be(stbi__context *s) -{ - stbi__uint32 z = stbi__get16be(s); - return (z << 16) + stbi__get16be(s); +static stbi__uint32 stbi__get32be(stbi__context* s) { + stbi__uint32 z = stbi__get16be(s); + return (z << 16) + stbi__get16be(s); } #endif #if defined(STBI_NO_BMP) && defined(STBI_NO_TGA) && defined(STBI_NO_GIF) // nothing #else -static int stbi__get16le(stbi__context *s) -{ - int z = stbi__get8(s); - return z + (stbi__get8(s) << 8); +static int stbi__get16le(stbi__context* s) { + int z = stbi__get8(s); + return z + (stbi__get8(s) << 8); } #endif #ifndef STBI_NO_BMP -static stbi__uint32 stbi__get32le(stbi__context *s) -{ - stbi__uint32 z = stbi__get16le(s); - z += (stbi__uint32)stbi__get16le(s) << 16; - return z; +static stbi__uint32 stbi__get32le(stbi__context* s) { + stbi__uint32 z = stbi__get16le(s); + z += (stbi__uint32)stbi__get16le(s) << 16; + return z; } #endif -#define STBI__BYTECAST(x) ((stbi_uc) ((x) & 255)) // truncate int to byte without warnings +#define STBI__BYTECAST(x) \ + ((stbi_uc)((x) & 255)) // truncate int to byte without warnings -#if defined(STBI_NO_JPEG) && defined(STBI_NO_PNG) && defined(STBI_NO_BMP) && defined(STBI_NO_PSD) && defined(STBI_NO_TGA) && defined(STBI_NO_GIF) && defined(STBI_NO_PIC) && defined(STBI_NO_PNM) +#if defined(STBI_NO_JPEG) && defined(STBI_NO_PNG) && defined(STBI_NO_BMP) && \ + defined(STBI_NO_PSD) && defined(STBI_NO_TGA) && defined(STBI_NO_GIF) && \ + defined(STBI_NO_PIC) && defined(STBI_NO_PNM) // nothing #else ////////////////////////////////////////////////////////////////////////////// @@ -1741,169 +1831,289 @@ static stbi__uint32 stbi__get32le(stbi__context *s) // assume data buffer is malloced, so malloc a new one and free that one // only failure mode is malloc failing -static stbi_uc stbi__compute_y(int r, int g, int b) -{ - return (stbi_uc) (((r*77) + (g*150) + (29*b)) >> 8); +static stbi_uc stbi__compute_y(int r, int g, int b) { + return (stbi_uc)(((r * 77) + (g * 150) + (29 * b)) >> 8); } #endif -#if defined(STBI_NO_PNG) && defined(STBI_NO_BMP) && defined(STBI_NO_PSD) && defined(STBI_NO_TGA) && defined(STBI_NO_GIF) && defined(STBI_NO_PIC) && defined(STBI_NO_PNM) +#if defined(STBI_NO_PNG) && defined(STBI_NO_BMP) && defined(STBI_NO_PSD) && \ + defined(STBI_NO_TGA) && defined(STBI_NO_GIF) && defined(STBI_NO_PIC) && \ + defined(STBI_NO_PNM) // nothing #else -static unsigned char *stbi__convert_format(unsigned char *data, int img_n, int req_comp, unsigned int x, unsigned int y) -{ - int i,j; - unsigned char *good; +static unsigned char* stbi__convert_format(unsigned char* data, int img_n, + int req_comp, unsigned int x, + unsigned int y) { + int i, j; + unsigned char* good; - if (req_comp == img_n) return data; - STBI_ASSERT(req_comp >= 1 && req_comp <= 4); + if (req_comp == img_n) + return data; + STBI_ASSERT(req_comp >= 1 && req_comp <= 4); - good = (unsigned char *) stbi__malloc_mad3(req_comp, x, y, 0); - if (good == NULL) { - STBI_FREE(data); - return stbi__errpuc("outofmem", "Out of memory"); - } + good = (unsigned char*)stbi__malloc_mad3(req_comp, x, y, 0); + if (good == NULL) { + STBI_FREE(data); + return stbi__errpuc("outofmem", "Out of memory"); + } - for (j=0; j < (int) y; ++j) { - unsigned char *src = data + j * x * img_n ; - unsigned char *dest = good + j * x * req_comp; + for (j = 0; j < (int)y; ++j) { + unsigned char* src = data + j * x * img_n; + unsigned char* dest = good + j * x * req_comp; - #define STBI__COMBO(a,b) ((a)*8+(b)) - #define STBI__CASE(a,b) case STBI__COMBO(a,b): for(i=x-1; i >= 0; --i, src += a, dest += b) - // convert source image with img_n components to one with req_comp components; - // avoid switch per pixel, so use switch per scanline and massive macros - switch (STBI__COMBO(img_n, req_comp)) { - STBI__CASE(1,2) { dest[0]=src[0]; dest[1]=255; } break; - STBI__CASE(1,3) { dest[0]=dest[1]=dest[2]=src[0]; } break; - STBI__CASE(1,4) { dest[0]=dest[1]=dest[2]=src[0]; dest[3]=255; } break; - STBI__CASE(2,1) { dest[0]=src[0]; } break; - STBI__CASE(2,3) { dest[0]=dest[1]=dest[2]=src[0]; } break; - STBI__CASE(2,4) { dest[0]=dest[1]=dest[2]=src[0]; dest[3]=src[1]; } break; - STBI__CASE(3,4) { dest[0]=src[0];dest[1]=src[1];dest[2]=src[2];dest[3]=255; } break; - STBI__CASE(3,1) { dest[0]=stbi__compute_y(src[0],src[1],src[2]); } break; - STBI__CASE(3,2) { dest[0]=stbi__compute_y(src[0],src[1],src[2]); dest[1] = 255; } break; - STBI__CASE(4,1) { dest[0]=stbi__compute_y(src[0],src[1],src[2]); } break; - STBI__CASE(4,2) { dest[0]=stbi__compute_y(src[0],src[1],src[2]); dest[1] = src[3]; } break; - STBI__CASE(4,3) { dest[0]=src[0];dest[1]=src[1];dest[2]=src[2]; } break; - default: STBI_ASSERT(0); STBI_FREE(data); STBI_FREE(good); return stbi__errpuc("unsupported", "Unsupported format conversion"); - } - #undef STBI__CASE - } +#define STBI__COMBO(a, b) ((a) * 8 + (b)) +#define STBI__CASE(a, b) \ + case STBI__COMBO(a, b): \ + for (i = x - 1; i >= 0; --i, src += a, dest += b) + // convert source image with img_n components to one with req_comp + // components; avoid switch per pixel, so use switch per scanline and + // massive macros + switch (STBI__COMBO(img_n, req_comp)) { + STBI__CASE(1, 2) { + dest[0] = src[0]; + dest[1] = 255; + } + break; + STBI__CASE(1, 3) { dest[0] = dest[1] = dest[2] = src[0]; } + break; + STBI__CASE(1, 4) { + dest[0] = dest[1] = dest[2] = src[0]; + dest[3] = 255; + } + break; + STBI__CASE(2, 1) { dest[0] = src[0]; } + break; + STBI__CASE(2, 3) { dest[0] = dest[1] = dest[2] = src[0]; } + break; + STBI__CASE(2, 4) { + dest[0] = dest[1] = dest[2] = src[0]; + dest[3] = src[1]; + } + break; + STBI__CASE(3, 4) { + dest[0] = src[0]; + dest[1] = src[1]; + dest[2] = src[2]; + dest[3] = 255; + } + break; + STBI__CASE(3, 1) { + dest[0] = stbi__compute_y(src[0], src[1], src[2]); + } + break; + STBI__CASE(3, 2) { + dest[0] = stbi__compute_y(src[0], src[1], src[2]); + dest[1] = 255; + } + break; + STBI__CASE(4, 1) { + dest[0] = stbi__compute_y(src[0], src[1], src[2]); + } + break; + STBI__CASE(4, 2) { + dest[0] = stbi__compute_y(src[0], src[1], src[2]); + dest[1] = src[3]; + } + break; + STBI__CASE(4, 3) { + dest[0] = src[0]; + dest[1] = src[1]; + dest[2] = src[2]; + } + break; + default: + STBI_ASSERT(0); + STBI_FREE(data); + STBI_FREE(good); + return stbi__errpuc("unsupported", "Unsupported format conversion"); + } +#undef STBI__CASE + } - STBI_FREE(data); - return good; + STBI_FREE(data); + return good; } #endif #if defined(STBI_NO_PNG) && defined(STBI_NO_PSD) // nothing #else -static stbi__uint16 stbi__compute_y_16(int r, int g, int b) -{ - return (stbi__uint16) (((r*77) + (g*150) + (29*b)) >> 8); +static stbi__uint16 stbi__compute_y_16(int r, int g, int b) { + return (stbi__uint16)(((r * 77) + (g * 150) + (29 * b)) >> 8); } #endif #if defined(STBI_NO_PNG) && defined(STBI_NO_PSD) // nothing #else -static stbi__uint16 *stbi__convert_format16(stbi__uint16 *data, int img_n, int req_comp, unsigned int x, unsigned int y) -{ - int i,j; - stbi__uint16 *good; +static stbi__uint16* stbi__convert_format16(stbi__uint16* data, int img_n, + int req_comp, unsigned int x, + unsigned int y) { + int i, j; + stbi__uint16* good; - if (req_comp == img_n) return data; - STBI_ASSERT(req_comp >= 1 && req_comp <= 4); + if (req_comp == img_n) + return data; + STBI_ASSERT(req_comp >= 1 && req_comp <= 4); - good = (stbi__uint16 *) stbi__malloc(req_comp * x * y * 2); - if (good == NULL) { - STBI_FREE(data); - return (stbi__uint16 *) stbi__errpuc("outofmem", "Out of memory"); - } + good = (stbi__uint16*)stbi__malloc(req_comp * x * y * 2); + if (good == NULL) { + STBI_FREE(data); + return (stbi__uint16*)stbi__errpuc("outofmem", "Out of memory"); + } - for (j=0; j < (int) y; ++j) { - stbi__uint16 *src = data + j * x * img_n ; - stbi__uint16 *dest = good + j * x * req_comp; + for (j = 0; j < (int)y; ++j) { + stbi__uint16* src = data + j * x * img_n; + stbi__uint16* dest = good + j * x * req_comp; - #define STBI__COMBO(a,b) ((a)*8+(b)) - #define STBI__CASE(a,b) case STBI__COMBO(a,b): for(i=x-1; i >= 0; --i, src += a, dest += b) - // convert source image with img_n components to one with req_comp components; - // avoid switch per pixel, so use switch per scanline and massive macros - switch (STBI__COMBO(img_n, req_comp)) { - STBI__CASE(1,2) { dest[0]=src[0]; dest[1]=0xffff; } break; - STBI__CASE(1,3) { dest[0]=dest[1]=dest[2]=src[0]; } break; - STBI__CASE(1,4) { dest[0]=dest[1]=dest[2]=src[0]; dest[3]=0xffff; } break; - STBI__CASE(2,1) { dest[0]=src[0]; } break; - STBI__CASE(2,3) { dest[0]=dest[1]=dest[2]=src[0]; } break; - STBI__CASE(2,4) { dest[0]=dest[1]=dest[2]=src[0]; dest[3]=src[1]; } break; - STBI__CASE(3,4) { dest[0]=src[0];dest[1]=src[1];dest[2]=src[2];dest[3]=0xffff; } break; - STBI__CASE(3,1) { dest[0]=stbi__compute_y_16(src[0],src[1],src[2]); } break; - STBI__CASE(3,2) { dest[0]=stbi__compute_y_16(src[0],src[1],src[2]); dest[1] = 0xffff; } break; - STBI__CASE(4,1) { dest[0]=stbi__compute_y_16(src[0],src[1],src[2]); } break; - STBI__CASE(4,2) { dest[0]=stbi__compute_y_16(src[0],src[1],src[2]); dest[1] = src[3]; } break; - STBI__CASE(4,3) { dest[0]=src[0];dest[1]=src[1];dest[2]=src[2]; } break; - default: STBI_ASSERT(0); STBI_FREE(data); STBI_FREE(good); return (stbi__uint16*) stbi__errpuc("unsupported", "Unsupported format conversion"); - } - #undef STBI__CASE - } +#define STBI__COMBO(a, b) ((a) * 8 + (b)) +#define STBI__CASE(a, b) \ + case STBI__COMBO(a, b): \ + for (i = x - 1; i >= 0; --i, src += a, dest += b) + // convert source image with img_n components to one with req_comp + // components; avoid switch per pixel, so use switch per scanline and + // massive macros + switch (STBI__COMBO(img_n, req_comp)) { + STBI__CASE(1, 2) { + dest[0] = src[0]; + dest[1] = 0xffff; + } + break; + STBI__CASE(1, 3) { dest[0] = dest[1] = dest[2] = src[0]; } + break; + STBI__CASE(1, 4) { + dest[0] = dest[1] = dest[2] = src[0]; + dest[3] = 0xffff; + } + break; + STBI__CASE(2, 1) { dest[0] = src[0]; } + break; + STBI__CASE(2, 3) { dest[0] = dest[1] = dest[2] = src[0]; } + break; + STBI__CASE(2, 4) { + dest[0] = dest[1] = dest[2] = src[0]; + dest[3] = src[1]; + } + break; + STBI__CASE(3, 4) { + dest[0] = src[0]; + dest[1] = src[1]; + dest[2] = src[2]; + dest[3] = 0xffff; + } + break; + STBI__CASE(3, 1) { + dest[0] = stbi__compute_y_16(src[0], src[1], src[2]); + } + break; + STBI__CASE(3, 2) { + dest[0] = stbi__compute_y_16(src[0], src[1], src[2]); + dest[1] = 0xffff; + } + break; + STBI__CASE(4, 1) { + dest[0] = stbi__compute_y_16(src[0], src[1], src[2]); + } + break; + STBI__CASE(4, 2) { + dest[0] = stbi__compute_y_16(src[0], src[1], src[2]); + dest[1] = src[3]; + } + break; + STBI__CASE(4, 3) { + dest[0] = src[0]; + dest[1] = src[1]; + dest[2] = src[2]; + } + break; + default: + STBI_ASSERT(0); + STBI_FREE(data); + STBI_FREE(good); + return (stbi__uint16*)stbi__errpuc("unsupported", + "Unsupported format conversion"); + } +#undef STBI__CASE + } - STBI_FREE(data); - return good; + STBI_FREE(data); + return good; } #endif #ifndef STBI_NO_LINEAR -static float *stbi__ldr_to_hdr(stbi_uc *data, int x, int y, int comp) -{ - int i,k,n; - float *output; - if (!data) return NULL; - output = (float *) stbi__malloc_mad4(x, y, comp, sizeof(float), 0); - if (output == NULL) { STBI_FREE(data); return stbi__errpf("outofmem", "Out of memory"); } - // compute number of non-alpha components - if (comp & 1) n = comp; else n = comp-1; - for (i=0; i < x*y; ++i) { - for (k=0; k < n; ++k) { - output[i*comp + k] = (float) (pow(data[i*comp+k]/255.0f, stbi__l2h_gamma) * stbi__l2h_scale); - } - } - if (n < comp) { - for (i=0; i < x*y; ++i) { - output[i*comp + n] = data[i*comp + n]/255.0f; - } - } - STBI_FREE(data); - return output; +static float* stbi__ldr_to_hdr(stbi_uc* data, int x, int y, int comp) { + int i, k, n; + float* output; + if (!data) + return NULL; + output = (float*)stbi__malloc_mad4(x, y, comp, sizeof(float), 0); + if (output == NULL) { + STBI_FREE(data); + return stbi__errpf("outofmem", "Out of memory"); + } + // compute number of non-alpha components + if (comp & 1) + n = comp; + else + n = comp - 1; + for (i = 0; i < x * y; ++i) { + for (k = 0; k < n; ++k) { + output[i * comp + k] = + (float)(pow(data[i * comp + k] / 255.0f, stbi__l2h_gamma) * + stbi__l2h_scale); + } + } + if (n < comp) { + for (i = 0; i < x * y; ++i) { + output[i * comp + n] = data[i * comp + n] / 255.0f; + } + } + STBI_FREE(data); + return output; } #endif #ifndef STBI_NO_HDR -#define stbi__float2int(x) ((int) (x)) -static stbi_uc *stbi__hdr_to_ldr(float *data, int x, int y, int comp) -{ - int i,k,n; - stbi_uc *output; - if (!data) return NULL; - output = (stbi_uc *) stbi__malloc_mad3(x, y, comp, 0); - if (output == NULL) { STBI_FREE(data); return stbi__errpuc("outofmem", "Out of memory"); } - // compute number of non-alpha components - if (comp & 1) n = comp; else n = comp-1; - for (i=0; i < x*y; ++i) { - for (k=0; k < n; ++k) { - float z = (float) pow(data[i*comp+k]*stbi__h2l_scale_i, stbi__h2l_gamma_i) * 255 + 0.5f; - if (z < 0) z = 0; - if (z > 255) z = 255; - output[i*comp + k] = (stbi_uc) stbi__float2int(z); - } - if (k < comp) { - float z = data[i*comp+k] * 255 + 0.5f; - if (z < 0) z = 0; - if (z > 255) z = 255; - output[i*comp + k] = (stbi_uc) stbi__float2int(z); - } - } - STBI_FREE(data); - return output; +#define stbi__float2int(x) ((int)(x)) +static stbi_uc* stbi__hdr_to_ldr(float* data, int x, int y, int comp) { + int i, k, n; + stbi_uc* output; + if (!data) + return NULL; + output = (stbi_uc*)stbi__malloc_mad3(x, y, comp, 0); + if (output == NULL) { + STBI_FREE(data); + return stbi__errpuc("outofmem", "Out of memory"); + } + // compute number of non-alpha components + if (comp & 1) + n = comp; + else + n = comp - 1; + for (i = 0; i < x * y; ++i) { + for (k = 0; k < n; ++k) { + float z = (float)pow(data[i * comp + k] * stbi__h2l_scale_i, + stbi__h2l_gamma_i) * + 255 + + 0.5f; + if (z < 0) + z = 0; + if (z > 255) + z = 255; + output[i * comp + k] = (stbi_uc)stbi__float2int(z); + } + if (k < comp) { + float z = data[i * comp + k] * 255 + 0.5f; + if (z < 0) + z = 0; + if (z > 255) + z = 255; + output[i * comp + k] = (stbi_uc)stbi__float2int(z); + } + } + STBI_FREE(data); + return output; } #endif @@ -1931,763 +2141,827 @@ static stbi_uc *stbi__hdr_to_ldr(float *data, int x, int y, int comp) #ifndef STBI_NO_JPEG // huffman decoding acceleration -#define FAST_BITS 9 // larger handles more cases; smaller stomps less cache +#define FAST_BITS 9 // larger handles more cases; smaller stomps less cache -typedef struct -{ - stbi_uc fast[1 << FAST_BITS]; - // weirdly, repacking this into AoS is a 10% speed loss, instead of a win - stbi__uint16 code[256]; - stbi_uc values[256]; - stbi_uc size[257]; - unsigned int maxcode[18]; - int delta[17]; // old 'firstsymbol' - old 'firstcode' +typedef struct { + stbi_uc fast[1 << FAST_BITS]; + // weirdly, repacking this into AoS is a 10% speed loss, instead of a win + stbi__uint16 code[256]; + stbi_uc values[256]; + stbi_uc size[257]; + unsigned int maxcode[18]; + int delta[17]; // old 'firstsymbol' - old 'firstcode' } stbi__huffman; -typedef struct -{ - stbi__context *s; - stbi__huffman huff_dc[4]; - stbi__huffman huff_ac[4]; - stbi__uint16 dequant[4][64]; - stbi__int16 fast_ac[4][1 << FAST_BITS]; +typedef struct { + stbi__context* s; + stbi__huffman huff_dc[4]; + stbi__huffman huff_ac[4]; + stbi__uint16 dequant[4][64]; + stbi__int16 fast_ac[4][1 << FAST_BITS]; -// sizes for components, interleaved MCUs - int img_h_max, img_v_max; - int img_mcu_x, img_mcu_y; - int img_mcu_w, img_mcu_h; + // sizes for components, interleaved MCUs + int img_h_max, img_v_max; + int img_mcu_x, img_mcu_y; + int img_mcu_w, img_mcu_h; -// definition of jpeg image component - struct - { - int id; - int h,v; - int tq; - int hd,ha; - int dc_pred; + // definition of jpeg image component + struct { + int id; + int h, v; + int tq; + int hd, ha; + int dc_pred; - int x,y,w2,h2; - stbi_uc *data; - void *raw_data, *raw_coeff; - stbi_uc *linebuf; - short *coeff; // progressive only - int coeff_w, coeff_h; // number of 8x8 coefficient blocks - } img_comp[4]; + int x, y, w2, h2; + stbi_uc* data; + void *raw_data, *raw_coeff; + stbi_uc* linebuf; + short* coeff; // progressive only + int coeff_w, coeff_h; // number of 8x8 coefficient blocks + } img_comp[4]; - stbi__uint32 code_buffer; // jpeg entropy-coded buffer - int code_bits; // number of valid bits - unsigned char marker; // marker seen while filling entropy buffer - int nomore; // flag if we saw a marker so must stop + stbi__uint32 code_buffer; // jpeg entropy-coded buffer + int code_bits; // number of valid bits + unsigned char marker; // marker seen while filling entropy buffer + int nomore; // flag if we saw a marker so must stop - int progressive; - int spec_start; - int spec_end; - int succ_high; - int succ_low; - int eob_run; - int jfif; - int app14_color_transform; // Adobe APP14 tag - int rgb; + int progressive; + int spec_start; + int spec_end; + int succ_high; + int succ_low; + int eob_run; + int jfif; + int app14_color_transform; // Adobe APP14 tag + int rgb; - int scan_n, order[4]; - int restart_interval, todo; + int scan_n, order[4]; + int restart_interval, todo; -// kernels - void (*idct_block_kernel)(stbi_uc *out, int out_stride, short data[64]); - void (*YCbCr_to_RGB_kernel)(stbi_uc *out, const stbi_uc *y, const stbi_uc *pcb, const stbi_uc *pcr, int count, int step); - stbi_uc *(*resample_row_hv_2_kernel)(stbi_uc *out, stbi_uc *in_near, stbi_uc *in_far, int w, int hs); + // kernels + void (*idct_block_kernel)(stbi_uc* out, int out_stride, short data[64]); + void (*YCbCr_to_RGB_kernel)(stbi_uc* out, const stbi_uc* y, + const stbi_uc* pcb, const stbi_uc* pcr, + int count, int step); + stbi_uc* (*resample_row_hv_2_kernel)(stbi_uc* out, stbi_uc* in_near, + stbi_uc* in_far, int w, int hs); } stbi__jpeg; -static int stbi__build_huffman(stbi__huffman *h, int *count) -{ - int i,j,k=0; - unsigned int code; - // build size list for each symbol (from JPEG spec) - for (i=0; i < 16; ++i) { - for (j=0; j < count[i]; ++j) { - h->size[k++] = (stbi_uc) (i+1); - if(k >= 257) return stbi__err("bad size list","Corrupt JPEG"); - } - } - h->size[k] = 0; +static int stbi__build_huffman(stbi__huffman* h, int* count) { + int i, j, k = 0; + unsigned int code; + // build size list for each symbol (from JPEG spec) + for (i = 0; i < 16; ++i) { + for (j = 0; j < count[i]; ++j) { + h->size[k++] = (stbi_uc)(i + 1); + if (k >= 257) + return stbi__err("bad size list", "Corrupt JPEG"); + } + } + h->size[k] = 0; - // compute actual symbols (from jpeg spec) - code = 0; - k = 0; - for(j=1; j <= 16; ++j) { - // compute delta to add to code to compute symbol id - h->delta[j] = k - code; - if (h->size[k] == j) { - while (h->size[k] == j) - h->code[k++] = (stbi__uint16) (code++); - if (code-1 >= (1u << j)) return stbi__err("bad code lengths","Corrupt JPEG"); - } - // compute largest code + 1 for this size, preshifted as needed later - h->maxcode[j] = code << (16-j); - code <<= 1; - } - h->maxcode[j] = 0xffffffff; + // compute actual symbols (from jpeg spec) + code = 0; + k = 0; + for (j = 1; j <= 16; ++j) { + // compute delta to add to code to compute symbol id + h->delta[j] = k - code; + if (h->size[k] == j) { + while (h->size[k] == j) + h->code[k++] = (stbi__uint16)(code++); + if (code - 1 >= (1u << j)) + return stbi__err("bad code lengths", "Corrupt JPEG"); + } + // compute largest code + 1 for this size, preshifted as needed later + h->maxcode[j] = code << (16 - j); + code <<= 1; + } + h->maxcode[j] = 0xffffffff; - // build non-spec acceleration table; 255 is flag for not-accelerated - memset(h->fast, 255, 1 << FAST_BITS); - for (i=0; i < k; ++i) { - int s = h->size[i]; - if (s <= FAST_BITS) { - int c = h->code[i] << (FAST_BITS-s); - int m = 1 << (FAST_BITS-s); - for (j=0; j < m; ++j) { - h->fast[c+j] = (stbi_uc) i; - } - } - } - return 1; + // build non-spec acceleration table; 255 is flag for not-accelerated + memset(h->fast, 255, 1 << FAST_BITS); + for (i = 0; i < k; ++i) { + int s = h->size[i]; + if (s <= FAST_BITS) { + int c = h->code[i] << (FAST_BITS - s); + int m = 1 << (FAST_BITS - s); + for (j = 0; j < m; ++j) { + h->fast[c + j] = (stbi_uc)i; + } + } + } + return 1; } // build a table that decodes both magnitude and value of small ACs in // one go. -static void stbi__build_fast_ac(stbi__int16 *fast_ac, stbi__huffman *h) -{ - int i; - for (i=0; i < (1 << FAST_BITS); ++i) { - stbi_uc fast = h->fast[i]; - fast_ac[i] = 0; - if (fast < 255) { - int rs = h->values[fast]; - int run = (rs >> 4) & 15; - int magbits = rs & 15; - int len = h->size[fast]; +static void stbi__build_fast_ac(stbi__int16* fast_ac, stbi__huffman* h) { + int i; + for (i = 0; i < (1 << FAST_BITS); ++i) { + stbi_uc fast = h->fast[i]; + fast_ac[i] = 0; + if (fast < 255) { + int rs = h->values[fast]; + int run = (rs >> 4) & 15; + int magbits = rs & 15; + int len = h->size[fast]; - if (magbits && len + magbits <= FAST_BITS) { - // magnitude code followed by receive_extend code - int k = ((i << len) & ((1 << FAST_BITS) - 1)) >> (FAST_BITS - magbits); - int m = 1 << (magbits - 1); - if (k < m) k += (~0U << magbits) + 1; - // if the result is small enough, we can fit it in fast_ac table - if (k >= -128 && k <= 127) - fast_ac[i] = (stbi__int16) ((k * 256) + (run * 16) + (len + magbits)); - } - } - } + if (magbits && len + magbits <= FAST_BITS) { + // magnitude code followed by receive_extend code + int k = ((i << len) & ((1 << FAST_BITS) - 1)) >> + (FAST_BITS - magbits); + int m = 1 << (magbits - 1); + if (k < m) + k += (~0U << magbits) + 1; + // if the result is small enough, we can fit it in fast_ac table + if (k >= -128 && k <= 127) + fast_ac[i] = + (stbi__int16)((k * 256) + (run * 16) + (len + magbits)); + } + } + } } -static void stbi__grow_buffer_unsafe(stbi__jpeg *j) -{ - do { - unsigned int b = j->nomore ? 0 : stbi__get8(j->s); - if (b == 0xff) { - int c = stbi__get8(j->s); - while (c == 0xff) c = stbi__get8(j->s); // consume fill bytes - if (c != 0) { - j->marker = (unsigned char) c; - j->nomore = 1; - return; - } - } - j->code_buffer |= b << (24 - j->code_bits); - j->code_bits += 8; - } while (j->code_bits <= 24); +static void stbi__grow_buffer_unsafe(stbi__jpeg* j) { + do { + unsigned int b = j->nomore ? 0 : stbi__get8(j->s); + if (b == 0xff) { + int c = stbi__get8(j->s); + while (c == 0xff) + c = stbi__get8(j->s); // consume fill bytes + if (c != 0) { + j->marker = (unsigned char)c; + j->nomore = 1; + return; + } + } + j->code_buffer |= b << (24 - j->code_bits); + j->code_bits += 8; + } while (j->code_bits <= 24); } // (1 << n) - 1 -static const stbi__uint32 stbi__bmask[17]={0,1,3,7,15,31,63,127,255,511,1023,2047,4095,8191,16383,32767,65535}; +static const stbi__uint32 stbi__bmask[17] = { + 0, 1, 3, 7, 15, 31, 63, 127, 255, + 511, 1023, 2047, 4095, 8191, 16383, 32767, 65535}; // decode a jpeg huffman value from the bitstream -stbi_inline static int stbi__jpeg_huff_decode(stbi__jpeg *j, stbi__huffman *h) -{ - unsigned int temp; - int c,k; +stbi_inline static int stbi__jpeg_huff_decode(stbi__jpeg* j, stbi__huffman* h) { + unsigned int temp; + int c, k; - if (j->code_bits < 16) stbi__grow_buffer_unsafe(j); + if (j->code_bits < 16) + stbi__grow_buffer_unsafe(j); - // look at the top FAST_BITS and determine what symbol ID it is, - // if the code is <= FAST_BITS - c = (j->code_buffer >> (32 - FAST_BITS)) & ((1 << FAST_BITS)-1); - k = h->fast[c]; - if (k < 255) { - int s = h->size[k]; - if (s > j->code_bits) - return -1; - j->code_buffer <<= s; - j->code_bits -= s; - return h->values[k]; - } + // look at the top FAST_BITS and determine what symbol ID it is, + // if the code is <= FAST_BITS + c = (j->code_buffer >> (32 - FAST_BITS)) & ((1 << FAST_BITS) - 1); + k = h->fast[c]; + if (k < 255) { + int s = h->size[k]; + if (s > j->code_bits) + return -1; + j->code_buffer <<= s; + j->code_bits -= s; + return h->values[k]; + } - // naive test is to shift the code_buffer down so k bits are - // valid, then test against maxcode. To speed this up, we've - // preshifted maxcode left so that it has (16-k) 0s at the - // end; in other words, regardless of the number of bits, it - // wants to be compared against something shifted to have 16; - // that way we don't need to shift inside the loop. - temp = j->code_buffer >> 16; - for (k=FAST_BITS+1 ; ; ++k) - if (temp < h->maxcode[k]) - break; - if (k == 17) { - // error! code not found - j->code_bits -= 16; - return -1; - } + // naive test is to shift the code_buffer down so k bits are + // valid, then test against maxcode. To speed this up, we've + // preshifted maxcode left so that it has (16-k) 0s at the + // end; in other words, regardless of the number of bits, it + // wants to be compared against something shifted to have 16; + // that way we don't need to shift inside the loop. + temp = j->code_buffer >> 16; + for (k = FAST_BITS + 1;; ++k) + if (temp < h->maxcode[k]) + break; + if (k == 17) { + // error! code not found + j->code_bits -= 16; + return -1; + } - if (k > j->code_bits) - return -1; + if (k > j->code_bits) + return -1; - // convert the huffman code to the symbol id - c = ((j->code_buffer >> (32 - k)) & stbi__bmask[k]) + h->delta[k]; - if(c < 0 || c >= 256) // symbol id out of bounds! - return -1; - STBI_ASSERT((((j->code_buffer) >> (32 - h->size[c])) & stbi__bmask[h->size[c]]) == h->code[c]); + // convert the huffman code to the symbol id + c = ((j->code_buffer >> (32 - k)) & stbi__bmask[k]) + h->delta[k]; + if (c < 0 || c >= 256) // symbol id out of bounds! + return -1; + STBI_ASSERT((((j->code_buffer) >> (32 - h->size[c])) & + stbi__bmask[h->size[c]]) == h->code[c]); - // convert the id to a symbol - j->code_bits -= k; - j->code_buffer <<= k; - return h->values[c]; + // convert the id to a symbol + j->code_bits -= k; + j->code_buffer <<= k; + return h->values[c]; } // bias[n] = (-1<code_bits < n) stbi__grow_buffer_unsafe(j); - if (j->code_bits < n) return 0; // ran out of bits from stream, return 0s intead of continuing +stbi_inline static int stbi__extend_receive(stbi__jpeg* j, int n) { + unsigned int k; + int sgn; + if (j->code_bits < n) + stbi__grow_buffer_unsafe(j); + if (j->code_bits < n) + return 0; // ran out of bits from stream, return 0s intead of continuing - sgn = j->code_buffer >> 31; // sign bit always in MSB; 0 if MSB clear (positive), 1 if MSB set (negative) - k = stbi_lrot(j->code_buffer, n); - j->code_buffer = k & ~stbi__bmask[n]; - k &= stbi__bmask[n]; - j->code_bits -= n; - return k + (stbi__jbias[n] & (sgn - 1)); + sgn = j->code_buffer >> 31; // sign bit always in MSB; 0 if MSB clear + // (positive), 1 if MSB set (negative) + k = stbi_lrot(j->code_buffer, n); + j->code_buffer = k & ~stbi__bmask[n]; + k &= stbi__bmask[n]; + j->code_bits -= n; + return k + (stbi__jbias[n] & (sgn - 1)); } // get some unsigned bits -stbi_inline static int stbi__jpeg_get_bits(stbi__jpeg *j, int n) -{ - unsigned int k; - if (j->code_bits < n) stbi__grow_buffer_unsafe(j); - if (j->code_bits < n) return 0; // ran out of bits from stream, return 0s intead of continuing - k = stbi_lrot(j->code_buffer, n); - j->code_buffer = k & ~stbi__bmask[n]; - k &= stbi__bmask[n]; - j->code_bits -= n; - return k; +stbi_inline static int stbi__jpeg_get_bits(stbi__jpeg* j, int n) { + unsigned int k; + if (j->code_bits < n) + stbi__grow_buffer_unsafe(j); + if (j->code_bits < n) + return 0; // ran out of bits from stream, return 0s intead of continuing + k = stbi_lrot(j->code_buffer, n); + j->code_buffer = k & ~stbi__bmask[n]; + k &= stbi__bmask[n]; + j->code_bits -= n; + return k; } -stbi_inline static int stbi__jpeg_get_bit(stbi__jpeg *j) -{ - unsigned int k; - if (j->code_bits < 1) stbi__grow_buffer_unsafe(j); - if (j->code_bits < 1) return 0; // ran out of bits from stream, return 0s intead of continuing - k = j->code_buffer; - j->code_buffer <<= 1; - --j->code_bits; - return k & 0x80000000; +stbi_inline static int stbi__jpeg_get_bit(stbi__jpeg* j) { + unsigned int k; + if (j->code_bits < 1) + stbi__grow_buffer_unsafe(j); + if (j->code_bits < 1) + return 0; // ran out of bits from stream, return 0s intead of continuing + k = j->code_buffer; + j->code_buffer <<= 1; + --j->code_bits; + return k & 0x80000000; } // given a value that's at position X in the zigzag stream, // where does it appear in the 8x8 matrix coded as row-major? -static const stbi_uc stbi__jpeg_dezigzag[64+15] = -{ - 0, 1, 8, 16, 9, 2, 3, 10, - 17, 24, 32, 25, 18, 11, 4, 5, - 12, 19, 26, 33, 40, 48, 41, 34, - 27, 20, 13, 6, 7, 14, 21, 28, - 35, 42, 49, 56, 57, 50, 43, 36, - 29, 22, 15, 23, 30, 37, 44, 51, - 58, 59, 52, 45, 38, 31, 39, 46, - 53, 60, 61, 54, 47, 55, 62, 63, - // let corrupt input sample past end - 63, 63, 63, 63, 63, 63, 63, 63, - 63, 63, 63, 63, 63, 63, 63 -}; +static const stbi_uc stbi__jpeg_dezigzag[64 + 15] = { + 0, 1, 8, 16, 9, 2, 3, 10, 17, 24, 32, 25, 18, 11, 4, 5, 12, 19, 26, 33, 40, + 48, 41, 34, 27, 20, 13, 6, 7, 14, 21, 28, 35, 42, 49, 56, 57, 50, 43, 36, + 29, 22, 15, 23, 30, 37, 44, 51, 58, 59, 52, 45, 38, 31, 39, 46, 53, 60, 61, + 54, 47, 55, 62, 63, + // let corrupt input sample past end + 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63}; // decode one 64-entry block-- -static int stbi__jpeg_decode_block(stbi__jpeg *j, short data[64], stbi__huffman *hdc, stbi__huffman *hac, stbi__int16 *fac, int b, stbi__uint16 *dequant) -{ - int diff,dc,k; - int t; +static int stbi__jpeg_decode_block(stbi__jpeg* j, short data[64], + stbi__huffman* hdc, stbi__huffman* hac, + stbi__int16* fac, int b, + stbi__uint16* dequant) { + int diff, dc, k; + int t; - if (j->code_bits < 16) stbi__grow_buffer_unsafe(j); - t = stbi__jpeg_huff_decode(j, hdc); - if (t < 0 || t > 15) return stbi__err("bad huffman code","Corrupt JPEG"); + if (j->code_bits < 16) + stbi__grow_buffer_unsafe(j); + t = stbi__jpeg_huff_decode(j, hdc); + if (t < 0 || t > 15) + return stbi__err("bad huffman code", "Corrupt JPEG"); - // 0 all the ac values now so we can do it 32-bits at a time - memset(data,0,64*sizeof(data[0])); + // 0 all the ac values now so we can do it 32-bits at a time + memset(data, 0, 64 * sizeof(data[0])); - diff = t ? stbi__extend_receive(j, t) : 0; - if (!stbi__addints_valid(j->img_comp[b].dc_pred, diff)) return stbi__err("bad delta","Corrupt JPEG"); - dc = j->img_comp[b].dc_pred + diff; - j->img_comp[b].dc_pred = dc; - if (!stbi__mul2shorts_valid(dc, dequant[0])) return stbi__err("can't merge dc and ac", "Corrupt JPEG"); - data[0] = (short) (dc * dequant[0]); + diff = t ? stbi__extend_receive(j, t) : 0; + if (!stbi__addints_valid(j->img_comp[b].dc_pred, diff)) + return stbi__err("bad delta", "Corrupt JPEG"); + dc = j->img_comp[b].dc_pred + diff; + j->img_comp[b].dc_pred = dc; + if (!stbi__mul2shorts_valid(dc, dequant[0])) + return stbi__err("can't merge dc and ac", "Corrupt JPEG"); + data[0] = (short)(dc * dequant[0]); - // decode AC components, see JPEG spec - k = 1; - do { - unsigned int zig; - int c,r,s; - if (j->code_bits < 16) stbi__grow_buffer_unsafe(j); - c = (j->code_buffer >> (32 - FAST_BITS)) & ((1 << FAST_BITS)-1); - r = fac[c]; - if (r) { // fast-AC path - k += (r >> 4) & 15; // run - s = r & 15; // combined length - if (s > j->code_bits) return stbi__err("bad huffman code", "Combined length longer than code bits available"); - j->code_buffer <<= s; - j->code_bits -= s; - // decode into unzigzag'd location - zig = stbi__jpeg_dezigzag[k++]; - data[zig] = (short) ((r >> 8) * dequant[zig]); - } else { - int rs = stbi__jpeg_huff_decode(j, hac); - if (rs < 0) return stbi__err("bad huffman code","Corrupt JPEG"); - s = rs & 15; - r = rs >> 4; - if (s == 0) { - if (rs != 0xf0) break; // end block - k += 16; - } else { - k += r; + // decode AC components, see JPEG spec + k = 1; + do { + unsigned int zig; + int c, r, s; + if (j->code_bits < 16) + stbi__grow_buffer_unsafe(j); + c = (j->code_buffer >> (32 - FAST_BITS)) & ((1 << FAST_BITS) - 1); + r = fac[c]; + if (r) { // fast-AC path + k += (r >> 4) & 15; // run + s = r & 15; // combined length + if (s > j->code_bits) + return stbi__err( + "bad huffman code", + "Combined length longer than code bits available"); + j->code_buffer <<= s; + j->code_bits -= s; // decode into unzigzag'd location zig = stbi__jpeg_dezigzag[k++]; - data[zig] = (short) (stbi__extend_receive(j,s) * dequant[zig]); - } - } - } while (k < 64); - return 1; + data[zig] = (short)((r >> 8) * dequant[zig]); + } else { + int rs = stbi__jpeg_huff_decode(j, hac); + if (rs < 0) + return stbi__err("bad huffman code", "Corrupt JPEG"); + s = rs & 15; + r = rs >> 4; + if (s == 0) { + if (rs != 0xf0) + break; // end block + k += 16; + } else { + k += r; + // decode into unzigzag'd location + zig = stbi__jpeg_dezigzag[k++]; + data[zig] = (short)(stbi__extend_receive(j, s) * dequant[zig]); + } + } + } while (k < 64); + return 1; } -static int stbi__jpeg_decode_block_prog_dc(stbi__jpeg *j, short data[64], stbi__huffman *hdc, int b) -{ - int diff,dc; - int t; - if (j->spec_end != 0) return stbi__err("can't merge dc and ac", "Corrupt JPEG"); +static int stbi__jpeg_decode_block_prog_dc(stbi__jpeg* j, short data[64], + stbi__huffman* hdc, int b) { + int diff, dc; + int t; + if (j->spec_end != 0) + return stbi__err("can't merge dc and ac", "Corrupt JPEG"); - if (j->code_bits < 16) stbi__grow_buffer_unsafe(j); + if (j->code_bits < 16) + stbi__grow_buffer_unsafe(j); - if (j->succ_high == 0) { - // first scan for DC coefficient, must be first - memset(data,0,64*sizeof(data[0])); // 0 all the ac values now - t = stbi__jpeg_huff_decode(j, hdc); - if (t < 0 || t > 15) return stbi__err("can't merge dc and ac", "Corrupt JPEG"); - diff = t ? stbi__extend_receive(j, t) : 0; + if (j->succ_high == 0) { + // first scan for DC coefficient, must be first + memset(data, 0, 64 * sizeof(data[0])); // 0 all the ac values now + t = stbi__jpeg_huff_decode(j, hdc); + if (t < 0 || t > 15) + return stbi__err("can't merge dc and ac", "Corrupt JPEG"); + diff = t ? stbi__extend_receive(j, t) : 0; - if (!stbi__addints_valid(j->img_comp[b].dc_pred, diff)) return stbi__err("bad delta", "Corrupt JPEG"); - dc = j->img_comp[b].dc_pred + diff; - j->img_comp[b].dc_pred = dc; - if (!stbi__mul2shorts_valid(dc, 1 << j->succ_low)) return stbi__err("can't merge dc and ac", "Corrupt JPEG"); - data[0] = (short) (dc * (1 << j->succ_low)); - } else { - // refinement scan for DC coefficient - if (stbi__jpeg_get_bit(j)) - data[0] += (short) (1 << j->succ_low); - } - return 1; + if (!stbi__addints_valid(j->img_comp[b].dc_pred, diff)) + return stbi__err("bad delta", "Corrupt JPEG"); + dc = j->img_comp[b].dc_pred + diff; + j->img_comp[b].dc_pred = dc; + if (!stbi__mul2shorts_valid(dc, 1 << j->succ_low)) + return stbi__err("can't merge dc and ac", "Corrupt JPEG"); + data[0] = (short)(dc * (1 << j->succ_low)); + } else { + // refinement scan for DC coefficient + if (stbi__jpeg_get_bit(j)) + data[0] += (short)(1 << j->succ_low); + } + return 1; } // @OPTIMIZE: store non-zigzagged during the decode passes, // and only de-zigzag when dequantizing -static int stbi__jpeg_decode_block_prog_ac(stbi__jpeg *j, short data[64], stbi__huffman *hac, stbi__int16 *fac) -{ - int k; - if (j->spec_start == 0) return stbi__err("can't merge dc and ac", "Corrupt JPEG"); +static int stbi__jpeg_decode_block_prog_ac(stbi__jpeg* j, short data[64], + stbi__huffman* hac, + stbi__int16* fac) { + int k; + if (j->spec_start == 0) + return stbi__err("can't merge dc and ac", "Corrupt JPEG"); - if (j->succ_high == 0) { - int shift = j->succ_low; + if (j->succ_high == 0) { + int shift = j->succ_low; - if (j->eob_run) { - --j->eob_run; - return 1; - } + if (j->eob_run) { + --j->eob_run; + return 1; + } - k = j->spec_start; - do { - unsigned int zig; - int c,r,s; - if (j->code_bits < 16) stbi__grow_buffer_unsafe(j); - c = (j->code_buffer >> (32 - FAST_BITS)) & ((1 << FAST_BITS)-1); - r = fac[c]; - if (r) { // fast-AC path - k += (r >> 4) & 15; // run - s = r & 15; // combined length - if (s > j->code_bits) return stbi__err("bad huffman code", "Combined length longer than code bits available"); - j->code_buffer <<= s; - j->code_bits -= s; - zig = stbi__jpeg_dezigzag[k++]; - data[zig] = (short) ((r >> 8) * (1 << shift)); - } else { - int rs = stbi__jpeg_huff_decode(j, hac); - if (rs < 0) return stbi__err("bad huffman code","Corrupt JPEG"); - s = rs & 15; - r = rs >> 4; - if (s == 0) { - if (r < 15) { - j->eob_run = (1 << r); - if (r) - j->eob_run += stbi__jpeg_get_bits(j, r); - --j->eob_run; - break; - } - k += 16; + k = j->spec_start; + do { + unsigned int zig; + int c, r, s; + if (j->code_bits < 16) + stbi__grow_buffer_unsafe(j); + c = (j->code_buffer >> (32 - FAST_BITS)) & ((1 << FAST_BITS) - 1); + r = fac[c]; + if (r) { // fast-AC path + k += (r >> 4) & 15; // run + s = r & 15; // combined length + if (s > j->code_bits) + return stbi__err( + "bad huffman code", + "Combined length longer than code bits available"); + j->code_buffer <<= s; + j->code_bits -= s; + zig = stbi__jpeg_dezigzag[k++]; + data[zig] = (short)((r >> 8) * (1 << shift)); } else { - k += r; - zig = stbi__jpeg_dezigzag[k++]; - data[zig] = (short) (stbi__extend_receive(j,s) * (1 << shift)); + int rs = stbi__jpeg_huff_decode(j, hac); + if (rs < 0) + return stbi__err("bad huffman code", "Corrupt JPEG"); + s = rs & 15; + r = rs >> 4; + if (s == 0) { + if (r < 15) { + j->eob_run = (1 << r); + if (r) + j->eob_run += stbi__jpeg_get_bits(j, r); + --j->eob_run; + break; + } + k += 16; + } else { + k += r; + zig = stbi__jpeg_dezigzag[k++]; + data[zig] = + (short)(stbi__extend_receive(j, s) * (1 << shift)); + } } - } - } while (k <= j->spec_end); - } else { - // refinement scan for these AC coefficients + } while (k <= j->spec_end); + } else { + // refinement scan for these AC coefficients - short bit = (short) (1 << j->succ_low); + short bit = (short)(1 << j->succ_low); - if (j->eob_run) { - --j->eob_run; - for (k = j->spec_start; k <= j->spec_end; ++k) { - short *p = &data[stbi__jpeg_dezigzag[k]]; - if (*p != 0) - if (stbi__jpeg_get_bit(j)) - if ((*p & bit)==0) { - if (*p > 0) - *p += bit; - else - *p -= bit; - } - } - } else { - k = j->spec_start; - do { - int r,s; - int rs = stbi__jpeg_huff_decode(j, hac); // @OPTIMIZE see if we can use the fast path here, advance-by-r is so slow, eh - if (rs < 0) return stbi__err("bad huffman code","Corrupt JPEG"); - s = rs & 15; - r = rs >> 4; - if (s == 0) { - if (r < 15) { - j->eob_run = (1 << r) - 1; - if (r) - j->eob_run += stbi__jpeg_get_bits(j, r); - r = 64; // force end of block - } else { - // r=15 s=0 should write 16 0s, so we just do - // a run of 15 0s and then write s (which is 0), - // so we don't have to do anything special here - } - } else { - if (s != 1) return stbi__err("bad huffman code", "Corrupt JPEG"); - // sign bit - if (stbi__jpeg_get_bit(j)) - s = bit; - else - s = -bit; + if (j->eob_run) { + --j->eob_run; + for (k = j->spec_start; k <= j->spec_end; ++k) { + short* p = &data[stbi__jpeg_dezigzag[k]]; + if (*p != 0) + if (stbi__jpeg_get_bit(j)) + if ((*p & bit) == 0) { + if (*p > 0) + *p += bit; + else + *p -= bit; + } } + } else { + k = j->spec_start; + do { + int r, s; + int rs = stbi__jpeg_huff_decode( + j, hac); // @OPTIMIZE see if we can use the fast path here, + // advance-by-r is so slow, eh + if (rs < 0) + return stbi__err("bad huffman code", "Corrupt JPEG"); + s = rs & 15; + r = rs >> 4; + if (s == 0) { + if (r < 15) { + j->eob_run = (1 << r) - 1; + if (r) + j->eob_run += stbi__jpeg_get_bits(j, r); + r = 64; // force end of block + } else { + // r=15 s=0 should write 16 0s, so we just do + // a run of 15 0s and then write s (which is 0), + // so we don't have to do anything special here + } + } else { + if (s != 1) + return stbi__err("bad huffman code", "Corrupt JPEG"); + // sign bit + if (stbi__jpeg_get_bit(j)) + s = bit; + else + s = -bit; + } - // advance by r - while (k <= j->spec_end) { - short *p = &data[stbi__jpeg_dezigzag[k++]]; - if (*p != 0) { - if (stbi__jpeg_get_bit(j)) - if ((*p & bit)==0) { - if (*p > 0) - *p += bit; - else - *p -= bit; - } - } else { - if (r == 0) { - *p = (short) s; - break; - } - --r; - } - } - } while (k <= j->spec_end); - } - } - return 1; + // advance by r + while (k <= j->spec_end) { + short* p = &data[stbi__jpeg_dezigzag[k++]]; + if (*p != 0) { + if (stbi__jpeg_get_bit(j)) + if ((*p & bit) == 0) { + if (*p > 0) + *p += bit; + else + *p -= bit; + } + } else { + if (r == 0) { + *p = (short)s; + break; + } + --r; + } + } + } while (k <= j->spec_end); + } + } + return 1; } // take a -128..127 value and stbi__clamp it and convert to 0..255 -stbi_inline static stbi_uc stbi__clamp(int x) -{ - // trick to use a single test to catch both cases - if ((unsigned int) x > 255) { - if (x < 0) return 0; - if (x > 255) return 255; - } - return (stbi_uc) x; +stbi_inline static stbi_uc stbi__clamp(int x) { + // trick to use a single test to catch both cases + if ((unsigned int)x > 255) { + if (x < 0) + return 0; + if (x > 255) + return 255; + } + return (stbi_uc)x; } -#define stbi__f2f(x) ((int) (((x) * 4096 + 0.5))) -#define stbi__fsh(x) ((x) * 4096) +#define stbi__f2f(x) ((int)(((x) * 4096 + 0.5))) +#define stbi__fsh(x) ((x) * 4096) // derived from jidctint -- DCT_ISLOW -#define STBI__IDCT_1D(s0,s1,s2,s3,s4,s5,s6,s7) \ - int t0,t1,t2,t3,p1,p2,p3,p4,p5,x0,x1,x2,x3; \ - p2 = s2; \ - p3 = s6; \ - p1 = (p2+p3) * stbi__f2f(0.5411961f); \ - t2 = p1 + p3*stbi__f2f(-1.847759065f); \ - t3 = p1 + p2*stbi__f2f( 0.765366865f); \ - p2 = s0; \ - p3 = s4; \ - t0 = stbi__fsh(p2+p3); \ - t1 = stbi__fsh(p2-p3); \ - x0 = t0+t3; \ - x3 = t0-t3; \ - x1 = t1+t2; \ - x2 = t1-t2; \ - t0 = s7; \ - t1 = s5; \ - t2 = s3; \ - t3 = s1; \ - p3 = t0+t2; \ - p4 = t1+t3; \ - p1 = t0+t3; \ - p2 = t1+t2; \ - p5 = (p3+p4)*stbi__f2f( 1.175875602f); \ - t0 = t0*stbi__f2f( 0.298631336f); \ - t1 = t1*stbi__f2f( 2.053119869f); \ - t2 = t2*stbi__f2f( 3.072711026f); \ - t3 = t3*stbi__f2f( 1.501321110f); \ - p1 = p5 + p1*stbi__f2f(-0.899976223f); \ - p2 = p5 + p2*stbi__f2f(-2.562915447f); \ - p3 = p3*stbi__f2f(-1.961570560f); \ - p4 = p4*stbi__f2f(-0.390180644f); \ - t3 += p1+p4; \ - t2 += p2+p3; \ - t1 += p2+p4; \ - t0 += p1+p3; +#define STBI__IDCT_1D(s0, s1, s2, s3, s4, s5, s6, s7) \ + int t0, t1, t2, t3, p1, p2, p3, p4, p5, x0, x1, x2, x3; \ + p2 = s2; \ + p3 = s6; \ + p1 = (p2 + p3) * stbi__f2f(0.5411961f); \ + t2 = p1 + p3 * stbi__f2f(-1.847759065f); \ + t3 = p1 + p2 * stbi__f2f(0.765366865f); \ + p2 = s0; \ + p3 = s4; \ + t0 = stbi__fsh(p2 + p3); \ + t1 = stbi__fsh(p2 - p3); \ + x0 = t0 + t3; \ + x3 = t0 - t3; \ + x1 = t1 + t2; \ + x2 = t1 - t2; \ + t0 = s7; \ + t1 = s5; \ + t2 = s3; \ + t3 = s1; \ + p3 = t0 + t2; \ + p4 = t1 + t3; \ + p1 = t0 + t3; \ + p2 = t1 + t2; \ + p5 = (p3 + p4) * stbi__f2f(1.175875602f); \ + t0 = t0 * stbi__f2f(0.298631336f); \ + t1 = t1 * stbi__f2f(2.053119869f); \ + t2 = t2 * stbi__f2f(3.072711026f); \ + t3 = t3 * stbi__f2f(1.501321110f); \ + p1 = p5 + p1 * stbi__f2f(-0.899976223f); \ + p2 = p5 + p2 * stbi__f2f(-2.562915447f); \ + p3 = p3 * stbi__f2f(-1.961570560f); \ + p4 = p4 * stbi__f2f(-0.390180644f); \ + t3 += p1 + p4; \ + t2 += p2 + p3; \ + t1 += p2 + p4; \ + t0 += p1 + p3; -static void stbi__idct_block(stbi_uc *out, int out_stride, short data[64]) -{ - int i,val[64],*v=val; - stbi_uc *o; - short *d = data; +static void stbi__idct_block(stbi_uc* out, int out_stride, short data[64]) { + int i, val[64], *v = val; + stbi_uc* o; + short* d = data; - // columns - for (i=0; i < 8; ++i,++d, ++v) { - // if all zeroes, shortcut -- this avoids dequantizing 0s and IDCTing - if (d[ 8]==0 && d[16]==0 && d[24]==0 && d[32]==0 - && d[40]==0 && d[48]==0 && d[56]==0) { - // no shortcut 0 seconds - // (1|2|3|4|5|6|7)==0 0 seconds - // all separate -0.047 seconds - // 1 && 2|3 && 4|5 && 6|7: -0.047 seconds - int dcterm = d[0]*4; - v[0] = v[8] = v[16] = v[24] = v[32] = v[40] = v[48] = v[56] = dcterm; - } else { - STBI__IDCT_1D(d[ 0],d[ 8],d[16],d[24],d[32],d[40],d[48],d[56]) - // constants scaled things up by 1<<12; let's bring them back - // down, but keep 2 extra bits of precision - x0 += 512; x1 += 512; x2 += 512; x3 += 512; - v[ 0] = (x0+t3) >> 10; - v[56] = (x0-t3) >> 10; - v[ 8] = (x1+t2) >> 10; - v[48] = (x1-t2) >> 10; - v[16] = (x2+t1) >> 10; - v[40] = (x2-t1) >> 10; - v[24] = (x3+t0) >> 10; - v[32] = (x3-t0) >> 10; - } - } + // columns + for (i = 0; i < 8; ++i, ++d, ++v) { + // if all zeroes, shortcut -- this avoids dequantizing 0s and IDCTing + if (d[8] == 0 && d[16] == 0 && d[24] == 0 && d[32] == 0 && d[40] == 0 && + d[48] == 0 && d[56] == 0) { + // no shortcut 0 seconds + // (1|2|3|4|5|6|7)==0 0 seconds + // all separate -0.047 seconds + // 1 && 2|3 && 4|5 && 6|7: -0.047 seconds + int dcterm = d[0] * 4; + v[0] = v[8] = v[16] = v[24] = v[32] = v[40] = v[48] = v[56] = + dcterm; + } else { + STBI__IDCT_1D(d[0], d[8], d[16], d[24], d[32], d[40], d[48], d[56]) + // constants scaled things up by 1<<12; let's bring them back + // down, but keep 2 extra bits of precision + x0 += 512; + x1 += 512; + x2 += 512; + x3 += 512; + v[0] = (x0 + t3) >> 10; + v[56] = (x0 - t3) >> 10; + v[8] = (x1 + t2) >> 10; + v[48] = (x1 - t2) >> 10; + v[16] = (x2 + t1) >> 10; + v[40] = (x2 - t1) >> 10; + v[24] = (x3 + t0) >> 10; + v[32] = (x3 - t0) >> 10; + } + } - for (i=0, v=val, o=out; i < 8; ++i,v+=8,o+=out_stride) { - // no fast case since the first 1D IDCT spread components out - STBI__IDCT_1D(v[0],v[1],v[2],v[3],v[4],v[5],v[6],v[7]) - // constants scaled things up by 1<<12, plus we had 1<<2 from first - // loop, plus horizontal and vertical each scale by sqrt(8) so together - // we've got an extra 1<<3, so 1<<17 total we need to remove. - // so we want to round that, which means adding 0.5 * 1<<17, - // aka 65536. Also, we'll end up with -128 to 127 that we want - // to encode as 0..255 by adding 128, so we'll add that before the shift - x0 += 65536 + (128<<17); - x1 += 65536 + (128<<17); - x2 += 65536 + (128<<17); - x3 += 65536 + (128<<17); - // tried computing the shifts into temps, or'ing the temps to see - // if any were out of range, but that was slower - o[0] = stbi__clamp((x0+t3) >> 17); - o[7] = stbi__clamp((x0-t3) >> 17); - o[1] = stbi__clamp((x1+t2) >> 17); - o[6] = stbi__clamp((x1-t2) >> 17); - o[2] = stbi__clamp((x2+t1) >> 17); - o[5] = stbi__clamp((x2-t1) >> 17); - o[3] = stbi__clamp((x3+t0) >> 17); - o[4] = stbi__clamp((x3-t0) >> 17); - } + for (i = 0, v = val, o = out; i < 8; ++i, v += 8, o += out_stride) { + // no fast case since the first 1D IDCT spread components out + STBI__IDCT_1D(v[0], v[1], v[2], v[3], v[4], v[5], v[6], v[7]) + // constants scaled things up by 1<<12, plus we had 1<<2 from first + // loop, plus horizontal and vertical each scale by sqrt(8) so together + // we've got an extra 1<<3, so 1<<17 total we need to remove. + // so we want to round that, which means adding 0.5 * 1<<17, + // aka 65536. Also, we'll end up with -128 to 127 that we want + // to encode as 0..255 by adding 128, so we'll add that before the shift + x0 += 65536 + (128 << 17); + x1 += 65536 + (128 << 17); + x2 += 65536 + (128 << 17); + x3 += 65536 + (128 << 17); + // tried computing the shifts into temps, or'ing the temps to see + // if any were out of range, but that was slower + o[0] = stbi__clamp((x0 + t3) >> 17); + o[7] = stbi__clamp((x0 - t3) >> 17); + o[1] = stbi__clamp((x1 + t2) >> 17); + o[6] = stbi__clamp((x1 - t2) >> 17); + o[2] = stbi__clamp((x2 + t1) >> 17); + o[5] = stbi__clamp((x2 - t1) >> 17); + o[3] = stbi__clamp((x3 + t0) >> 17); + o[4] = stbi__clamp((x3 - t0) >> 17); + } } #ifdef STBI_SSE2 // sse2 integer IDCT. not the fastest possible implementation but it // produces bit-identical results to the generic C version so it's // fully "transparent". -static void stbi__idct_simd(stbi_uc *out, int out_stride, short data[64]) -{ - // This is constructed to match our regular (generic) integer IDCT exactly. - __m128i row0, row1, row2, row3, row4, row5, row6, row7; - __m128i tmp; +static void stbi__idct_simd(stbi_uc* out, int out_stride, short data[64]) { + // This is constructed to match our regular (generic) integer IDCT exactly. + __m128i row0, row1, row2, row3, row4, row5, row6, row7; + __m128i tmp; - // dot product constant: even elems=x, odd elems=y - #define dct_const(x,y) _mm_setr_epi16((x),(y),(x),(y),(x),(y),(x),(y)) +// dot product constant: even elems=x, odd elems=y +#define dct_const(x, y) _mm_setr_epi16((x), (y), (x), (y), (x), (y), (x), (y)) - // out(0) = c0[even]*x + c0[odd]*y (c0, x, y 16-bit, out 32-bit) - // out(1) = c1[even]*x + c1[odd]*y - #define dct_rot(out0,out1, x,y,c0,c1) \ - __m128i c0##lo = _mm_unpacklo_epi16((x),(y)); \ - __m128i c0##hi = _mm_unpackhi_epi16((x),(y)); \ - __m128i out0##_l = _mm_madd_epi16(c0##lo, c0); \ - __m128i out0##_h = _mm_madd_epi16(c0##hi, c0); \ - __m128i out1##_l = _mm_madd_epi16(c0##lo, c1); \ - __m128i out1##_h = _mm_madd_epi16(c0##hi, c1) +// out(0) = c0[even]*x + c0[odd]*y (c0, x, y 16-bit, out 32-bit) +// out(1) = c1[even]*x + c1[odd]*y +#define dct_rot(out0, out1, x, y, c0, c1) \ + __m128i c0##lo = _mm_unpacklo_epi16((x), (y)); \ + __m128i c0##hi = _mm_unpackhi_epi16((x), (y)); \ + __m128i out0##_l = _mm_madd_epi16(c0##lo, c0); \ + __m128i out0##_h = _mm_madd_epi16(c0##hi, c0); \ + __m128i out1##_l = _mm_madd_epi16(c0##lo, c1); \ + __m128i out1##_h = _mm_madd_epi16(c0##hi, c1) - // out = in << 12 (in 16-bit, out 32-bit) - #define dct_widen(out, in) \ - __m128i out##_l = _mm_srai_epi32(_mm_unpacklo_epi16(_mm_setzero_si128(), (in)), 4); \ - __m128i out##_h = _mm_srai_epi32(_mm_unpackhi_epi16(_mm_setzero_si128(), (in)), 4) +// out = in << 12 (in 16-bit, out 32-bit) +#define dct_widen(out, in) \ + __m128i out##_l = \ + _mm_srai_epi32(_mm_unpacklo_epi16(_mm_setzero_si128(), (in)), 4); \ + __m128i out##_h = \ + _mm_srai_epi32(_mm_unpackhi_epi16(_mm_setzero_si128(), (in)), 4) - // wide add - #define dct_wadd(out, a, b) \ - __m128i out##_l = _mm_add_epi32(a##_l, b##_l); \ - __m128i out##_h = _mm_add_epi32(a##_h, b##_h) +// wide add +#define dct_wadd(out, a, b) \ + __m128i out##_l = _mm_add_epi32(a##_l, b##_l); \ + __m128i out##_h = _mm_add_epi32(a##_h, b##_h) - // wide sub - #define dct_wsub(out, a, b) \ - __m128i out##_l = _mm_sub_epi32(a##_l, b##_l); \ - __m128i out##_h = _mm_sub_epi32(a##_h, b##_h) +// wide sub +#define dct_wsub(out, a, b) \ + __m128i out##_l = _mm_sub_epi32(a##_l, b##_l); \ + __m128i out##_h = _mm_sub_epi32(a##_h, b##_h) - // butterfly a/b, add bias, then shift by "s" and pack - #define dct_bfly32o(out0, out1, a,b,bias,s) \ - { \ - __m128i abiased_l = _mm_add_epi32(a##_l, bias); \ - __m128i abiased_h = _mm_add_epi32(a##_h, bias); \ - dct_wadd(sum, abiased, b); \ - dct_wsub(dif, abiased, b); \ - out0 = _mm_packs_epi32(_mm_srai_epi32(sum_l, s), _mm_srai_epi32(sum_h, s)); \ - out1 = _mm_packs_epi32(_mm_srai_epi32(dif_l, s), _mm_srai_epi32(dif_h, s)); \ - } +// butterfly a/b, add bias, then shift by "s" and pack +#define dct_bfly32o(out0, out1, a, b, bias, s) \ + { \ + __m128i abiased_l = _mm_add_epi32(a##_l, bias); \ + __m128i abiased_h = _mm_add_epi32(a##_h, bias); \ + dct_wadd(sum, abiased, b); \ + dct_wsub(dif, abiased, b); \ + out0 = _mm_packs_epi32(_mm_srai_epi32(sum_l, s), \ + _mm_srai_epi32(sum_h, s)); \ + out1 = _mm_packs_epi32(_mm_srai_epi32(dif_l, s), \ + _mm_srai_epi32(dif_h, s)); \ + } - // 8-bit interleave step (for transposes) - #define dct_interleave8(a, b) \ - tmp = a; \ - a = _mm_unpacklo_epi8(a, b); \ - b = _mm_unpackhi_epi8(tmp, b) +// 8-bit interleave step (for transposes) +#define dct_interleave8(a, b) \ + tmp = a; \ + a = _mm_unpacklo_epi8(a, b); \ + b = _mm_unpackhi_epi8(tmp, b) - // 16-bit interleave step (for transposes) - #define dct_interleave16(a, b) \ - tmp = a; \ - a = _mm_unpacklo_epi16(a, b); \ - b = _mm_unpackhi_epi16(tmp, b) +// 16-bit interleave step (for transposes) +#define dct_interleave16(a, b) \ + tmp = a; \ + a = _mm_unpacklo_epi16(a, b); \ + b = _mm_unpackhi_epi16(tmp, b) - #define dct_pass(bias,shift) \ - { \ - /* even part */ \ - dct_rot(t2e,t3e, row2,row6, rot0_0,rot0_1); \ - __m128i sum04 = _mm_add_epi16(row0, row4); \ - __m128i dif04 = _mm_sub_epi16(row0, row4); \ - dct_widen(t0e, sum04); \ - dct_widen(t1e, dif04); \ - dct_wadd(x0, t0e, t3e); \ - dct_wsub(x3, t0e, t3e); \ - dct_wadd(x1, t1e, t2e); \ - dct_wsub(x2, t1e, t2e); \ - /* odd part */ \ - dct_rot(y0o,y2o, row7,row3, rot2_0,rot2_1); \ - dct_rot(y1o,y3o, row5,row1, rot3_0,rot3_1); \ - __m128i sum17 = _mm_add_epi16(row1, row7); \ - __m128i sum35 = _mm_add_epi16(row3, row5); \ - dct_rot(y4o,y5o, sum17,sum35, rot1_0,rot1_1); \ - dct_wadd(x4, y0o, y4o); \ - dct_wadd(x5, y1o, y5o); \ - dct_wadd(x6, y2o, y5o); \ - dct_wadd(x7, y3o, y4o); \ - dct_bfly32o(row0,row7, x0,x7,bias,shift); \ - dct_bfly32o(row1,row6, x1,x6,bias,shift); \ - dct_bfly32o(row2,row5, x2,x5,bias,shift); \ - dct_bfly32o(row3,row4, x3,x4,bias,shift); \ - } +#define dct_pass(bias, shift) \ + { \ + /* even part */ \ + dct_rot(t2e, t3e, row2, row6, rot0_0, rot0_1); \ + __m128i sum04 = _mm_add_epi16(row0, row4); \ + __m128i dif04 = _mm_sub_epi16(row0, row4); \ + dct_widen(t0e, sum04); \ + dct_widen(t1e, dif04); \ + dct_wadd(x0, t0e, t3e); \ + dct_wsub(x3, t0e, t3e); \ + dct_wadd(x1, t1e, t2e); \ + dct_wsub(x2, t1e, t2e); \ + /* odd part */ \ + dct_rot(y0o, y2o, row7, row3, rot2_0, rot2_1); \ + dct_rot(y1o, y3o, row5, row1, rot3_0, rot3_1); \ + __m128i sum17 = _mm_add_epi16(row1, row7); \ + __m128i sum35 = _mm_add_epi16(row3, row5); \ + dct_rot(y4o, y5o, sum17, sum35, rot1_0, rot1_1); \ + dct_wadd(x4, y0o, y4o); \ + dct_wadd(x5, y1o, y5o); \ + dct_wadd(x6, y2o, y5o); \ + dct_wadd(x7, y3o, y4o); \ + dct_bfly32o(row0, row7, x0, x7, bias, shift); \ + dct_bfly32o(row1, row6, x1, x6, bias, shift); \ + dct_bfly32o(row2, row5, x2, x5, bias, shift); \ + dct_bfly32o(row3, row4, x3, x4, bias, shift); \ + } - __m128i rot0_0 = dct_const(stbi__f2f(0.5411961f), stbi__f2f(0.5411961f) + stbi__f2f(-1.847759065f)); - __m128i rot0_1 = dct_const(stbi__f2f(0.5411961f) + stbi__f2f( 0.765366865f), stbi__f2f(0.5411961f)); - __m128i rot1_0 = dct_const(stbi__f2f(1.175875602f) + stbi__f2f(-0.899976223f), stbi__f2f(1.175875602f)); - __m128i rot1_1 = dct_const(stbi__f2f(1.175875602f), stbi__f2f(1.175875602f) + stbi__f2f(-2.562915447f)); - __m128i rot2_0 = dct_const(stbi__f2f(-1.961570560f) + stbi__f2f( 0.298631336f), stbi__f2f(-1.961570560f)); - __m128i rot2_1 = dct_const(stbi__f2f(-1.961570560f), stbi__f2f(-1.961570560f) + stbi__f2f( 3.072711026f)); - __m128i rot3_0 = dct_const(stbi__f2f(-0.390180644f) + stbi__f2f( 2.053119869f), stbi__f2f(-0.390180644f)); - __m128i rot3_1 = dct_const(stbi__f2f(-0.390180644f), stbi__f2f(-0.390180644f) + stbi__f2f( 1.501321110f)); + __m128i rot0_0 = + dct_const(stbi__f2f(0.5411961f), + stbi__f2f(0.5411961f) + stbi__f2f(-1.847759065f)); + __m128i rot0_1 = dct_const(stbi__f2f(0.5411961f) + stbi__f2f(0.765366865f), + stbi__f2f(0.5411961f)); + __m128i rot1_0 = + dct_const(stbi__f2f(1.175875602f) + stbi__f2f(-0.899976223f), + stbi__f2f(1.175875602f)); + __m128i rot1_1 = + dct_const(stbi__f2f(1.175875602f), + stbi__f2f(1.175875602f) + stbi__f2f(-2.562915447f)); + __m128i rot2_0 = + dct_const(stbi__f2f(-1.961570560f) + stbi__f2f(0.298631336f), + stbi__f2f(-1.961570560f)); + __m128i rot2_1 = + dct_const(stbi__f2f(-1.961570560f), + stbi__f2f(-1.961570560f) + stbi__f2f(3.072711026f)); + __m128i rot3_0 = + dct_const(stbi__f2f(-0.390180644f) + stbi__f2f(2.053119869f), + stbi__f2f(-0.390180644f)); + __m128i rot3_1 = + dct_const(stbi__f2f(-0.390180644f), + stbi__f2f(-0.390180644f) + stbi__f2f(1.501321110f)); - // rounding biases in column/row passes, see stbi__idct_block for explanation. - __m128i bias_0 = _mm_set1_epi32(512); - __m128i bias_1 = _mm_set1_epi32(65536 + (128<<17)); + // rounding biases in column/row passes, see stbi__idct_block for + // explanation. + __m128i bias_0 = _mm_set1_epi32(512); + __m128i bias_1 = _mm_set1_epi32(65536 + (128 << 17)); - // load - row0 = _mm_load_si128((const __m128i *) (data + 0*8)); - row1 = _mm_load_si128((const __m128i *) (data + 1*8)); - row2 = _mm_load_si128((const __m128i *) (data + 2*8)); - row3 = _mm_load_si128((const __m128i *) (data + 3*8)); - row4 = _mm_load_si128((const __m128i *) (data + 4*8)); - row5 = _mm_load_si128((const __m128i *) (data + 5*8)); - row6 = _mm_load_si128((const __m128i *) (data + 6*8)); - row7 = _mm_load_si128((const __m128i *) (data + 7*8)); + // load + row0 = _mm_load_si128((const __m128i*)(data + 0 * 8)); + row1 = _mm_load_si128((const __m128i*)(data + 1 * 8)); + row2 = _mm_load_si128((const __m128i*)(data + 2 * 8)); + row3 = _mm_load_si128((const __m128i*)(data + 3 * 8)); + row4 = _mm_load_si128((const __m128i*)(data + 4 * 8)); + row5 = _mm_load_si128((const __m128i*)(data + 5 * 8)); + row6 = _mm_load_si128((const __m128i*)(data + 6 * 8)); + row7 = _mm_load_si128((const __m128i*)(data + 7 * 8)); - // column pass - dct_pass(bias_0, 10); + // column pass + dct_pass(bias_0, 10); - { - // 16bit 8x8 transpose pass 1 - dct_interleave16(row0, row4); - dct_interleave16(row1, row5); - dct_interleave16(row2, row6); - dct_interleave16(row3, row7); + { + // 16bit 8x8 transpose pass 1 + dct_interleave16(row0, row4); + dct_interleave16(row1, row5); + dct_interleave16(row2, row6); + dct_interleave16(row3, row7); - // transpose pass 2 - dct_interleave16(row0, row2); - dct_interleave16(row1, row3); - dct_interleave16(row4, row6); - dct_interleave16(row5, row7); + // transpose pass 2 + dct_interleave16(row0, row2); + dct_interleave16(row1, row3); + dct_interleave16(row4, row6); + dct_interleave16(row5, row7); - // transpose pass 3 - dct_interleave16(row0, row1); - dct_interleave16(row2, row3); - dct_interleave16(row4, row5); - dct_interleave16(row6, row7); - } + // transpose pass 3 + dct_interleave16(row0, row1); + dct_interleave16(row2, row3); + dct_interleave16(row4, row5); + dct_interleave16(row6, row7); + } - // row pass - dct_pass(bias_1, 17); + // row pass + dct_pass(bias_1, 17); - { - // pack - __m128i p0 = _mm_packus_epi16(row0, row1); // a0a1a2a3...a7b0b1b2b3...b7 - __m128i p1 = _mm_packus_epi16(row2, row3); - __m128i p2 = _mm_packus_epi16(row4, row5); - __m128i p3 = _mm_packus_epi16(row6, row7); + { + // pack + __m128i p0 = _mm_packus_epi16(row0, row1); // a0a1a2a3...a7b0b1b2b3...b7 + __m128i p1 = _mm_packus_epi16(row2, row3); + __m128i p2 = _mm_packus_epi16(row4, row5); + __m128i p3 = _mm_packus_epi16(row6, row7); - // 8bit 8x8 transpose pass 1 - dct_interleave8(p0, p2); // a0e0a1e1... - dct_interleave8(p1, p3); // c0g0c1g1... + // 8bit 8x8 transpose pass 1 + dct_interleave8(p0, p2); // a0e0a1e1... + dct_interleave8(p1, p3); // c0g0c1g1... - // transpose pass 2 - dct_interleave8(p0, p1); // a0c0e0g0... - dct_interleave8(p2, p3); // b0d0f0h0... + // transpose pass 2 + dct_interleave8(p0, p1); // a0c0e0g0... + dct_interleave8(p2, p3); // b0d0f0h0... - // transpose pass 3 - dct_interleave8(p0, p2); // a0b0c0d0... - dct_interleave8(p1, p3); // a4b4c4d4... + // transpose pass 3 + dct_interleave8(p0, p2); // a0b0c0d0... + dct_interleave8(p1, p3); // a4b4c4d4... - // store - _mm_storel_epi64((__m128i *) out, p0); out += out_stride; - _mm_storel_epi64((__m128i *) out, _mm_shuffle_epi32(p0, 0x4e)); out += out_stride; - _mm_storel_epi64((__m128i *) out, p2); out += out_stride; - _mm_storel_epi64((__m128i *) out, _mm_shuffle_epi32(p2, 0x4e)); out += out_stride; - _mm_storel_epi64((__m128i *) out, p1); out += out_stride; - _mm_storel_epi64((__m128i *) out, _mm_shuffle_epi32(p1, 0x4e)); out += out_stride; - _mm_storel_epi64((__m128i *) out, p3); out += out_stride; - _mm_storel_epi64((__m128i *) out, _mm_shuffle_epi32(p3, 0x4e)); - } + // store + _mm_storel_epi64((__m128i*)out, p0); + out += out_stride; + _mm_storel_epi64((__m128i*)out, _mm_shuffle_epi32(p0, 0x4e)); + out += out_stride; + _mm_storel_epi64((__m128i*)out, p2); + out += out_stride; + _mm_storel_epi64((__m128i*)out, _mm_shuffle_epi32(p2, 0x4e)); + out += out_stride; + _mm_storel_epi64((__m128i*)out, p1); + out += out_stride; + _mm_storel_epi64((__m128i*)out, _mm_shuffle_epi32(p1, 0x4e)); + out += out_stride; + _mm_storel_epi64((__m128i*)out, p3); + out += out_stride; + _mm_storel_epi64((__m128i*)out, _mm_shuffle_epi32(p3, 0x4e)); + } #undef dct_const #undef dct_rot @@ -2706,198 +2980,238 @@ static void stbi__idct_simd(stbi_uc *out, int out_stride, short data[64]) // NEON integer IDCT. should produce bit-identical // results to the generic C version. -static void stbi__idct_simd(stbi_uc *out, int out_stride, short data[64]) -{ - int16x8_t row0, row1, row2, row3, row4, row5, row6, row7; +static void stbi__idct_simd(stbi_uc* out, int out_stride, short data[64]) { + int16x8_t row0, row1, row2, row3, row4, row5, row6, row7; - int16x4_t rot0_0 = vdup_n_s16(stbi__f2f(0.5411961f)); - int16x4_t rot0_1 = vdup_n_s16(stbi__f2f(-1.847759065f)); - int16x4_t rot0_2 = vdup_n_s16(stbi__f2f( 0.765366865f)); - int16x4_t rot1_0 = vdup_n_s16(stbi__f2f( 1.175875602f)); - int16x4_t rot1_1 = vdup_n_s16(stbi__f2f(-0.899976223f)); - int16x4_t rot1_2 = vdup_n_s16(stbi__f2f(-2.562915447f)); - int16x4_t rot2_0 = vdup_n_s16(stbi__f2f(-1.961570560f)); - int16x4_t rot2_1 = vdup_n_s16(stbi__f2f(-0.390180644f)); - int16x4_t rot3_0 = vdup_n_s16(stbi__f2f( 0.298631336f)); - int16x4_t rot3_1 = vdup_n_s16(stbi__f2f( 2.053119869f)); - int16x4_t rot3_2 = vdup_n_s16(stbi__f2f( 3.072711026f)); - int16x4_t rot3_3 = vdup_n_s16(stbi__f2f( 1.501321110f)); + int16x4_t rot0_0 = vdup_n_s16(stbi__f2f(0.5411961f)); + int16x4_t rot0_1 = vdup_n_s16(stbi__f2f(-1.847759065f)); + int16x4_t rot0_2 = vdup_n_s16(stbi__f2f(0.765366865f)); + int16x4_t rot1_0 = vdup_n_s16(stbi__f2f(1.175875602f)); + int16x4_t rot1_1 = vdup_n_s16(stbi__f2f(-0.899976223f)); + int16x4_t rot1_2 = vdup_n_s16(stbi__f2f(-2.562915447f)); + int16x4_t rot2_0 = vdup_n_s16(stbi__f2f(-1.961570560f)); + int16x4_t rot2_1 = vdup_n_s16(stbi__f2f(-0.390180644f)); + int16x4_t rot3_0 = vdup_n_s16(stbi__f2f(0.298631336f)); + int16x4_t rot3_1 = vdup_n_s16(stbi__f2f(2.053119869f)); + int16x4_t rot3_2 = vdup_n_s16(stbi__f2f(3.072711026f)); + int16x4_t rot3_3 = vdup_n_s16(stbi__f2f(1.501321110f)); -#define dct_long_mul(out, inq, coeff) \ - int32x4_t out##_l = vmull_s16(vget_low_s16(inq), coeff); \ - int32x4_t out##_h = vmull_s16(vget_high_s16(inq), coeff) +#define dct_long_mul(out, inq, coeff) \ + int32x4_t out##_l = vmull_s16(vget_low_s16(inq), coeff); \ + int32x4_t out##_h = vmull_s16(vget_high_s16(inq), coeff) -#define dct_long_mac(out, acc, inq, coeff) \ - int32x4_t out##_l = vmlal_s16(acc##_l, vget_low_s16(inq), coeff); \ - int32x4_t out##_h = vmlal_s16(acc##_h, vget_high_s16(inq), coeff) +#define dct_long_mac(out, acc, inq, coeff) \ + int32x4_t out##_l = vmlal_s16(acc##_l, vget_low_s16(inq), coeff); \ + int32x4_t out##_h = vmlal_s16(acc##_h, vget_high_s16(inq), coeff) -#define dct_widen(out, inq) \ - int32x4_t out##_l = vshll_n_s16(vget_low_s16(inq), 12); \ - int32x4_t out##_h = vshll_n_s16(vget_high_s16(inq), 12) +#define dct_widen(out, inq) \ + int32x4_t out##_l = vshll_n_s16(vget_low_s16(inq), 12); \ + int32x4_t out##_h = vshll_n_s16(vget_high_s16(inq), 12) // wide add -#define dct_wadd(out, a, b) \ - int32x4_t out##_l = vaddq_s32(a##_l, b##_l); \ - int32x4_t out##_h = vaddq_s32(a##_h, b##_h) +#define dct_wadd(out, a, b) \ + int32x4_t out##_l = vaddq_s32(a##_l, b##_l); \ + int32x4_t out##_h = vaddq_s32(a##_h, b##_h) // wide sub -#define dct_wsub(out, a, b) \ - int32x4_t out##_l = vsubq_s32(a##_l, b##_l); \ - int32x4_t out##_h = vsubq_s32(a##_h, b##_h) +#define dct_wsub(out, a, b) \ + int32x4_t out##_l = vsubq_s32(a##_l, b##_l); \ + int32x4_t out##_h = vsubq_s32(a##_h, b##_h) // butterfly a/b, then shift using "shiftop" by "s" and pack -#define dct_bfly32o(out0,out1, a,b,shiftop,s) \ - { \ - dct_wadd(sum, a, b); \ - dct_wsub(dif, a, b); \ - out0 = vcombine_s16(shiftop(sum_l, s), shiftop(sum_h, s)); \ - out1 = vcombine_s16(shiftop(dif_l, s), shiftop(dif_h, s)); \ - } +#define dct_bfly32o(out0, out1, a, b, shiftop, s) \ + { \ + dct_wadd(sum, a, b); \ + dct_wsub(dif, a, b); \ + out0 = vcombine_s16(shiftop(sum_l, s), shiftop(sum_h, s)); \ + out1 = vcombine_s16(shiftop(dif_l, s), shiftop(dif_h, s)); \ + } -#define dct_pass(shiftop, shift) \ - { \ - /* even part */ \ - int16x8_t sum26 = vaddq_s16(row2, row6); \ - dct_long_mul(p1e, sum26, rot0_0); \ - dct_long_mac(t2e, p1e, row6, rot0_1); \ - dct_long_mac(t3e, p1e, row2, rot0_2); \ - int16x8_t sum04 = vaddq_s16(row0, row4); \ - int16x8_t dif04 = vsubq_s16(row0, row4); \ - dct_widen(t0e, sum04); \ - dct_widen(t1e, dif04); \ - dct_wadd(x0, t0e, t3e); \ - dct_wsub(x3, t0e, t3e); \ - dct_wadd(x1, t1e, t2e); \ - dct_wsub(x2, t1e, t2e); \ - /* odd part */ \ - int16x8_t sum15 = vaddq_s16(row1, row5); \ - int16x8_t sum17 = vaddq_s16(row1, row7); \ - int16x8_t sum35 = vaddq_s16(row3, row5); \ - int16x8_t sum37 = vaddq_s16(row3, row7); \ - int16x8_t sumodd = vaddq_s16(sum17, sum35); \ - dct_long_mul(p5o, sumodd, rot1_0); \ - dct_long_mac(p1o, p5o, sum17, rot1_1); \ - dct_long_mac(p2o, p5o, sum35, rot1_2); \ - dct_long_mul(p3o, sum37, rot2_0); \ - dct_long_mul(p4o, sum15, rot2_1); \ - dct_wadd(sump13o, p1o, p3o); \ - dct_wadd(sump24o, p2o, p4o); \ - dct_wadd(sump23o, p2o, p3o); \ - dct_wadd(sump14o, p1o, p4o); \ - dct_long_mac(x4, sump13o, row7, rot3_0); \ - dct_long_mac(x5, sump24o, row5, rot3_1); \ - dct_long_mac(x6, sump23o, row3, rot3_2); \ - dct_long_mac(x7, sump14o, row1, rot3_3); \ - dct_bfly32o(row0,row7, x0,x7,shiftop,shift); \ - dct_bfly32o(row1,row6, x1,x6,shiftop,shift); \ - dct_bfly32o(row2,row5, x2,x5,shiftop,shift); \ - dct_bfly32o(row3,row4, x3,x4,shiftop,shift); \ - } +#define dct_pass(shiftop, shift) \ + { \ + /* even part */ \ + int16x8_t sum26 = vaddq_s16(row2, row6); \ + dct_long_mul(p1e, sum26, rot0_0); \ + dct_long_mac(t2e, p1e, row6, rot0_1); \ + dct_long_mac(t3e, p1e, row2, rot0_2); \ + int16x8_t sum04 = vaddq_s16(row0, row4); \ + int16x8_t dif04 = vsubq_s16(row0, row4); \ + dct_widen(t0e, sum04); \ + dct_widen(t1e, dif04); \ + dct_wadd(x0, t0e, t3e); \ + dct_wsub(x3, t0e, t3e); \ + dct_wadd(x1, t1e, t2e); \ + dct_wsub(x2, t1e, t2e); \ + /* odd part */ \ + int16x8_t sum15 = vaddq_s16(row1, row5); \ + int16x8_t sum17 = vaddq_s16(row1, row7); \ + int16x8_t sum35 = vaddq_s16(row3, row5); \ + int16x8_t sum37 = vaddq_s16(row3, row7); \ + int16x8_t sumodd = vaddq_s16(sum17, sum35); \ + dct_long_mul(p5o, sumodd, rot1_0); \ + dct_long_mac(p1o, p5o, sum17, rot1_1); \ + dct_long_mac(p2o, p5o, sum35, rot1_2); \ + dct_long_mul(p3o, sum37, rot2_0); \ + dct_long_mul(p4o, sum15, rot2_1); \ + dct_wadd(sump13o, p1o, p3o); \ + dct_wadd(sump24o, p2o, p4o); \ + dct_wadd(sump23o, p2o, p3o); \ + dct_wadd(sump14o, p1o, p4o); \ + dct_long_mac(x4, sump13o, row7, rot3_0); \ + dct_long_mac(x5, sump24o, row5, rot3_1); \ + dct_long_mac(x6, sump23o, row3, rot3_2); \ + dct_long_mac(x7, sump14o, row1, rot3_3); \ + dct_bfly32o(row0, row7, x0, x7, shiftop, shift); \ + dct_bfly32o(row1, row6, x1, x6, shiftop, shift); \ + dct_bfly32o(row2, row5, x2, x5, shiftop, shift); \ + dct_bfly32o(row3, row4, x3, x4, shiftop, shift); \ + } - // load - row0 = vld1q_s16(data + 0*8); - row1 = vld1q_s16(data + 1*8); - row2 = vld1q_s16(data + 2*8); - row3 = vld1q_s16(data + 3*8); - row4 = vld1q_s16(data + 4*8); - row5 = vld1q_s16(data + 5*8); - row6 = vld1q_s16(data + 6*8); - row7 = vld1q_s16(data + 7*8); + // load + row0 = vld1q_s16(data + 0 * 8); + row1 = vld1q_s16(data + 1 * 8); + row2 = vld1q_s16(data + 2 * 8); + row3 = vld1q_s16(data + 3 * 8); + row4 = vld1q_s16(data + 4 * 8); + row5 = vld1q_s16(data + 5 * 8); + row6 = vld1q_s16(data + 6 * 8); + row7 = vld1q_s16(data + 7 * 8); - // add DC bias - row0 = vaddq_s16(row0, vsetq_lane_s16(1024, vdupq_n_s16(0), 0)); + // add DC bias + row0 = vaddq_s16(row0, vsetq_lane_s16(1024, vdupq_n_s16(0), 0)); - // column pass - dct_pass(vrshrn_n_s32, 10); + // column pass + dct_pass(vrshrn_n_s32, 10); - // 16bit 8x8 transpose - { + // 16bit 8x8 transpose + { // these three map to a single VTRN.16, VTRN.32, and VSWP, respectively. // whether compilers actually get this is another story, sadly. -#define dct_trn16(x, y) { int16x8x2_t t = vtrnq_s16(x, y); x = t.val[0]; y = t.val[1]; } -#define dct_trn32(x, y) { int32x4x2_t t = vtrnq_s32(vreinterpretq_s32_s16(x), vreinterpretq_s32_s16(y)); x = vreinterpretq_s16_s32(t.val[0]); y = vreinterpretq_s16_s32(t.val[1]); } -#define dct_trn64(x, y) { int16x8_t x0 = x; int16x8_t y0 = y; x = vcombine_s16(vget_low_s16(x0), vget_low_s16(y0)); y = vcombine_s16(vget_high_s16(x0), vget_high_s16(y0)); } +#define dct_trn16(x, y) \ + { \ + int16x8x2_t t = vtrnq_s16(x, y); \ + x = t.val[0]; \ + y = t.val[1]; \ + } +#define dct_trn32(x, y) \ + { \ + int32x4x2_t t = \ + vtrnq_s32(vreinterpretq_s32_s16(x), vreinterpretq_s32_s16(y)); \ + x = vreinterpretq_s16_s32(t.val[0]); \ + y = vreinterpretq_s16_s32(t.val[1]); \ + } +#define dct_trn64(x, y) \ + { \ + int16x8_t x0 = x; \ + int16x8_t y0 = y; \ + x = vcombine_s16(vget_low_s16(x0), vget_low_s16(y0)); \ + y = vcombine_s16(vget_high_s16(x0), vget_high_s16(y0)); \ + } - // pass 1 - dct_trn16(row0, row1); // a0b0a2b2a4b4a6b6 - dct_trn16(row2, row3); - dct_trn16(row4, row5); - dct_trn16(row6, row7); + // pass 1 + dct_trn16(row0, row1); // a0b0a2b2a4b4a6b6 + dct_trn16(row2, row3); + dct_trn16(row4, row5); + dct_trn16(row6, row7); - // pass 2 - dct_trn32(row0, row2); // a0b0c0d0a4b4c4d4 - dct_trn32(row1, row3); - dct_trn32(row4, row6); - dct_trn32(row5, row7); + // pass 2 + dct_trn32(row0, row2); // a0b0c0d0a4b4c4d4 + dct_trn32(row1, row3); + dct_trn32(row4, row6); + dct_trn32(row5, row7); - // pass 3 - dct_trn64(row0, row4); // a0b0c0d0e0f0g0h0 - dct_trn64(row1, row5); - dct_trn64(row2, row6); - dct_trn64(row3, row7); + // pass 3 + dct_trn64(row0, row4); // a0b0c0d0e0f0g0h0 + dct_trn64(row1, row5); + dct_trn64(row2, row6); + dct_trn64(row3, row7); #undef dct_trn16 #undef dct_trn32 #undef dct_trn64 - } + } - // row pass - // vrshrn_n_s32 only supports shifts up to 16, we need - // 17. so do a non-rounding shift of 16 first then follow - // up with a rounding shift by 1. - dct_pass(vshrn_n_s32, 16); + // row pass + // vrshrn_n_s32 only supports shifts up to 16, we need + // 17. so do a non-rounding shift of 16 first then follow + // up with a rounding shift by 1. + dct_pass(vshrn_n_s32, 16); - { - // pack and round - uint8x8_t p0 = vqrshrun_n_s16(row0, 1); - uint8x8_t p1 = vqrshrun_n_s16(row1, 1); - uint8x8_t p2 = vqrshrun_n_s16(row2, 1); - uint8x8_t p3 = vqrshrun_n_s16(row3, 1); - uint8x8_t p4 = vqrshrun_n_s16(row4, 1); - uint8x8_t p5 = vqrshrun_n_s16(row5, 1); - uint8x8_t p6 = vqrshrun_n_s16(row6, 1); - uint8x8_t p7 = vqrshrun_n_s16(row7, 1); + { + // pack and round + uint8x8_t p0 = vqrshrun_n_s16(row0, 1); + uint8x8_t p1 = vqrshrun_n_s16(row1, 1); + uint8x8_t p2 = vqrshrun_n_s16(row2, 1); + uint8x8_t p3 = vqrshrun_n_s16(row3, 1); + uint8x8_t p4 = vqrshrun_n_s16(row4, 1); + uint8x8_t p5 = vqrshrun_n_s16(row5, 1); + uint8x8_t p6 = vqrshrun_n_s16(row6, 1); + uint8x8_t p7 = vqrshrun_n_s16(row7, 1); - // again, these can translate into one instruction, but often don't. -#define dct_trn8_8(x, y) { uint8x8x2_t t = vtrn_u8(x, y); x = t.val[0]; y = t.val[1]; } -#define dct_trn8_16(x, y) { uint16x4x2_t t = vtrn_u16(vreinterpret_u16_u8(x), vreinterpret_u16_u8(y)); x = vreinterpret_u8_u16(t.val[0]); y = vreinterpret_u8_u16(t.val[1]); } -#define dct_trn8_32(x, y) { uint32x2x2_t t = vtrn_u32(vreinterpret_u32_u8(x), vreinterpret_u32_u8(y)); x = vreinterpret_u8_u32(t.val[0]); y = vreinterpret_u8_u32(t.val[1]); } + // again, these can translate into one instruction, but often don't. +#define dct_trn8_8(x, y) \ + { \ + uint8x8x2_t t = vtrn_u8(x, y); \ + x = t.val[0]; \ + y = t.val[1]; \ + } +#define dct_trn8_16(x, y) \ + { \ + uint16x4x2_t t = \ + vtrn_u16(vreinterpret_u16_u8(x), vreinterpret_u16_u8(y)); \ + x = vreinterpret_u8_u16(t.val[0]); \ + y = vreinterpret_u8_u16(t.val[1]); \ + } +#define dct_trn8_32(x, y) \ + { \ + uint32x2x2_t t = \ + vtrn_u32(vreinterpret_u32_u8(x), vreinterpret_u32_u8(y)); \ + x = vreinterpret_u8_u32(t.val[0]); \ + y = vreinterpret_u8_u32(t.val[1]); \ + } - // sadly can't use interleaved stores here since we only write - // 8 bytes to each scan line! + // sadly can't use interleaved stores here since we only write + // 8 bytes to each scan line! - // 8x8 8-bit transpose pass 1 - dct_trn8_8(p0, p1); - dct_trn8_8(p2, p3); - dct_trn8_8(p4, p5); - dct_trn8_8(p6, p7); + // 8x8 8-bit transpose pass 1 + dct_trn8_8(p0, p1); + dct_trn8_8(p2, p3); + dct_trn8_8(p4, p5); + dct_trn8_8(p6, p7); - // pass 2 - dct_trn8_16(p0, p2); - dct_trn8_16(p1, p3); - dct_trn8_16(p4, p6); - dct_trn8_16(p5, p7); + // pass 2 + dct_trn8_16(p0, p2); + dct_trn8_16(p1, p3); + dct_trn8_16(p4, p6); + dct_trn8_16(p5, p7); - // pass 3 - dct_trn8_32(p0, p4); - dct_trn8_32(p1, p5); - dct_trn8_32(p2, p6); - dct_trn8_32(p3, p7); + // pass 3 + dct_trn8_32(p0, p4); + dct_trn8_32(p1, p5); + dct_trn8_32(p2, p6); + dct_trn8_32(p3, p7); - // store - vst1_u8(out, p0); out += out_stride; - vst1_u8(out, p1); out += out_stride; - vst1_u8(out, p2); out += out_stride; - vst1_u8(out, p3); out += out_stride; - vst1_u8(out, p4); out += out_stride; - vst1_u8(out, p5); out += out_stride; - vst1_u8(out, p6); out += out_stride; - vst1_u8(out, p7); + // store + vst1_u8(out, p0); + out += out_stride; + vst1_u8(out, p1); + out += out_stride; + vst1_u8(out, p2); + out += out_stride; + vst1_u8(out, p3); + out += out_stride; + vst1_u8(out, p4); + out += out_stride; + vst1_u8(out, p5); + out += out_stride; + vst1_u8(out, p6); + out += out_stride; + vst1_u8(out, p7); #undef dct_trn8_8 #undef dct_trn8_16 #undef dct_trn8_32 - } + } #undef dct_long_mul #undef dct_long_mac @@ -2910,1169 +3224,1346 @@ static void stbi__idct_simd(stbi_uc *out, int out_stride, short data[64]) #endif // STBI_NEON -#define STBI__MARKER_none 0xff +#define STBI__MARKER_none 0xff // if there's a pending marker from the entropy stream, return that // otherwise, fetch from the stream and get a marker. if there's no // marker, return 0xff, which is never a valid marker value -static stbi_uc stbi__get_marker(stbi__jpeg *j) -{ - stbi_uc x; - if (j->marker != STBI__MARKER_none) { x = j->marker; j->marker = STBI__MARKER_none; return x; } - x = stbi__get8(j->s); - if (x != 0xff) return STBI__MARKER_none; - while (x == 0xff) - x = stbi__get8(j->s); // consume repeated 0xff fill bytes - return x; +static stbi_uc stbi__get_marker(stbi__jpeg* j) { + stbi_uc x; + if (j->marker != STBI__MARKER_none) { + x = j->marker; + j->marker = STBI__MARKER_none; + return x; + } + x = stbi__get8(j->s); + if (x != 0xff) + return STBI__MARKER_none; + while (x == 0xff) + x = stbi__get8(j->s); // consume repeated 0xff fill bytes + return x; } // in each scan, we'll have scan_n components, and the order // of the components is specified by order[] -#define STBI__RESTART(x) ((x) >= 0xd0 && (x) <= 0xd7) +#define STBI__RESTART(x) ((x) >= 0xd0 && (x) <= 0xd7) // after a restart interval, stbi__jpeg_reset the entropy decoder and // the dc prediction -static void stbi__jpeg_reset(stbi__jpeg *j) -{ - j->code_bits = 0; - j->code_buffer = 0; - j->nomore = 0; - j->img_comp[0].dc_pred = j->img_comp[1].dc_pred = j->img_comp[2].dc_pred = j->img_comp[3].dc_pred = 0; - j->marker = STBI__MARKER_none; - j->todo = j->restart_interval ? j->restart_interval : 0x7fffffff; - j->eob_run = 0; - // no more than 1<<31 MCUs if no restart_interal? that's plenty safe, - // since we don't even allow 1<<30 pixels +static void stbi__jpeg_reset(stbi__jpeg* j) { + j->code_bits = 0; + j->code_buffer = 0; + j->nomore = 0; + j->img_comp[0].dc_pred = j->img_comp[1].dc_pred = j->img_comp[2].dc_pred = + j->img_comp[3].dc_pred = 0; + j->marker = STBI__MARKER_none; + j->todo = j->restart_interval ? j->restart_interval : 0x7fffffff; + j->eob_run = 0; + // no more than 1<<31 MCUs if no restart_interal? that's plenty safe, + // since we don't even allow 1<<30 pixels } -static int stbi__parse_entropy_coded_data(stbi__jpeg *z) -{ - stbi__jpeg_reset(z); - if (!z->progressive) { - if (z->scan_n == 1) { - int i,j; - STBI_SIMD_ALIGN(short, data[64]); - int n = z->order[0]; - // non-interleaved data, we just need to process one block at a time, - // in trivial scanline order - // number of blocks to do just depends on how many actual "pixels" this - // component has, independent of interleaved MCU blocking and such - int w = (z->img_comp[n].x+7) >> 3; - int h = (z->img_comp[n].y+7) >> 3; - for (j=0; j < h; ++j) { - for (i=0; i < w; ++i) { - int ha = z->img_comp[n].ha; - if (!stbi__jpeg_decode_block(z, data, z->huff_dc+z->img_comp[n].hd, z->huff_ac+ha, z->fast_ac[ha], n, z->dequant[z->img_comp[n].tq])) return 0; - z->idct_block_kernel(z->img_comp[n].data+z->img_comp[n].w2*j*8+i*8, z->img_comp[n].w2, data); - // every data block is an MCU, so countdown the restart interval - if (--z->todo <= 0) { - if (z->code_bits < 24) stbi__grow_buffer_unsafe(z); - // if it's NOT a restart, then just bail, so we get corrupt data - // rather than no data - if (!STBI__RESTART(z->marker)) return 1; - stbi__jpeg_reset(z); - } +static int stbi__parse_entropy_coded_data(stbi__jpeg* z) { + stbi__jpeg_reset(z); + if (!z->progressive) { + if (z->scan_n == 1) { + int i, j; + STBI_SIMD_ALIGN(short, data[64]); + int n = z->order[0]; + // non-interleaved data, we just need to process one block at a + // time, in trivial scanline order number of blocks to do just + // depends on how many actual "pixels" this component has, + // independent of interleaved MCU blocking and such + int w = (z->img_comp[n].x + 7) >> 3; + int h = (z->img_comp[n].y + 7) >> 3; + for (j = 0; j < h; ++j) { + for (i = 0; i < w; ++i) { + int ha = z->img_comp[n].ha; + if (!stbi__jpeg_decode_block( + z, data, z->huff_dc + z->img_comp[n].hd, + z->huff_ac + ha, z->fast_ac[ha], n, + z->dequant[z->img_comp[n].tq])) + return 0; + z->idct_block_kernel(z->img_comp[n].data + + z->img_comp[n].w2 * j * 8 + i * 8, + z->img_comp[n].w2, data); + // every data block is an MCU, so countdown the restart + // interval + if (--z->todo <= 0) { + if (z->code_bits < 24) + stbi__grow_buffer_unsafe(z); + // if it's NOT a restart, then just bail, so we get + // corrupt data rather than no data + if (!STBI__RESTART(z->marker)) + return 1; + stbi__jpeg_reset(z); + } + } } - } - return 1; - } else { // interleaved - int i,j,k,x,y; - STBI_SIMD_ALIGN(short, data[64]); - for (j=0; j < z->img_mcu_y; ++j) { - for (i=0; i < z->img_mcu_x; ++i) { - // scan an interleaved mcu... process scan_n components in order - for (k=0; k < z->scan_n; ++k) { - int n = z->order[k]; - // scan out an mcu's worth of this component; that's just determined - // by the basic H and V specified for the component - for (y=0; y < z->img_comp[n].v; ++y) { - for (x=0; x < z->img_comp[n].h; ++x) { - int x2 = (i*z->img_comp[n].h + x)*8; - int y2 = (j*z->img_comp[n].v + y)*8; + return 1; + } else { // interleaved + int i, j, k, x, y; + STBI_SIMD_ALIGN(short, data[64]); + for (j = 0; j < z->img_mcu_y; ++j) { + for (i = 0; i < z->img_mcu_x; ++i) { + // scan an interleaved mcu... process scan_n components in + // order + for (k = 0; k < z->scan_n; ++k) { + int n = z->order[k]; + // scan out an mcu's worth of this component; that's + // just determined by the basic H and V specified for + // the component + for (y = 0; y < z->img_comp[n].v; ++y) { + for (x = 0; x < z->img_comp[n].h; ++x) { + int x2 = (i * z->img_comp[n].h + x) * 8; + int y2 = (j * z->img_comp[n].v + y) * 8; + int ha = z->img_comp[n].ha; + if (!stbi__jpeg_decode_block( + z, data, z->huff_dc + z->img_comp[n].hd, + z->huff_ac + ha, z->fast_ac[ha], n, + z->dequant[z->img_comp[n].tq])) + return 0; + z->idct_block_kernel( + z->img_comp[n].data + + z->img_comp[n].w2 * y2 + x2, + z->img_comp[n].w2, data); + } + } + } + // after all interleaved components, that's an interleaved + // MCU, so now count down the restart interval + if (--z->todo <= 0) { + if (z->code_bits < 24) + stbi__grow_buffer_unsafe(z); + if (!STBI__RESTART(z->marker)) + return 1; + stbi__jpeg_reset(z); + } + } + } + return 1; + } + } else { + if (z->scan_n == 1) { + int i, j; + int n = z->order[0]; + // non-interleaved data, we just need to process one block at a + // time, in trivial scanline order number of blocks to do just + // depends on how many actual "pixels" this component has, + // independent of interleaved MCU blocking and such + int w = (z->img_comp[n].x + 7) >> 3; + int h = (z->img_comp[n].y + 7) >> 3; + for (j = 0; j < h; ++j) { + for (i = 0; i < w; ++i) { + short* data = z->img_comp[n].coeff + + 64 * (i + j * z->img_comp[n].coeff_w); + if (z->spec_start == 0) { + if (!stbi__jpeg_decode_block_prog_dc( + z, data, &z->huff_dc[z->img_comp[n].hd], n)) + return 0; + } else { int ha = z->img_comp[n].ha; - if (!stbi__jpeg_decode_block(z, data, z->huff_dc+z->img_comp[n].hd, z->huff_ac+ha, z->fast_ac[ha], n, z->dequant[z->img_comp[n].tq])) return 0; - z->idct_block_kernel(z->img_comp[n].data+z->img_comp[n].w2*y2+x2, z->img_comp[n].w2, data); - } - } - } - // after all interleaved components, that's an interleaved MCU, - // so now count down the restart interval - if (--z->todo <= 0) { - if (z->code_bits < 24) stbi__grow_buffer_unsafe(z); - if (!STBI__RESTART(z->marker)) return 1; - stbi__jpeg_reset(z); - } + if (!stbi__jpeg_decode_block_prog_ac( + z, data, &z->huff_ac[ha], z->fast_ac[ha])) + return 0; + } + // every data block is an MCU, so countdown the restart + // interval + if (--z->todo <= 0) { + if (z->code_bits < 24) + stbi__grow_buffer_unsafe(z); + if (!STBI__RESTART(z->marker)) + return 1; + stbi__jpeg_reset(z); + } + } } - } - return 1; - } - } else { - if (z->scan_n == 1) { - int i,j; - int n = z->order[0]; - // non-interleaved data, we just need to process one block at a time, - // in trivial scanline order - // number of blocks to do just depends on how many actual "pixels" this - // component has, independent of interleaved MCU blocking and such - int w = (z->img_comp[n].x+7) >> 3; - int h = (z->img_comp[n].y+7) >> 3; - for (j=0; j < h; ++j) { - for (i=0; i < w; ++i) { - short *data = z->img_comp[n].coeff + 64 * (i + j * z->img_comp[n].coeff_w); - if (z->spec_start == 0) { - if (!stbi__jpeg_decode_block_prog_dc(z, data, &z->huff_dc[z->img_comp[n].hd], n)) - return 0; - } else { - int ha = z->img_comp[n].ha; - if (!stbi__jpeg_decode_block_prog_ac(z, data, &z->huff_ac[ha], z->fast_ac[ha])) - return 0; - } - // every data block is an MCU, so countdown the restart interval - if (--z->todo <= 0) { - if (z->code_bits < 24) stbi__grow_buffer_unsafe(z); - if (!STBI__RESTART(z->marker)) return 1; - stbi__jpeg_reset(z); - } + return 1; + } else { // interleaved + int i, j, k, x, y; + for (j = 0; j < z->img_mcu_y; ++j) { + for (i = 0; i < z->img_mcu_x; ++i) { + // scan an interleaved mcu... process scan_n components in + // order + for (k = 0; k < z->scan_n; ++k) { + int n = z->order[k]; + // scan out an mcu's worth of this component; that's + // just determined by the basic H and V specified for + // the component + for (y = 0; y < z->img_comp[n].v; ++y) { + for (x = 0; x < z->img_comp[n].h; ++x) { + int x2 = (i * z->img_comp[n].h + x); + int y2 = (j * z->img_comp[n].v + y); + short* data = + z->img_comp[n].coeff + + 64 * (x2 + y2 * z->img_comp[n].coeff_w); + if (!stbi__jpeg_decode_block_prog_dc( + z, data, &z->huff_dc[z->img_comp[n].hd], + n)) + return 0; + } + } + } + // after all interleaved components, that's an interleaved + // MCU, so now count down the restart interval + if (--z->todo <= 0) { + if (z->code_bits < 24) + stbi__grow_buffer_unsafe(z); + if (!STBI__RESTART(z->marker)) + return 1; + stbi__jpeg_reset(z); + } + } } - } - return 1; - } else { // interleaved - int i,j,k,x,y; - for (j=0; j < z->img_mcu_y; ++j) { - for (i=0; i < z->img_mcu_x; ++i) { - // scan an interleaved mcu... process scan_n components in order - for (k=0; k < z->scan_n; ++k) { - int n = z->order[k]; - // scan out an mcu's worth of this component; that's just determined - // by the basic H and V specified for the component - for (y=0; y < z->img_comp[n].v; ++y) { - for (x=0; x < z->img_comp[n].h; ++x) { - int x2 = (i*z->img_comp[n].h + x); - int y2 = (j*z->img_comp[n].v + y); - short *data = z->img_comp[n].coeff + 64 * (x2 + y2 * z->img_comp[n].coeff_w); - if (!stbi__jpeg_decode_block_prog_dc(z, data, &z->huff_dc[z->img_comp[n].hd], n)) - return 0; - } - } - } - // after all interleaved components, that's an interleaved MCU, - // so now count down the restart interval - if (--z->todo <= 0) { - if (z->code_bits < 24) stbi__grow_buffer_unsafe(z); - if (!STBI__RESTART(z->marker)) return 1; - stbi__jpeg_reset(z); - } - } - } - return 1; - } - } + return 1; + } + } } -static void stbi__jpeg_dequantize(short *data, stbi__uint16 *dequant) -{ - int i; - for (i=0; i < 64; ++i) - data[i] *= dequant[i]; +static void stbi__jpeg_dequantize(short* data, stbi__uint16* dequant) { + int i; + for (i = 0; i < 64; ++i) + data[i] *= dequant[i]; } -static void stbi__jpeg_finish(stbi__jpeg *z) -{ - if (z->progressive) { - // dequantize and idct the data - int i,j,n; - for (n=0; n < z->s->img_n; ++n) { - int w = (z->img_comp[n].x+7) >> 3; - int h = (z->img_comp[n].y+7) >> 3; - for (j=0; j < h; ++j) { - for (i=0; i < w; ++i) { - short *data = z->img_comp[n].coeff + 64 * (i + j * z->img_comp[n].coeff_w); - stbi__jpeg_dequantize(data, z->dequant[z->img_comp[n].tq]); - z->idct_block_kernel(z->img_comp[n].data+z->img_comp[n].w2*j*8+i*8, z->img_comp[n].w2, data); +static void stbi__jpeg_finish(stbi__jpeg* z) { + if (z->progressive) { + // dequantize and idct the data + int i, j, n; + for (n = 0; n < z->s->img_n; ++n) { + int w = (z->img_comp[n].x + 7) >> 3; + int h = (z->img_comp[n].y + 7) >> 3; + for (j = 0; j < h; ++j) { + for (i = 0; i < w; ++i) { + short* data = z->img_comp[n].coeff + + 64 * (i + j * z->img_comp[n].coeff_w); + stbi__jpeg_dequantize(data, z->dequant[z->img_comp[n].tq]); + z->idct_block_kernel(z->img_comp[n].data + + z->img_comp[n].w2 * j * 8 + i * 8, + z->img_comp[n].w2, data); + } } - } - } - } + } + } } -static int stbi__process_marker(stbi__jpeg *z, int m) -{ - int L; - switch (m) { - case STBI__MARKER_none: // no marker found - return stbi__err("expected marker","Corrupt JPEG"); +static int stbi__process_marker(stbi__jpeg* z, int m) { + int L; + switch (m) { + case STBI__MARKER_none: // no marker found + return stbi__err("expected marker", "Corrupt JPEG"); - case 0xDD: // DRI - specify restart interval - if (stbi__get16be(z->s) != 4) return stbi__err("bad DRI len","Corrupt JPEG"); - z->restart_interval = stbi__get16be(z->s); - return 1; + case 0xDD: // DRI - specify restart interval + if (stbi__get16be(z->s) != 4) + return stbi__err("bad DRI len", "Corrupt JPEG"); + z->restart_interval = stbi__get16be(z->s); + return 1; - case 0xDB: // DQT - define quantization table - L = stbi__get16be(z->s)-2; - while (L > 0) { + case 0xDB: // DQT - define quantization table + L = stbi__get16be(z->s) - 2; + while (L > 0) { int q = stbi__get8(z->s); int p = q >> 4, sixteen = (p != 0); - int t = q & 15,i; - if (p != 0 && p != 1) return stbi__err("bad DQT type","Corrupt JPEG"); - if (t > 3) return stbi__err("bad DQT table","Corrupt JPEG"); + int t = q & 15, i; + if (p != 0 && p != 1) + return stbi__err("bad DQT type", "Corrupt JPEG"); + if (t > 3) + return stbi__err("bad DQT table", "Corrupt JPEG"); - for (i=0; i < 64; ++i) - z->dequant[t][stbi__jpeg_dezigzag[i]] = (stbi__uint16)(sixteen ? stbi__get16be(z->s) : stbi__get8(z->s)); + for (i = 0; i < 64; ++i) + z->dequant[t][stbi__jpeg_dezigzag[i]] = + (stbi__uint16)(sixteen ? stbi__get16be(z->s) + : stbi__get8(z->s)); L -= (sixteen ? 129 : 65); - } - return L==0; + } + return L == 0; - case 0xC4: // DHT - define huffman table - L = stbi__get16be(z->s)-2; - while (L > 0) { - stbi_uc *v; - int sizes[16],i,n=0; + case 0xC4: // DHT - define huffman table + L = stbi__get16be(z->s) - 2; + while (L > 0) { + stbi_uc* v; + int sizes[16], i, n = 0; int q = stbi__get8(z->s); int tc = q >> 4; int th = q & 15; - if (tc > 1 || th > 3) return stbi__err("bad DHT header","Corrupt JPEG"); - for (i=0; i < 16; ++i) { - sizes[i] = stbi__get8(z->s); - n += sizes[i]; + if (tc > 1 || th > 3) + return stbi__err("bad DHT header", "Corrupt JPEG"); + for (i = 0; i < 16; ++i) { + sizes[i] = stbi__get8(z->s); + n += sizes[i]; } - if(n > 256) return stbi__err("bad DHT header","Corrupt JPEG"); // Loop over i < n would write past end of values! + if (n > 256) + return stbi__err("bad DHT header", + "Corrupt JPEG"); // Loop over i < n would write + // past end of values! L -= 17; if (tc == 0) { - if (!stbi__build_huffman(z->huff_dc+th, sizes)) return 0; - v = z->huff_dc[th].values; + if (!stbi__build_huffman(z->huff_dc + th, sizes)) + return 0; + v = z->huff_dc[th].values; } else { - if (!stbi__build_huffman(z->huff_ac+th, sizes)) return 0; - v = z->huff_ac[th].values; + if (!stbi__build_huffman(z->huff_ac + th, sizes)) + return 0; + v = z->huff_ac[th].values; } - for (i=0; i < n; ++i) - v[i] = stbi__get8(z->s); + for (i = 0; i < n; ++i) + v[i] = stbi__get8(z->s); if (tc != 0) - stbi__build_fast_ac(z->fast_ac[th], z->huff_ac + th); + stbi__build_fast_ac(z->fast_ac[th], z->huff_ac + th); L -= n; - } - return L==0; - } + } + return L == 0; + } - // check for comment block or APP blocks - if ((m >= 0xE0 && m <= 0xEF) || m == 0xFE) { - L = stbi__get16be(z->s); - if (L < 2) { - if (m == 0xFE) - return stbi__err("bad COM len","Corrupt JPEG"); - else - return stbi__err("bad APP len","Corrupt JPEG"); - } - L -= 2; + // check for comment block or APP blocks + if ((m >= 0xE0 && m <= 0xEF) || m == 0xFE) { + L = stbi__get16be(z->s); + if (L < 2) { + if (m == 0xFE) + return stbi__err("bad COM len", "Corrupt JPEG"); + else + return stbi__err("bad APP len", "Corrupt JPEG"); + } + L -= 2; - if (m == 0xE0 && L >= 5) { // JFIF APP0 segment - static const unsigned char tag[5] = {'J','F','I','F','\0'}; - int ok = 1; - int i; - for (i=0; i < 5; ++i) - if (stbi__get8(z->s) != tag[i]) - ok = 0; - L -= 5; - if (ok) - z->jfif = 1; - } else if (m == 0xEE && L >= 12) { // Adobe APP14 segment - static const unsigned char tag[6] = {'A','d','o','b','e','\0'}; - int ok = 1; - int i; - for (i=0; i < 6; ++i) - if (stbi__get8(z->s) != tag[i]) - ok = 0; - L -= 6; - if (ok) { - stbi__get8(z->s); // version - stbi__get16be(z->s); // flags0 - stbi__get16be(z->s); // flags1 - z->app14_color_transform = stbi__get8(z->s); // color transform + if (m == 0xE0 && L >= 5) { // JFIF APP0 segment + static const unsigned char tag[5] = {'J', 'F', 'I', 'F', '\0'}; + int ok = 1; + int i; + for (i = 0; i < 5; ++i) + if (stbi__get8(z->s) != tag[i]) + ok = 0; + L -= 5; + if (ok) + z->jfif = 1; + } else if (m == 0xEE && L >= 12) { // Adobe APP14 segment + static const unsigned char tag[6] = {'A', 'd', 'o', 'b', 'e', '\0'}; + int ok = 1; + int i; + for (i = 0; i < 6; ++i) + if (stbi__get8(z->s) != tag[i]) + ok = 0; L -= 6; - } - } + if (ok) { + stbi__get8(z->s); // version + stbi__get16be(z->s); // flags0 + stbi__get16be(z->s); // flags1 + z->app14_color_transform = stbi__get8(z->s); // color transform + L -= 6; + } + } - stbi__skip(z->s, L); - return 1; - } + stbi__skip(z->s, L); + return 1; + } - return stbi__err("unknown marker","Corrupt JPEG"); + return stbi__err("unknown marker", "Corrupt JPEG"); } // after we see SOS -static int stbi__process_scan_header(stbi__jpeg *z) -{ - int i; - int Ls = stbi__get16be(z->s); - z->scan_n = stbi__get8(z->s); - if (z->scan_n < 1 || z->scan_n > 4 || z->scan_n > (int) z->s->img_n) return stbi__err("bad SOS component count","Corrupt JPEG"); - if (Ls != 6+2*z->scan_n) return stbi__err("bad SOS len","Corrupt JPEG"); - for (i=0; i < z->scan_n; ++i) { - int id = stbi__get8(z->s), which; - int q = stbi__get8(z->s); - for (which = 0; which < z->s->img_n; ++which) - if (z->img_comp[which].id == id) - break; - if (which == z->s->img_n) return 0; // no match - z->img_comp[which].hd = q >> 4; if (z->img_comp[which].hd > 3) return stbi__err("bad DC huff","Corrupt JPEG"); - z->img_comp[which].ha = q & 15; if (z->img_comp[which].ha > 3) return stbi__err("bad AC huff","Corrupt JPEG"); - z->order[i] = which; - } +static int stbi__process_scan_header(stbi__jpeg* z) { + int i; + int Ls = stbi__get16be(z->s); + z->scan_n = stbi__get8(z->s); + if (z->scan_n < 1 || z->scan_n > 4 || z->scan_n > (int)z->s->img_n) + return stbi__err("bad SOS component count", "Corrupt JPEG"); + if (Ls != 6 + 2 * z->scan_n) + return stbi__err("bad SOS len", "Corrupt JPEG"); + for (i = 0; i < z->scan_n; ++i) { + int id = stbi__get8(z->s), which; + int q = stbi__get8(z->s); + for (which = 0; which < z->s->img_n; ++which) + if (z->img_comp[which].id == id) + break; + if (which == z->s->img_n) + return 0; // no match + z->img_comp[which].hd = q >> 4; + if (z->img_comp[which].hd > 3) + return stbi__err("bad DC huff", "Corrupt JPEG"); + z->img_comp[which].ha = q & 15; + if (z->img_comp[which].ha > 3) + return stbi__err("bad AC huff", "Corrupt JPEG"); + z->order[i] = which; + } - { - int aa; - z->spec_start = stbi__get8(z->s); - z->spec_end = stbi__get8(z->s); // should be 63, but might be 0 - aa = stbi__get8(z->s); - z->succ_high = (aa >> 4); - z->succ_low = (aa & 15); - if (z->progressive) { - if (z->spec_start > 63 || z->spec_end > 63 || z->spec_start > z->spec_end || z->succ_high > 13 || z->succ_low > 13) - return stbi__err("bad SOS", "Corrupt JPEG"); - } else { - if (z->spec_start != 0) return stbi__err("bad SOS","Corrupt JPEG"); - if (z->succ_high != 0 || z->succ_low != 0) return stbi__err("bad SOS","Corrupt JPEG"); - z->spec_end = 63; - } - } + { + int aa; + z->spec_start = stbi__get8(z->s); + z->spec_end = stbi__get8(z->s); // should be 63, but might be 0 + aa = stbi__get8(z->s); + z->succ_high = (aa >> 4); + z->succ_low = (aa & 15); + if (z->progressive) { + if (z->spec_start > 63 || z->spec_end > 63 || + z->spec_start > z->spec_end || z->succ_high > 13 || + z->succ_low > 13) + return stbi__err("bad SOS", "Corrupt JPEG"); + } else { + if (z->spec_start != 0) + return stbi__err("bad SOS", "Corrupt JPEG"); + if (z->succ_high != 0 || z->succ_low != 0) + return stbi__err("bad SOS", "Corrupt JPEG"); + z->spec_end = 63; + } + } - return 1; + return 1; } -static int stbi__free_jpeg_components(stbi__jpeg *z, int ncomp, int why) -{ - int i; - for (i=0; i < ncomp; ++i) { - if (z->img_comp[i].raw_data) { - STBI_FREE(z->img_comp[i].raw_data); - z->img_comp[i].raw_data = NULL; - z->img_comp[i].data = NULL; - } - if (z->img_comp[i].raw_coeff) { - STBI_FREE(z->img_comp[i].raw_coeff); - z->img_comp[i].raw_coeff = 0; - z->img_comp[i].coeff = 0; - } - if (z->img_comp[i].linebuf) { - STBI_FREE(z->img_comp[i].linebuf); - z->img_comp[i].linebuf = NULL; - } - } - return why; +static int stbi__free_jpeg_components(stbi__jpeg* z, int ncomp, int why) { + int i; + for (i = 0; i < ncomp; ++i) { + if (z->img_comp[i].raw_data) { + STBI_FREE(z->img_comp[i].raw_data); + z->img_comp[i].raw_data = NULL; + z->img_comp[i].data = NULL; + } + if (z->img_comp[i].raw_coeff) { + STBI_FREE(z->img_comp[i].raw_coeff); + z->img_comp[i].raw_coeff = 0; + z->img_comp[i].coeff = 0; + } + if (z->img_comp[i].linebuf) { + STBI_FREE(z->img_comp[i].linebuf); + z->img_comp[i].linebuf = NULL; + } + } + return why; } -static int stbi__process_frame_header(stbi__jpeg *z, int scan) -{ - stbi__context *s = z->s; - int Lf,p,i,q, h_max=1,v_max=1,c; - Lf = stbi__get16be(s); if (Lf < 11) return stbi__err("bad SOF len","Corrupt JPEG"); // JPEG - p = stbi__get8(s); if (p != 8) return stbi__err("only 8-bit","JPEG format not supported: 8-bit only"); // JPEG baseline - s->img_y = stbi__get16be(s); if (s->img_y == 0) return stbi__err("no header height", "JPEG format not supported: delayed height"); // Legal, but we don't handle it--but neither does IJG - s->img_x = stbi__get16be(s); if (s->img_x == 0) return stbi__err("0 width","Corrupt JPEG"); // JPEG requires - if (s->img_y > STBI_MAX_DIMENSIONS) return stbi__err("too large","Very large image (corrupt?)"); - if (s->img_x > STBI_MAX_DIMENSIONS) return stbi__err("too large","Very large image (corrupt?)"); - c = stbi__get8(s); - if (c != 3 && c != 1 && c != 4) return stbi__err("bad component count","Corrupt JPEG"); - s->img_n = c; - for (i=0; i < c; ++i) { - z->img_comp[i].data = NULL; - z->img_comp[i].linebuf = NULL; - } +static int stbi__process_frame_header(stbi__jpeg* z, int scan) { + stbi__context* s = z->s; + int Lf, p, i, q, h_max = 1, v_max = 1, c; + Lf = stbi__get16be(s); + if (Lf < 11) + return stbi__err("bad SOF len", "Corrupt JPEG"); // JPEG + p = stbi__get8(s); + if (p != 8) + return stbi__err( + "only 8-bit", + "JPEG format not supported: 8-bit only"); // JPEG baseline + s->img_y = stbi__get16be(s); + if (s->img_y == 0) + return stbi__err( + "no header height", + "JPEG format not supported: delayed height"); // Legal, but we don't + // handle it--but + // neither does IJG + s->img_x = stbi__get16be(s); + if (s->img_x == 0) + return stbi__err("0 width", "Corrupt JPEG"); // JPEG requires + if (s->img_y > STBI_MAX_DIMENSIONS) + return stbi__err("too large", "Very large image (corrupt?)"); + if (s->img_x > STBI_MAX_DIMENSIONS) + return stbi__err("too large", "Very large image (corrupt?)"); + c = stbi__get8(s); + if (c != 3 && c != 1 && c != 4) + return stbi__err("bad component count", "Corrupt JPEG"); + s->img_n = c; + for (i = 0; i < c; ++i) { + z->img_comp[i].data = NULL; + z->img_comp[i].linebuf = NULL; + } - if (Lf != 8+3*s->img_n) return stbi__err("bad SOF len","Corrupt JPEG"); + if (Lf != 8 + 3 * s->img_n) + return stbi__err("bad SOF len", "Corrupt JPEG"); - z->rgb = 0; - for (i=0; i < s->img_n; ++i) { - static const unsigned char rgb[3] = { 'R', 'G', 'B' }; - z->img_comp[i].id = stbi__get8(s); - if (s->img_n == 3 && z->img_comp[i].id == rgb[i]) - ++z->rgb; - q = stbi__get8(s); - z->img_comp[i].h = (q >> 4); if (!z->img_comp[i].h || z->img_comp[i].h > 4) return stbi__err("bad H","Corrupt JPEG"); - z->img_comp[i].v = q & 15; if (!z->img_comp[i].v || z->img_comp[i].v > 4) return stbi__err("bad V","Corrupt JPEG"); - z->img_comp[i].tq = stbi__get8(s); if (z->img_comp[i].tq > 3) return stbi__err("bad TQ","Corrupt JPEG"); - } + z->rgb = 0; + for (i = 0; i < s->img_n; ++i) { + static const unsigned char rgb[3] = {'R', 'G', 'B'}; + z->img_comp[i].id = stbi__get8(s); + if (s->img_n == 3 && z->img_comp[i].id == rgb[i]) + ++z->rgb; + q = stbi__get8(s); + z->img_comp[i].h = (q >> 4); + if (!z->img_comp[i].h || z->img_comp[i].h > 4) + return stbi__err("bad H", "Corrupt JPEG"); + z->img_comp[i].v = q & 15; + if (!z->img_comp[i].v || z->img_comp[i].v > 4) + return stbi__err("bad V", "Corrupt JPEG"); + z->img_comp[i].tq = stbi__get8(s); + if (z->img_comp[i].tq > 3) + return stbi__err("bad TQ", "Corrupt JPEG"); + } - if (scan != STBI__SCAN_load) return 1; + if (scan != STBI__SCAN_load) + return 1; - if (!stbi__mad3sizes_valid(s->img_x, s->img_y, s->img_n, 0)) return stbi__err("too large", "Image too large to decode"); + if (!stbi__mad3sizes_valid(s->img_x, s->img_y, s->img_n, 0)) + return stbi__err("too large", "Image too large to decode"); - for (i=0; i < s->img_n; ++i) { - if (z->img_comp[i].h > h_max) h_max = z->img_comp[i].h; - if (z->img_comp[i].v > v_max) v_max = z->img_comp[i].v; - } + for (i = 0; i < s->img_n; ++i) { + if (z->img_comp[i].h > h_max) + h_max = z->img_comp[i].h; + if (z->img_comp[i].v > v_max) + v_max = z->img_comp[i].v; + } - // check that plane subsampling factors are integer ratios; our resamplers can't deal with fractional ratios - // and I've never seen a non-corrupted JPEG file actually use them - for (i=0; i < s->img_n; ++i) { - if (h_max % z->img_comp[i].h != 0) return stbi__err("bad H","Corrupt JPEG"); - if (v_max % z->img_comp[i].v != 0) return stbi__err("bad V","Corrupt JPEG"); - } + // check that plane subsampling factors are integer ratios; our resamplers + // can't deal with fractional ratios and I've never seen a non-corrupted + // JPEG file actually use them + for (i = 0; i < s->img_n; ++i) { + if (h_max % z->img_comp[i].h != 0) + return stbi__err("bad H", "Corrupt JPEG"); + if (v_max % z->img_comp[i].v != 0) + return stbi__err("bad V", "Corrupt JPEG"); + } - // compute interleaved mcu info - z->img_h_max = h_max; - z->img_v_max = v_max; - z->img_mcu_w = h_max * 8; - z->img_mcu_h = v_max * 8; - // these sizes can't be more than 17 bits - z->img_mcu_x = (s->img_x + z->img_mcu_w-1) / z->img_mcu_w; - z->img_mcu_y = (s->img_y + z->img_mcu_h-1) / z->img_mcu_h; + // compute interleaved mcu info + z->img_h_max = h_max; + z->img_v_max = v_max; + z->img_mcu_w = h_max * 8; + z->img_mcu_h = v_max * 8; + // these sizes can't be more than 17 bits + z->img_mcu_x = (s->img_x + z->img_mcu_w - 1) / z->img_mcu_w; + z->img_mcu_y = (s->img_y + z->img_mcu_h - 1) / z->img_mcu_h; - for (i=0; i < s->img_n; ++i) { - // number of effective pixels (e.g. for non-interleaved MCU) - z->img_comp[i].x = (s->img_x * z->img_comp[i].h + h_max-1) / h_max; - z->img_comp[i].y = (s->img_y * z->img_comp[i].v + v_max-1) / v_max; - // to simplify generation, we'll allocate enough memory to decode - // the bogus oversized data from using interleaved MCUs and their - // big blocks (e.g. a 16x16 iMCU on an image of width 33); we won't - // discard the extra data until colorspace conversion - // - // img_mcu_x, img_mcu_y: <=17 bits; comp[i].h and .v are <=4 (checked earlier) - // so these muls can't overflow with 32-bit ints (which we require) - z->img_comp[i].w2 = z->img_mcu_x * z->img_comp[i].h * 8; - z->img_comp[i].h2 = z->img_mcu_y * z->img_comp[i].v * 8; - z->img_comp[i].coeff = 0; - z->img_comp[i].raw_coeff = 0; - z->img_comp[i].linebuf = NULL; - z->img_comp[i].raw_data = stbi__malloc_mad2(z->img_comp[i].w2, z->img_comp[i].h2, 15); - if (z->img_comp[i].raw_data == NULL) - return stbi__free_jpeg_components(z, i+1, stbi__err("outofmem", "Out of memory")); - // align blocks for idct using mmx/sse - z->img_comp[i].data = (stbi_uc*) (((size_t) z->img_comp[i].raw_data + 15) & ~15); - if (z->progressive) { - // w2, h2 are multiples of 8 (see above) - z->img_comp[i].coeff_w = z->img_comp[i].w2 / 8; - z->img_comp[i].coeff_h = z->img_comp[i].h2 / 8; - z->img_comp[i].raw_coeff = stbi__malloc_mad3(z->img_comp[i].w2, z->img_comp[i].h2, sizeof(short), 15); - if (z->img_comp[i].raw_coeff == NULL) - return stbi__free_jpeg_components(z, i+1, stbi__err("outofmem", "Out of memory")); - z->img_comp[i].coeff = (short*) (((size_t) z->img_comp[i].raw_coeff + 15) & ~15); - } - } + for (i = 0; i < s->img_n; ++i) { + // number of effective pixels (e.g. for non-interleaved MCU) + z->img_comp[i].x = (s->img_x * z->img_comp[i].h + h_max - 1) / h_max; + z->img_comp[i].y = (s->img_y * z->img_comp[i].v + v_max - 1) / v_max; + // to simplify generation, we'll allocate enough memory to decode + // the bogus oversized data from using interleaved MCUs and their + // big blocks (e.g. a 16x16 iMCU on an image of width 33); we won't + // discard the extra data until colorspace conversion + // + // img_mcu_x, img_mcu_y: <=17 bits; comp[i].h and .v are <=4 (checked + // earlier) so these muls can't overflow with 32-bit ints (which we + // require) + z->img_comp[i].w2 = z->img_mcu_x * z->img_comp[i].h * 8; + z->img_comp[i].h2 = z->img_mcu_y * z->img_comp[i].v * 8; + z->img_comp[i].coeff = 0; + z->img_comp[i].raw_coeff = 0; + z->img_comp[i].linebuf = NULL; + z->img_comp[i].raw_data = + stbi__malloc_mad2(z->img_comp[i].w2, z->img_comp[i].h2, 15); + if (z->img_comp[i].raw_data == NULL) + return stbi__free_jpeg_components( + z, i + 1, stbi__err("outofmem", "Out of memory")); + // align blocks for idct using mmx/sse + z->img_comp[i].data = + (stbi_uc*)(((size_t)z->img_comp[i].raw_data + 15) & ~15); + if (z->progressive) { + // w2, h2 are multiples of 8 (see above) + z->img_comp[i].coeff_w = z->img_comp[i].w2 / 8; + z->img_comp[i].coeff_h = z->img_comp[i].h2 / 8; + z->img_comp[i].raw_coeff = stbi__malloc_mad3( + z->img_comp[i].w2, z->img_comp[i].h2, sizeof(short), 15); + if (z->img_comp[i].raw_coeff == NULL) + return stbi__free_jpeg_components( + z, i + 1, stbi__err("outofmem", "Out of memory")); + z->img_comp[i].coeff = + (short*)(((size_t)z->img_comp[i].raw_coeff + 15) & ~15); + } + } - return 1; + return 1; } // use comparisons since in some cases we handle more than one case (e.g. SOF) -#define stbi__DNL(x) ((x) == 0xdc) -#define stbi__SOI(x) ((x) == 0xd8) -#define stbi__EOI(x) ((x) == 0xd9) -#define stbi__SOF(x) ((x) == 0xc0 || (x) == 0xc1 || (x) == 0xc2) -#define stbi__SOS(x) ((x) == 0xda) +#define stbi__DNL(x) ((x) == 0xdc) +#define stbi__SOI(x) ((x) == 0xd8) +#define stbi__EOI(x) ((x) == 0xd9) +#define stbi__SOF(x) ((x) == 0xc0 || (x) == 0xc1 || (x) == 0xc2) +#define stbi__SOS(x) ((x) == 0xda) -#define stbi__SOF_progressive(x) ((x) == 0xc2) +#define stbi__SOF_progressive(x) ((x) == 0xc2) -static int stbi__decode_jpeg_header(stbi__jpeg *z, int scan) -{ - int m; - z->jfif = 0; - z->app14_color_transform = -1; // valid values are 0,1,2 - z->marker = STBI__MARKER_none; // initialize cached marker to empty - m = stbi__get_marker(z); - if (!stbi__SOI(m)) return stbi__err("no SOI","Corrupt JPEG"); - if (scan == STBI__SCAN_type) return 1; - m = stbi__get_marker(z); - while (!stbi__SOF(m)) { - if (!stbi__process_marker(z,m)) return 0; - m = stbi__get_marker(z); - while (m == STBI__MARKER_none) { - // some files have extra padding after their blocks, so ok, we'll scan - if (stbi__at_eof(z->s)) return stbi__err("no SOF", "Corrupt JPEG"); - m = stbi__get_marker(z); - } - } - z->progressive = stbi__SOF_progressive(m); - if (!stbi__process_frame_header(z, scan)) return 0; - return 1; +static int stbi__decode_jpeg_header(stbi__jpeg* z, int scan) { + int m; + z->jfif = 0; + z->app14_color_transform = -1; // valid values are 0,1,2 + z->marker = STBI__MARKER_none; // initialize cached marker to empty + m = stbi__get_marker(z); + if (!stbi__SOI(m)) + return stbi__err("no SOI", "Corrupt JPEG"); + if (scan == STBI__SCAN_type) + return 1; + m = stbi__get_marker(z); + while (!stbi__SOF(m)) { + if (!stbi__process_marker(z, m)) + return 0; + m = stbi__get_marker(z); + while (m == STBI__MARKER_none) { + // some files have extra padding after their blocks, so ok, we'll + // scan + if (stbi__at_eof(z->s)) + return stbi__err("no SOF", "Corrupt JPEG"); + m = stbi__get_marker(z); + } + } + z->progressive = stbi__SOF_progressive(m); + if (!stbi__process_frame_header(z, scan)) + return 0; + return 1; } -static int stbi__skip_jpeg_junk_at_end(stbi__jpeg *j) -{ - // some JPEGs have junk at end, skip over it but if we find what looks - // like a valid marker, resume there - while (!stbi__at_eof(j->s)) { - int x = stbi__get8(j->s); - while (x == 255) { // might be a marker - if (stbi__at_eof(j->s)) return STBI__MARKER_none; - x = stbi__get8(j->s); - if (x != 0x00 && x != 0xff) { - // not a stuffed zero or lead-in to another marker, looks - // like an actual marker, return it - return x; - } - // stuffed zero has x=0 now which ends the loop, meaning we go - // back to regular scan loop. - // repeated 0xff keeps trying to read the next byte of the marker. - } - } - return STBI__MARKER_none; +static stbi_uc stbi__skip_jpeg_junk_at_end(stbi__jpeg* j) { + // some JPEGs have junk at end, skip over it but if we find what looks + // like a valid marker, resume there + while (!stbi__at_eof(j->s)) { + stbi_uc x = stbi__get8(j->s); + while (x == 0xff) { // might be a marker + if (stbi__at_eof(j->s)) + return STBI__MARKER_none; + x = stbi__get8(j->s); + if (x != 0x00 && x != 0xff) { + // not a stuffed zero or lead-in to another marker, looks + // like an actual marker, return it + return x; + } + // stuffed zero has x=0 now which ends the loop, meaning we go + // back to regular scan loop. + // repeated 0xff keeps trying to read the next byte of the marker. + } + } + return STBI__MARKER_none; } // decode image to YCbCr format -static int stbi__decode_jpeg_image(stbi__jpeg *j) -{ - int m; - for (m = 0; m < 4; m++) { - j->img_comp[m].raw_data = NULL; - j->img_comp[m].raw_coeff = NULL; - } - j->restart_interval = 0; - if (!stbi__decode_jpeg_header(j, STBI__SCAN_load)) return 0; - m = stbi__get_marker(j); - while (!stbi__EOI(m)) { - if (stbi__SOS(m)) { - if (!stbi__process_scan_header(j)) return 0; - if (!stbi__parse_entropy_coded_data(j)) return 0; - if (j->marker == STBI__MARKER_none ) { - j->marker = stbi__skip_jpeg_junk_at_end(j); - // if we reach eof without hitting a marker, stbi__get_marker() below will fail and we'll eventually return 0 - } - m = stbi__get_marker(j); - if (STBI__RESTART(m)) +static int stbi__decode_jpeg_image(stbi__jpeg* j) { + int m; + for (m = 0; m < 4; m++) { + j->img_comp[m].raw_data = NULL; + j->img_comp[m].raw_coeff = NULL; + } + j->restart_interval = 0; + if (!stbi__decode_jpeg_header(j, STBI__SCAN_load)) + return 0; + m = stbi__get_marker(j); + while (!stbi__EOI(m)) { + if (stbi__SOS(m)) { + if (!stbi__process_scan_header(j)) + return 0; + if (!stbi__parse_entropy_coded_data(j)) + return 0; + if (j->marker == STBI__MARKER_none) { + j->marker = stbi__skip_jpeg_junk_at_end(j); + // if we reach eof without hitting a marker, stbi__get_marker() + // below will fail and we'll eventually return 0 + } m = stbi__get_marker(j); - } else if (stbi__DNL(m)) { - int Ld = stbi__get16be(j->s); - stbi__uint32 NL = stbi__get16be(j->s); - if (Ld != 4) return stbi__err("bad DNL len", "Corrupt JPEG"); - if (NL != j->s->img_y) return stbi__err("bad DNL height", "Corrupt JPEG"); - m = stbi__get_marker(j); - } else { - if (!stbi__process_marker(j, m)) return 1; - m = stbi__get_marker(j); - } - } - if (j->progressive) - stbi__jpeg_finish(j); - return 1; + if (STBI__RESTART(m)) + m = stbi__get_marker(j); + } else if (stbi__DNL(m)) { + int Ld = stbi__get16be(j->s); + stbi__uint32 NL = stbi__get16be(j->s); + if (Ld != 4) + return stbi__err("bad DNL len", "Corrupt JPEG"); + if (NL != j->s->img_y) + return stbi__err("bad DNL height", "Corrupt JPEG"); + m = stbi__get_marker(j); + } else { + if (!stbi__process_marker(j, m)) + return 1; + m = stbi__get_marker(j); + } + } + if (j->progressive) + stbi__jpeg_finish(j); + return 1; } // static jfif-centered resampling (across block boundaries) -typedef stbi_uc *(*resample_row_func)(stbi_uc *out, stbi_uc *in0, stbi_uc *in1, - int w, int hs); +typedef stbi_uc* (*resample_row_func)(stbi_uc* out, stbi_uc* in0, stbi_uc* in1, + int w, int hs); -#define stbi__div4(x) ((stbi_uc) ((x) >> 2)) +#define stbi__div4(x) ((stbi_uc)((x) >> 2)) -static stbi_uc *resample_row_1(stbi_uc *out, stbi_uc *in_near, stbi_uc *in_far, int w, int hs) -{ - STBI_NOTUSED(out); - STBI_NOTUSED(in_far); - STBI_NOTUSED(w); - STBI_NOTUSED(hs); - return in_near; +static stbi_uc* resample_row_1(stbi_uc* out, stbi_uc* in_near, stbi_uc* in_far, + int w, int hs) { + STBI_NOTUSED(out); + STBI_NOTUSED(in_far); + STBI_NOTUSED(w); + STBI_NOTUSED(hs); + return in_near; } -static stbi_uc* stbi__resample_row_v_2(stbi_uc *out, stbi_uc *in_near, stbi_uc *in_far, int w, int hs) -{ - // need to generate two samples vertically for every one in input - int i; - STBI_NOTUSED(hs); - for (i=0; i < w; ++i) - out[i] = stbi__div4(3*in_near[i] + in_far[i] + 2); - return out; +static stbi_uc* stbi__resample_row_v_2(stbi_uc* out, stbi_uc* in_near, + stbi_uc* in_far, int w, int hs) { + // need to generate two samples vertically for every one in input + int i; + STBI_NOTUSED(hs); + for (i = 0; i < w; ++i) + out[i] = stbi__div4(3 * in_near[i] + in_far[i] + 2); + return out; } -static stbi_uc* stbi__resample_row_h_2(stbi_uc *out, stbi_uc *in_near, stbi_uc *in_far, int w, int hs) -{ - // need to generate two samples horizontally for every one in input - int i; - stbi_uc *input = in_near; +static stbi_uc* stbi__resample_row_h_2(stbi_uc* out, stbi_uc* in_near, + stbi_uc* in_far, int w, int hs) { + // need to generate two samples horizontally for every one in input + int i; + stbi_uc* input = in_near; - if (w == 1) { - // if only one sample, can't do any interpolation - out[0] = out[1] = input[0]; - return out; - } + if (w == 1) { + // if only one sample, can't do any interpolation + out[0] = out[1] = input[0]; + return out; + } - out[0] = input[0]; - out[1] = stbi__div4(input[0]*3 + input[1] + 2); - for (i=1; i < w-1; ++i) { - int n = 3*input[i]+2; - out[i*2+0] = stbi__div4(n+input[i-1]); - out[i*2+1] = stbi__div4(n+input[i+1]); - } - out[i*2+0] = stbi__div4(input[w-2]*3 + input[w-1] + 2); - out[i*2+1] = input[w-1]; + out[0] = input[0]; + out[1] = stbi__div4(input[0] * 3 + input[1] + 2); + for (i = 1; i < w - 1; ++i) { + int n = 3 * input[i] + 2; + out[i * 2 + 0] = stbi__div4(n + input[i - 1]); + out[i * 2 + 1] = stbi__div4(n + input[i + 1]); + } + out[i * 2 + 0] = stbi__div4(input[w - 2] * 3 + input[w - 1] + 2); + out[i * 2 + 1] = input[w - 1]; - STBI_NOTUSED(in_far); - STBI_NOTUSED(hs); + STBI_NOTUSED(in_far); + STBI_NOTUSED(hs); - return out; + return out; } -#define stbi__div16(x) ((stbi_uc) ((x) >> 4)) +#define stbi__div16(x) ((stbi_uc)((x) >> 4)) -static stbi_uc *stbi__resample_row_hv_2(stbi_uc *out, stbi_uc *in_near, stbi_uc *in_far, int w, int hs) -{ - // need to generate 2x2 samples for every one in input - int i,t0,t1; - if (w == 1) { - out[0] = out[1] = stbi__div4(3*in_near[0] + in_far[0] + 2); - return out; - } +static stbi_uc* stbi__resample_row_hv_2(stbi_uc* out, stbi_uc* in_near, + stbi_uc* in_far, int w, int hs) { + // need to generate 2x2 samples for every one in input + int i, t0, t1; + if (w == 1) { + out[0] = out[1] = stbi__div4(3 * in_near[0] + in_far[0] + 2); + return out; + } - t1 = 3*in_near[0] + in_far[0]; - out[0] = stbi__div4(t1+2); - for (i=1; i < w; ++i) { - t0 = t1; - t1 = 3*in_near[i]+in_far[i]; - out[i*2-1] = stbi__div16(3*t0 + t1 + 8); - out[i*2 ] = stbi__div16(3*t1 + t0 + 8); - } - out[w*2-1] = stbi__div4(t1+2); + t1 = 3 * in_near[0] + in_far[0]; + out[0] = stbi__div4(t1 + 2); + for (i = 1; i < w; ++i) { + t0 = t1; + t1 = 3 * in_near[i] + in_far[i]; + out[i * 2 - 1] = stbi__div16(3 * t0 + t1 + 8); + out[i * 2] = stbi__div16(3 * t1 + t0 + 8); + } + out[w * 2 - 1] = stbi__div4(t1 + 2); - STBI_NOTUSED(hs); + STBI_NOTUSED(hs); - return out; + return out; } #if defined(STBI_SSE2) || defined(STBI_NEON) -static stbi_uc *stbi__resample_row_hv_2_simd(stbi_uc *out, stbi_uc *in_near, stbi_uc *in_far, int w, int hs) -{ - // need to generate 2x2 samples for every one in input - int i=0,t0,t1; +static stbi_uc* stbi__resample_row_hv_2_simd(stbi_uc* out, stbi_uc* in_near, + stbi_uc* in_far, int w, int hs) { + // need to generate 2x2 samples for every one in input + int i = 0, t0, t1; - if (w == 1) { - out[0] = out[1] = stbi__div4(3*in_near[0] + in_far[0] + 2); - return out; - } + if (w == 1) { + out[0] = out[1] = stbi__div4(3 * in_near[0] + in_far[0] + 2); + return out; + } - t1 = 3*in_near[0] + in_far[0]; - // process groups of 8 pixels for as long as we can. - // note we can't handle the last pixel in a row in this loop - // because we need to handle the filter boundary conditions. - for (; i < ((w-1) & ~7); i += 8) { + t1 = 3 * in_near[0] + in_far[0]; + // process groups of 8 pixels for as long as we can. + // note we can't handle the last pixel in a row in this loop + // because we need to handle the filter boundary conditions. + for (; i < ((w - 1) & ~7); i += 8) { #if defined(STBI_SSE2) - // load and perform the vertical filtering pass - // this uses 3*x + y = 4*x + (y - x) - __m128i zero = _mm_setzero_si128(); - __m128i farb = _mm_loadl_epi64((__m128i *) (in_far + i)); - __m128i nearb = _mm_loadl_epi64((__m128i *) (in_near + i)); - __m128i farw = _mm_unpacklo_epi8(farb, zero); - __m128i nearw = _mm_unpacklo_epi8(nearb, zero); - __m128i diff = _mm_sub_epi16(farw, nearw); - __m128i nears = _mm_slli_epi16(nearw, 2); - __m128i curr = _mm_add_epi16(nears, diff); // current row + // load and perform the vertical filtering pass + // this uses 3*x + y = 4*x + (y - x) + __m128i zero = _mm_setzero_si128(); + __m128i farb = _mm_loadl_epi64((__m128i*)(in_far + i)); + __m128i nearb = _mm_loadl_epi64((__m128i*)(in_near + i)); + __m128i farw = _mm_unpacklo_epi8(farb, zero); + __m128i nearw = _mm_unpacklo_epi8(nearb, zero); + __m128i diff = _mm_sub_epi16(farw, nearw); + __m128i nears = _mm_slli_epi16(nearw, 2); + __m128i curr = _mm_add_epi16(nears, diff); // current row - // horizontal filter works the same based on shifted vers of current - // row. "prev" is current row shifted right by 1 pixel; we need to - // insert the previous pixel value (from t1). - // "next" is current row shifted left by 1 pixel, with first pixel - // of next block of 8 pixels added in. - __m128i prv0 = _mm_slli_si128(curr, 2); - __m128i nxt0 = _mm_srli_si128(curr, 2); - __m128i prev = _mm_insert_epi16(prv0, t1, 0); - __m128i next = _mm_insert_epi16(nxt0, 3*in_near[i+8] + in_far[i+8], 7); + // horizontal filter works the same based on shifted vers of current + // row. "prev" is current row shifted right by 1 pixel; we need to + // insert the previous pixel value (from t1). + // "next" is current row shifted left by 1 pixel, with first pixel + // of next block of 8 pixels added in. + __m128i prv0 = _mm_slli_si128(curr, 2); + __m128i nxt0 = _mm_srli_si128(curr, 2); + __m128i prev = _mm_insert_epi16(prv0, t1, 0); + __m128i next = + _mm_insert_epi16(nxt0, 3 * in_near[i + 8] + in_far[i + 8], 7); - // horizontal filter, polyphase implementation since it's convenient: - // even pixels = 3*cur + prev = cur*4 + (prev - cur) - // odd pixels = 3*cur + next = cur*4 + (next - cur) - // note the shared term. - __m128i bias = _mm_set1_epi16(8); - __m128i curs = _mm_slli_epi16(curr, 2); - __m128i prvd = _mm_sub_epi16(prev, curr); - __m128i nxtd = _mm_sub_epi16(next, curr); - __m128i curb = _mm_add_epi16(curs, bias); - __m128i even = _mm_add_epi16(prvd, curb); - __m128i odd = _mm_add_epi16(nxtd, curb); + // horizontal filter, polyphase implementation since it's convenient: + // even pixels = 3*cur + prev = cur*4 + (prev - cur) + // odd pixels = 3*cur + next = cur*4 + (next - cur) + // note the shared term. + __m128i bias = _mm_set1_epi16(8); + __m128i curs = _mm_slli_epi16(curr, 2); + __m128i prvd = _mm_sub_epi16(prev, curr); + __m128i nxtd = _mm_sub_epi16(next, curr); + __m128i curb = _mm_add_epi16(curs, bias); + __m128i even = _mm_add_epi16(prvd, curb); + __m128i odd = _mm_add_epi16(nxtd, curb); - // interleave even and odd pixels, then undo scaling. - __m128i int0 = _mm_unpacklo_epi16(even, odd); - __m128i int1 = _mm_unpackhi_epi16(even, odd); - __m128i de0 = _mm_srli_epi16(int0, 4); - __m128i de1 = _mm_srli_epi16(int1, 4); + // interleave even and odd pixels, then undo scaling. + __m128i int0 = _mm_unpacklo_epi16(even, odd); + __m128i int1 = _mm_unpackhi_epi16(even, odd); + __m128i de0 = _mm_srli_epi16(int0, 4); + __m128i de1 = _mm_srli_epi16(int1, 4); - // pack and write output - __m128i outv = _mm_packus_epi16(de0, de1); - _mm_storeu_si128((__m128i *) (out + i*2), outv); + // pack and write output + __m128i outv = _mm_packus_epi16(de0, de1); + _mm_storeu_si128((__m128i*)(out + i * 2), outv); #elif defined(STBI_NEON) - // load and perform the vertical filtering pass - // this uses 3*x + y = 4*x + (y - x) - uint8x8_t farb = vld1_u8(in_far + i); - uint8x8_t nearb = vld1_u8(in_near + i); - int16x8_t diff = vreinterpretq_s16_u16(vsubl_u8(farb, nearb)); - int16x8_t nears = vreinterpretq_s16_u16(vshll_n_u8(nearb, 2)); - int16x8_t curr = vaddq_s16(nears, diff); // current row + // load and perform the vertical filtering pass + // this uses 3*x + y = 4*x + (y - x) + uint8x8_t farb = vld1_u8(in_far + i); + uint8x8_t nearb = vld1_u8(in_near + i); + int16x8_t diff = vreinterpretq_s16_u16(vsubl_u8(farb, nearb)); + int16x8_t nears = vreinterpretq_s16_u16(vshll_n_u8(nearb, 2)); + int16x8_t curr = vaddq_s16(nears, diff); // current row - // horizontal filter works the same based on shifted vers of current - // row. "prev" is current row shifted right by 1 pixel; we need to - // insert the previous pixel value (from t1). - // "next" is current row shifted left by 1 pixel, with first pixel - // of next block of 8 pixels added in. - int16x8_t prv0 = vextq_s16(curr, curr, 7); - int16x8_t nxt0 = vextq_s16(curr, curr, 1); - int16x8_t prev = vsetq_lane_s16(t1, prv0, 0); - int16x8_t next = vsetq_lane_s16(3*in_near[i+8] + in_far[i+8], nxt0, 7); + // horizontal filter works the same based on shifted vers of current + // row. "prev" is current row shifted right by 1 pixel; we need to + // insert the previous pixel value (from t1). + // "next" is current row shifted left by 1 pixel, with first pixel + // of next block of 8 pixels added in. + int16x8_t prv0 = vextq_s16(curr, curr, 7); + int16x8_t nxt0 = vextq_s16(curr, curr, 1); + int16x8_t prev = vsetq_lane_s16(t1, prv0, 0); + int16x8_t next = + vsetq_lane_s16(3 * in_near[i + 8] + in_far[i + 8], nxt0, 7); - // horizontal filter, polyphase implementation since it's convenient: - // even pixels = 3*cur + prev = cur*4 + (prev - cur) - // odd pixels = 3*cur + next = cur*4 + (next - cur) - // note the shared term. - int16x8_t curs = vshlq_n_s16(curr, 2); - int16x8_t prvd = vsubq_s16(prev, curr); - int16x8_t nxtd = vsubq_s16(next, curr); - int16x8_t even = vaddq_s16(curs, prvd); - int16x8_t odd = vaddq_s16(curs, nxtd); + // horizontal filter, polyphase implementation since it's convenient: + // even pixels = 3*cur + prev = cur*4 + (prev - cur) + // odd pixels = 3*cur + next = cur*4 + (next - cur) + // note the shared term. + int16x8_t curs = vshlq_n_s16(curr, 2); + int16x8_t prvd = vsubq_s16(prev, curr); + int16x8_t nxtd = vsubq_s16(next, curr); + int16x8_t even = vaddq_s16(curs, prvd); + int16x8_t odd = vaddq_s16(curs, nxtd); - // undo scaling and round, then store with even/odd phases interleaved - uint8x8x2_t o; - o.val[0] = vqrshrun_n_s16(even, 4); - o.val[1] = vqrshrun_n_s16(odd, 4); - vst2_u8(out + i*2, o); + // undo scaling and round, then store with even/odd phases interleaved + uint8x8x2_t o; + o.val[0] = vqrshrun_n_s16(even, 4); + o.val[1] = vqrshrun_n_s16(odd, 4); + vst2_u8(out + i * 2, o); #endif - // "previous" value for next iter - t1 = 3*in_near[i+7] + in_far[i+7]; - } + // "previous" value for next iter + t1 = 3 * in_near[i + 7] + in_far[i + 7]; + } - t0 = t1; - t1 = 3*in_near[i] + in_far[i]; - out[i*2] = stbi__div16(3*t1 + t0 + 8); + t0 = t1; + t1 = 3 * in_near[i] + in_far[i]; + out[i * 2] = stbi__div16(3 * t1 + t0 + 8); - for (++i; i < w; ++i) { - t0 = t1; - t1 = 3*in_near[i]+in_far[i]; - out[i*2-1] = stbi__div16(3*t0 + t1 + 8); - out[i*2 ] = stbi__div16(3*t1 + t0 + 8); - } - out[w*2-1] = stbi__div4(t1+2); + for (++i; i < w; ++i) { + t0 = t1; + t1 = 3 * in_near[i] + in_far[i]; + out[i * 2 - 1] = stbi__div16(3 * t0 + t1 + 8); + out[i * 2] = stbi__div16(3 * t1 + t0 + 8); + } + out[w * 2 - 1] = stbi__div4(t1 + 2); - STBI_NOTUSED(hs); + STBI_NOTUSED(hs); - return out; + return out; } #endif -static stbi_uc *stbi__resample_row_generic(stbi_uc *out, stbi_uc *in_near, stbi_uc *in_far, int w, int hs) -{ - // resample with nearest-neighbor - int i,j; - STBI_NOTUSED(in_far); - for (i=0; i < w; ++i) - for (j=0; j < hs; ++j) - out[i*hs+j] = in_near[i]; - return out; +static stbi_uc* stbi__resample_row_generic(stbi_uc* out, stbi_uc* in_near, + stbi_uc* in_far, int w, int hs) { + // resample with nearest-neighbor + int i, j; + STBI_NOTUSED(in_far); + for (i = 0; i < w; ++i) + for (j = 0; j < hs; ++j) + out[i * hs + j] = in_near[i]; + return out; } // this is a reduced-precision calculation of YCbCr-to-RGB introduced // to make sure the code produces the same results in both SIMD and scalar -#define stbi__float2fixed(x) (((int) ((x) * 4096.0f + 0.5f)) << 8) -static void stbi__YCbCr_to_RGB_row(stbi_uc *out, const stbi_uc *y, const stbi_uc *pcb, const stbi_uc *pcr, int count, int step) -{ - int i; - for (i=0; i < count; ++i) { - int y_fixed = (y[i] << 20) + (1<<19); // rounding - int r,g,b; - int cr = pcr[i] - 128; - int cb = pcb[i] - 128; - r = y_fixed + cr* stbi__float2fixed(1.40200f); - g = y_fixed + (cr*-stbi__float2fixed(0.71414f)) + ((cb*-stbi__float2fixed(0.34414f)) & 0xffff0000); - b = y_fixed + cb* stbi__float2fixed(1.77200f); - r >>= 20; - g >>= 20; - b >>= 20; - if ((unsigned) r > 255) { if (r < 0) r = 0; else r = 255; } - if ((unsigned) g > 255) { if (g < 0) g = 0; else g = 255; } - if ((unsigned) b > 255) { if (b < 0) b = 0; else b = 255; } - out[0] = (stbi_uc)r; - out[1] = (stbi_uc)g; - out[2] = (stbi_uc)b; - out[3] = 255; - out += step; - } +#define stbi__float2fixed(x) (((int)((x) * 4096.0f + 0.5f)) << 8) +static void stbi__YCbCr_to_RGB_row(stbi_uc* out, const stbi_uc* y, + const stbi_uc* pcb, const stbi_uc* pcr, + int count, int step) { + int i; + for (i = 0; i < count; ++i) { + int y_fixed = (y[i] << 20) + (1 << 19); // rounding + int r, g, b; + int cr = pcr[i] - 128; + int cb = pcb[i] - 128; + r = y_fixed + cr * stbi__float2fixed(1.40200f); + g = y_fixed + (cr * -stbi__float2fixed(0.71414f)) + + ((cb * -stbi__float2fixed(0.34414f)) & 0xffff0000); + b = y_fixed + cb * stbi__float2fixed(1.77200f); + r >>= 20; + g >>= 20; + b >>= 20; + if ((unsigned)r > 255) { + if (r < 0) + r = 0; + else + r = 255; + } + if ((unsigned)g > 255) { + if (g < 0) + g = 0; + else + g = 255; + } + if ((unsigned)b > 255) { + if (b < 0) + b = 0; + else + b = 255; + } + out[0] = (stbi_uc)r; + out[1] = (stbi_uc)g; + out[2] = (stbi_uc)b; + out[3] = 255; + out += step; + } } #if defined(STBI_SSE2) || defined(STBI_NEON) -static void stbi__YCbCr_to_RGB_simd(stbi_uc *out, stbi_uc const *y, stbi_uc const *pcb, stbi_uc const *pcr, int count, int step) -{ - int i = 0; +static void stbi__YCbCr_to_RGB_simd(stbi_uc* out, stbi_uc const* y, + stbi_uc const* pcb, stbi_uc const* pcr, + int count, int step) { + int i = 0; #ifdef STBI_SSE2 - // step == 3 is pretty ugly on the final interleave, and i'm not convinced - // it's useful in practice (you wouldn't use it for textures, for example). - // so just accelerate step == 4 case. - if (step == 4) { - // this is a fairly straightforward implementation and not super-optimized. - __m128i signflip = _mm_set1_epi8(-0x80); - __m128i cr_const0 = _mm_set1_epi16( (short) ( 1.40200f*4096.0f+0.5f)); - __m128i cr_const1 = _mm_set1_epi16( - (short) ( 0.71414f*4096.0f+0.5f)); - __m128i cb_const0 = _mm_set1_epi16( - (short) ( 0.34414f*4096.0f+0.5f)); - __m128i cb_const1 = _mm_set1_epi16( (short) ( 1.77200f*4096.0f+0.5f)); - __m128i y_bias = _mm_set1_epi8((char) (unsigned char) 128); - __m128i xw = _mm_set1_epi16(255); // alpha channel + // step == 3 is pretty ugly on the final interleave, and i'm not convinced + // it's useful in practice (you wouldn't use it for textures, for example). + // so just accelerate step == 4 case. + if (step == 4) { + // this is a fairly straightforward implementation and not + // super-optimized. + __m128i signflip = _mm_set1_epi8(-0x80); + __m128i cr_const0 = _mm_set1_epi16((short)(1.40200f * 4096.0f + 0.5f)); + __m128i cr_const1 = _mm_set1_epi16(-(short)(0.71414f * 4096.0f + 0.5f)); + __m128i cb_const0 = _mm_set1_epi16(-(short)(0.34414f * 4096.0f + 0.5f)); + __m128i cb_const1 = _mm_set1_epi16((short)(1.77200f * 4096.0f + 0.5f)); + __m128i y_bias = _mm_set1_epi8((char)(unsigned char)128); + __m128i xw = _mm_set1_epi16(255); // alpha channel - for (; i+7 < count; i += 8) { - // load - __m128i y_bytes = _mm_loadl_epi64((__m128i *) (y+i)); - __m128i cr_bytes = _mm_loadl_epi64((__m128i *) (pcr+i)); - __m128i cb_bytes = _mm_loadl_epi64((__m128i *) (pcb+i)); - __m128i cr_biased = _mm_xor_si128(cr_bytes, signflip); // -128 - __m128i cb_biased = _mm_xor_si128(cb_bytes, signflip); // -128 + for (; i + 7 < count; i += 8) { + // load + __m128i y_bytes = _mm_loadl_epi64((__m128i*)(y + i)); + __m128i cr_bytes = _mm_loadl_epi64((__m128i*)(pcr + i)); + __m128i cb_bytes = _mm_loadl_epi64((__m128i*)(pcb + i)); + __m128i cr_biased = _mm_xor_si128(cr_bytes, signflip); // -128 + __m128i cb_biased = _mm_xor_si128(cb_bytes, signflip); // -128 - // unpack to short (and left-shift cr, cb by 8) - __m128i yw = _mm_unpacklo_epi8(y_bias, y_bytes); - __m128i crw = _mm_unpacklo_epi8(_mm_setzero_si128(), cr_biased); - __m128i cbw = _mm_unpacklo_epi8(_mm_setzero_si128(), cb_biased); + // unpack to short (and left-shift cr, cb by 8) + __m128i yw = _mm_unpacklo_epi8(y_bias, y_bytes); + __m128i crw = _mm_unpacklo_epi8(_mm_setzero_si128(), cr_biased); + __m128i cbw = _mm_unpacklo_epi8(_mm_setzero_si128(), cb_biased); - // color transform - __m128i yws = _mm_srli_epi16(yw, 4); - __m128i cr0 = _mm_mulhi_epi16(cr_const0, crw); - __m128i cb0 = _mm_mulhi_epi16(cb_const0, cbw); - __m128i cb1 = _mm_mulhi_epi16(cbw, cb_const1); - __m128i cr1 = _mm_mulhi_epi16(crw, cr_const1); - __m128i rws = _mm_add_epi16(cr0, yws); - __m128i gwt = _mm_add_epi16(cb0, yws); - __m128i bws = _mm_add_epi16(yws, cb1); - __m128i gws = _mm_add_epi16(gwt, cr1); + // color transform + __m128i yws = _mm_srli_epi16(yw, 4); + __m128i cr0 = _mm_mulhi_epi16(cr_const0, crw); + __m128i cb0 = _mm_mulhi_epi16(cb_const0, cbw); + __m128i cb1 = _mm_mulhi_epi16(cbw, cb_const1); + __m128i cr1 = _mm_mulhi_epi16(crw, cr_const1); + __m128i rws = _mm_add_epi16(cr0, yws); + __m128i gwt = _mm_add_epi16(cb0, yws); + __m128i bws = _mm_add_epi16(yws, cb1); + __m128i gws = _mm_add_epi16(gwt, cr1); - // descale - __m128i rw = _mm_srai_epi16(rws, 4); - __m128i bw = _mm_srai_epi16(bws, 4); - __m128i gw = _mm_srai_epi16(gws, 4); + // descale + __m128i rw = _mm_srai_epi16(rws, 4); + __m128i bw = _mm_srai_epi16(bws, 4); + __m128i gw = _mm_srai_epi16(gws, 4); - // back to byte, set up for transpose - __m128i brb = _mm_packus_epi16(rw, bw); - __m128i gxb = _mm_packus_epi16(gw, xw); + // back to byte, set up for transpose + __m128i brb = _mm_packus_epi16(rw, bw); + __m128i gxb = _mm_packus_epi16(gw, xw); - // transpose to interleave channels - __m128i t0 = _mm_unpacklo_epi8(brb, gxb); - __m128i t1 = _mm_unpackhi_epi8(brb, gxb); - __m128i o0 = _mm_unpacklo_epi16(t0, t1); - __m128i o1 = _mm_unpackhi_epi16(t0, t1); + // transpose to interleave channels + __m128i t0 = _mm_unpacklo_epi8(brb, gxb); + __m128i t1 = _mm_unpackhi_epi8(brb, gxb); + __m128i o0 = _mm_unpacklo_epi16(t0, t1); + __m128i o1 = _mm_unpackhi_epi16(t0, t1); - // store - _mm_storeu_si128((__m128i *) (out + 0), o0); - _mm_storeu_si128((__m128i *) (out + 16), o1); - out += 32; - } - } + // store + _mm_storeu_si128((__m128i*)(out + 0), o0); + _mm_storeu_si128((__m128i*)(out + 16), o1); + out += 32; + } + } #endif #ifdef STBI_NEON - // in this version, step=3 support would be easy to add. but is there demand? - if (step == 4) { - // this is a fairly straightforward implementation and not super-optimized. - uint8x8_t signflip = vdup_n_u8(0x80); - int16x8_t cr_const0 = vdupq_n_s16( (short) ( 1.40200f*4096.0f+0.5f)); - int16x8_t cr_const1 = vdupq_n_s16( - (short) ( 0.71414f*4096.0f+0.5f)); - int16x8_t cb_const0 = vdupq_n_s16( - (short) ( 0.34414f*4096.0f+0.5f)); - int16x8_t cb_const1 = vdupq_n_s16( (short) ( 1.77200f*4096.0f+0.5f)); + // in this version, step=3 support would be easy to add. but is there + // demand? + if (step == 4) { + // this is a fairly straightforward implementation and not + // super-optimized. + uint8x8_t signflip = vdup_n_u8(0x80); + int16x8_t cr_const0 = vdupq_n_s16((short)(1.40200f * 4096.0f + 0.5f)); + int16x8_t cr_const1 = vdupq_n_s16(-(short)(0.71414f * 4096.0f + 0.5f)); + int16x8_t cb_const0 = vdupq_n_s16(-(short)(0.34414f * 4096.0f + 0.5f)); + int16x8_t cb_const1 = vdupq_n_s16((short)(1.77200f * 4096.0f + 0.5f)); - for (; i+7 < count; i += 8) { - // load - uint8x8_t y_bytes = vld1_u8(y + i); - uint8x8_t cr_bytes = vld1_u8(pcr + i); - uint8x8_t cb_bytes = vld1_u8(pcb + i); - int8x8_t cr_biased = vreinterpret_s8_u8(vsub_u8(cr_bytes, signflip)); - int8x8_t cb_biased = vreinterpret_s8_u8(vsub_u8(cb_bytes, signflip)); + for (; i + 7 < count; i += 8) { + // load + uint8x8_t y_bytes = vld1_u8(y + i); + uint8x8_t cr_bytes = vld1_u8(pcr + i); + uint8x8_t cb_bytes = vld1_u8(pcb + i); + int8x8_t cr_biased = + vreinterpret_s8_u8(vsub_u8(cr_bytes, signflip)); + int8x8_t cb_biased = + vreinterpret_s8_u8(vsub_u8(cb_bytes, signflip)); - // expand to s16 - int16x8_t yws = vreinterpretq_s16_u16(vshll_n_u8(y_bytes, 4)); - int16x8_t crw = vshll_n_s8(cr_biased, 7); - int16x8_t cbw = vshll_n_s8(cb_biased, 7); + // expand to s16 + int16x8_t yws = vreinterpretq_s16_u16(vshll_n_u8(y_bytes, 4)); + int16x8_t crw = vshll_n_s8(cr_biased, 7); + int16x8_t cbw = vshll_n_s8(cb_biased, 7); - // color transform - int16x8_t cr0 = vqdmulhq_s16(crw, cr_const0); - int16x8_t cb0 = vqdmulhq_s16(cbw, cb_const0); - int16x8_t cr1 = vqdmulhq_s16(crw, cr_const1); - int16x8_t cb1 = vqdmulhq_s16(cbw, cb_const1); - int16x8_t rws = vaddq_s16(yws, cr0); - int16x8_t gws = vaddq_s16(vaddq_s16(yws, cb0), cr1); - int16x8_t bws = vaddq_s16(yws, cb1); + // color transform + int16x8_t cr0 = vqdmulhq_s16(crw, cr_const0); + int16x8_t cb0 = vqdmulhq_s16(cbw, cb_const0); + int16x8_t cr1 = vqdmulhq_s16(crw, cr_const1); + int16x8_t cb1 = vqdmulhq_s16(cbw, cb_const1); + int16x8_t rws = vaddq_s16(yws, cr0); + int16x8_t gws = vaddq_s16(vaddq_s16(yws, cb0), cr1); + int16x8_t bws = vaddq_s16(yws, cb1); - // undo scaling, round, convert to byte - uint8x8x4_t o; - o.val[0] = vqrshrun_n_s16(rws, 4); - o.val[1] = vqrshrun_n_s16(gws, 4); - o.val[2] = vqrshrun_n_s16(bws, 4); - o.val[3] = vdup_n_u8(255); + // undo scaling, round, convert to byte + uint8x8x4_t o; + o.val[0] = vqrshrun_n_s16(rws, 4); + o.val[1] = vqrshrun_n_s16(gws, 4); + o.val[2] = vqrshrun_n_s16(bws, 4); + o.val[3] = vdup_n_u8(255); - // store, interleaving r/g/b/a - vst4_u8(out, o); - out += 8*4; - } - } + // store, interleaving r/g/b/a + vst4_u8(out, o); + out += 8 * 4; + } + } #endif - for (; i < count; ++i) { - int y_fixed = (y[i] << 20) + (1<<19); // rounding - int r,g,b; - int cr = pcr[i] - 128; - int cb = pcb[i] - 128; - r = y_fixed + cr* stbi__float2fixed(1.40200f); - g = y_fixed + cr*-stbi__float2fixed(0.71414f) + ((cb*-stbi__float2fixed(0.34414f)) & 0xffff0000); - b = y_fixed + cb* stbi__float2fixed(1.77200f); - r >>= 20; - g >>= 20; - b >>= 20; - if ((unsigned) r > 255) { if (r < 0) r = 0; else r = 255; } - if ((unsigned) g > 255) { if (g < 0) g = 0; else g = 255; } - if ((unsigned) b > 255) { if (b < 0) b = 0; else b = 255; } - out[0] = (stbi_uc)r; - out[1] = (stbi_uc)g; - out[2] = (stbi_uc)b; - out[3] = 255; - out += step; - } + for (; i < count; ++i) { + int y_fixed = (y[i] << 20) + (1 << 19); // rounding + int r, g, b; + int cr = pcr[i] - 128; + int cb = pcb[i] - 128; + r = y_fixed + cr * stbi__float2fixed(1.40200f); + g = y_fixed + cr * -stbi__float2fixed(0.71414f) + + ((cb * -stbi__float2fixed(0.34414f)) & 0xffff0000); + b = y_fixed + cb * stbi__float2fixed(1.77200f); + r >>= 20; + g >>= 20; + b >>= 20; + if ((unsigned)r > 255) { + if (r < 0) + r = 0; + else + r = 255; + } + if ((unsigned)g > 255) { + if (g < 0) + g = 0; + else + g = 255; + } + if ((unsigned)b > 255) { + if (b < 0) + b = 0; + else + b = 255; + } + out[0] = (stbi_uc)r; + out[1] = (stbi_uc)g; + out[2] = (stbi_uc)b; + out[3] = 255; + out += step; + } } #endif // set up the kernels -static void stbi__setup_jpeg(stbi__jpeg *j) -{ - j->idct_block_kernel = stbi__idct_block; - j->YCbCr_to_RGB_kernel = stbi__YCbCr_to_RGB_row; - j->resample_row_hv_2_kernel = stbi__resample_row_hv_2; +static void stbi__setup_jpeg(stbi__jpeg* j) { + j->idct_block_kernel = stbi__idct_block; + j->YCbCr_to_RGB_kernel = stbi__YCbCr_to_RGB_row; + j->resample_row_hv_2_kernel = stbi__resample_row_hv_2; #ifdef STBI_SSE2 - if (stbi__sse2_available()) { - j->idct_block_kernel = stbi__idct_simd; - j->YCbCr_to_RGB_kernel = stbi__YCbCr_to_RGB_simd; - j->resample_row_hv_2_kernel = stbi__resample_row_hv_2_simd; - } + if (stbi__sse2_available()) { + j->idct_block_kernel = stbi__idct_simd; + j->YCbCr_to_RGB_kernel = stbi__YCbCr_to_RGB_simd; + j->resample_row_hv_2_kernel = stbi__resample_row_hv_2_simd; + } #endif #ifdef STBI_NEON - j->idct_block_kernel = stbi__idct_simd; - j->YCbCr_to_RGB_kernel = stbi__YCbCr_to_RGB_simd; - j->resample_row_hv_2_kernel = stbi__resample_row_hv_2_simd; + j->idct_block_kernel = stbi__idct_simd; + j->YCbCr_to_RGB_kernel = stbi__YCbCr_to_RGB_simd; + j->resample_row_hv_2_kernel = stbi__resample_row_hv_2_simd; #endif } // clean up the temporary component buffers -static void stbi__cleanup_jpeg(stbi__jpeg *j) -{ - stbi__free_jpeg_components(j, j->s->img_n, 0); +static void stbi__cleanup_jpeg(stbi__jpeg* j) { + stbi__free_jpeg_components(j, j->s->img_n, 0); } -typedef struct -{ - resample_row_func resample; - stbi_uc *line0,*line1; - int hs,vs; // expansion factor in each axis - int w_lores; // horizontal pixels pre-expansion - int ystep; // how far through vertical expansion we are - int ypos; // which pre-expansion row we're on +typedef struct { + resample_row_func resample; + stbi_uc *line0, *line1; + int hs, vs; // expansion factor in each axis + int w_lores; // horizontal pixels pre-expansion + int ystep; // how far through vertical expansion we are + int ypos; // which pre-expansion row we're on } stbi__resample; // fast 0..255 * 0..255 => 0..255 rounded multiplication -static stbi_uc stbi__blinn_8x8(stbi_uc x, stbi_uc y) -{ - unsigned int t = x*y + 128; - return (stbi_uc) ((t + (t >>8)) >> 8); +static stbi_uc stbi__blinn_8x8(stbi_uc x, stbi_uc y) { + unsigned int t = x * y + 128; + return (stbi_uc)((t + (t >> 8)) >> 8); } -static stbi_uc *load_jpeg_image(stbi__jpeg *z, int *out_x, int *out_y, int *comp, int req_comp) -{ - int n, decode_n, is_rgb; - z->s->img_n = 0; // make stbi__cleanup_jpeg safe +static stbi_uc* load_jpeg_image(stbi__jpeg* z, int* out_x, int* out_y, + int* comp, int req_comp) { + int n, decode_n, is_rgb; + z->s->img_n = 0; // make stbi__cleanup_jpeg safe - // validate req_comp - if (req_comp < 0 || req_comp > 4) return stbi__errpuc("bad req_comp", "Internal error"); + // validate req_comp + if (req_comp < 0 || req_comp > 4) + return stbi__errpuc("bad req_comp", "Internal error"); - // load a jpeg image from whichever source, but leave in YCbCr format - if (!stbi__decode_jpeg_image(z)) { stbi__cleanup_jpeg(z); return NULL; } + // load a jpeg image from whichever source, but leave in YCbCr format + if (!stbi__decode_jpeg_image(z)) { + stbi__cleanup_jpeg(z); + return NULL; + } - // determine actual number of components to generate - n = req_comp ? req_comp : z->s->img_n >= 3 ? 3 : 1; + // determine actual number of components to generate + n = req_comp ? req_comp : z->s->img_n >= 3 ? 3 : 1; - is_rgb = z->s->img_n == 3 && (z->rgb == 3 || (z->app14_color_transform == 0 && !z->jfif)); + is_rgb = z->s->img_n == 3 && + (z->rgb == 3 || (z->app14_color_transform == 0 && !z->jfif)); - if (z->s->img_n == 3 && n < 3 && !is_rgb) - decode_n = 1; - else - decode_n = z->s->img_n; + if (z->s->img_n == 3 && n < 3 && !is_rgb) + decode_n = 1; + else + decode_n = z->s->img_n; - // nothing to do if no components requested; check this now to avoid - // accessing uninitialized coutput[0] later - if (decode_n <= 0) { stbi__cleanup_jpeg(z); return NULL; } + // nothing to do if no components requested; check this now to avoid + // accessing uninitialized coutput[0] later + if (decode_n <= 0) { + stbi__cleanup_jpeg(z); + return NULL; + } - // resample and color-convert - { - int k; - unsigned int i,j; - stbi_uc *output; - stbi_uc *coutput[4] = { NULL, NULL, NULL, NULL }; + // resample and color-convert + { + int k; + unsigned int i, j; + stbi_uc* output; + stbi_uc* coutput[4] = {NULL, NULL, NULL, NULL}; - stbi__resample res_comp[4]; + stbi__resample res_comp[4]; - for (k=0; k < decode_n; ++k) { - stbi__resample *r = &res_comp[k]; + for (k = 0; k < decode_n; ++k) { + stbi__resample* r = &res_comp[k]; - // allocate line buffer big enough for upsampling off the edges - // with upsample factor of 4 - z->img_comp[k].linebuf = (stbi_uc *) stbi__malloc(z->s->img_x + 3); - if (!z->img_comp[k].linebuf) { stbi__cleanup_jpeg(z); return stbi__errpuc("outofmem", "Out of memory"); } - - r->hs = z->img_h_max / z->img_comp[k].h; - r->vs = z->img_v_max / z->img_comp[k].v; - r->ystep = r->vs >> 1; - r->w_lores = (z->s->img_x + r->hs-1) / r->hs; - r->ypos = 0; - r->line0 = r->line1 = z->img_comp[k].data; - - if (r->hs == 1 && r->vs == 1) r->resample = resample_row_1; - else if (r->hs == 1 && r->vs == 2) r->resample = stbi__resample_row_v_2; - else if (r->hs == 2 && r->vs == 1) r->resample = stbi__resample_row_h_2; - else if (r->hs == 2 && r->vs == 2) r->resample = z->resample_row_hv_2_kernel; - else r->resample = stbi__resample_row_generic; - } - - // can't error after this so, this is safe - output = (stbi_uc *) stbi__malloc_mad3(n, z->s->img_x, z->s->img_y, 1); - if (!output) { stbi__cleanup_jpeg(z); return stbi__errpuc("outofmem", "Out of memory"); } - - // now go ahead and resample - for (j=0; j < z->s->img_y; ++j) { - stbi_uc *out = output + n * z->s->img_x * j; - for (k=0; k < decode_n; ++k) { - stbi__resample *r = &res_comp[k]; - int y_bot = r->ystep >= (r->vs >> 1); - coutput[k] = r->resample(z->img_comp[k].linebuf, - y_bot ? r->line1 : r->line0, - y_bot ? r->line0 : r->line1, - r->w_lores, r->hs); - if (++r->ystep >= r->vs) { - r->ystep = 0; - r->line0 = r->line1; - if (++r->ypos < z->img_comp[k].y) - r->line1 += z->img_comp[k].w2; + // allocate line buffer big enough for upsampling off the edges + // with upsample factor of 4 + z->img_comp[k].linebuf = (stbi_uc*)stbi__malloc(z->s->img_x + 3); + if (!z->img_comp[k].linebuf) { + stbi__cleanup_jpeg(z); + return stbi__errpuc("outofmem", "Out of memory"); } - } - if (n >= 3) { - stbi_uc *y = coutput[0]; - if (z->s->img_n == 3) { - if (is_rgb) { - for (i=0; i < z->s->img_x; ++i) { - out[0] = y[i]; - out[1] = coutput[1][i]; - out[2] = coutput[2][i]; - out[3] = 255; - out += n; - } - } else { - z->YCbCr_to_RGB_kernel(out, y, coutput[1], coutput[2], z->s->img_x, n); - } - } else if (z->s->img_n == 4) { - if (z->app14_color_transform == 0) { // CMYK - for (i=0; i < z->s->img_x; ++i) { - stbi_uc m = coutput[3][i]; - out[0] = stbi__blinn_8x8(coutput[0][i], m); - out[1] = stbi__blinn_8x8(coutput[1][i], m); - out[2] = stbi__blinn_8x8(coutput[2][i], m); - out[3] = 255; - out += n; - } - } else if (z->app14_color_transform == 2) { // YCCK - z->YCbCr_to_RGB_kernel(out, y, coutput[1], coutput[2], z->s->img_x, n); - for (i=0; i < z->s->img_x; ++i) { - stbi_uc m = coutput[3][i]; - out[0] = stbi__blinn_8x8(255 - out[0], m); - out[1] = stbi__blinn_8x8(255 - out[1], m); - out[2] = stbi__blinn_8x8(255 - out[2], m); - out += n; - } - } else { // YCbCr + alpha? Ignore the fourth channel for now - z->YCbCr_to_RGB_kernel(out, y, coutput[1], coutput[2], z->s->img_x, n); - } - } else - for (i=0; i < z->s->img_x; ++i) { - out[0] = out[1] = out[2] = y[i]; - out[3] = 255; // not used if n==3 - out += n; - } - } else { - if (is_rgb) { - if (n == 1) - for (i=0; i < z->s->img_x; ++i) - *out++ = stbi__compute_y(coutput[0][i], coutput[1][i], coutput[2][i]); - else { - for (i=0; i < z->s->img_x; ++i, out += 2) { - out[0] = stbi__compute_y(coutput[0][i], coutput[1][i], coutput[2][i]); - out[1] = 255; - } - } - } else if (z->s->img_n == 4 && z->app14_color_transform == 0) { - for (i=0; i < z->s->img_x; ++i) { - stbi_uc m = coutput[3][i]; - stbi_uc r = stbi__blinn_8x8(coutput[0][i], m); - stbi_uc g = stbi__blinn_8x8(coutput[1][i], m); - stbi_uc b = stbi__blinn_8x8(coutput[2][i], m); - out[0] = stbi__compute_y(r, g, b); - out[1] = 255; - out += n; - } - } else if (z->s->img_n == 4 && z->app14_color_transform == 2) { - for (i=0; i < z->s->img_x; ++i) { - out[0] = stbi__blinn_8x8(255 - coutput[0][i], coutput[3][i]); - out[1] = 255; - out += n; - } + + r->hs = z->img_h_max / z->img_comp[k].h; + r->vs = z->img_v_max / z->img_comp[k].v; + r->ystep = r->vs >> 1; + r->w_lores = (z->s->img_x + r->hs - 1) / r->hs; + r->ypos = 0; + r->line0 = r->line1 = z->img_comp[k].data; + + if (r->hs == 1 && r->vs == 1) + r->resample = resample_row_1; + else if (r->hs == 1 && r->vs == 2) + r->resample = stbi__resample_row_v_2; + else if (r->hs == 2 && r->vs == 1) + r->resample = stbi__resample_row_h_2; + else if (r->hs == 2 && r->vs == 2) + r->resample = z->resample_row_hv_2_kernel; + else + r->resample = stbi__resample_row_generic; + } + + // can't error after this so, this is safe + output = (stbi_uc*)stbi__malloc_mad3(n, z->s->img_x, z->s->img_y, 1); + if (!output) { + stbi__cleanup_jpeg(z); + return stbi__errpuc("outofmem", "Out of memory"); + } + + // now go ahead and resample + for (j = 0; j < z->s->img_y; ++j) { + stbi_uc* out = output + n * z->s->img_x * j; + for (k = 0; k < decode_n; ++k) { + stbi__resample* r = &res_comp[k]; + int y_bot = r->ystep >= (r->vs >> 1); + coutput[k] = r->resample( + z->img_comp[k].linebuf, y_bot ? r->line1 : r->line0, + y_bot ? r->line0 : r->line1, r->w_lores, r->hs); + if (++r->ystep >= r->vs) { + r->ystep = 0; + r->line0 = r->line1; + if (++r->ypos < z->img_comp[k].y) + r->line1 += z->img_comp[k].w2; + } + } + if (n >= 3) { + stbi_uc* y = coutput[0]; + if (z->s->img_n == 3) { + if (is_rgb) { + for (i = 0; i < z->s->img_x; ++i) { + out[0] = y[i]; + out[1] = coutput[1][i]; + out[2] = coutput[2][i]; + out[3] = 255; + out += n; + } + } else { + z->YCbCr_to_RGB_kernel(out, y, coutput[1], coutput[2], + z->s->img_x, n); + } + } else if (z->s->img_n == 4) { + if (z->app14_color_transform == 0) { // CMYK + for (i = 0; i < z->s->img_x; ++i) { + stbi_uc m = coutput[3][i]; + out[0] = stbi__blinn_8x8(coutput[0][i], m); + out[1] = stbi__blinn_8x8(coutput[1][i], m); + out[2] = stbi__blinn_8x8(coutput[2][i], m); + out[3] = 255; + out += n; + } + } else if (z->app14_color_transform == 2) { // YCCK + z->YCbCr_to_RGB_kernel(out, y, coutput[1], coutput[2], + z->s->img_x, n); + for (i = 0; i < z->s->img_x; ++i) { + stbi_uc m = coutput[3][i]; + out[0] = stbi__blinn_8x8(255 - out[0], m); + out[1] = stbi__blinn_8x8(255 - out[1], m); + out[2] = stbi__blinn_8x8(255 - out[2], m); + out += n; + } + } else { // YCbCr + alpha? Ignore the fourth channel for + // now + z->YCbCr_to_RGB_kernel(out, y, coutput[1], coutput[2], + z->s->img_x, n); + } + } else + for (i = 0; i < z->s->img_x; ++i) { + out[0] = out[1] = out[2] = y[i]; + out[3] = 255; // not used if n==3 + out += n; + } } else { - stbi_uc *y = coutput[0]; - if (n == 1) - for (i=0; i < z->s->img_x; ++i) out[i] = y[i]; - else - for (i=0; i < z->s->img_x; ++i) { *out++ = y[i]; *out++ = 255; } + if (is_rgb) { + if (n == 1) + for (i = 0; i < z->s->img_x; ++i) + *out++ = stbi__compute_y( + coutput[0][i], coutput[1][i], coutput[2][i]); + else { + for (i = 0; i < z->s->img_x; ++i, out += 2) { + out[0] = stbi__compute_y( + coutput[0][i], coutput[1][i], coutput[2][i]); + out[1] = 255; + } + } + } else if (z->s->img_n == 4 && z->app14_color_transform == 0) { + for (i = 0; i < z->s->img_x; ++i) { + stbi_uc m = coutput[3][i]; + stbi_uc r = stbi__blinn_8x8(coutput[0][i], m); + stbi_uc g = stbi__blinn_8x8(coutput[1][i], m); + stbi_uc b = stbi__blinn_8x8(coutput[2][i], m); + out[0] = stbi__compute_y(r, g, b); + out[1] = 255; + out += n; + } + } else if (z->s->img_n == 4 && z->app14_color_transform == 2) { + for (i = 0; i < z->s->img_x; ++i) { + out[0] = + stbi__blinn_8x8(255 - coutput[0][i], coutput[3][i]); + out[1] = 255; + out += n; + } + } else { + stbi_uc* y = coutput[0]; + if (n == 1) + for (i = 0; i < z->s->img_x; ++i) + out[i] = y[i]; + else + for (i = 0; i < z->s->img_x; ++i) { + *out++ = y[i]; + *out++ = 255; + } + } } - } - } - stbi__cleanup_jpeg(z); - *out_x = z->s->img_x; - *out_y = z->s->img_y; - if (comp) *comp = z->s->img_n >= 3 ? 3 : 1; // report original components, not output - return output; - } + } + stbi__cleanup_jpeg(z); + *out_x = z->s->img_x; + *out_y = z->s->img_y; + if (comp) + *comp = z->s->img_n >= 3 + ? 3 + : 1; // report original components, not output + return output; + } } -static void *stbi__jpeg_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri) -{ - unsigned char* result; - stbi__jpeg* j = (stbi__jpeg*) stbi__malloc(sizeof(stbi__jpeg)); - if (!j) return stbi__errpuc("outofmem", "Out of memory"); - memset(j, 0, sizeof(stbi__jpeg)); - STBI_NOTUSED(ri); - j->s = s; - stbi__setup_jpeg(j); - result = load_jpeg_image(j, x,y,comp,req_comp); - STBI_FREE(j); - return result; +static void* stbi__jpeg_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri) { + unsigned char* result; + stbi__jpeg* j = (stbi__jpeg*)stbi__malloc(sizeof(stbi__jpeg)); + if (!j) + return stbi__errpuc("outofmem", "Out of memory"); + memset(j, 0, sizeof(stbi__jpeg)); + STBI_NOTUSED(ri); + j->s = s; + stbi__setup_jpeg(j); + result = load_jpeg_image(j, x, y, comp, req_comp); + STBI_FREE(j); + return result; } -static int stbi__jpeg_test(stbi__context *s) -{ - int r; - stbi__jpeg* j = (stbi__jpeg*)stbi__malloc(sizeof(stbi__jpeg)); - if (!j) return stbi__err("outofmem", "Out of memory"); - memset(j, 0, sizeof(stbi__jpeg)); - j->s = s; - stbi__setup_jpeg(j); - r = stbi__decode_jpeg_header(j, STBI__SCAN_type); - stbi__rewind(s); - STBI_FREE(j); - return r; +static int stbi__jpeg_test(stbi__context* s) { + int r; + stbi__jpeg* j = (stbi__jpeg*)stbi__malloc(sizeof(stbi__jpeg)); + if (!j) + return stbi__err("outofmem", "Out of memory"); + memset(j, 0, sizeof(stbi__jpeg)); + j->s = s; + stbi__setup_jpeg(j); + r = stbi__decode_jpeg_header(j, STBI__SCAN_type); + stbi__rewind(s); + STBI_FREE(j); + return r; } -static int stbi__jpeg_info_raw(stbi__jpeg *j, int *x, int *y, int *comp) -{ - if (!stbi__decode_jpeg_header(j, STBI__SCAN_header)) { - stbi__rewind( j->s ); - return 0; - } - if (x) *x = j->s->img_x; - if (y) *y = j->s->img_y; - if (comp) *comp = j->s->img_n >= 3 ? 3 : 1; - return 1; +static int stbi__jpeg_info_raw(stbi__jpeg* j, int* x, int* y, int* comp) { + if (!stbi__decode_jpeg_header(j, STBI__SCAN_header)) { + stbi__rewind(j->s); + return 0; + } + if (x) + *x = j->s->img_x; + if (y) + *y = j->s->img_y; + if (comp) + *comp = j->s->img_n >= 3 ? 3 : 1; + return 1; } -static int stbi__jpeg_info(stbi__context *s, int *x, int *y, int *comp) -{ - int result; - stbi__jpeg* j = (stbi__jpeg*) (stbi__malloc(sizeof(stbi__jpeg))); - if (!j) return stbi__err("outofmem", "Out of memory"); - memset(j, 0, sizeof(stbi__jpeg)); - j->s = s; - result = stbi__jpeg_info_raw(j, x, y, comp); - STBI_FREE(j); - return result; +static int stbi__jpeg_info(stbi__context* s, int* x, int* y, int* comp) { + int result; + stbi__jpeg* j = (stbi__jpeg*)(stbi__malloc(sizeof(stbi__jpeg))); + if (!j) + return stbi__err("outofmem", "Out of memory"); + memset(j, 0, sizeof(stbi__jpeg)); + j->s = s; + result = stbi__jpeg_info_raw(j, x, y, comp); + STBI_FREE(j); + return result; } #endif @@ -4086,84 +4577,82 @@ static int stbi__jpeg_info(stbi__context *s, int *x, int *y, int *comp) #ifndef STBI_NO_ZLIB // fast-way is faster to check than jpeg huffman, but slow way is slower -#define STBI__ZFAST_BITS 9 // accelerate all cases in default tables -#define STBI__ZFAST_MASK ((1 << STBI__ZFAST_BITS) - 1) +#define STBI__ZFAST_BITS 9 // accelerate all cases in default tables +#define STBI__ZFAST_MASK ((1 << STBI__ZFAST_BITS) - 1) #define STBI__ZNSYMS 288 // number of symbols in literal/length alphabet // zlib-style huffman encoding // (jpegs packs from left, zlib from right, so can't share code) -typedef struct -{ - stbi__uint16 fast[1 << STBI__ZFAST_BITS]; - stbi__uint16 firstcode[16]; - int maxcode[17]; - stbi__uint16 firstsymbol[16]; - stbi_uc size[STBI__ZNSYMS]; - stbi__uint16 value[STBI__ZNSYMS]; +typedef struct { + stbi__uint16 fast[1 << STBI__ZFAST_BITS]; + stbi__uint16 firstcode[16]; + int maxcode[17]; + stbi__uint16 firstsymbol[16]; + stbi_uc size[STBI__ZNSYMS]; + stbi__uint16 value[STBI__ZNSYMS]; } stbi__zhuffman; -stbi_inline static int stbi__bitreverse16(int n) -{ - n = ((n & 0xAAAA) >> 1) | ((n & 0x5555) << 1); - n = ((n & 0xCCCC) >> 2) | ((n & 0x3333) << 2); - n = ((n & 0xF0F0) >> 4) | ((n & 0x0F0F) << 4); - n = ((n & 0xFF00) >> 8) | ((n & 0x00FF) << 8); - return n; +stbi_inline static int stbi__bitreverse16(int n) { + n = ((n & 0xAAAA) >> 1) | ((n & 0x5555) << 1); + n = ((n & 0xCCCC) >> 2) | ((n & 0x3333) << 2); + n = ((n & 0xF0F0) >> 4) | ((n & 0x0F0F) << 4); + n = ((n & 0xFF00) >> 8) | ((n & 0x00FF) << 8); + return n; } -stbi_inline static int stbi__bit_reverse(int v, int bits) -{ - STBI_ASSERT(bits <= 16); - // to bit reverse n bits, reverse 16 and shift - // e.g. 11 bits, bit reverse and shift away 5 - return stbi__bitreverse16(v) >> (16-bits); +stbi_inline static int stbi__bit_reverse(int v, int bits) { + STBI_ASSERT(bits <= 16); + // to bit reverse n bits, reverse 16 and shift + // e.g. 11 bits, bit reverse and shift away 5 + return stbi__bitreverse16(v) >> (16 - bits); } -static int stbi__zbuild_huffman(stbi__zhuffman *z, const stbi_uc *sizelist, int num) -{ - int i,k=0; - int code, next_code[16], sizes[17]; +static int stbi__zbuild_huffman(stbi__zhuffman* z, const stbi_uc* sizelist, + int num) { + int i, k = 0; + int code, next_code[16], sizes[17]; - // DEFLATE spec for generating codes - memset(sizes, 0, sizeof(sizes)); - memset(z->fast, 0, sizeof(z->fast)); - for (i=0; i < num; ++i) - ++sizes[sizelist[i]]; - sizes[0] = 0; - for (i=1; i < 16; ++i) - if (sizes[i] > (1 << i)) - return stbi__err("bad sizes", "Corrupt PNG"); - code = 0; - for (i=1; i < 16; ++i) { - next_code[i] = code; - z->firstcode[i] = (stbi__uint16) code; - z->firstsymbol[i] = (stbi__uint16) k; - code = (code + sizes[i]); - if (sizes[i]) - if (code-1 >= (1 << i)) return stbi__err("bad codelengths","Corrupt PNG"); - z->maxcode[i] = code << (16-i); // preshift for inner loop - code <<= 1; - k += sizes[i]; - } - z->maxcode[16] = 0x10000; // sentinel - for (i=0; i < num; ++i) { - int s = sizelist[i]; - if (s) { - int c = next_code[s] - z->firstcode[s] + z->firstsymbol[s]; - stbi__uint16 fastv = (stbi__uint16) ((s << 9) | i); - z->size [c] = (stbi_uc ) s; - z->value[c] = (stbi__uint16) i; - if (s <= STBI__ZFAST_BITS) { - int j = stbi__bit_reverse(next_code[s],s); - while (j < (1 << STBI__ZFAST_BITS)) { - z->fast[j] = fastv; - j += (1 << s); + // DEFLATE spec for generating codes + memset(sizes, 0, sizeof(sizes)); + memset(z->fast, 0, sizeof(z->fast)); + for (i = 0; i < num; ++i) + ++sizes[sizelist[i]]; + sizes[0] = 0; + for (i = 1; i < 16; ++i) + if (sizes[i] > (1 << i)) + return stbi__err("bad sizes", "Corrupt PNG"); + code = 0; + for (i = 1; i < 16; ++i) { + next_code[i] = code; + z->firstcode[i] = (stbi__uint16)code; + z->firstsymbol[i] = (stbi__uint16)k; + code = (code + sizes[i]); + if (sizes[i]) + if (code - 1 >= (1 << i)) + return stbi__err("bad codelengths", "Corrupt PNG"); + z->maxcode[i] = code << (16 - i); // preshift for inner loop + code <<= 1; + k += sizes[i]; + } + z->maxcode[16] = 0x10000; // sentinel + for (i = 0; i < num; ++i) { + int s = sizelist[i]; + if (s) { + int c = next_code[s] - z->firstcode[s] + z->firstsymbol[s]; + stbi__uint16 fastv = (stbi__uint16)((s << 9) | i); + z->size[c] = (stbi_uc)s; + z->value[c] = (stbi__uint16)i; + if (s <= STBI__ZFAST_BITS) { + int j = stbi__bit_reverse(next_code[s], s); + while (j < (1 << STBI__ZFAST_BITS)) { + z->fast[j] = fastv; + j += (1 << s); + } } - } - ++next_code[s]; - } - } - return 1; + ++next_code[s]; + } + } + return 1; } // zlib-from-memory implementation for PNG reading @@ -4172,278 +4661,341 @@ static int stbi__zbuild_huffman(stbi__zhuffman *z, const stbi_uc *sizelist, int // we require PNG read all the IDATs and combine them into a single // memory buffer -typedef struct -{ - stbi_uc *zbuffer, *zbuffer_end; - int num_bits; - stbi__uint32 code_buffer; +typedef struct { + stbi_uc *zbuffer, *zbuffer_end; + int num_bits; + int hit_zeof_once; + stbi__uint32 code_buffer; - char *zout; - char *zout_start; - char *zout_end; - int z_expandable; + char* zout; + char* zout_start; + char* zout_end; + int z_expandable; - stbi__zhuffman z_length, z_distance; + stbi__zhuffman z_length, z_distance; } stbi__zbuf; -stbi_inline static int stbi__zeof(stbi__zbuf *z) -{ - return (z->zbuffer >= z->zbuffer_end); +stbi_inline static int stbi__zeof(stbi__zbuf* z) { + return (z->zbuffer >= z->zbuffer_end); } -stbi_inline static stbi_uc stbi__zget8(stbi__zbuf *z) -{ - return stbi__zeof(z) ? 0 : *z->zbuffer++; +stbi_inline static stbi_uc stbi__zget8(stbi__zbuf* z) { + return stbi__zeof(z) ? 0 : *z->zbuffer++; } -static void stbi__fill_bits(stbi__zbuf *z) -{ - do { - if (z->code_buffer >= (1U << z->num_bits)) { - z->zbuffer = z->zbuffer_end; /* treat this as EOF so we fail. */ - return; - } - z->code_buffer |= (unsigned int) stbi__zget8(z) << z->num_bits; - z->num_bits += 8; - } while (z->num_bits <= 24); +static void stbi__fill_bits(stbi__zbuf* z) { + do { + if (z->code_buffer >= (1U << z->num_bits)) { + z->zbuffer = z->zbuffer_end; /* treat this as EOF so we fail. */ + return; + } + z->code_buffer |= (unsigned int)stbi__zget8(z) << z->num_bits; + z->num_bits += 8; + } while (z->num_bits <= 24); } -stbi_inline static unsigned int stbi__zreceive(stbi__zbuf *z, int n) -{ - unsigned int k; - if (z->num_bits < n) stbi__fill_bits(z); - k = z->code_buffer & ((1 << n) - 1); - z->code_buffer >>= n; - z->num_bits -= n; - return k; +stbi_inline static unsigned int stbi__zreceive(stbi__zbuf* z, int n) { + unsigned int k; + if (z->num_bits < n) + stbi__fill_bits(z); + k = z->code_buffer & ((1 << n) - 1); + z->code_buffer >>= n; + z->num_bits -= n; + return k; } -static int stbi__zhuffman_decode_slowpath(stbi__zbuf *a, stbi__zhuffman *z) -{ - int b,s,k; - // not resolved by fast table, so compute it the slow way - // use jpeg approach, which requires MSbits at top - k = stbi__bit_reverse(a->code_buffer, 16); - for (s=STBI__ZFAST_BITS+1; ; ++s) - if (k < z->maxcode[s]) - break; - if (s >= 16) return -1; // invalid code! - // code size is s, so: - b = (k >> (16-s)) - z->firstcode[s] + z->firstsymbol[s]; - if (b >= STBI__ZNSYMS) return -1; // some data was corrupt somewhere! - if (z->size[b] != s) return -1; // was originally an assert, but report failure instead. - a->code_buffer >>= s; - a->num_bits -= s; - return z->value[b]; +static int stbi__zhuffman_decode_slowpath(stbi__zbuf* a, stbi__zhuffman* z) { + int b, s, k; + // not resolved by fast table, so compute it the slow way + // use jpeg approach, which requires MSbits at top + k = stbi__bit_reverse(a->code_buffer, 16); + for (s = STBI__ZFAST_BITS + 1;; ++s) + if (k < z->maxcode[s]) + break; + if (s >= 16) + return -1; // invalid code! + // code size is s, so: + b = (k >> (16 - s)) - z->firstcode[s] + z->firstsymbol[s]; + if (b >= STBI__ZNSYMS) + return -1; // some data was corrupt somewhere! + if (z->size[b] != s) + return -1; // was originally an assert, but report failure instead. + a->code_buffer >>= s; + a->num_bits -= s; + return z->value[b]; } -stbi_inline static int stbi__zhuffman_decode(stbi__zbuf *a, stbi__zhuffman *z) -{ - int b,s; - if (a->num_bits < 16) { - if (stbi__zeof(a)) { - return -1; /* report error for unexpected end of data. */ - } - stbi__fill_bits(a); - } - b = z->fast[a->code_buffer & STBI__ZFAST_MASK]; - if (b) { - s = b >> 9; - a->code_buffer >>= s; - a->num_bits -= s; - return b & 511; - } - return stbi__zhuffman_decode_slowpath(a, z); +stbi_inline static int stbi__zhuffman_decode(stbi__zbuf* a, stbi__zhuffman* z) { + int b, s; + if (a->num_bits < 16) { + if (stbi__zeof(a)) { + if (!a->hit_zeof_once) { + // This is the first time we hit eof, insert 16 extra padding + // btis to allow us to keep going; if we actually consume any of + // them though, that is invalid data. This is caught later. + a->hit_zeof_once = 1; + a->num_bits += 16; // add 16 implicit zero bits + } else { + // We already inserted our extra 16 padding bits and are again + // out, this stream is actually prematurely terminated. + return -1; + } + } else { + stbi__fill_bits(a); + } + } + b = z->fast[a->code_buffer & STBI__ZFAST_MASK]; + if (b) { + s = b >> 9; + a->code_buffer >>= s; + a->num_bits -= s; + return b & 511; + } + return stbi__zhuffman_decode_slowpath(a, z); } -static int stbi__zexpand(stbi__zbuf *z, char *zout, int n) // need to make room for n bytes +static int stbi__zexpand(stbi__zbuf* z, char* zout, + int n) // need to make room for n bytes { - char *q; - unsigned int cur, limit, old_limit; - z->zout = zout; - if (!z->z_expandable) return stbi__err("output buffer limit","Corrupt PNG"); - cur = (unsigned int) (z->zout - z->zout_start); - limit = old_limit = (unsigned) (z->zout_end - z->zout_start); - if (UINT_MAX - cur < (unsigned) n) return stbi__err("outofmem", "Out of memory"); - while (cur + n > limit) { - if(limit > UINT_MAX / 2) return stbi__err("outofmem", "Out of memory"); - limit *= 2; - } - q = (char *) STBI_REALLOC_SIZED(z->zout_start, old_limit, limit); - STBI_NOTUSED(old_limit); - if (q == NULL) return stbi__err("outofmem", "Out of memory"); - z->zout_start = q; - z->zout = q + cur; - z->zout_end = q + limit; - return 1; + char* q; + unsigned int cur, limit, old_limit; + z->zout = zout; + if (!z->z_expandable) + return stbi__err("output buffer limit", "Corrupt PNG"); + cur = (unsigned int)(z->zout - z->zout_start); + limit = old_limit = (unsigned)(z->zout_end - z->zout_start); + if (UINT_MAX - cur < (unsigned)n) + return stbi__err("outofmem", "Out of memory"); + while (cur + n > limit) { + if (limit > UINT_MAX / 2) + return stbi__err("outofmem", "Out of memory"); + limit *= 2; + } + q = (char*)STBI_REALLOC_SIZED(z->zout_start, old_limit, limit); + STBI_NOTUSED(old_limit); + if (q == NULL) + return stbi__err("outofmem", "Out of memory"); + z->zout_start = q; + z->zout = q + cur; + z->zout_end = q + limit; + return 1; } static const int stbi__zlength_base[31] = { - 3,4,5,6,7,8,9,10,11,13, - 15,17,19,23,27,31,35,43,51,59, - 67,83,99,115,131,163,195,227,258,0,0 }; + 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31, + 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0}; -static const int stbi__zlength_extra[31]= -{ 0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0,0,0 }; +static const int stbi__zlength_extra[31] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, + 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, + 4, 4, 5, 5, 5, 5, 0, 0, 0}; -static const int stbi__zdist_base[32] = { 1,2,3,4,5,7,9,13,17,25,33,49,65,97,129,193, -257,385,513,769,1025,1537,2049,3073,4097,6145,8193,12289,16385,24577,0,0}; +static const int stbi__zdist_base[32] = { + 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, + 49, 65, 97, 129, 193, 257, 385, 513, 769, 1025, 1537, + 2049, 3073, 4097, 6145, 8193, 12289, 16385, 24577, 0, 0}; -static const int stbi__zdist_extra[32] = -{ 0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13}; +static const int stbi__zdist_extra[32] = {0, 0, 0, 0, 1, 1, 2, 2, 3, 3, + 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, + 9, 9, 10, 10, 11, 11, 12, 12, 13, 13}; -static int stbi__parse_huffman_block(stbi__zbuf *a) -{ - char *zout = a->zout; - for(;;) { - int z = stbi__zhuffman_decode(a, &a->z_length); - if (z < 256) { - if (z < 0) return stbi__err("bad huffman code","Corrupt PNG"); // error in huffman codes - if (zout >= a->zout_end) { - if (!stbi__zexpand(a, zout, 1)) return 0; - zout = a->zout; - } - *zout++ = (char) z; - } else { - stbi_uc *p; - int len,dist; - if (z == 256) { - a->zout = zout; - return 1; - } - if (z >= 286) return stbi__err("bad huffman code","Corrupt PNG"); // per DEFLATE, length codes 286 and 287 must not appear in compressed data - z -= 257; - len = stbi__zlength_base[z]; - if (stbi__zlength_extra[z]) len += stbi__zreceive(a, stbi__zlength_extra[z]); - z = stbi__zhuffman_decode(a, &a->z_distance); - if (z < 0 || z >= 30) return stbi__err("bad huffman code","Corrupt PNG"); // per DEFLATE, distance codes 30 and 31 must not appear in compressed data - dist = stbi__zdist_base[z]; - if (stbi__zdist_extra[z]) dist += stbi__zreceive(a, stbi__zdist_extra[z]); - if (zout - a->zout_start < dist) return stbi__err("bad dist","Corrupt PNG"); - if (zout + len > a->zout_end) { - if (!stbi__zexpand(a, zout, len)) return 0; - zout = a->zout; - } - p = (stbi_uc *) (zout - dist); - if (dist == 1) { // run of one byte; common in images. - stbi_uc v = *p; - if (len) { do *zout++ = v; while (--len); } - } else { - if (len) { do *zout++ = *p++; while (--len); } - } - } - } +static int stbi__parse_huffman_block(stbi__zbuf* a) { + char* zout = a->zout; + for (;;) { + int z = stbi__zhuffman_decode(a, &a->z_length); + if (z < 256) { + if (z < 0) + return stbi__err("bad huffman code", + "Corrupt PNG"); // error in huffman codes + if (zout >= a->zout_end) { + if (!stbi__zexpand(a, zout, 1)) + return 0; + zout = a->zout; + } + *zout++ = (char)z; + } else { + stbi_uc* p; + int len, dist; + if (z == 256) { + a->zout = zout; + if (a->hit_zeof_once && a->num_bits < 16) { + // The first time we hit zeof, we inserted 16 extra zero + // bits into our bit buffer so the decoder can just do its + // speculative decoding. But if we actually consumed any of + // those bits (which is the case when num_bits < 16), the + // stream actually read past the end so it is malformed. + return stbi__err("unexpected end", "Corrupt PNG"); + } + return 1; + } + if (z >= 286) + return stbi__err( + "bad huffman code", + "Corrupt PNG"); // per DEFLATE, length codes 286 and 287 + // must not appear in compressed data + z -= 257; + len = stbi__zlength_base[z]; + if (stbi__zlength_extra[z]) + len += stbi__zreceive(a, stbi__zlength_extra[z]); + z = stbi__zhuffman_decode(a, &a->z_distance); + if (z < 0 || z >= 30) + return stbi__err( + "bad huffman code", + "Corrupt PNG"); // per DEFLATE, distance codes 30 and 31 + // must not appear in compressed data + dist = stbi__zdist_base[z]; + if (stbi__zdist_extra[z]) + dist += stbi__zreceive(a, stbi__zdist_extra[z]); + if (zout - a->zout_start < dist) + return stbi__err("bad dist", "Corrupt PNG"); + if (len > a->zout_end - zout) { + if (!stbi__zexpand(a, zout, len)) + return 0; + zout = a->zout; + } + p = (stbi_uc*)(zout - dist); + if (dist == 1) { // run of one byte; common in images. + stbi_uc v = *p; + if (len) { + do + *zout++ = v; + while (--len); + } + } else { + if (len) { + do + *zout++ = *p++; + while (--len); + } + } + } + } } -static int stbi__compute_huffman_codes(stbi__zbuf *a) -{ - static const stbi_uc length_dezigzag[19] = { 16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15 }; - stbi__zhuffman z_codelength; - stbi_uc lencodes[286+32+137];//padding for maximum single op - stbi_uc codelength_sizes[19]; - int i,n; +static int stbi__compute_huffman_codes(stbi__zbuf* a) { + static const stbi_uc length_dezigzag[19] = { + 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15}; + stbi__zhuffman z_codelength; + stbi_uc lencodes[286 + 32 + 137]; // padding for maximum single op + stbi_uc codelength_sizes[19]; + int i, n; - int hlit = stbi__zreceive(a,5) + 257; - int hdist = stbi__zreceive(a,5) + 1; - int hclen = stbi__zreceive(a,4) + 4; - int ntot = hlit + hdist; + int hlit = stbi__zreceive(a, 5) + 257; + int hdist = stbi__zreceive(a, 5) + 1; + int hclen = stbi__zreceive(a, 4) + 4; + int ntot = hlit + hdist; - memset(codelength_sizes, 0, sizeof(codelength_sizes)); - for (i=0; i < hclen; ++i) { - int s = stbi__zreceive(a,3); - codelength_sizes[length_dezigzag[i]] = (stbi_uc) s; - } - if (!stbi__zbuild_huffman(&z_codelength, codelength_sizes, 19)) return 0; + memset(codelength_sizes, 0, sizeof(codelength_sizes)); + for (i = 0; i < hclen; ++i) { + int s = stbi__zreceive(a, 3); + codelength_sizes[length_dezigzag[i]] = (stbi_uc)s; + } + if (!stbi__zbuild_huffman(&z_codelength, codelength_sizes, 19)) + return 0; - n = 0; - while (n < ntot) { - int c = stbi__zhuffman_decode(a, &z_codelength); - if (c < 0 || c >= 19) return stbi__err("bad codelengths", "Corrupt PNG"); - if (c < 16) - lencodes[n++] = (stbi_uc) c; - else { - stbi_uc fill = 0; - if (c == 16) { - c = stbi__zreceive(a,2)+3; - if (n == 0) return stbi__err("bad codelengths", "Corrupt PNG"); - fill = lencodes[n-1]; - } else if (c == 17) { - c = stbi__zreceive(a,3)+3; - } else if (c == 18) { - c = stbi__zreceive(a,7)+11; - } else { + n = 0; + while (n < ntot) { + int c = stbi__zhuffman_decode(a, &z_codelength); + if (c < 0 || c >= 19) return stbi__err("bad codelengths", "Corrupt PNG"); - } - if (ntot - n < c) return stbi__err("bad codelengths", "Corrupt PNG"); - memset(lencodes+n, fill, c); - n += c; - } - } - if (n != ntot) return stbi__err("bad codelengths","Corrupt PNG"); - if (!stbi__zbuild_huffman(&a->z_length, lencodes, hlit)) return 0; - if (!stbi__zbuild_huffman(&a->z_distance, lencodes+hlit, hdist)) return 0; - return 1; + if (c < 16) + lencodes[n++] = (stbi_uc)c; + else { + stbi_uc fill = 0; + if (c == 16) { + c = stbi__zreceive(a, 2) + 3; + if (n == 0) + return stbi__err("bad codelengths", "Corrupt PNG"); + fill = lencodes[n - 1]; + } else if (c == 17) { + c = stbi__zreceive(a, 3) + 3; + } else if (c == 18) { + c = stbi__zreceive(a, 7) + 11; + } else { + return stbi__err("bad codelengths", "Corrupt PNG"); + } + if (ntot - n < c) + return stbi__err("bad codelengths", "Corrupt PNG"); + memset(lencodes + n, fill, c); + n += c; + } + } + if (n != ntot) + return stbi__err("bad codelengths", "Corrupt PNG"); + if (!stbi__zbuild_huffman(&a->z_length, lencodes, hlit)) + return 0; + if (!stbi__zbuild_huffman(&a->z_distance, lencodes + hlit, hdist)) + return 0; + return 1; } -static int stbi__parse_uncompressed_block(stbi__zbuf *a) -{ - stbi_uc header[4]; - int len,nlen,k; - if (a->num_bits & 7) - stbi__zreceive(a, a->num_bits & 7); // discard - // drain the bit-packed data into header - k = 0; - while (a->num_bits > 0) { - header[k++] = (stbi_uc) (a->code_buffer & 255); // suppress MSVC run-time check - a->code_buffer >>= 8; - a->num_bits -= 8; - } - if (a->num_bits < 0) return stbi__err("zlib corrupt","Corrupt PNG"); - // now fill header the normal way - while (k < 4) - header[k++] = stbi__zget8(a); - len = header[1] * 256 + header[0]; - nlen = header[3] * 256 + header[2]; - if (nlen != (len ^ 0xffff)) return stbi__err("zlib corrupt","Corrupt PNG"); - if (a->zbuffer + len > a->zbuffer_end) return stbi__err("read past buffer","Corrupt PNG"); - if (a->zout + len > a->zout_end) - if (!stbi__zexpand(a, a->zout, len)) return 0; - memcpy(a->zout, a->zbuffer, len); - a->zbuffer += len; - a->zout += len; - return 1; +static int stbi__parse_uncompressed_block(stbi__zbuf* a) { + stbi_uc header[4]; + int len, nlen, k; + if (a->num_bits & 7) + stbi__zreceive(a, a->num_bits & 7); // discard + // drain the bit-packed data into header + k = 0; + while (a->num_bits > 0) { + header[k++] = + (stbi_uc)(a->code_buffer & 255); // suppress MSVC run-time check + a->code_buffer >>= 8; + a->num_bits -= 8; + } + if (a->num_bits < 0) + return stbi__err("zlib corrupt", "Corrupt PNG"); + // now fill header the normal way + while (k < 4) + header[k++] = stbi__zget8(a); + len = header[1] * 256 + header[0]; + nlen = header[3] * 256 + header[2]; + if (nlen != (len ^ 0xffff)) + return stbi__err("zlib corrupt", "Corrupt PNG"); + if (a->zbuffer + len > a->zbuffer_end) + return stbi__err("read past buffer", "Corrupt PNG"); + if (a->zout + len > a->zout_end) + if (!stbi__zexpand(a, a->zout, len)) + return 0; + memcpy(a->zout, a->zbuffer, len); + a->zbuffer += len; + a->zout += len; + return 1; } -static int stbi__parse_zlib_header(stbi__zbuf *a) -{ - int cmf = stbi__zget8(a); - int cm = cmf & 15; - /* int cinfo = cmf >> 4; */ - int flg = stbi__zget8(a); - if (stbi__zeof(a)) return stbi__err("bad zlib header","Corrupt PNG"); // zlib spec - if ((cmf*256+flg) % 31 != 0) return stbi__err("bad zlib header","Corrupt PNG"); // zlib spec - if (flg & 32) return stbi__err("no preset dict","Corrupt PNG"); // preset dictionary not allowed in png - if (cm != 8) return stbi__err("bad compression","Corrupt PNG"); // DEFLATE required for png - // window = 1 << (8 + cinfo)... but who cares, we fully buffer output - return 1; +static int stbi__parse_zlib_header(stbi__zbuf* a) { + int cmf = stbi__zget8(a); + int cm = cmf & 15; + /* int cinfo = cmf >> 4; */ + int flg = stbi__zget8(a); + if (stbi__zeof(a)) + return stbi__err("bad zlib header", "Corrupt PNG"); // zlib spec + if ((cmf * 256 + flg) % 31 != 0) + return stbi__err("bad zlib header", "Corrupt PNG"); // zlib spec + if (flg & 32) + return stbi__err("no preset dict", + "Corrupt PNG"); // preset dictionary not allowed in png + if (cm != 8) + return stbi__err("bad compression", + "Corrupt PNG"); // DEFLATE required for png + // window = 1 << (8 + cinfo)... but who cares, we fully buffer output + return 1; } -static const stbi_uc stbi__zdefault_length[STBI__ZNSYMS] = -{ - 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, - 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, - 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, - 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, - 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, 9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9, - 9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9, 9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9, - 9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9, 9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9, - 9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9, 9,9,9,9,9,9,9,9,9,9,9,9,9,9,9,9, - 7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7, 7,7,7,7,7,7,7,7,8,8,8,8,8,8,8,8 -}; -static const stbi_uc stbi__zdefault_distance[32] = -{ - 5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5 -}; +static const stbi_uc stbi__zdefault_length[STBI__ZNSYMS] = { + 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, + 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, + 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, + 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, + 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, + 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, + 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, + 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, + 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, + 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, + 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 7, 7, 7, 7, 7, 7, 7, 7, + 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 8, 8, 8, 8, 8, 8, 8, 8}; +static const stbi_uc stbi__zdefault_distance[32] = { + 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, + 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5}; /* Init algorithm: { @@ -4457,117 +5009,134 @@ Init algorithm: } */ -static int stbi__parse_zlib(stbi__zbuf *a, int parse_header) -{ - int final, type; - if (parse_header) - if (!stbi__parse_zlib_header(a)) return 0; - a->num_bits = 0; - a->code_buffer = 0; - do { - final = stbi__zreceive(a,1); - type = stbi__zreceive(a,2); - if (type == 0) { - if (!stbi__parse_uncompressed_block(a)) return 0; - } else if (type == 3) { - return 0; - } else { - if (type == 1) { - // use fixed code lengths - if (!stbi__zbuild_huffman(&a->z_length , stbi__zdefault_length , STBI__ZNSYMS)) return 0; - if (!stbi__zbuild_huffman(&a->z_distance, stbi__zdefault_distance, 32)) return 0; - } else { - if (!stbi__compute_huffman_codes(a)) return 0; - } - if (!stbi__parse_huffman_block(a)) return 0; - } - } while (!final); - return 1; +static int stbi__parse_zlib(stbi__zbuf* a, int parse_header) { + int final, type; + if (parse_header) + if (!stbi__parse_zlib_header(a)) + return 0; + a->num_bits = 0; + a->code_buffer = 0; + a->hit_zeof_once = 0; + do { + final = stbi__zreceive(a, 1); + type = stbi__zreceive(a, 2); + if (type == 0) { + if (!stbi__parse_uncompressed_block(a)) + return 0; + } else if (type == 3) { + return 0; + } else { + if (type == 1) { + // use fixed code lengths + if (!stbi__zbuild_huffman(&a->z_length, stbi__zdefault_length, + STBI__ZNSYMS)) + return 0; + if (!stbi__zbuild_huffman(&a->z_distance, + stbi__zdefault_distance, 32)) + return 0; + } else { + if (!stbi__compute_huffman_codes(a)) + return 0; + } + if (!stbi__parse_huffman_block(a)) + return 0; + } + } while (!final); + return 1; } -static int stbi__do_zlib(stbi__zbuf *a, char *obuf, int olen, int exp, int parse_header) -{ - a->zout_start = obuf; - a->zout = obuf; - a->zout_end = obuf + olen; - a->z_expandable = exp; +static int stbi__do_zlib(stbi__zbuf* a, char* obuf, int olen, int exp, + int parse_header) { + a->zout_start = obuf; + a->zout = obuf; + a->zout_end = obuf + olen; + a->z_expandable = exp; - return stbi__parse_zlib(a, parse_header); + return stbi__parse_zlib(a, parse_header); } -STBIDEF char *stbi_zlib_decode_malloc_guesssize(const char *buffer, int len, int initial_size, int *outlen) -{ - stbi__zbuf a; - char *p = (char *) stbi__malloc(initial_size); - if (p == NULL) return NULL; - a.zbuffer = (stbi_uc *) buffer; - a.zbuffer_end = (stbi_uc *) buffer + len; - if (stbi__do_zlib(&a, p, initial_size, 1, 1)) { - if (outlen) *outlen = (int) (a.zout - a.zout_start); - return a.zout_start; - } else { - STBI_FREE(a.zout_start); - return NULL; - } +STBIDEF char* stbi_zlib_decode_malloc_guesssize(const char* buffer, int len, + int initial_size, int* outlen) { + stbi__zbuf a; + char* p = (char*)stbi__malloc(initial_size); + if (p == NULL) + return NULL; + a.zbuffer = (stbi_uc*)buffer; + a.zbuffer_end = (stbi_uc*)buffer + len; + if (stbi__do_zlib(&a, p, initial_size, 1, 1)) { + if (outlen) + *outlen = (int)(a.zout - a.zout_start); + return a.zout_start; + } else { + STBI_FREE(a.zout_start); + return NULL; + } } -STBIDEF char *stbi_zlib_decode_malloc(char const *buffer, int len, int *outlen) -{ - return stbi_zlib_decode_malloc_guesssize(buffer, len, 16384, outlen); +STBIDEF char* stbi_zlib_decode_malloc(char const* buffer, int len, + int* outlen) { + return stbi_zlib_decode_malloc_guesssize(buffer, len, 16384, outlen); } -STBIDEF char *stbi_zlib_decode_malloc_guesssize_headerflag(const char *buffer, int len, int initial_size, int *outlen, int parse_header) -{ - stbi__zbuf a; - char *p = (char *) stbi__malloc(initial_size); - if (p == NULL) return NULL; - a.zbuffer = (stbi_uc *) buffer; - a.zbuffer_end = (stbi_uc *) buffer + len; - if (stbi__do_zlib(&a, p, initial_size, 1, parse_header)) { - if (outlen) *outlen = (int) (a.zout - a.zout_start); - return a.zout_start; - } else { - STBI_FREE(a.zout_start); - return NULL; - } +STBIDEF char* stbi_zlib_decode_malloc_guesssize_headerflag(const char* buffer, + int len, + int initial_size, + int* outlen, + int parse_header) { + stbi__zbuf a; + char* p = (char*)stbi__malloc(initial_size); + if (p == NULL) + return NULL; + a.zbuffer = (stbi_uc*)buffer; + a.zbuffer_end = (stbi_uc*)buffer + len; + if (stbi__do_zlib(&a, p, initial_size, 1, parse_header)) { + if (outlen) + *outlen = (int)(a.zout - a.zout_start); + return a.zout_start; + } else { + STBI_FREE(a.zout_start); + return NULL; + } } -STBIDEF int stbi_zlib_decode_buffer(char *obuffer, int olen, char const *ibuffer, int ilen) -{ - stbi__zbuf a; - a.zbuffer = (stbi_uc *) ibuffer; - a.zbuffer_end = (stbi_uc *) ibuffer + ilen; - if (stbi__do_zlib(&a, obuffer, olen, 0, 1)) - return (int) (a.zout - a.zout_start); - else - return -1; +STBIDEF int stbi_zlib_decode_buffer(char* obuffer, int olen, + char const* ibuffer, int ilen) { + stbi__zbuf a; + a.zbuffer = (stbi_uc*)ibuffer; + a.zbuffer_end = (stbi_uc*)ibuffer + ilen; + if (stbi__do_zlib(&a, obuffer, olen, 0, 1)) + return (int)(a.zout - a.zout_start); + else + return -1; } -STBIDEF char *stbi_zlib_decode_noheader_malloc(char const *buffer, int len, int *outlen) -{ - stbi__zbuf a; - char *p = (char *) stbi__malloc(16384); - if (p == NULL) return NULL; - a.zbuffer = (stbi_uc *) buffer; - a.zbuffer_end = (stbi_uc *) buffer+len; - if (stbi__do_zlib(&a, p, 16384, 1, 0)) { - if (outlen) *outlen = (int) (a.zout - a.zout_start); - return a.zout_start; - } else { - STBI_FREE(a.zout_start); - return NULL; - } +STBIDEF char* stbi_zlib_decode_noheader_malloc(char const* buffer, int len, + int* outlen) { + stbi__zbuf a; + char* p = (char*)stbi__malloc(16384); + if (p == NULL) + return NULL; + a.zbuffer = (stbi_uc*)buffer; + a.zbuffer_end = (stbi_uc*)buffer + len; + if (stbi__do_zlib(&a, p, 16384, 1, 0)) { + if (outlen) + *outlen = (int)(a.zout - a.zout_start); + return a.zout_start; + } else { + STBI_FREE(a.zout_start); + return NULL; + } } -STBIDEF int stbi_zlib_decode_noheader_buffer(char *obuffer, int olen, const char *ibuffer, int ilen) -{ - stbi__zbuf a; - a.zbuffer = (stbi_uc *) ibuffer; - a.zbuffer_end = (stbi_uc *) ibuffer + ilen; - if (stbi__do_zlib(&a, obuffer, olen, 0, 0)) - return (int) (a.zout - a.zout_start); - else - return -1; +STBIDEF int stbi_zlib_decode_noheader_buffer(char* obuffer, int olen, + const char* ibuffer, int ilen) { + stbi__zbuf a; + a.zbuffer = (stbi_uc*)ibuffer; + a.zbuffer_end = (stbi_uc*)ibuffer + ilen; + if (stbi__do_zlib(&a, obuffer, olen, 0, 0)) + return (int)(a.zout - a.zout_start); + else + return -1; } #endif @@ -4582,1152 +5151,1320 @@ STBIDEF int stbi_zlib_decode_noheader_buffer(char *obuffer, int olen, const char // - uses stb_zlib, a PD zlib implementation with fast huffman decoding #ifndef STBI_NO_PNG -typedef struct -{ - stbi__uint32 length; - stbi__uint32 type; +typedef struct { + stbi__uint32 length; + stbi__uint32 type; } stbi__pngchunk; -static stbi__pngchunk stbi__get_chunk_header(stbi__context *s) -{ - stbi__pngchunk c; - c.length = stbi__get32be(s); - c.type = stbi__get32be(s); - return c; +static stbi__pngchunk stbi__get_chunk_header(stbi__context* s) { + stbi__pngchunk c; + c.length = stbi__get32be(s); + c.type = stbi__get32be(s); + return c; } -static int stbi__check_png_header(stbi__context *s) -{ - static const stbi_uc png_sig[8] = { 137,80,78,71,13,10,26,10 }; - int i; - for (i=0; i < 8; ++i) - if (stbi__get8(s) != png_sig[i]) return stbi__err("bad png sig","Not a PNG"); - return 1; +static int stbi__check_png_header(stbi__context* s) { + static const stbi_uc png_sig[8] = {137, 80, 78, 71, 13, 10, 26, 10}; + int i; + for (i = 0; i < 8; ++i) + if (stbi__get8(s) != png_sig[i]) + return stbi__err("bad png sig", "Not a PNG"); + return 1; } -typedef struct -{ - stbi__context *s; - stbi_uc *idata, *expanded, *out; - int depth; +typedef struct { + stbi__context* s; + stbi_uc *idata, *expanded, *out; + int depth; } stbi__png; - enum { - STBI__F_none=0, - STBI__F_sub=1, - STBI__F_up=2, - STBI__F_avg=3, - STBI__F_paeth=4, - // synthetic filters used for first scanline to avoid needing a dummy row of 0s - STBI__F_avg_first, - STBI__F_paeth_first + STBI__F_none = 0, + STBI__F_sub = 1, + STBI__F_up = 2, + STBI__F_avg = 3, + STBI__F_paeth = 4, + // synthetic filter used for first scanline to avoid needing a dummy row of + // 0s + STBI__F_avg_first }; -static stbi_uc first_row_filter[5] = -{ - STBI__F_none, - STBI__F_sub, - STBI__F_none, - STBI__F_avg_first, - STBI__F_paeth_first +static stbi_uc first_row_filter[5] = { + STBI__F_none, STBI__F_sub, STBI__F_none, STBI__F_avg_first, + STBI__F_sub // Paeth with b=c=0 turns out to be equivalent to sub }; -static int stbi__paeth(int a, int b, int c) -{ - int p = a + b - c; - int pa = abs(p-a); - int pb = abs(p-b); - int pc = abs(p-c); - if (pa <= pb && pa <= pc) return a; - if (pb <= pc) return b; - return c; +static int stbi__paeth(int a, int b, int c) { + // This formulation looks very different from the reference in the PNG spec, + // but is actually equivalent and has favorable data dependencies and admits + // straightforward generation of branch-free code, which helps performance + // significantly. + int thresh = c * 3 - (a + b); + int lo = a < b ? a : b; + int hi = a < b ? b : a; + int t0 = (hi <= thresh) ? lo : c; + int t1 = (thresh <= lo) ? hi : t0; + return t1; } -static const stbi_uc stbi__depth_scale_table[9] = { 0, 0xff, 0x55, 0, 0x11, 0,0,0, 0x01 }; +static const stbi_uc stbi__depth_scale_table[9] = {0, 0xff, 0x55, 0, 0x11, + 0, 0, 0, 0x01}; + +// adds an extra all-255 alpha channel +// dest == src is legal +// img_n must be 1 or 3 +static void stbi__create_png_alpha_expand8(stbi_uc* dest, stbi_uc* src, + stbi__uint32 x, int img_n) { + int i; + // must process data backwards since we allow dest==src + if (img_n == 1) { + for (i = x - 1; i >= 0; --i) { + dest[i * 2 + 1] = 255; + dest[i * 2 + 0] = src[i]; + } + } else { + STBI_ASSERT(img_n == 3); + for (i = x - 1; i >= 0; --i) { + dest[i * 4 + 3] = 255; + dest[i * 4 + 2] = src[i * 3 + 2]; + dest[i * 4 + 1] = src[i * 3 + 1]; + dest[i * 4 + 0] = src[i * 3 + 0]; + } + } +} // create the png data from post-deflated data -static int stbi__create_png_image_raw(stbi__png *a, stbi_uc *raw, stbi__uint32 raw_len, int out_n, stbi__uint32 x, stbi__uint32 y, int depth, int color) -{ - int bytes = (depth == 16? 2 : 1); - stbi__context *s = a->s; - stbi__uint32 i,j,stride = x*out_n*bytes; - stbi__uint32 img_len, img_width_bytes; - int k; - int img_n = s->img_n; // copy it into a local for later +static int stbi__create_png_image_raw(stbi__png* a, stbi_uc* raw, + stbi__uint32 raw_len, int out_n, + stbi__uint32 x, stbi__uint32 y, int depth, + int color) { + int bytes = (depth == 16 ? 2 : 1); + stbi__context* s = a->s; + stbi__uint32 i, j, stride = x * out_n * bytes; + stbi__uint32 img_len, img_width_bytes; + stbi_uc* filter_buf; + int all_ok = 1; + int k; + int img_n = s->img_n; // copy it into a local for later - int output_bytes = out_n*bytes; - int filter_bytes = img_n*bytes; - int width = x; + int output_bytes = out_n * bytes; + int filter_bytes = img_n * bytes; + int width = x; - STBI_ASSERT(out_n == s->img_n || out_n == s->img_n+1); - a->out = (stbi_uc *) stbi__malloc_mad3(x, y, output_bytes, 0); // extra bytes to write off the end into - if (!a->out) return stbi__err("outofmem", "Out of memory"); + STBI_ASSERT(out_n == s->img_n || out_n == s->img_n + 1); + a->out = (stbi_uc*)stbi__malloc_mad3( + x, y, output_bytes, 0); // extra bytes to write off the end into + if (!a->out) + return stbi__err("outofmem", "Out of memory"); - if (!stbi__mad3sizes_valid(img_n, x, depth, 7)) return stbi__err("too large", "Corrupt PNG"); - img_width_bytes = (((img_n * x * depth) + 7) >> 3); - img_len = (img_width_bytes + 1) * y; + // note: error exits here don't need to clean up a->out individually, + // stbi__do_png always does on error. + if (!stbi__mad3sizes_valid(img_n, x, depth, 7)) + return stbi__err("too large", "Corrupt PNG"); + img_width_bytes = (((img_n * x * depth) + 7) >> 3); + if (!stbi__mad2sizes_valid(img_width_bytes, y, img_width_bytes)) + return stbi__err("too large", "Corrupt PNG"); + img_len = (img_width_bytes + 1) * y; - // we used to check for exact match between raw_len and img_len on non-interlaced PNGs, - // but issue #276 reported a PNG in the wild that had extra data at the end (all zeros), - // so just check for raw_len < img_len always. - if (raw_len < img_len) return stbi__err("not enough pixels","Corrupt PNG"); + // we used to check for exact match between raw_len and img_len on + // non-interlaced PNGs, but issue #276 reported a PNG in the wild that had + // extra data at the end (all zeros), so just check for raw_len < img_len + // always. + if (raw_len < img_len) + return stbi__err("not enough pixels", "Corrupt PNG"); - for (j=0; j < y; ++j) { - stbi_uc *cur = a->out + stride*j; - stbi_uc *prior; - int filter = *raw++; + // Allocate two scan lines worth of filter workspace buffer. + filter_buf = (stbi_uc*)stbi__malloc_mad2(img_width_bytes, 2, 0); + if (!filter_buf) + return stbi__err("outofmem", "Out of memory"); - if (filter > 4) - return stbi__err("invalid filter","Corrupt PNG"); + // Filtering for low-bit-depth images + if (depth < 8) { + filter_bytes = 1; + width = img_width_bytes; + } - if (depth < 8) { - if (img_width_bytes > x) return stbi__err("invalid width","Corrupt PNG"); - cur += x*out_n - img_width_bytes; // store output to the rightmost img_len bytes, so we can decode in place - filter_bytes = 1; - width = img_width_bytes; - } - prior = cur - stride; // bugfix: need to compute this after 'cur +=' computation above + for (j = 0; j < y; ++j) { + // cur/prior filter buffers alternate + stbi_uc* cur = filter_buf + (j & 1) * img_width_bytes; + stbi_uc* prior = filter_buf + (~j & 1) * img_width_bytes; + stbi_uc* dest = a->out + stride * j; + int nk = width * filter_bytes; + int filter = *raw++; - // if first row, use special filter that doesn't sample previous row - if (j == 0) filter = first_row_filter[filter]; + // check filter type + if (filter > 4) { + all_ok = stbi__err("invalid filter", "Corrupt PNG"); + break; + } - // handle first byte explicitly - for (k=0; k < filter_bytes; ++k) { - switch (filter) { - case STBI__F_none : cur[k] = raw[k]; break; - case STBI__F_sub : cur[k] = raw[k]; break; - case STBI__F_up : cur[k] = STBI__BYTECAST(raw[k] + prior[k]); break; - case STBI__F_avg : cur[k] = STBI__BYTECAST(raw[k] + (prior[k]>>1)); break; - case STBI__F_paeth : cur[k] = STBI__BYTECAST(raw[k] + stbi__paeth(0,prior[k],0)); break; - case STBI__F_avg_first : cur[k] = raw[k]; break; - case STBI__F_paeth_first: cur[k] = raw[k]; break; - } - } + // if first row, use special filter that doesn't sample previous row + if (j == 0) + filter = first_row_filter[filter]; - if (depth == 8) { - if (img_n != out_n) - cur[img_n] = 255; // first pixel - raw += img_n; - cur += out_n; - prior += out_n; - } else if (depth == 16) { - if (img_n != out_n) { - cur[filter_bytes] = 255; // first pixel top byte - cur[filter_bytes+1] = 255; // first pixel bottom byte - } - raw += filter_bytes; - cur += output_bytes; - prior += output_bytes; - } else { - raw += 1; - cur += 1; - prior += 1; - } + // perform actual filtering + switch (filter) { + case STBI__F_none: + memcpy(cur, raw, nk); + break; + case STBI__F_sub: + memcpy(cur, raw, filter_bytes); + for (k = filter_bytes; k < nk; ++k) + cur[k] = STBI__BYTECAST(raw[k] + cur[k - filter_bytes]); + break; + case STBI__F_up: + for (k = 0; k < nk; ++k) + cur[k] = STBI__BYTECAST(raw[k] + prior[k]); + break; + case STBI__F_avg: + for (k = 0; k < filter_bytes; ++k) + cur[k] = STBI__BYTECAST(raw[k] + (prior[k] >> 1)); + for (k = filter_bytes; k < nk; ++k) + cur[k] = STBI__BYTECAST( + raw[k] + ((prior[k] + cur[k - filter_bytes]) >> 1)); + break; + case STBI__F_paeth: + for (k = 0; k < filter_bytes; ++k) + cur[k] = STBI__BYTECAST( + raw[k] + prior[k]); // prior[k] == stbi__paeth(0,prior[k],0) + for (k = filter_bytes; k < nk; ++k) + cur[k] = STBI__BYTECAST( + raw[k] + stbi__paeth(cur[k - filter_bytes], prior[k], + prior[k - filter_bytes])); + break; + case STBI__F_avg_first: + memcpy(cur, raw, filter_bytes); + for (k = filter_bytes; k < nk; ++k) + cur[k] = STBI__BYTECAST(raw[k] + (cur[k - filter_bytes] >> 1)); + break; + } - // this is a little gross, so that we don't switch per-pixel or per-component - if (depth < 8 || img_n == out_n) { - int nk = (width - 1)*filter_bytes; - #define STBI__CASE(f) \ - case f: \ - for (k=0; k < nk; ++k) - switch (filter) { - // "none" filter turns into a memcpy here; make that explicit. - case STBI__F_none: memcpy(cur, raw, nk); break; - STBI__CASE(STBI__F_sub) { cur[k] = STBI__BYTECAST(raw[k] + cur[k-filter_bytes]); } break; - STBI__CASE(STBI__F_up) { cur[k] = STBI__BYTECAST(raw[k] + prior[k]); } break; - STBI__CASE(STBI__F_avg) { cur[k] = STBI__BYTECAST(raw[k] + ((prior[k] + cur[k-filter_bytes])>>1)); } break; - STBI__CASE(STBI__F_paeth) { cur[k] = STBI__BYTECAST(raw[k] + stbi__paeth(cur[k-filter_bytes],prior[k],prior[k-filter_bytes])); } break; - STBI__CASE(STBI__F_avg_first) { cur[k] = STBI__BYTECAST(raw[k] + (cur[k-filter_bytes] >> 1)); } break; - STBI__CASE(STBI__F_paeth_first) { cur[k] = STBI__BYTECAST(raw[k] + stbi__paeth(cur[k-filter_bytes],0,0)); } break; - } - #undef STBI__CASE - raw += nk; - } else { - STBI_ASSERT(img_n+1 == out_n); - #define STBI__CASE(f) \ - case f: \ - for (i=x-1; i >= 1; --i, cur[filter_bytes]=255,raw+=filter_bytes,cur+=output_bytes,prior+=output_bytes) \ - for (k=0; k < filter_bytes; ++k) - switch (filter) { - STBI__CASE(STBI__F_none) { cur[k] = raw[k]; } break; - STBI__CASE(STBI__F_sub) { cur[k] = STBI__BYTECAST(raw[k] + cur[k- output_bytes]); } break; - STBI__CASE(STBI__F_up) { cur[k] = STBI__BYTECAST(raw[k] + prior[k]); } break; - STBI__CASE(STBI__F_avg) { cur[k] = STBI__BYTECAST(raw[k] + ((prior[k] + cur[k- output_bytes])>>1)); } break; - STBI__CASE(STBI__F_paeth) { cur[k] = STBI__BYTECAST(raw[k] + stbi__paeth(cur[k- output_bytes],prior[k],prior[k- output_bytes])); } break; - STBI__CASE(STBI__F_avg_first) { cur[k] = STBI__BYTECAST(raw[k] + (cur[k- output_bytes] >> 1)); } break; - STBI__CASE(STBI__F_paeth_first) { cur[k] = STBI__BYTECAST(raw[k] + stbi__paeth(cur[k- output_bytes],0,0)); } break; - } - #undef STBI__CASE + raw += nk; - // the loop above sets the high byte of the pixels' alpha, but for - // 16 bit png files we also need the low byte set. we'll do that here. - if (depth == 16) { - cur = a->out + stride*j; // start at the beginning of the row again - for (i=0; i < x; ++i,cur+=output_bytes) { - cur[filter_bytes+1] = 255; - } - } - } - } + // expand decoded bits in cur to dest, also adding an extra alpha + // channel if desired + if (depth < 8) { + stbi_uc scale = (color == 0) + ? stbi__depth_scale_table[depth] + : 1; // scale grayscale values to 0..255 range + stbi_uc* in = cur; + stbi_uc* out = dest; + stbi_uc inb = 0; + stbi__uint32 nsmp = x * img_n; - // we make a separate pass to expand bits to pixels; for performance, - // this could run two scanlines behind the above code, so it won't - // intefere with filtering but will still be in the cache. - if (depth < 8) { - for (j=0; j < y; ++j) { - stbi_uc *cur = a->out + stride*j; - stbi_uc *in = a->out + stride*j + x*out_n - img_width_bytes; - // unpack 1/2/4-bit into a 8-bit buffer. allows us to keep the common 8-bit path optimal at minimal cost for 1/2/4-bit - // png guarante byte alignment, if width is not multiple of 8/4/2 we'll decode dummy trailing data that will be skipped in the later loop - stbi_uc scale = (color == 0) ? stbi__depth_scale_table[depth] : 1; // scale grayscale values to 0..255 range - - // note that the final byte might overshoot and write more data than desired. - // we can allocate enough data that this never writes out of memory, but it - // could also overwrite the next scanline. can it overwrite non-empty data - // on the next scanline? yes, consider 1-pixel-wide scanlines with 1-bit-per-pixel. - // so we need to explicitly clamp the final ones - - if (depth == 4) { - for (k=x*img_n; k >= 2; k-=2, ++in) { - *cur++ = scale * ((*in >> 4) ); - *cur++ = scale * ((*in ) & 0x0f); - } - if (k > 0) *cur++ = scale * ((*in >> 4) ); - } else if (depth == 2) { - for (k=x*img_n; k >= 4; k-=4, ++in) { - *cur++ = scale * ((*in >> 6) ); - *cur++ = scale * ((*in >> 4) & 0x03); - *cur++ = scale * ((*in >> 2) & 0x03); - *cur++ = scale * ((*in ) & 0x03); - } - if (k > 0) *cur++ = scale * ((*in >> 6) ); - if (k > 1) *cur++ = scale * ((*in >> 4) & 0x03); - if (k > 2) *cur++ = scale * ((*in >> 2) & 0x03); - } else if (depth == 1) { - for (k=x*img_n; k >= 8; k-=8, ++in) { - *cur++ = scale * ((*in >> 7) ); - *cur++ = scale * ((*in >> 6) & 0x01); - *cur++ = scale * ((*in >> 5) & 0x01); - *cur++ = scale * ((*in >> 4) & 0x01); - *cur++ = scale * ((*in >> 3) & 0x01); - *cur++ = scale * ((*in >> 2) & 0x01); - *cur++ = scale * ((*in >> 1) & 0x01); - *cur++ = scale * ((*in ) & 0x01); - } - if (k > 0) *cur++ = scale * ((*in >> 7) ); - if (k > 1) *cur++ = scale * ((*in >> 6) & 0x01); - if (k > 2) *cur++ = scale * ((*in >> 5) & 0x01); - if (k > 3) *cur++ = scale * ((*in >> 4) & 0x01); - if (k > 4) *cur++ = scale * ((*in >> 3) & 0x01); - if (k > 5) *cur++ = scale * ((*in >> 2) & 0x01); - if (k > 6) *cur++ = scale * ((*in >> 1) & 0x01); - } - if (img_n != out_n) { - int q; - // insert alpha = 255 - cur = a->out + stride*j; - if (img_n == 1) { - for (q=x-1; q >= 0; --q) { - cur[q*2+1] = 255; - cur[q*2+0] = cur[q]; - } + // expand bits to bytes first + if (depth == 4) { + for (i = 0; i < nsmp; ++i) { + if ((i & 1) == 0) + inb = *in++; + *out++ = scale * (inb >> 4); + inb <<= 4; + } + } else if (depth == 2) { + for (i = 0; i < nsmp; ++i) { + if ((i & 3) == 0) + inb = *in++; + *out++ = scale * (inb >> 6); + inb <<= 2; + } } else { - STBI_ASSERT(img_n == 3); - for (q=x-1; q >= 0; --q) { - cur[q*4+3] = 255; - cur[q*4+2] = cur[q*3+2]; - cur[q*4+1] = cur[q*3+1]; - cur[q*4+0] = cur[q*3+0]; - } + STBI_ASSERT(depth == 1); + for (i = 0; i < nsmp; ++i) { + if ((i & 7) == 0) + inb = *in++; + *out++ = scale * (inb >> 7); + inb <<= 1; + } } - } - } - } else if (depth == 16) { - // force the image data from big-endian to platform-native. - // this is done in a separate pass due to the decoding relying - // on the data being untouched, but could probably be done - // per-line during decode if care is taken. - stbi_uc *cur = a->out; - stbi__uint16 *cur16 = (stbi__uint16*)cur; - for(i=0; i < x*y*out_n; ++i,cur16++,cur+=2) { - *cur16 = (cur[0] << 8) | cur[1]; - } - } + // insert alpha=255 values if desired + if (img_n != out_n) + stbi__create_png_alpha_expand8(dest, dest, x, img_n); + } else if (depth == 8) { + if (img_n == out_n) + memcpy(dest, cur, x * img_n); + else + stbi__create_png_alpha_expand8(dest, cur, x, img_n); + } else if (depth == 16) { + // convert the image data from big-endian to platform-native + stbi__uint16* dest16 = (stbi__uint16*)dest; + stbi__uint32 nsmp = x * img_n; - return 1; -} - -static int stbi__create_png_image(stbi__png *a, stbi_uc *image_data, stbi__uint32 image_data_len, int out_n, int depth, int color, int interlaced) -{ - int bytes = (depth == 16 ? 2 : 1); - int out_bytes = out_n * bytes; - stbi_uc *final; - int p; - if (!interlaced) - return stbi__create_png_image_raw(a, image_data, image_data_len, out_n, a->s->img_x, a->s->img_y, depth, color); - - // de-interlacing - final = (stbi_uc *) stbi__malloc_mad3(a->s->img_x, a->s->img_y, out_bytes, 0); - if (!final) return stbi__err("outofmem", "Out of memory"); - for (p=0; p < 7; ++p) { - int xorig[] = { 0,4,0,2,0,1,0 }; - int yorig[] = { 0,0,4,0,2,0,1 }; - int xspc[] = { 8,8,4,4,2,2,1 }; - int yspc[] = { 8,8,8,4,4,2,2 }; - int i,j,x,y; - // pass1_x[4] = 0, pass1_x[5] = 1, pass1_x[12] = 1 - x = (a->s->img_x - xorig[p] + xspc[p]-1) / xspc[p]; - y = (a->s->img_y - yorig[p] + yspc[p]-1) / yspc[p]; - if (x && y) { - stbi__uint32 img_len = ((((a->s->img_n * x * depth) + 7) >> 3) + 1) * y; - if (!stbi__create_png_image_raw(a, image_data, image_data_len, out_n, x, y, depth, color)) { - STBI_FREE(final); - return 0; - } - for (j=0; j < y; ++j) { - for (i=0; i < x; ++i) { - int out_y = j*yspc[p]+yorig[p]; - int out_x = i*xspc[p]+xorig[p]; - memcpy(final + out_y*a->s->img_x*out_bytes + out_x*out_bytes, - a->out + (j*x+i)*out_bytes, out_bytes); + if (img_n == out_n) { + for (i = 0; i < nsmp; ++i, ++dest16, cur += 2) + *dest16 = (cur[0] << 8) | cur[1]; + } else { + STBI_ASSERT(img_n + 1 == out_n); + if (img_n == 1) { + for (i = 0; i < x; ++i, dest16 += 2, cur += 2) { + dest16[0] = (cur[0] << 8) | cur[1]; + dest16[1] = 0xffff; + } + } else { + STBI_ASSERT(img_n == 3); + for (i = 0; i < x; ++i, dest16 += 4, cur += 6) { + dest16[0] = (cur[0] << 8) | cur[1]; + dest16[1] = (cur[2] << 8) | cur[3]; + dest16[2] = (cur[4] << 8) | cur[5]; + dest16[3] = 0xffff; + } + } } - } - STBI_FREE(a->out); - image_data += img_len; - image_data_len -= img_len; - } - } - a->out = final; + } + } - return 1; + STBI_FREE(filter_buf); + if (!all_ok) + return 0; + + return 1; } -static int stbi__compute_transparency(stbi__png *z, stbi_uc tc[3], int out_n) -{ - stbi__context *s = z->s; - stbi__uint32 i, pixel_count = s->img_x * s->img_y; - stbi_uc *p = z->out; +static int stbi__create_png_image(stbi__png* a, stbi_uc* image_data, + stbi__uint32 image_data_len, int out_n, + int depth, int color, int interlaced) { + int bytes = (depth == 16 ? 2 : 1); + int out_bytes = out_n * bytes; + stbi_uc* final; + int p; + if (!interlaced) + return stbi__create_png_image_raw(a, image_data, image_data_len, out_n, + a->s->img_x, a->s->img_y, depth, + color); - // compute color-based transparency, assuming we've - // already got 255 as the alpha value in the output - STBI_ASSERT(out_n == 2 || out_n == 4); + // de-interlacing + final = (stbi_uc*)stbi__malloc_mad3(a->s->img_x, a->s->img_y, out_bytes, 0); + if (!final) + return stbi__err("outofmem", "Out of memory"); + for (p = 0; p < 7; ++p) { + int xorig[] = {0, 4, 0, 2, 0, 1, 0}; + int yorig[] = {0, 0, 4, 0, 2, 0, 1}; + int xspc[] = {8, 8, 4, 4, 2, 2, 1}; + int yspc[] = {8, 8, 8, 4, 4, 2, 2}; + int i, j, x, y; + // pass1_x[4] = 0, pass1_x[5] = 1, pass1_x[12] = 1 + x = (a->s->img_x - xorig[p] + xspc[p] - 1) / xspc[p]; + y = (a->s->img_y - yorig[p] + yspc[p] - 1) / yspc[p]; + if (x && y) { + stbi__uint32 img_len = + ((((a->s->img_n * x * depth) + 7) >> 3) + 1) * y; + if (!stbi__create_png_image_raw(a, image_data, image_data_len, + out_n, x, y, depth, color)) { + STBI_FREE(final); + return 0; + } + for (j = 0; j < y; ++j) { + for (i = 0; i < x; ++i) { + int out_y = j * yspc[p] + yorig[p]; + int out_x = i * xspc[p] + xorig[p]; + memcpy(final + out_y * a->s->img_x * out_bytes + + out_x * out_bytes, + a->out + (j * x + i) * out_bytes, out_bytes); + } + } + STBI_FREE(a->out); + image_data += img_len; + image_data_len -= img_len; + } + } + a->out = final; - if (out_n == 2) { - for (i=0; i < pixel_count; ++i) { - p[1] = (p[0] == tc[0] ? 0 : 255); - p += 2; - } - } else { - for (i=0; i < pixel_count; ++i) { - if (p[0] == tc[0] && p[1] == tc[1] && p[2] == tc[2]) - p[3] = 0; - p += 4; - } - } - return 1; + return 1; } -static int stbi__compute_transparency16(stbi__png *z, stbi__uint16 tc[3], int out_n) -{ - stbi__context *s = z->s; - stbi__uint32 i, pixel_count = s->img_x * s->img_y; - stbi__uint16 *p = (stbi__uint16*) z->out; +static int stbi__compute_transparency(stbi__png* z, stbi_uc tc[3], int out_n) { + stbi__context* s = z->s; + stbi__uint32 i, pixel_count = s->img_x * s->img_y; + stbi_uc* p = z->out; - // compute color-based transparency, assuming we've - // already got 65535 as the alpha value in the output - STBI_ASSERT(out_n == 2 || out_n == 4); + // compute color-based transparency, assuming we've + // already got 255 as the alpha value in the output + STBI_ASSERT(out_n == 2 || out_n == 4); - if (out_n == 2) { - for (i = 0; i < pixel_count; ++i) { - p[1] = (p[0] == tc[0] ? 0 : 65535); - p += 2; - } - } else { - for (i = 0; i < pixel_count; ++i) { - if (p[0] == tc[0] && p[1] == tc[1] && p[2] == tc[2]) - p[3] = 0; - p += 4; - } - } - return 1; + if (out_n == 2) { + for (i = 0; i < pixel_count; ++i) { + p[1] = (p[0] == tc[0] ? 0 : 255); + p += 2; + } + } else { + for (i = 0; i < pixel_count; ++i) { + if (p[0] == tc[0] && p[1] == tc[1] && p[2] == tc[2]) + p[3] = 0; + p += 4; + } + } + return 1; } -static int stbi__expand_png_palette(stbi__png *a, stbi_uc *palette, int len, int pal_img_n) -{ - stbi__uint32 i, pixel_count = a->s->img_x * a->s->img_y; - stbi_uc *p, *temp_out, *orig = a->out; +static int stbi__compute_transparency16(stbi__png* z, stbi__uint16 tc[3], + int out_n) { + stbi__context* s = z->s; + stbi__uint32 i, pixel_count = s->img_x * s->img_y; + stbi__uint16* p = (stbi__uint16*)z->out; - p = (stbi_uc *) stbi__malloc_mad2(pixel_count, pal_img_n, 0); - if (p == NULL) return stbi__err("outofmem", "Out of memory"); + // compute color-based transparency, assuming we've + // already got 65535 as the alpha value in the output + STBI_ASSERT(out_n == 2 || out_n == 4); - // between here and free(out) below, exitting would leak - temp_out = p; + if (out_n == 2) { + for (i = 0; i < pixel_count; ++i) { + p[1] = (p[0] == tc[0] ? 0 : 65535); + p += 2; + } + } else { + for (i = 0; i < pixel_count; ++i) { + if (p[0] == tc[0] && p[1] == tc[1] && p[2] == tc[2]) + p[3] = 0; + p += 4; + } + } + return 1; +} - if (pal_img_n == 3) { - for (i=0; i < pixel_count; ++i) { - int n = orig[i]*4; - p[0] = palette[n ]; - p[1] = palette[n+1]; - p[2] = palette[n+2]; - p += 3; - } - } else { - for (i=0; i < pixel_count; ++i) { - int n = orig[i]*4; - p[0] = palette[n ]; - p[1] = palette[n+1]; - p[2] = palette[n+2]; - p[3] = palette[n+3]; - p += 4; - } - } - STBI_FREE(a->out); - a->out = temp_out; +static int stbi__expand_png_palette(stbi__png* a, stbi_uc* palette, int len, + int pal_img_n) { + stbi__uint32 i, pixel_count = a->s->img_x * a->s->img_y; + stbi_uc *p, *temp_out, *orig = a->out; - STBI_NOTUSED(len); + p = (stbi_uc*)stbi__malloc_mad2(pixel_count, pal_img_n, 0); + if (p == NULL) + return stbi__err("outofmem", "Out of memory"); - return 1; + // between here and free(out) below, exitting would leak + temp_out = p; + + if (pal_img_n == 3) { + for (i = 0; i < pixel_count; ++i) { + int n = orig[i] * 4; + p[0] = palette[n]; + p[1] = palette[n + 1]; + p[2] = palette[n + 2]; + p += 3; + } + } else { + for (i = 0; i < pixel_count; ++i) { + int n = orig[i] * 4; + p[0] = palette[n]; + p[1] = palette[n + 1]; + p[2] = palette[n + 2]; + p[3] = palette[n + 3]; + p += 4; + } + } + STBI_FREE(a->out); + a->out = temp_out; + + STBI_NOTUSED(len); + + return 1; } static int stbi__unpremultiply_on_load_global = 0; static int stbi__de_iphone_flag_global = 0; -STBIDEF void stbi_set_unpremultiply_on_load(int flag_true_if_should_unpremultiply) -{ - stbi__unpremultiply_on_load_global = flag_true_if_should_unpremultiply; +STBIDEF void +stbi_set_unpremultiply_on_load(int flag_true_if_should_unpremultiply) { + stbi__unpremultiply_on_load_global = flag_true_if_should_unpremultiply; } -STBIDEF void stbi_convert_iphone_png_to_rgb(int flag_true_if_should_convert) -{ - stbi__de_iphone_flag_global = flag_true_if_should_convert; +STBIDEF void stbi_convert_iphone_png_to_rgb(int flag_true_if_should_convert) { + stbi__de_iphone_flag_global = flag_true_if_should_convert; } #ifndef STBI_THREAD_LOCAL -#define stbi__unpremultiply_on_load stbi__unpremultiply_on_load_global -#define stbi__de_iphone_flag stbi__de_iphone_flag_global +#define stbi__unpremultiply_on_load stbi__unpremultiply_on_load_global +#define stbi__de_iphone_flag stbi__de_iphone_flag_global #else -static STBI_THREAD_LOCAL int stbi__unpremultiply_on_load_local, stbi__unpremultiply_on_load_set; -static STBI_THREAD_LOCAL int stbi__de_iphone_flag_local, stbi__de_iphone_flag_set; +static STBI_THREAD_LOCAL int stbi__unpremultiply_on_load_local, + stbi__unpremultiply_on_load_set; +static STBI_THREAD_LOCAL int stbi__de_iphone_flag_local, + stbi__de_iphone_flag_set; -STBIDEF void stbi_set_unpremultiply_on_load_thread(int flag_true_if_should_unpremultiply) -{ - stbi__unpremultiply_on_load_local = flag_true_if_should_unpremultiply; - stbi__unpremultiply_on_load_set = 1; +STBIDEF void +stbi_set_unpremultiply_on_load_thread(int flag_true_if_should_unpremultiply) { + stbi__unpremultiply_on_load_local = flag_true_if_should_unpremultiply; + stbi__unpremultiply_on_load_set = 1; } -STBIDEF void stbi_convert_iphone_png_to_rgb_thread(int flag_true_if_should_convert) -{ - stbi__de_iphone_flag_local = flag_true_if_should_convert; - stbi__de_iphone_flag_set = 1; +STBIDEF void +stbi_convert_iphone_png_to_rgb_thread(int flag_true_if_should_convert) { + stbi__de_iphone_flag_local = flag_true_if_should_convert; + stbi__de_iphone_flag_set = 1; } -#define stbi__unpremultiply_on_load (stbi__unpremultiply_on_load_set \ - ? stbi__unpremultiply_on_load_local \ - : stbi__unpremultiply_on_load_global) -#define stbi__de_iphone_flag (stbi__de_iphone_flag_set \ - ? stbi__de_iphone_flag_local \ - : stbi__de_iphone_flag_global) +#define stbi__unpremultiply_on_load \ + (stbi__unpremultiply_on_load_set ? stbi__unpremultiply_on_load_local \ + : stbi__unpremultiply_on_load_global) +#define stbi__de_iphone_flag \ + (stbi__de_iphone_flag_set ? stbi__de_iphone_flag_local \ + : stbi__de_iphone_flag_global) #endif // STBI_THREAD_LOCAL -static void stbi__de_iphone(stbi__png *z) -{ - stbi__context *s = z->s; - stbi__uint32 i, pixel_count = s->img_x * s->img_y; - stbi_uc *p = z->out; +static void stbi__de_iphone(stbi__png* z) { + stbi__context* s = z->s; + stbi__uint32 i, pixel_count = s->img_x * s->img_y; + stbi_uc* p = z->out; - if (s->img_out_n == 3) { // convert bgr to rgb - for (i=0; i < pixel_count; ++i) { - stbi_uc t = p[0]; - p[0] = p[2]; - p[2] = t; - p += 3; - } - } else { - STBI_ASSERT(s->img_out_n == 4); - if (stbi__unpremultiply_on_load) { - // convert bgr to rgb and unpremultiply - for (i=0; i < pixel_count; ++i) { - stbi_uc a = p[3]; - stbi_uc t = p[0]; - if (a) { - stbi_uc half = a / 2; - p[0] = (p[2] * 255 + half) / a; - p[1] = (p[1] * 255 + half) / a; - p[2] = ( t * 255 + half) / a; - } else { - p[0] = p[2]; - p[2] = t; - } - p += 4; - } - } else { - // convert bgr to rgb - for (i=0; i < pixel_count; ++i) { + if (s->img_out_n == 3) { // convert bgr to rgb + for (i = 0; i < pixel_count; ++i) { stbi_uc t = p[0]; p[0] = p[2]; p[2] = t; - p += 4; - } - } - } + p += 3; + } + } else { + STBI_ASSERT(s->img_out_n == 4); + if (stbi__unpremultiply_on_load) { + // convert bgr to rgb and unpremultiply + for (i = 0; i < pixel_count; ++i) { + stbi_uc a = p[3]; + stbi_uc t = p[0]; + if (a) { + stbi_uc half = a / 2; + p[0] = (p[2] * 255 + half) / a; + p[1] = (p[1] * 255 + half) / a; + p[2] = (t * 255 + half) / a; + } else { + p[0] = p[2]; + p[2] = t; + } + p += 4; + } + } else { + // convert bgr to rgb + for (i = 0; i < pixel_count; ++i) { + stbi_uc t = p[0]; + p[0] = p[2]; + p[2] = t; + p += 4; + } + } + } } -#define STBI__PNG_TYPE(a,b,c,d) (((unsigned) (a) << 24) + ((unsigned) (b) << 16) + ((unsigned) (c) << 8) + (unsigned) (d)) +#define STBI__PNG_TYPE(a, b, c, d) \ + (((unsigned)(a) << 24) + ((unsigned)(b) << 16) + ((unsigned)(c) << 8) + \ + (unsigned)(d)) -static int stbi__parse_png_file(stbi__png *z, int scan, int req_comp) -{ - stbi_uc palette[1024], pal_img_n=0; - stbi_uc has_trans=0, tc[3]={0}; - stbi__uint16 tc16[3]; - stbi__uint32 ioff=0, idata_limit=0, i, pal_len=0; - int first=1,k,interlace=0, color=0, is_iphone=0; - stbi__context *s = z->s; +static int stbi__parse_png_file(stbi__png* z, int scan, int req_comp) { + stbi_uc palette[1024], pal_img_n = 0; + stbi_uc has_trans = 0, tc[3] = {0}; + stbi__uint16 tc16[3]; + stbi__uint32 ioff = 0, idata_limit = 0, i, pal_len = 0; + int first = 1, k, interlace = 0, color = 0, is_iphone = 0; + stbi__context* s = z->s; - z->expanded = NULL; - z->idata = NULL; - z->out = NULL; + z->expanded = NULL; + z->idata = NULL; + z->out = NULL; - if (!stbi__check_png_header(s)) return 0; + if (!stbi__check_png_header(s)) + return 0; - if (scan == STBI__SCAN_type) return 1; + if (scan == STBI__SCAN_type) + return 1; - for (;;) { - stbi__pngchunk c = stbi__get_chunk_header(s); - switch (c.type) { - case STBI__PNG_TYPE('C','g','B','I'): + for (;;) { + stbi__pngchunk c = stbi__get_chunk_header(s); + switch (c.type) { + case STBI__PNG_TYPE('C', 'g', 'B', 'I'): is_iphone = 1; stbi__skip(s, c.length); break; - case STBI__PNG_TYPE('I','H','D','R'): { - int comp,filter; - if (!first) return stbi__err("multiple IHDR","Corrupt PNG"); + case STBI__PNG_TYPE('I', 'H', 'D', 'R'): { + int comp, filter; + if (!first) + return stbi__err("multiple IHDR", "Corrupt PNG"); first = 0; - if (c.length != 13) return stbi__err("bad IHDR len","Corrupt PNG"); + if (c.length != 13) + return stbi__err("bad IHDR len", "Corrupt PNG"); s->img_x = stbi__get32be(s); s->img_y = stbi__get32be(s); - if (s->img_y > STBI_MAX_DIMENSIONS) return stbi__err("too large","Very large image (corrupt?)"); - if (s->img_x > STBI_MAX_DIMENSIONS) return stbi__err("too large","Very large image (corrupt?)"); - z->depth = stbi__get8(s); if (z->depth != 1 && z->depth != 2 && z->depth != 4 && z->depth != 8 && z->depth != 16) return stbi__err("1/2/4/8/16-bit only","PNG not supported: 1/2/4/8/16-bit only"); - color = stbi__get8(s); if (color > 6) return stbi__err("bad ctype","Corrupt PNG"); - if (color == 3 && z->depth == 16) return stbi__err("bad ctype","Corrupt PNG"); - if (color == 3) pal_img_n = 3; else if (color & 1) return stbi__err("bad ctype","Corrupt PNG"); - comp = stbi__get8(s); if (comp) return stbi__err("bad comp method","Corrupt PNG"); - filter= stbi__get8(s); if (filter) return stbi__err("bad filter method","Corrupt PNG"); - interlace = stbi__get8(s); if (interlace>1) return stbi__err("bad interlace method","Corrupt PNG"); - if (!s->img_x || !s->img_y) return stbi__err("0-pixel image","Corrupt PNG"); + if (s->img_y > STBI_MAX_DIMENSIONS) + return stbi__err("too large", "Very large image (corrupt?)"); + if (s->img_x > STBI_MAX_DIMENSIONS) + return stbi__err("too large", "Very large image (corrupt?)"); + z->depth = stbi__get8(s); + if (z->depth != 1 && z->depth != 2 && z->depth != 4 && + z->depth != 8 && z->depth != 16) + return stbi__err("1/2/4/8/16-bit only", + "PNG not supported: 1/2/4/8/16-bit only"); + color = stbi__get8(s); + if (color > 6) + return stbi__err("bad ctype", "Corrupt PNG"); + if (color == 3 && z->depth == 16) + return stbi__err("bad ctype", "Corrupt PNG"); + if (color == 3) + pal_img_n = 3; + else if (color & 1) + return stbi__err("bad ctype", "Corrupt PNG"); + comp = stbi__get8(s); + if (comp) + return stbi__err("bad comp method", "Corrupt PNG"); + filter = stbi__get8(s); + if (filter) + return stbi__err("bad filter method", "Corrupt PNG"); + interlace = stbi__get8(s); + if (interlace > 1) + return stbi__err("bad interlace method", "Corrupt PNG"); + if (!s->img_x || !s->img_y) + return stbi__err("0-pixel image", "Corrupt PNG"); if (!pal_img_n) { - s->img_n = (color & 2 ? 3 : 1) + (color & 4 ? 1 : 0); - if ((1 << 30) / s->img_x / s->img_n < s->img_y) return stbi__err("too large", "Image too large to decode"); + s->img_n = (color & 2 ? 3 : 1) + (color & 4 ? 1 : 0); + if ((1 << 30) / s->img_x / s->img_n < s->img_y) + return stbi__err("too large", "Image too large to decode"); } else { - // if paletted, then pal_n is our final components, and - // img_n is # components to decompress/filter. - s->img_n = 1; - if ((1 << 30) / s->img_x / 4 < s->img_y) return stbi__err("too large","Corrupt PNG"); + // if paletted, then pal_n is our final components, and + // img_n is # components to decompress/filter. + s->img_n = 1; + if ((1 << 30) / s->img_x / 4 < s->img_y) + return stbi__err("too large", "Corrupt PNG"); } // even with SCAN_header, have to scan to see if we have a tRNS break; - } + } - case STBI__PNG_TYPE('P','L','T','E'): { - if (first) return stbi__err("first not IHDR", "Corrupt PNG"); - if (c.length > 256*3) return stbi__err("invalid PLTE","Corrupt PNG"); + case STBI__PNG_TYPE('P', 'L', 'T', 'E'): { + if (first) + return stbi__err("first not IHDR", "Corrupt PNG"); + if (c.length > 256 * 3) + return stbi__err("invalid PLTE", "Corrupt PNG"); pal_len = c.length / 3; - if (pal_len * 3 != c.length) return stbi__err("invalid PLTE","Corrupt PNG"); - for (i=0; i < pal_len; ++i) { - palette[i*4+0] = stbi__get8(s); - palette[i*4+1] = stbi__get8(s); - palette[i*4+2] = stbi__get8(s); - palette[i*4+3] = 255; + if (pal_len * 3 != c.length) + return stbi__err("invalid PLTE", "Corrupt PNG"); + for (i = 0; i < pal_len; ++i) { + palette[i * 4 + 0] = stbi__get8(s); + palette[i * 4 + 1] = stbi__get8(s); + palette[i * 4 + 2] = stbi__get8(s); + palette[i * 4 + 3] = 255; } break; - } + } - case STBI__PNG_TYPE('t','R','N','S'): { - if (first) return stbi__err("first not IHDR", "Corrupt PNG"); - if (z->idata) return stbi__err("tRNS after IDAT","Corrupt PNG"); + case STBI__PNG_TYPE('t', 'R', 'N', 'S'): { + if (first) + return stbi__err("first not IHDR", "Corrupt PNG"); + if (z->idata) + return stbi__err("tRNS after IDAT", "Corrupt PNG"); if (pal_img_n) { - if (scan == STBI__SCAN_header) { s->img_n = 4; return 1; } - if (pal_len == 0) return stbi__err("tRNS before PLTE","Corrupt PNG"); - if (c.length > pal_len) return stbi__err("bad tRNS len","Corrupt PNG"); - pal_img_n = 4; - for (i=0; i < c.length; ++i) - palette[i*4+3] = stbi__get8(s); + if (scan == STBI__SCAN_header) { + s->img_n = 4; + return 1; + } + if (pal_len == 0) + return stbi__err("tRNS before PLTE", "Corrupt PNG"); + if (c.length > pal_len) + return stbi__err("bad tRNS len", "Corrupt PNG"); + pal_img_n = 4; + for (i = 0; i < c.length; ++i) + palette[i * 4 + 3] = stbi__get8(s); } else { - if (!(s->img_n & 1)) return stbi__err("tRNS with alpha","Corrupt PNG"); - if (c.length != (stbi__uint32) s->img_n*2) return stbi__err("bad tRNS len","Corrupt PNG"); - has_trans = 1; - // non-paletted with tRNS = constant alpha. if header-scanning, we can stop now. - if (scan == STBI__SCAN_header) { ++s->img_n; return 1; } - if (z->depth == 16) { - for (k = 0; k < s->img_n; ++k) tc16[k] = (stbi__uint16)stbi__get16be(s); // copy the values as-is - } else { - for (k = 0; k < s->img_n; ++k) tc[k] = (stbi_uc)(stbi__get16be(s) & 255) * stbi__depth_scale_table[z->depth]; // non 8-bit images will be larger - } + if (!(s->img_n & 1)) + return stbi__err("tRNS with alpha", "Corrupt PNG"); + if (c.length != (stbi__uint32)s->img_n * 2) + return stbi__err("bad tRNS len", "Corrupt PNG"); + has_trans = 1; + // non-paletted with tRNS = constant alpha. if header-scanning, + // we can stop now. + if (scan == STBI__SCAN_header) { + ++s->img_n; + return 1; + } + if (z->depth == 16) { + for (k = 0; k < s->img_n && k < 3; + ++k) // extra loop test to suppress false GCC warning + tc16[k] = (stbi__uint16)stbi__get16be( + s); // copy the values as-is + } else { + for (k = 0; k < s->img_n && k < 3; ++k) + tc[k] = + (stbi_uc)(stbi__get16be(s) & 255) * + stbi__depth_scale_table + [z->depth]; // non 8-bit images will be larger + } } break; - } + } - case STBI__PNG_TYPE('I','D','A','T'): { - if (first) return stbi__err("first not IHDR", "Corrupt PNG"); - if (pal_img_n && !pal_len) return stbi__err("no PLTE","Corrupt PNG"); + case STBI__PNG_TYPE('I', 'D', 'A', 'T'): { + if (first) + return stbi__err("first not IHDR", "Corrupt PNG"); + if (pal_img_n && !pal_len) + return stbi__err("no PLTE", "Corrupt PNG"); if (scan == STBI__SCAN_header) { - // header scan definitely stops at first IDAT - if (pal_img_n) - s->img_n = pal_img_n; - return 1; + // header scan definitely stops at first IDAT + if (pal_img_n) + s->img_n = pal_img_n; + return 1; } - if (c.length > (1u << 30)) return stbi__err("IDAT size limit", "IDAT section larger than 2^30 bytes"); - if ((int)(ioff + c.length) < (int)ioff) return 0; + if (c.length > (1u << 30)) + return stbi__err("IDAT size limit", + "IDAT section larger than 2^30 bytes"); + if ((int)(ioff + c.length) < (int)ioff) + return 0; if (ioff + c.length > idata_limit) { - stbi__uint32 idata_limit_old = idata_limit; - stbi_uc *p; - if (idata_limit == 0) idata_limit = c.length > 4096 ? c.length : 4096; - while (ioff + c.length > idata_limit) - idata_limit *= 2; - STBI_NOTUSED(idata_limit_old); - p = (stbi_uc *) STBI_REALLOC_SIZED(z->idata, idata_limit_old, idata_limit); if (p == NULL) return stbi__err("outofmem", "Out of memory"); - z->idata = p; + stbi__uint32 idata_limit_old = idata_limit; + stbi_uc* p; + if (idata_limit == 0) + idata_limit = c.length > 4096 ? c.length : 4096; + while (ioff + c.length > idata_limit) + idata_limit *= 2; + STBI_NOTUSED(idata_limit_old); + p = (stbi_uc*)STBI_REALLOC_SIZED(z->idata, idata_limit_old, + idata_limit); + if (p == NULL) + return stbi__err("outofmem", "Out of memory"); + z->idata = p; } - if (!stbi__getn(s, z->idata+ioff,c.length)) return stbi__err("outofdata","Corrupt PNG"); + if (!stbi__getn(s, z->idata + ioff, c.length)) + return stbi__err("outofdata", "Corrupt PNG"); ioff += c.length; break; - } + } - case STBI__PNG_TYPE('I','E','N','D'): { + case STBI__PNG_TYPE('I', 'E', 'N', 'D'): { stbi__uint32 raw_len, bpl; - if (first) return stbi__err("first not IHDR", "Corrupt PNG"); - if (scan != STBI__SCAN_load) return 1; - if (z->idata == NULL) return stbi__err("no IDAT","Corrupt PNG"); + if (first) + return stbi__err("first not IHDR", "Corrupt PNG"); + if (scan != STBI__SCAN_load) + return 1; + if (z->idata == NULL) + return stbi__err("no IDAT", "Corrupt PNG"); // initial guess for decoded data size to avoid unnecessary reallocs - bpl = (s->img_x * z->depth + 7) / 8; // bytes per line, per component - raw_len = bpl * s->img_y * s->img_n /* pixels */ + s->img_y /* filter mode per row */; - z->expanded = (stbi_uc *) stbi_zlib_decode_malloc_guesssize_headerflag((char *) z->idata, ioff, raw_len, (int *) &raw_len, !is_iphone); - if (z->expanded == NULL) return 0; // zlib should set error - STBI_FREE(z->idata); z->idata = NULL; - if ((req_comp == s->img_n+1 && req_comp != 3 && !pal_img_n) || has_trans) - s->img_out_n = s->img_n+1; + bpl = + (s->img_x * z->depth + 7) / 8; // bytes per line, per component + raw_len = bpl * s->img_y * s->img_n /* pixels */ + + s->img_y /* filter mode per row */; + z->expanded = + (stbi_uc*)stbi_zlib_decode_malloc_guesssize_headerflag( + (char*)z->idata, ioff, raw_len, (int*)&raw_len, !is_iphone); + if (z->expanded == NULL) + return 0; // zlib should set error + STBI_FREE(z->idata); + z->idata = NULL; + if ((req_comp == s->img_n + 1 && req_comp != 3 && !pal_img_n) || + has_trans) + s->img_out_n = s->img_n + 1; else - s->img_out_n = s->img_n; - if (!stbi__create_png_image(z, z->expanded, raw_len, s->img_out_n, z->depth, color, interlace)) return 0; + s->img_out_n = s->img_n; + if (!stbi__create_png_image(z, z->expanded, raw_len, s->img_out_n, + z->depth, color, interlace)) + return 0; if (has_trans) { - if (z->depth == 16) { - if (!stbi__compute_transparency16(z, tc16, s->img_out_n)) return 0; - } else { - if (!stbi__compute_transparency(z, tc, s->img_out_n)) return 0; - } + if (z->depth == 16) { + if (!stbi__compute_transparency16(z, tc16, s->img_out_n)) + return 0; + } else { + if (!stbi__compute_transparency(z, tc, s->img_out_n)) + return 0; + } } if (is_iphone && stbi__de_iphone_flag && s->img_out_n > 2) - stbi__de_iphone(z); + stbi__de_iphone(z); if (pal_img_n) { - // pal_img_n == 3 or 4 - s->img_n = pal_img_n; // record the actual colors we had - s->img_out_n = pal_img_n; - if (req_comp >= 3) s->img_out_n = req_comp; - if (!stbi__expand_png_palette(z, palette, pal_len, s->img_out_n)) - return 0; + // pal_img_n == 3 or 4 + s->img_n = pal_img_n; // record the actual colors we had + s->img_out_n = pal_img_n; + if (req_comp >= 3) + s->img_out_n = req_comp; + if (!stbi__expand_png_palette(z, palette, pal_len, + s->img_out_n)) + return 0; } else if (has_trans) { - // non-paletted image with tRNS -> source image has (constant) alpha - ++s->img_n; + // non-paletted image with tRNS -> source image has (constant) + // alpha + ++s->img_n; } - STBI_FREE(z->expanded); z->expanded = NULL; + STBI_FREE(z->expanded); + z->expanded = NULL; // end of PNG chunk, read and skip CRC stbi__get32be(s); return 1; - } + } - default: + default: // if critical, fail - if (first) return stbi__err("first not IHDR", "Corrupt PNG"); + if (first) + return stbi__err("first not IHDR", "Corrupt PNG"); if ((c.type & (1 << 29)) == 0) { - #ifndef STBI_NO_FAILURE_STRINGS - // not threadsafe - static char invalid_chunk[] = "XXXX PNG chunk not known"; - invalid_chunk[0] = STBI__BYTECAST(c.type >> 24); - invalid_chunk[1] = STBI__BYTECAST(c.type >> 16); - invalid_chunk[2] = STBI__BYTECAST(c.type >> 8); - invalid_chunk[3] = STBI__BYTECAST(c.type >> 0); - #endif - return stbi__err(invalid_chunk, "PNG not supported: unknown PNG chunk type"); +#ifndef STBI_NO_FAILURE_STRINGS + // not threadsafe + static char invalid_chunk[] = "XXXX PNG chunk not known"; + invalid_chunk[0] = STBI__BYTECAST(c.type >> 24); + invalid_chunk[1] = STBI__BYTECAST(c.type >> 16); + invalid_chunk[2] = STBI__BYTECAST(c.type >> 8); + invalid_chunk[3] = STBI__BYTECAST(c.type >> 0); +#endif + return stbi__err(invalid_chunk, + "PNG not supported: unknown PNG chunk type"); } stbi__skip(s, c.length); break; - } - // end of PNG chunk, read and skip CRC - stbi__get32be(s); - } + } + // end of PNG chunk, read and skip CRC + stbi__get32be(s); + } } -static void *stbi__do_png(stbi__png *p, int *x, int *y, int *n, int req_comp, stbi__result_info *ri) -{ - void *result=NULL; - if (req_comp < 0 || req_comp > 4) return stbi__errpuc("bad req_comp", "Internal error"); - if (stbi__parse_png_file(p, STBI__SCAN_load, req_comp)) { - if (p->depth <= 8) - ri->bits_per_channel = 8; - else if (p->depth == 16) - ri->bits_per_channel = 16; - else - return stbi__errpuc("bad bits_per_channel", "PNG not supported: unsupported color depth"); - result = p->out; - p->out = NULL; - if (req_comp && req_comp != p->s->img_out_n) { - if (ri->bits_per_channel == 8) - result = stbi__convert_format((unsigned char *) result, p->s->img_out_n, req_comp, p->s->img_x, p->s->img_y); - else - result = stbi__convert_format16((stbi__uint16 *) result, p->s->img_out_n, req_comp, p->s->img_x, p->s->img_y); - p->s->img_out_n = req_comp; - if (result == NULL) return result; - } - *x = p->s->img_x; - *y = p->s->img_y; - if (n) *n = p->s->img_n; - } - STBI_FREE(p->out); p->out = NULL; - STBI_FREE(p->expanded); p->expanded = NULL; - STBI_FREE(p->idata); p->idata = NULL; +static void* stbi__do_png(stbi__png* p, int* x, int* y, int* n, int req_comp, + stbi__result_info* ri) { + void* result = NULL; + if (req_comp < 0 || req_comp > 4) + return stbi__errpuc("bad req_comp", "Internal error"); + if (stbi__parse_png_file(p, STBI__SCAN_load, req_comp)) { + if (p->depth <= 8) + ri->bits_per_channel = 8; + else if (p->depth == 16) + ri->bits_per_channel = 16; + else + return stbi__errpuc("bad bits_per_channel", + "PNG not supported: unsupported color depth"); + result = p->out; + p->out = NULL; + if (req_comp && req_comp != p->s->img_out_n) { + if (ri->bits_per_channel == 8) + result = stbi__convert_format((unsigned char*)result, + p->s->img_out_n, req_comp, + p->s->img_x, p->s->img_y); + else + result = stbi__convert_format16((stbi__uint16*)result, + p->s->img_out_n, req_comp, + p->s->img_x, p->s->img_y); + p->s->img_out_n = req_comp; + if (result == NULL) + return result; + } + *x = p->s->img_x; + *y = p->s->img_y; + if (n) + *n = p->s->img_n; + } + STBI_FREE(p->out); + p->out = NULL; + STBI_FREE(p->expanded); + p->expanded = NULL; + STBI_FREE(p->idata); + p->idata = NULL; - return result; + return result; } -static void *stbi__png_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri) -{ - stbi__png p; - p.s = s; - return stbi__do_png(&p, x,y,comp,req_comp, ri); +static void* stbi__png_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri) { + stbi__png p; + p.s = s; + return stbi__do_png(&p, x, y, comp, req_comp, ri); } -static int stbi__png_test(stbi__context *s) -{ - int r; - r = stbi__check_png_header(s); - stbi__rewind(s); - return r; +static int stbi__png_test(stbi__context* s) { + int r; + r = stbi__check_png_header(s); + stbi__rewind(s); + return r; } -static int stbi__png_info_raw(stbi__png *p, int *x, int *y, int *comp) -{ - if (!stbi__parse_png_file(p, STBI__SCAN_header, 0)) { - stbi__rewind( p->s ); - return 0; - } - if (x) *x = p->s->img_x; - if (y) *y = p->s->img_y; - if (comp) *comp = p->s->img_n; - return 1; +static int stbi__png_info_raw(stbi__png* p, int* x, int* y, int* comp) { + if (!stbi__parse_png_file(p, STBI__SCAN_header, 0)) { + stbi__rewind(p->s); + return 0; + } + if (x) + *x = p->s->img_x; + if (y) + *y = p->s->img_y; + if (comp) + *comp = p->s->img_n; + return 1; } -static int stbi__png_info(stbi__context *s, int *x, int *y, int *comp) -{ - stbi__png p; - p.s = s; - return stbi__png_info_raw(&p, x, y, comp); +static int stbi__png_info(stbi__context* s, int* x, int* y, int* comp) { + stbi__png p; + p.s = s; + return stbi__png_info_raw(&p, x, y, comp); } -static int stbi__png_is16(stbi__context *s) -{ - stbi__png p; - p.s = s; - if (!stbi__png_info_raw(&p, NULL, NULL, NULL)) - return 0; - if (p.depth != 16) { - stbi__rewind(p.s); - return 0; - } - return 1; +static int stbi__png_is16(stbi__context* s) { + stbi__png p; + p.s = s; + if (!stbi__png_info_raw(&p, NULL, NULL, NULL)) + return 0; + if (p.depth != 16) { + stbi__rewind(p.s); + return 0; + } + return 1; } #endif // Microsoft/Windows BMP image #ifndef STBI_NO_BMP -static int stbi__bmp_test_raw(stbi__context *s) -{ - int r; - int sz; - if (stbi__get8(s) != 'B') return 0; - if (stbi__get8(s) != 'M') return 0; - stbi__get32le(s); // discard filesize - stbi__get16le(s); // discard reserved - stbi__get16le(s); // discard reserved - stbi__get32le(s); // discard data offset - sz = stbi__get32le(s); - r = (sz == 12 || sz == 40 || sz == 56 || sz == 108 || sz == 124); - return r; +static int stbi__bmp_test_raw(stbi__context* s) { + int r; + int sz; + if (stbi__get8(s) != 'B') + return 0; + if (stbi__get8(s) != 'M') + return 0; + stbi__get32le(s); // discard filesize + stbi__get16le(s); // discard reserved + stbi__get16le(s); // discard reserved + stbi__get32le(s); // discard data offset + sz = stbi__get32le(s); + r = (sz == 12 || sz == 40 || sz == 56 || sz == 108 || sz == 124); + return r; } -static int stbi__bmp_test(stbi__context *s) -{ - int r = stbi__bmp_test_raw(s); - stbi__rewind(s); - return r; +static int stbi__bmp_test(stbi__context* s) { + int r = stbi__bmp_test_raw(s); + stbi__rewind(s); + return r; } - // returns 0..31 for the highest set bit -static int stbi__high_bit(unsigned int z) -{ - int n=0; - if (z == 0) return -1; - if (z >= 0x10000) { n += 16; z >>= 16; } - if (z >= 0x00100) { n += 8; z >>= 8; } - if (z >= 0x00010) { n += 4; z >>= 4; } - if (z >= 0x00004) { n += 2; z >>= 2; } - if (z >= 0x00002) { n += 1;/* >>= 1;*/ } - return n; +static int stbi__high_bit(unsigned int z) { + int n = 0; + if (z == 0) + return -1; + if (z >= 0x10000) { + n += 16; + z >>= 16; + } + if (z >= 0x00100) { + n += 8; + z >>= 8; + } + if (z >= 0x00010) { + n += 4; + z >>= 4; + } + if (z >= 0x00004) { + n += 2; + z >>= 2; + } + if (z >= 0x00002) { + n += 1; /* >>= 1;*/ + } + return n; } -static int stbi__bitcount(unsigned int a) -{ - a = (a & 0x55555555) + ((a >> 1) & 0x55555555); // max 2 - a = (a & 0x33333333) + ((a >> 2) & 0x33333333); // max 4 - a = (a + (a >> 4)) & 0x0f0f0f0f; // max 8 per 4, now 8 bits - a = (a + (a >> 8)); // max 16 per 8 bits - a = (a + (a >> 16)); // max 32 per 8 bits - return a & 0xff; +static int stbi__bitcount(unsigned int a) { + a = (a & 0x55555555) + ((a >> 1) & 0x55555555); // max 2 + a = (a & 0x33333333) + ((a >> 2) & 0x33333333); // max 4 + a = (a + (a >> 4)) & 0x0f0f0f0f; // max 8 per 4, now 8 bits + a = (a + (a >> 8)); // max 16 per 8 bits + a = (a + (a >> 16)); // max 32 per 8 bits + return a & 0xff; } // extract an arbitrarily-aligned N-bit value (N=bits) // from v, and then make it 8-bits long and fractionally // extend it to full full range. -static int stbi__shiftsigned(unsigned int v, int shift, int bits) -{ - static unsigned int mul_table[9] = { - 0, - 0xff/*0b11111111*/, 0x55/*0b01010101*/, 0x49/*0b01001001*/, 0x11/*0b00010001*/, - 0x21/*0b00100001*/, 0x41/*0b01000001*/, 0x81/*0b10000001*/, 0x01/*0b00000001*/, - }; - static unsigned int shift_table[9] = { - 0, 0,0,1,0,2,4,6,0, - }; - if (shift < 0) - v <<= -shift; - else - v >>= shift; - STBI_ASSERT(v < 256); - v >>= (8-bits); - STBI_ASSERT(bits >= 0 && bits <= 8); - return (int) ((unsigned) v * mul_table[bits]) >> shift_table[bits]; +static int stbi__shiftsigned(unsigned int v, int shift, int bits) { + static unsigned int mul_table[9] = { + 0, + 0xff /*0b11111111*/, + 0x55 /*0b01010101*/, + 0x49 /*0b01001001*/, + 0x11 /*0b00010001*/, + 0x21 /*0b00100001*/, + 0x41 /*0b01000001*/, + 0x81 /*0b10000001*/, + 0x01 /*0b00000001*/, + }; + static unsigned int shift_table[9] = { + 0, 0, 0, 1, 0, 2, 4, 6, 0, + }; + if (shift < 0) + v <<= -shift; + else + v >>= shift; + STBI_ASSERT(v < 256); + v >>= (8 - bits); + STBI_ASSERT(bits >= 0 && bits <= 8); + return (int)((unsigned)v * mul_table[bits]) >> shift_table[bits]; } -typedef struct -{ - int bpp, offset, hsz; - unsigned int mr,mg,mb,ma, all_a; - int extra_read; +typedef struct { + int bpp, offset, hsz; + unsigned int mr, mg, mb, ma, all_a; + int extra_read; } stbi__bmp_data; -static int stbi__bmp_set_mask_defaults(stbi__bmp_data *info, int compress) -{ - // BI_BITFIELDS specifies masks explicitly, don't override - if (compress == 3) - return 1; +static int stbi__bmp_set_mask_defaults(stbi__bmp_data* info, int compress) { + // BI_BITFIELDS specifies masks explicitly, don't override + if (compress == 3) + return 1; - if (compress == 0) { - if (info->bpp == 16) { - info->mr = 31u << 10; - info->mg = 31u << 5; - info->mb = 31u << 0; - } else if (info->bpp == 32) { - info->mr = 0xffu << 16; - info->mg = 0xffu << 8; - info->mb = 0xffu << 0; - info->ma = 0xffu << 24; - info->all_a = 0; // if all_a is 0 at end, then we loaded alpha channel but it was all 0 - } else { - // otherwise, use defaults, which is all-0 - info->mr = info->mg = info->mb = info->ma = 0; - } - return 1; - } - return 0; // error + if (compress == 0) { + if (info->bpp == 16) { + info->mr = 31u << 10; + info->mg = 31u << 5; + info->mb = 31u << 0; + } else if (info->bpp == 32) { + info->mr = 0xffu << 16; + info->mg = 0xffu << 8; + info->mb = 0xffu << 0; + info->ma = 0xffu << 24; + info->all_a = 0; // if all_a is 0 at end, then we loaded alpha + // channel but it was all 0 + } else { + // otherwise, use defaults, which is all-0 + info->mr = info->mg = info->mb = info->ma = 0; + } + return 1; + } + return 0; // error } -static void *stbi__bmp_parse_header(stbi__context *s, stbi__bmp_data *info) -{ - int hsz; - if (stbi__get8(s) != 'B' || stbi__get8(s) != 'M') return stbi__errpuc("not BMP", "Corrupt BMP"); - stbi__get32le(s); // discard filesize - stbi__get16le(s); // discard reserved - stbi__get16le(s); // discard reserved - info->offset = stbi__get32le(s); - info->hsz = hsz = stbi__get32le(s); - info->mr = info->mg = info->mb = info->ma = 0; - info->extra_read = 14; +static void* stbi__bmp_parse_header(stbi__context* s, stbi__bmp_data* info) { + int hsz; + if (stbi__get8(s) != 'B' || stbi__get8(s) != 'M') + return stbi__errpuc("not BMP", "Corrupt BMP"); + stbi__get32le(s); // discard filesize + stbi__get16le(s); // discard reserved + stbi__get16le(s); // discard reserved + info->offset = stbi__get32le(s); + info->hsz = hsz = stbi__get32le(s); + info->mr = info->mg = info->mb = info->ma = 0; + info->extra_read = 14; - if (info->offset < 0) return stbi__errpuc("bad BMP", "bad BMP"); + if (info->offset < 0) + return stbi__errpuc("bad BMP", "bad BMP"); - if (hsz != 12 && hsz != 40 && hsz != 56 && hsz != 108 && hsz != 124) return stbi__errpuc("unknown BMP", "BMP type not supported: unknown"); - if (hsz == 12) { - s->img_x = stbi__get16le(s); - s->img_y = stbi__get16le(s); - } else { - s->img_x = stbi__get32le(s); - s->img_y = stbi__get32le(s); - } - if (stbi__get16le(s) != 1) return stbi__errpuc("bad BMP", "bad BMP"); - info->bpp = stbi__get16le(s); - if (hsz != 12) { - int compress = stbi__get32le(s); - if (compress == 1 || compress == 2) return stbi__errpuc("BMP RLE", "BMP type not supported: RLE"); - if (compress >= 4) return stbi__errpuc("BMP JPEG/PNG", "BMP type not supported: unsupported compression"); // this includes PNG/JPEG modes - if (compress == 3 && info->bpp != 16 && info->bpp != 32) return stbi__errpuc("bad BMP", "bad BMP"); // bitfields requires 16 or 32 bits/pixel - stbi__get32le(s); // discard sizeof - stbi__get32le(s); // discard hres - stbi__get32le(s); // discard vres - stbi__get32le(s); // discard colorsused - stbi__get32le(s); // discard max important - if (hsz == 40 || hsz == 56) { - if (hsz == 56) { - stbi__get32le(s); - stbi__get32le(s); - stbi__get32le(s); - stbi__get32le(s); - } - if (info->bpp == 16 || info->bpp == 32) { - if (compress == 0) { - stbi__bmp_set_mask_defaults(info, compress); - } else if (compress == 3) { - info->mr = stbi__get32le(s); - info->mg = stbi__get32le(s); - info->mb = stbi__get32le(s); - info->extra_read += 12; - // not documented, but generated by photoshop and handled by mspaint - if (info->mr == info->mg && info->mg == info->mb) { - // ?!?!? - return stbi__errpuc("bad BMP", "bad BMP"); - } - } else - return stbi__errpuc("bad BMP", "bad BMP"); - } - } else { - // V4/V5 header - int i; - if (hsz != 108 && hsz != 124) - return stbi__errpuc("bad BMP", "bad BMP"); - info->mr = stbi__get32le(s); - info->mg = stbi__get32le(s); - info->mb = stbi__get32le(s); - info->ma = stbi__get32le(s); - if (compress != 3) // override mr/mg/mb unless in BI_BITFIELDS mode, as per docs - stbi__bmp_set_mask_defaults(info, compress); - stbi__get32le(s); // discard color space - for (i=0; i < 12; ++i) - stbi__get32le(s); // discard color space parameters - if (hsz == 124) { - stbi__get32le(s); // discard rendering intent - stbi__get32le(s); // discard offset of profile data - stbi__get32le(s); // discard size of profile data - stbi__get32le(s); // discard reserved - } - } - } - return (void *) 1; + if (hsz != 12 && hsz != 40 && hsz != 56 && hsz != 108 && hsz != 124) + return stbi__errpuc("unknown BMP", "BMP type not supported: unknown"); + if (hsz == 12) { + s->img_x = stbi__get16le(s); + s->img_y = stbi__get16le(s); + } else { + s->img_x = stbi__get32le(s); + s->img_y = stbi__get32le(s); + } + if (stbi__get16le(s) != 1) + return stbi__errpuc("bad BMP", "bad BMP"); + info->bpp = stbi__get16le(s); + if (hsz != 12) { + int compress = stbi__get32le(s); + if (compress == 1 || compress == 2) + return stbi__errpuc("BMP RLE", "BMP type not supported: RLE"); + if (compress >= 4) + return stbi__errpuc( + "BMP JPEG/PNG", + "BMP type not supported: unsupported compression"); // this + // includes + // PNG/JPEG + // modes + if (compress == 3 && info->bpp != 16 && info->bpp != 32) + return stbi__errpuc( + "bad BMP", "bad BMP"); // bitfields requires 16 or 32 bits/pixel + stbi__get32le(s); // discard sizeof + stbi__get32le(s); // discard hres + stbi__get32le(s); // discard vres + stbi__get32le(s); // discard colorsused + stbi__get32le(s); // discard max important + if (hsz == 40 || hsz == 56) { + if (hsz == 56) { + stbi__get32le(s); + stbi__get32le(s); + stbi__get32le(s); + stbi__get32le(s); + } + if (info->bpp == 16 || info->bpp == 32) { + if (compress == 0) { + stbi__bmp_set_mask_defaults(info, compress); + } else if (compress == 3) { + info->mr = stbi__get32le(s); + info->mg = stbi__get32le(s); + info->mb = stbi__get32le(s); + info->extra_read += 12; + // not documented, but generated by photoshop and handled by + // mspaint + if (info->mr == info->mg && info->mg == info->mb) { + // ?!?!? + return stbi__errpuc("bad BMP", "bad BMP"); + } + } else + return stbi__errpuc("bad BMP", "bad BMP"); + } + } else { + // V4/V5 header + int i; + if (hsz != 108 && hsz != 124) + return stbi__errpuc("bad BMP", "bad BMP"); + info->mr = stbi__get32le(s); + info->mg = stbi__get32le(s); + info->mb = stbi__get32le(s); + info->ma = stbi__get32le(s); + if (compress != + 3) // override mr/mg/mb unless in BI_BITFIELDS mode, as per docs + stbi__bmp_set_mask_defaults(info, compress); + stbi__get32le(s); // discard color space + for (i = 0; i < 12; ++i) + stbi__get32le(s); // discard color space parameters + if (hsz == 124) { + stbi__get32le(s); // discard rendering intent + stbi__get32le(s); // discard offset of profile data + stbi__get32le(s); // discard size of profile data + stbi__get32le(s); // discard reserved + } + } + } + return (void*)1; } +static void* stbi__bmp_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri) { + stbi_uc* out; + unsigned int mr = 0, mg = 0, mb = 0, ma = 0, all_a; + stbi_uc pal[256][4]; + int psize = 0, i, j, width; + int flip_vertically, pad, target; + stbi__bmp_data info; + STBI_NOTUSED(ri); -static void *stbi__bmp_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri) -{ - stbi_uc *out; - unsigned int mr=0,mg=0,mb=0,ma=0, all_a; - stbi_uc pal[256][4]; - int psize=0,i,j,width; - int flip_vertically, pad, target; - stbi__bmp_data info; - STBI_NOTUSED(ri); + info.all_a = 255; + if (stbi__bmp_parse_header(s, &info) == NULL) + return NULL; // error code already set - info.all_a = 255; - if (stbi__bmp_parse_header(s, &info) == NULL) - return NULL; // error code already set + flip_vertically = ((int)s->img_y) > 0; + s->img_y = abs((int)s->img_y); - flip_vertically = ((int) s->img_y) > 0; - s->img_y = abs((int) s->img_y); + if (s->img_y > STBI_MAX_DIMENSIONS) + return stbi__errpuc("too large", "Very large image (corrupt?)"); + if (s->img_x > STBI_MAX_DIMENSIONS) + return stbi__errpuc("too large", "Very large image (corrupt?)"); - if (s->img_y > STBI_MAX_DIMENSIONS) return stbi__errpuc("too large","Very large image (corrupt?)"); - if (s->img_x > STBI_MAX_DIMENSIONS) return stbi__errpuc("too large","Very large image (corrupt?)"); + mr = info.mr; + mg = info.mg; + mb = info.mb; + ma = info.ma; + all_a = info.all_a; - mr = info.mr; - mg = info.mg; - mb = info.mb; - ma = info.ma; - all_a = info.all_a; + if (info.hsz == 12) { + if (info.bpp < 24) + psize = (info.offset - info.extra_read - 24) / 3; + } else { + if (info.bpp < 16) + psize = (info.offset - info.extra_read - info.hsz) >> 2; + } + if (psize == 0) { + // accept some number of extra bytes after the header, but if the offset + // points either to before the header ends or implies a large amount of + // extra data, reject the file as malformed + int bytes_read_so_far = s->callback_already_read + + (int)(s->img_buffer - s->img_buffer_original); + int header_limit = + 1024; // max we actually read is below 256 bytes currently. + int extra_data_limit = + 256 * 4; // what ordinarily goes here is a palette; 256 entries*4 + // bytes is its max size. + if (bytes_read_so_far <= 0 || bytes_read_so_far > header_limit) { + return stbi__errpuc("bad header", "Corrupt BMP"); + } + // we established that bytes_read_so_far is positive and sensible. + // the first half of this test rejects offsets that are either too small + // positives, or negative, and guarantees that info.offset >= + // bytes_read_so_far > 0. this in turn ensures the number computed in + // the second half of the test can't overflow. + if (info.offset < bytes_read_so_far || + info.offset - bytes_read_so_far > extra_data_limit) { + return stbi__errpuc("bad offset", "Corrupt BMP"); + } else { + stbi__skip(s, info.offset - bytes_read_so_far); + } + } - if (info.hsz == 12) { - if (info.bpp < 24) - psize = (info.offset - info.extra_read - 24) / 3; - } else { - if (info.bpp < 16) - psize = (info.offset - info.extra_read - info.hsz) >> 2; - } - if (psize == 0) { - // accept some number of extra bytes after the header, but if the offset points either to before - // the header ends or implies a large amount of extra data, reject the file as malformed - int bytes_read_so_far = s->callback_already_read + (int)(s->img_buffer - s->img_buffer_original); - int header_limit = 1024; // max we actually read is below 256 bytes currently. - int extra_data_limit = 256*4; // what ordinarily goes here is a palette; 256 entries*4 bytes is its max size. - if (bytes_read_so_far <= 0 || bytes_read_so_far > header_limit) { - return stbi__errpuc("bad header", "Corrupt BMP"); - } - // we established that bytes_read_so_far is positive and sensible. - // the first half of this test rejects offsets that are either too small positives, or - // negative, and guarantees that info.offset >= bytes_read_so_far > 0. this in turn - // ensures the number computed in the second half of the test can't overflow. - if (info.offset < bytes_read_so_far || info.offset - bytes_read_so_far > extra_data_limit) { - return stbi__errpuc("bad offset", "Corrupt BMP"); - } else { - stbi__skip(s, info.offset - bytes_read_so_far); - } - } + if (info.bpp == 24 && ma == 0xff000000) + s->img_n = 3; + else + s->img_n = ma ? 4 : 3; + if (req_comp && req_comp >= 3) // we can directly decode 3 or 4 + target = req_comp; + else + target = s->img_n; // if they want monochrome, we'll post-convert - if (info.bpp == 24 && ma == 0xff000000) - s->img_n = 3; - else - s->img_n = ma ? 4 : 3; - if (req_comp && req_comp >= 3) // we can directly decode 3 or 4 - target = req_comp; - else - target = s->img_n; // if they want monochrome, we'll post-convert + // sanity-check size + if (!stbi__mad3sizes_valid(target, s->img_x, s->img_y, 0)) + return stbi__errpuc("too large", "Corrupt BMP"); - // sanity-check size - if (!stbi__mad3sizes_valid(target, s->img_x, s->img_y, 0)) - return stbi__errpuc("too large", "Corrupt BMP"); - - out = (stbi_uc *) stbi__malloc_mad3(target, s->img_x, s->img_y, 0); - if (!out) return stbi__errpuc("outofmem", "Out of memory"); - if (info.bpp < 16) { - int z=0; - if (psize == 0 || psize > 256) { STBI_FREE(out); return stbi__errpuc("invalid", "Corrupt BMP"); } - for (i=0; i < psize; ++i) { - pal[i][2] = stbi__get8(s); - pal[i][1] = stbi__get8(s); - pal[i][0] = stbi__get8(s); - if (info.hsz != 12) stbi__get8(s); - pal[i][3] = 255; - } - stbi__skip(s, info.offset - info.extra_read - info.hsz - psize * (info.hsz == 12 ? 3 : 4)); - if (info.bpp == 1) width = (s->img_x + 7) >> 3; - else if (info.bpp == 4) width = (s->img_x + 1) >> 1; - else if (info.bpp == 8) width = s->img_x; - else { STBI_FREE(out); return stbi__errpuc("bad bpp", "Corrupt BMP"); } - pad = (-width)&3; - if (info.bpp == 1) { - for (j=0; j < (int) s->img_y; ++j) { - int bit_offset = 7, v = stbi__get8(s); - for (i=0; i < (int) s->img_x; ++i) { - int color = (v>>bit_offset)&0x1; - out[z++] = pal[color][0]; - out[z++] = pal[color][1]; - out[z++] = pal[color][2]; - if (target == 4) out[z++] = 255; - if (i+1 == (int) s->img_x) break; - if((--bit_offset) < 0) { - bit_offset = 7; - v = stbi__get8(s); - } + out = (stbi_uc*)stbi__malloc_mad3(target, s->img_x, s->img_y, 0); + if (!out) + return stbi__errpuc("outofmem", "Out of memory"); + if (info.bpp < 16) { + int z = 0; + if (psize == 0 || psize > 256) { + STBI_FREE(out); + return stbi__errpuc("invalid", "Corrupt BMP"); + } + for (i = 0; i < psize; ++i) { + pal[i][2] = stbi__get8(s); + pal[i][1] = stbi__get8(s); + pal[i][0] = stbi__get8(s); + if (info.hsz != 12) + stbi__get8(s); + pal[i][3] = 255; + } + stbi__skip(s, info.offset - info.extra_read - info.hsz - + psize * (info.hsz == 12 ? 3 : 4)); + if (info.bpp == 1) + width = (s->img_x + 7) >> 3; + else if (info.bpp == 4) + width = (s->img_x + 1) >> 1; + else if (info.bpp == 8) + width = s->img_x; + else { + STBI_FREE(out); + return stbi__errpuc("bad bpp", "Corrupt BMP"); + } + pad = (-width) & 3; + if (info.bpp == 1) { + for (j = 0; j < (int)s->img_y; ++j) { + int bit_offset = 7, v = stbi__get8(s); + for (i = 0; i < (int)s->img_x; ++i) { + int color = (v >> bit_offset) & 0x1; + out[z++] = pal[color][0]; + out[z++] = pal[color][1]; + out[z++] = pal[color][2]; + if (target == 4) + out[z++] = 255; + if (i + 1 == (int)s->img_x) + break; + if ((--bit_offset) < 0) { + bit_offset = 7; + v = stbi__get8(s); + } + } + stbi__skip(s, pad); + } + } else { + for (j = 0; j < (int)s->img_y; ++j) { + for (i = 0; i < (int)s->img_x; i += 2) { + int v = stbi__get8(s), v2 = 0; + if (info.bpp == 4) { + v2 = v & 15; + v >>= 4; + } + out[z++] = pal[v][0]; + out[z++] = pal[v][1]; + out[z++] = pal[v][2]; + if (target == 4) + out[z++] = 255; + if (i + 1 == (int)s->img_x) + break; + v = (info.bpp == 8) ? stbi__get8(s) : v2; + out[z++] = pal[v][0]; + out[z++] = pal[v][1]; + out[z++] = pal[v][2]; + if (target == 4) + out[z++] = 255; + } + stbi__skip(s, pad); + } + } + } else { + int rshift = 0, gshift = 0, bshift = 0, ashift = 0, rcount = 0, + gcount = 0, bcount = 0, acount = 0; + int z = 0; + int easy = 0; + stbi__skip(s, info.offset - info.extra_read - info.hsz); + if (info.bpp == 24) + width = 3 * s->img_x; + else if (info.bpp == 16) + width = 2 * s->img_x; + else /* bpp = 32 and pad = 0 */ + width = 0; + pad = (-width) & 3; + if (info.bpp == 24) { + easy = 1; + } else if (info.bpp == 32) { + if (mb == 0xff && mg == 0xff00 && mr == 0x00ff0000 && + ma == 0xff000000) + easy = 2; + } + if (!easy) { + if (!mr || !mg || !mb) { + STBI_FREE(out); + return stbi__errpuc("bad masks", "Corrupt BMP"); + } + // right shift amt to put high bit in position #7 + rshift = stbi__high_bit(mr) - 7; + rcount = stbi__bitcount(mr); + gshift = stbi__high_bit(mg) - 7; + gcount = stbi__bitcount(mg); + bshift = stbi__high_bit(mb) - 7; + bcount = stbi__bitcount(mb); + ashift = stbi__high_bit(ma) - 7; + acount = stbi__bitcount(ma); + if (rcount > 8 || gcount > 8 || bcount > 8 || acount > 8) { + STBI_FREE(out); + return stbi__errpuc("bad masks", "Corrupt BMP"); + } + } + for (j = 0; j < (int)s->img_y; ++j) { + if (easy) { + for (i = 0; i < (int)s->img_x; ++i) { + unsigned char a; + out[z + 2] = stbi__get8(s); + out[z + 1] = stbi__get8(s); + out[z + 0] = stbi__get8(s); + z += 3; + a = (easy == 2 ? stbi__get8(s) : 255); + all_a |= a; + if (target == 4) + out[z++] = a; + } + } else { + int bpp = info.bpp; + for (i = 0; i < (int)s->img_x; ++i) { + stbi__uint32 v = (bpp == 16 ? (stbi__uint32)stbi__get16le(s) + : stbi__get32le(s)); + unsigned int a; + out[z++] = STBI__BYTECAST( + stbi__shiftsigned(v & mr, rshift, rcount)); + out[z++] = STBI__BYTECAST( + stbi__shiftsigned(v & mg, gshift, gcount)); + out[z++] = STBI__BYTECAST( + stbi__shiftsigned(v & mb, bshift, bcount)); + a = (ma ? stbi__shiftsigned(v & ma, ashift, acount) : 255); + all_a |= a; + if (target == 4) + out[z++] = STBI__BYTECAST(a); + } } stbi__skip(s, pad); - } - } else { - for (j=0; j < (int) s->img_y; ++j) { - for (i=0; i < (int) s->img_x; i += 2) { - int v=stbi__get8(s),v2=0; - if (info.bpp == 4) { - v2 = v & 15; - v >>= 4; - } - out[z++] = pal[v][0]; - out[z++] = pal[v][1]; - out[z++] = pal[v][2]; - if (target == 4) out[z++] = 255; - if (i+1 == (int) s->img_x) break; - v = (info.bpp == 8) ? stbi__get8(s) : v2; - out[z++] = pal[v][0]; - out[z++] = pal[v][1]; - out[z++] = pal[v][2]; - if (target == 4) out[z++] = 255; + } + } + + // if alpha channel is all 0s, replace with all 255s + if (target == 4 && all_a == 0) + for (i = 4 * s->img_x * s->img_y - 1; i >= 0; i -= 4) + out[i] = 255; + + if (flip_vertically) { + stbi_uc t; + for (j = 0; j < (int)s->img_y >> 1; ++j) { + stbi_uc* p1 = out + j * s->img_x * target; + stbi_uc* p2 = out + (s->img_y - 1 - j) * s->img_x * target; + for (i = 0; i < (int)s->img_x * target; ++i) { + t = p1[i]; + p1[i] = p2[i]; + p2[i] = t; } - stbi__skip(s, pad); - } - } - } else { - int rshift=0,gshift=0,bshift=0,ashift=0,rcount=0,gcount=0,bcount=0,acount=0; - int z = 0; - int easy=0; - stbi__skip(s, info.offset - info.extra_read - info.hsz); - if (info.bpp == 24) width = 3 * s->img_x; - else if (info.bpp == 16) width = 2*s->img_x; - else /* bpp = 32 and pad = 0 */ width=0; - pad = (-width) & 3; - if (info.bpp == 24) { - easy = 1; - } else if (info.bpp == 32) { - if (mb == 0xff && mg == 0xff00 && mr == 0x00ff0000 && ma == 0xff000000) - easy = 2; - } - if (!easy) { - if (!mr || !mg || !mb) { STBI_FREE(out); return stbi__errpuc("bad masks", "Corrupt BMP"); } - // right shift amt to put high bit in position #7 - rshift = stbi__high_bit(mr)-7; rcount = stbi__bitcount(mr); - gshift = stbi__high_bit(mg)-7; gcount = stbi__bitcount(mg); - bshift = stbi__high_bit(mb)-7; bcount = stbi__bitcount(mb); - ashift = stbi__high_bit(ma)-7; acount = stbi__bitcount(ma); - if (rcount > 8 || gcount > 8 || bcount > 8 || acount > 8) { STBI_FREE(out); return stbi__errpuc("bad masks", "Corrupt BMP"); } - } - for (j=0; j < (int) s->img_y; ++j) { - if (easy) { - for (i=0; i < (int) s->img_x; ++i) { - unsigned char a; - out[z+2] = stbi__get8(s); - out[z+1] = stbi__get8(s); - out[z+0] = stbi__get8(s); - z += 3; - a = (easy == 2 ? stbi__get8(s) : 255); - all_a |= a; - if (target == 4) out[z++] = a; - } - } else { - int bpp = info.bpp; - for (i=0; i < (int) s->img_x; ++i) { - stbi__uint32 v = (bpp == 16 ? (stbi__uint32) stbi__get16le(s) : stbi__get32le(s)); - unsigned int a; - out[z++] = STBI__BYTECAST(stbi__shiftsigned(v & mr, rshift, rcount)); - out[z++] = STBI__BYTECAST(stbi__shiftsigned(v & mg, gshift, gcount)); - out[z++] = STBI__BYTECAST(stbi__shiftsigned(v & mb, bshift, bcount)); - a = (ma ? stbi__shiftsigned(v & ma, ashift, acount) : 255); - all_a |= a; - if (target == 4) out[z++] = STBI__BYTECAST(a); - } - } - stbi__skip(s, pad); - } - } + } + } - // if alpha channel is all 0s, replace with all 255s - if (target == 4 && all_a == 0) - for (i=4*s->img_x*s->img_y-1; i >= 0; i -= 4) - out[i] = 255; + if (req_comp && req_comp != target) { + out = stbi__convert_format(out, target, req_comp, s->img_x, s->img_y); + if (out == NULL) + return out; // stbi__convert_format frees input on failure + } - if (flip_vertically) { - stbi_uc t; - for (j=0; j < (int) s->img_y>>1; ++j) { - stbi_uc *p1 = out + j *s->img_x*target; - stbi_uc *p2 = out + (s->img_y-1-j)*s->img_x*target; - for (i=0; i < (int) s->img_x*target; ++i) { - t = p1[i]; p1[i] = p2[i]; p2[i] = t; - } - } - } - - if (req_comp && req_comp != target) { - out = stbi__convert_format(out, target, req_comp, s->img_x, s->img_y); - if (out == NULL) return out; // stbi__convert_format frees input on failure - } - - *x = s->img_x; - *y = s->img_y; - if (comp) *comp = s->img_n; - return out; + *x = s->img_x; + *y = s->img_y; + if (comp) + *comp = s->img_n; + return out; } #endif @@ -5735,592 +6472,629 @@ static void *stbi__bmp_load(stbi__context *s, int *x, int *y, int *comp, int req // by Jonathan Dummer #ifndef STBI_NO_TGA // returns STBI_rgb or whatever, 0 on error -static int stbi__tga_get_comp(int bits_per_pixel, int is_grey, int* is_rgb16) -{ - // only RGB or RGBA (incl. 16bit) or grey allowed - if (is_rgb16) *is_rgb16 = 0; - switch(bits_per_pixel) { - case 8: return STBI_grey; - case 16: if(is_grey) return STBI_grey_alpha; - // fallthrough - case 15: if(is_rgb16) *is_rgb16 = 1; - return STBI_rgb; - case 24: // fallthrough - case 32: return bits_per_pixel/8; - default: return 0; - } +static int stbi__tga_get_comp(int bits_per_pixel, int is_grey, int* is_rgb16) { + // only RGB or RGBA (incl. 16bit) or grey allowed + if (is_rgb16) + *is_rgb16 = 0; + switch (bits_per_pixel) { + case 8: + return STBI_grey; + case 16: + if (is_grey) + return STBI_grey_alpha; + // fallthrough + case 15: + if (is_rgb16) + *is_rgb16 = 1; + return STBI_rgb; + case 24: // fallthrough + case 32: + return bits_per_pixel / 8; + default: + return 0; + } } -static int stbi__tga_info(stbi__context *s, int *x, int *y, int *comp) -{ - int tga_w, tga_h, tga_comp, tga_image_type, tga_bits_per_pixel, tga_colormap_bpp; +static int stbi__tga_info(stbi__context* s, int* x, int* y, int* comp) { + int tga_w, tga_h, tga_comp, tga_image_type, tga_bits_per_pixel, + tga_colormap_bpp; int sz, tga_colormap_type; - stbi__get8(s); // discard Offset + stbi__get8(s); // discard Offset tga_colormap_type = stbi__get8(s); // colormap type - if( tga_colormap_type > 1 ) { + if (tga_colormap_type > 1) { stbi__rewind(s); - return 0; // only RGB or indexed allowed + return 0; // only RGB or indexed allowed } tga_image_type = stbi__get8(s); // image type - if ( tga_colormap_type == 1 ) { // colormapped (paletted) image + if (tga_colormap_type == 1) { // colormapped (paletted) image if (tga_image_type != 1 && tga_image_type != 9) { stbi__rewind(s); return 0; } - stbi__skip(s,4); // skip index of first colormap entry and number of entries - sz = stbi__get8(s); // check bits per palette color entry - if ( (sz != 8) && (sz != 15) && (sz != 16) && (sz != 24) && (sz != 32) ) { + stbi__skip( + s, 4); // skip index of first colormap entry and number of entries + sz = stbi__get8(s); // check bits per palette color entry + if ((sz != 8) && (sz != 15) && (sz != 16) && (sz != 24) && (sz != 32)) { stbi__rewind(s); return 0; } - stbi__skip(s,4); // skip image x and y origin + stbi__skip(s, 4); // skip image x and y origin tga_colormap_bpp = sz; } else { // "normal" image w/o colormap - only RGB or grey allowed, +/- RLE - if ( (tga_image_type != 2) && (tga_image_type != 3) && (tga_image_type != 10) && (tga_image_type != 11) ) { + if ((tga_image_type != 2) && (tga_image_type != 3) && + (tga_image_type != 10) && (tga_image_type != 11)) { stbi__rewind(s); return 0; // only RGB or grey allowed, +/- RLE } - stbi__skip(s,9); // skip colormap specification and image x/y origin + stbi__skip(s, 9); // skip colormap specification and image x/y origin tga_colormap_bpp = 0; } tga_w = stbi__get16le(s); - if( tga_w < 1 ) { + if (tga_w < 1) { stbi__rewind(s); - return 0; // test width + return 0; // test width } tga_h = stbi__get16le(s); - if( tga_h < 1 ) { + if (tga_h < 1) { stbi__rewind(s); - return 0; // test height + return 0; // test height } tga_bits_per_pixel = stbi__get8(s); // bits per pixel - stbi__get8(s); // ignore alpha bits + stbi__get8(s); // ignore alpha bits if (tga_colormap_bpp != 0) { - if((tga_bits_per_pixel != 8) && (tga_bits_per_pixel != 16)) { - // when using a colormap, tga_bits_per_pixel is the size of the indexes - // I don't think anything but 8 or 16bit indexes makes sense + if ((tga_bits_per_pixel != 8) && (tga_bits_per_pixel != 16)) { + // when using a colormap, tga_bits_per_pixel is the size of the + // indexes I don't think anything but 8 or 16bit indexes makes sense stbi__rewind(s); return 0; } tga_comp = stbi__tga_get_comp(tga_colormap_bpp, 0, NULL); } else { - tga_comp = stbi__tga_get_comp(tga_bits_per_pixel, (tga_image_type == 3) || (tga_image_type == 11), NULL); + tga_comp = stbi__tga_get_comp( + tga_bits_per_pixel, (tga_image_type == 3) || (tga_image_type == 11), + NULL); } - if(!tga_comp) { - stbi__rewind(s); - return 0; + if (!tga_comp) { + stbi__rewind(s); + return 0; } - if (x) *x = tga_w; - if (y) *y = tga_h; - if (comp) *comp = tga_comp; - return 1; // seems to have passed everything + if (x) + *x = tga_w; + if (y) + *y = tga_h; + if (comp) + *comp = tga_comp; + return 1; // seems to have passed everything } -static int stbi__tga_test(stbi__context *s) -{ - int res = 0; - int sz, tga_color_type; - stbi__get8(s); // discard Offset - tga_color_type = stbi__get8(s); // color type - if ( tga_color_type > 1 ) goto errorEnd; // only RGB or indexed allowed - sz = stbi__get8(s); // image type - if ( tga_color_type == 1 ) { // colormapped (paletted) image - if (sz != 1 && sz != 9) goto errorEnd; // colortype 1 demands image type 1 or 9 - stbi__skip(s,4); // skip index of first colormap entry and number of entries - sz = stbi__get8(s); // check bits per palette color entry - if ( (sz != 8) && (sz != 15) && (sz != 16) && (sz != 24) && (sz != 32) ) goto errorEnd; - stbi__skip(s,4); // skip image x and y origin - } else { // "normal" image w/o colormap - if ( (sz != 2) && (sz != 3) && (sz != 10) && (sz != 11) ) goto errorEnd; // only RGB or grey allowed, +/- RLE - stbi__skip(s,9); // skip colormap specification and image x/y origin - } - if ( stbi__get16le(s) < 1 ) goto errorEnd; // test width - if ( stbi__get16le(s) < 1 ) goto errorEnd; // test height - sz = stbi__get8(s); // bits per pixel - if ( (tga_color_type == 1) && (sz != 8) && (sz != 16) ) goto errorEnd; // for colormapped images, bpp is size of an index - if ( (sz != 8) && (sz != 15) && (sz != 16) && (sz != 24) && (sz != 32) ) goto errorEnd; +static int stbi__tga_test(stbi__context* s) { + int res = 0; + int sz, tga_color_type; + stbi__get8(s); // discard Offset + tga_color_type = stbi__get8(s); // color type + if (tga_color_type > 1) + goto errorEnd; // only RGB or indexed allowed + sz = stbi__get8(s); // image type + if (tga_color_type == 1) { // colormapped (paletted) image + if (sz != 1 && sz != 9) + goto errorEnd; // colortype 1 demands image type 1 or 9 + stbi__skip( + s, 4); // skip index of first colormap entry and number of entries + sz = stbi__get8(s); // check bits per palette color entry + if ((sz != 8) && (sz != 15) && (sz != 16) && (sz != 24) && (sz != 32)) + goto errorEnd; + stbi__skip(s, 4); // skip image x and y origin + } else { // "normal" image w/o colormap + if ((sz != 2) && (sz != 3) && (sz != 10) && (sz != 11)) + goto errorEnd; // only RGB or grey allowed, +/- RLE + stbi__skip(s, 9); // skip colormap specification and image x/y origin + } + if (stbi__get16le(s) < 1) + goto errorEnd; // test width + if (stbi__get16le(s) < 1) + goto errorEnd; // test height + sz = stbi__get8(s); // bits per pixel + if ((tga_color_type == 1) && (sz != 8) && (sz != 16)) + goto errorEnd; // for colormapped images, bpp is size of an index + if ((sz != 8) && (sz != 15) && (sz != 16) && (sz != 24) && (sz != 32)) + goto errorEnd; - res = 1; // if we got this far, everything's good and we can return 1 instead of 0 + res = 1; // if we got this far, everything's good and we can return 1 + // instead of 0 errorEnd: - stbi__rewind(s); - return res; + stbi__rewind(s); + return res; } // read 16bit value and convert to 24bit RGB -static void stbi__tga_read_rgb16(stbi__context *s, stbi_uc* out) -{ - stbi__uint16 px = (stbi__uint16)stbi__get16le(s); - stbi__uint16 fiveBitMask = 31; - // we have 3 channels with 5bits each - int r = (px >> 10) & fiveBitMask; - int g = (px >> 5) & fiveBitMask; - int b = px & fiveBitMask; - // Note that this saves the data in RGB(A) order, so it doesn't need to be swapped later - out[0] = (stbi_uc)((r * 255)/31); - out[1] = (stbi_uc)((g * 255)/31); - out[2] = (stbi_uc)((b * 255)/31); +static void stbi__tga_read_rgb16(stbi__context* s, stbi_uc* out) { + stbi__uint16 px = (stbi__uint16)stbi__get16le(s); + stbi__uint16 fiveBitMask = 31; + // we have 3 channels with 5bits each + int r = (px >> 10) & fiveBitMask; + int g = (px >> 5) & fiveBitMask; + int b = px & fiveBitMask; + // Note that this saves the data in RGB(A) order, so it doesn't need to be + // swapped later + out[0] = (stbi_uc)((r * 255) / 31); + out[1] = (stbi_uc)((g * 255) / 31); + out[2] = (stbi_uc)((b * 255) / 31); - // some people claim that the most significant bit might be used for alpha - // (possibly if an alpha-bit is set in the "image descriptor byte") - // but that only made 16bit test images completely translucent.. - // so let's treat all 15 and 16bit TGAs as RGB with no alpha. + // some people claim that the most significant bit might be used for alpha + // (possibly if an alpha-bit is set in the "image descriptor byte") + // but that only made 16bit test images completely translucent.. + // so let's treat all 15 and 16bit TGAs as RGB with no alpha. } -static void *stbi__tga_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri) -{ - // read in the TGA header stuff - int tga_offset = stbi__get8(s); - int tga_indexed = stbi__get8(s); - int tga_image_type = stbi__get8(s); - int tga_is_RLE = 0; - int tga_palette_start = stbi__get16le(s); - int tga_palette_len = stbi__get16le(s); - int tga_palette_bits = stbi__get8(s); - int tga_x_origin = stbi__get16le(s); - int tga_y_origin = stbi__get16le(s); - int tga_width = stbi__get16le(s); - int tga_height = stbi__get16le(s); - int tga_bits_per_pixel = stbi__get8(s); - int tga_comp, tga_rgb16=0; - int tga_inverted = stbi__get8(s); - // int tga_alpha_bits = tga_inverted & 15; // the 4 lowest bits - unused (useless?) - // image data - unsigned char *tga_data; - unsigned char *tga_palette = NULL; - int i, j; - unsigned char raw_data[4] = {0}; - int RLE_count = 0; - int RLE_repeating = 0; - int read_next_pixel = 1; - STBI_NOTUSED(ri); - STBI_NOTUSED(tga_x_origin); // @TODO - STBI_NOTUSED(tga_y_origin); // @TODO +static void* stbi__tga_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri) { + // read in the TGA header stuff + int tga_offset = stbi__get8(s); + int tga_indexed = stbi__get8(s); + int tga_image_type = stbi__get8(s); + int tga_is_RLE = 0; + int tga_palette_start = stbi__get16le(s); + int tga_palette_len = stbi__get16le(s); + int tga_palette_bits = stbi__get8(s); + int tga_x_origin = stbi__get16le(s); + int tga_y_origin = stbi__get16le(s); + int tga_width = stbi__get16le(s); + int tga_height = stbi__get16le(s); + int tga_bits_per_pixel = stbi__get8(s); + int tga_comp, tga_rgb16 = 0; + int tga_inverted = stbi__get8(s); + // int tga_alpha_bits = tga_inverted & 15; // the 4 lowest bits - unused + // (useless?) + // image data + unsigned char* tga_data; + unsigned char* tga_palette = NULL; + int i, j; + unsigned char raw_data[4] = {0}; + int RLE_count = 0; + int RLE_repeating = 0; + int read_next_pixel = 1; + STBI_NOTUSED(ri); + STBI_NOTUSED(tga_x_origin); // @TODO + STBI_NOTUSED(tga_y_origin); // @TODO - if (tga_height > STBI_MAX_DIMENSIONS) return stbi__errpuc("too large","Very large image (corrupt?)"); - if (tga_width > STBI_MAX_DIMENSIONS) return stbi__errpuc("too large","Very large image (corrupt?)"); + if (tga_height > STBI_MAX_DIMENSIONS) + return stbi__errpuc("too large", "Very large image (corrupt?)"); + if (tga_width > STBI_MAX_DIMENSIONS) + return stbi__errpuc("too large", "Very large image (corrupt?)"); - // do a tiny bit of precessing - if ( tga_image_type >= 8 ) - { - tga_image_type -= 8; - tga_is_RLE = 1; - } - tga_inverted = 1 - ((tga_inverted >> 5) & 1); + // do a tiny bit of precessing + if (tga_image_type >= 8) { + tga_image_type -= 8; + tga_is_RLE = 1; + } + tga_inverted = 1 - ((tga_inverted >> 5) & 1); - // If I'm paletted, then I'll use the number of bits from the palette - if ( tga_indexed ) tga_comp = stbi__tga_get_comp(tga_palette_bits, 0, &tga_rgb16); - else tga_comp = stbi__tga_get_comp(tga_bits_per_pixel, (tga_image_type == 3), &tga_rgb16); + // If I'm paletted, then I'll use the number of bits from the palette + if (tga_indexed) + tga_comp = stbi__tga_get_comp(tga_palette_bits, 0, &tga_rgb16); + else + tga_comp = stbi__tga_get_comp(tga_bits_per_pixel, (tga_image_type == 3), + &tga_rgb16); - if(!tga_comp) // shouldn't really happen, stbi__tga_test() should have ensured basic consistency - return stbi__errpuc("bad format", "Can't find out TGA pixelformat"); + if (!tga_comp) // shouldn't really happen, stbi__tga_test() should have + // ensured basic consistency + return stbi__errpuc("bad format", "Can't find out TGA pixelformat"); - // tga info - *x = tga_width; - *y = tga_height; - if (comp) *comp = tga_comp; + // tga info + *x = tga_width; + *y = tga_height; + if (comp) + *comp = tga_comp; - if (!stbi__mad3sizes_valid(tga_width, tga_height, tga_comp, 0)) - return stbi__errpuc("too large", "Corrupt TGA"); + if (!stbi__mad3sizes_valid(tga_width, tga_height, tga_comp, 0)) + return stbi__errpuc("too large", "Corrupt TGA"); - tga_data = (unsigned char*)stbi__malloc_mad3(tga_width, tga_height, tga_comp, 0); - if (!tga_data) return stbi__errpuc("outofmem", "Out of memory"); + tga_data = + (unsigned char*)stbi__malloc_mad3(tga_width, tga_height, tga_comp, 0); + if (!tga_data) + return stbi__errpuc("outofmem", "Out of memory"); - // skip to the data's starting position (offset usually = 0) - stbi__skip(s, tga_offset ); + // skip to the data's starting position (offset usually = 0) + stbi__skip(s, tga_offset); - if ( !tga_indexed && !tga_is_RLE && !tga_rgb16 ) { - for (i=0; i < tga_height; ++i) { - int row = tga_inverted ? tga_height -i - 1 : i; - stbi_uc *tga_row = tga_data + row*tga_width*tga_comp; - stbi__getn(s, tga_row, tga_width * tga_comp); - } - } else { - // do I need to load a palette? - if ( tga_indexed) - { - if (tga_palette_len == 0) { /* you have to have at least one entry! */ - STBI_FREE(tga_data); - return stbi__errpuc("bad palette", "Corrupt TGA"); - } - - // any data to skip? (offset usually = 0) - stbi__skip(s, tga_palette_start ); - // load the palette - tga_palette = (unsigned char*)stbi__malloc_mad2(tga_palette_len, tga_comp, 0); - if (!tga_palette) { - STBI_FREE(tga_data); - return stbi__errpuc("outofmem", "Out of memory"); - } - if (tga_rgb16) { - stbi_uc *pal_entry = tga_palette; - STBI_ASSERT(tga_comp == STBI_rgb); - for (i=0; i < tga_palette_len; ++i) { - stbi__tga_read_rgb16(s, pal_entry); - pal_entry += tga_comp; + if (!tga_indexed && !tga_is_RLE && !tga_rgb16) { + for (i = 0; i < tga_height; ++i) { + int row = tga_inverted ? tga_height - i - 1 : i; + stbi_uc* tga_row = tga_data + row * tga_width * tga_comp; + stbi__getn(s, tga_row, tga_width * tga_comp); + } + } else { + // do I need to load a palette? + if (tga_indexed) { + if (tga_palette_len == + 0) { /* you have to have at least one entry! */ + STBI_FREE(tga_data); + return stbi__errpuc("bad palette", "Corrupt TGA"); } - } else if (!stbi__getn(s, tga_palette, tga_palette_len * tga_comp)) { - STBI_FREE(tga_data); - STBI_FREE(tga_palette); - return stbi__errpuc("bad palette", "Corrupt TGA"); - } - } - // load the data - for (i=0; i < tga_width * tga_height; ++i) - { - // if I'm in RLE mode, do I need to get a RLE stbi__pngchunk? - if ( tga_is_RLE ) - { - if ( RLE_count == 0 ) - { - // yep, get the next byte as a RLE command - int RLE_cmd = stbi__get8(s); - RLE_count = 1 + (RLE_cmd & 127); - RLE_repeating = RLE_cmd >> 7; - read_next_pixel = 1; - } else if ( !RLE_repeating ) - { - read_next_pixel = 1; + + // any data to skip? (offset usually = 0) + stbi__skip(s, tga_palette_start); + // load the palette + tga_palette = + (unsigned char*)stbi__malloc_mad2(tga_palette_len, tga_comp, 0); + if (!tga_palette) { + STBI_FREE(tga_data); + return stbi__errpuc("outofmem", "Out of memory"); } - } else - { - read_next_pixel = 1; - } - // OK, if I need to read a pixel, do it now - if ( read_next_pixel ) - { - // load however much data we did have - if ( tga_indexed ) - { - // read in index, then perform the lookup - int pal_idx = (tga_bits_per_pixel == 8) ? stbi__get8(s) : stbi__get16le(s); - if ( pal_idx >= tga_palette_len ) { - // invalid index - pal_idx = 0; - } - pal_idx *= tga_comp; - for (j = 0; j < tga_comp; ++j) { - raw_data[j] = tga_palette[pal_idx+j]; - } - } else if(tga_rgb16) { - STBI_ASSERT(tga_comp == STBI_rgb); - stbi__tga_read_rgb16(s, raw_data); + if (tga_rgb16) { + stbi_uc* pal_entry = tga_palette; + STBI_ASSERT(tga_comp == STBI_rgb); + for (i = 0; i < tga_palette_len; ++i) { + stbi__tga_read_rgb16(s, pal_entry); + pal_entry += tga_comp; + } + } else if (!stbi__getn(s, tga_palette, + tga_palette_len * tga_comp)) { + STBI_FREE(tga_data); + STBI_FREE(tga_palette); + return stbi__errpuc("bad palette", "Corrupt TGA"); + } + } + // load the data + for (i = 0; i < tga_width * tga_height; ++i) { + // if I'm in RLE mode, do I need to get a RLE stbi__pngchunk? + if (tga_is_RLE) { + if (RLE_count == 0) { + // yep, get the next byte as a RLE command + int RLE_cmd = stbi__get8(s); + RLE_count = 1 + (RLE_cmd & 127); + RLE_repeating = RLE_cmd >> 7; + read_next_pixel = 1; + } else if (!RLE_repeating) { + read_next_pixel = 1; + } } else { - // read in the data raw - for (j = 0; j < tga_comp; ++j) { - raw_data[j] = stbi__get8(s); - } + read_next_pixel = 1; } - // clear the reading flag for the next pixel - read_next_pixel = 0; - } // end of reading a pixel + // OK, if I need to read a pixel, do it now + if (read_next_pixel) { + // load however much data we did have + if (tga_indexed) { + // read in index, then perform the lookup + int pal_idx = (tga_bits_per_pixel == 8) ? stbi__get8(s) + : stbi__get16le(s); + if (pal_idx >= tga_palette_len) { + // invalid index + pal_idx = 0; + } + pal_idx *= tga_comp; + for (j = 0; j < tga_comp; ++j) { + raw_data[j] = tga_palette[pal_idx + j]; + } + } else if (tga_rgb16) { + STBI_ASSERT(tga_comp == STBI_rgb); + stbi__tga_read_rgb16(s, raw_data); + } else { + // read in the data raw + for (j = 0; j < tga_comp; ++j) { + raw_data[j] = stbi__get8(s); + } + } + // clear the reading flag for the next pixel + read_next_pixel = 0; + } // end of reading a pixel - // copy data - for (j = 0; j < tga_comp; ++j) - tga_data[i*tga_comp+j] = raw_data[j]; + // copy data + for (j = 0; j < tga_comp; ++j) + tga_data[i * tga_comp + j] = raw_data[j]; - // in case we're in RLE mode, keep counting down - --RLE_count; - } - // do I need to invert the image? - if ( tga_inverted ) - { - for (j = 0; j*2 < tga_height; ++j) - { - int index1 = j * tga_width * tga_comp; - int index2 = (tga_height - 1 - j) * tga_width * tga_comp; - for (i = tga_width * tga_comp; i > 0; --i) - { - unsigned char temp = tga_data[index1]; - tga_data[index1] = tga_data[index2]; - tga_data[index2] = temp; - ++index1; - ++index2; + // in case we're in RLE mode, keep counting down + --RLE_count; + } + // do I need to invert the image? + if (tga_inverted) { + for (j = 0; j * 2 < tga_height; ++j) { + int index1 = j * tga_width * tga_comp; + int index2 = (tga_height - 1 - j) * tga_width * tga_comp; + for (i = tga_width * tga_comp; i > 0; --i) { + unsigned char temp = tga_data[index1]; + tga_data[index1] = tga_data[index2]; + tga_data[index2] = temp; + ++index1; + ++index2; + } } - } - } - // clear my palette, if I had one - if ( tga_palette != NULL ) - { - STBI_FREE( tga_palette ); - } - } + } + // clear my palette, if I had one + if (tga_palette != NULL) { + STBI_FREE(tga_palette); + } + } - // swap RGB - if the source data was RGB16, it already is in the right order - if (tga_comp >= 3 && !tga_rgb16) - { - unsigned char* tga_pixel = tga_data; - for (i=0; i < tga_width * tga_height; ++i) - { - unsigned char temp = tga_pixel[0]; - tga_pixel[0] = tga_pixel[2]; - tga_pixel[2] = temp; - tga_pixel += tga_comp; - } - } + // swap RGB - if the source data was RGB16, it already is in the right order + if (tga_comp >= 3 && !tga_rgb16) { + unsigned char* tga_pixel = tga_data; + for (i = 0; i < tga_width * tga_height; ++i) { + unsigned char temp = tga_pixel[0]; + tga_pixel[0] = tga_pixel[2]; + tga_pixel[2] = temp; + tga_pixel += tga_comp; + } + } - // convert to target component count - if (req_comp && req_comp != tga_comp) - tga_data = stbi__convert_format(tga_data, tga_comp, req_comp, tga_width, tga_height); + // convert to target component count + if (req_comp && req_comp != tga_comp) + tga_data = stbi__convert_format(tga_data, tga_comp, req_comp, tga_width, + tga_height); - // the things I do to get rid of an error message, and yet keep - // Microsoft's C compilers happy... [8^( - tga_palette_start = tga_palette_len = tga_palette_bits = - tga_x_origin = tga_y_origin = 0; - STBI_NOTUSED(tga_palette_start); - // OK, done - return tga_data; + // the things I do to get rid of an error message, and yet keep + // Microsoft's C compilers happy... [8^( + tga_palette_start = tga_palette_len = tga_palette_bits = tga_x_origin = + tga_y_origin = 0; + STBI_NOTUSED(tga_palette_start); + // OK, done + return tga_data; } #endif // ************************************************************************************************* -// Photoshop PSD loader -- PD by Thatcher Ulrich, integration by Nicolas Schulz, tweaked by STB +// Photoshop PSD loader -- PD by Thatcher Ulrich, integration by Nicolas Schulz, +// tweaked by STB #ifndef STBI_NO_PSD -static int stbi__psd_test(stbi__context *s) -{ - int r = (stbi__get32be(s) == 0x38425053); - stbi__rewind(s); - return r; +static int stbi__psd_test(stbi__context* s) { + int r = (stbi__get32be(s) == 0x38425053); + stbi__rewind(s); + return r; } -static int stbi__psd_decode_rle(stbi__context *s, stbi_uc *p, int pixelCount) -{ - int count, nleft, len; +static int stbi__psd_decode_rle(stbi__context* s, stbi_uc* p, int pixelCount) { + int count, nleft, len; - count = 0; - while ((nleft = pixelCount - count) > 0) { - len = stbi__get8(s); - if (len == 128) { - // No-op. - } else if (len < 128) { - // Copy next len+1 bytes literally. - len++; - if (len > nleft) return 0; // corrupt data - count += len; - while (len) { - *p = stbi__get8(s); - p += 4; - len--; - } - } else if (len > 128) { - stbi_uc val; - // Next -len+1 bytes in the dest are replicated from next source byte. - // (Interpret len as a negative 8-bit int.) - len = 257 - len; - if (len > nleft) return 0; // corrupt data - val = stbi__get8(s); - count += len; - while (len) { - *p = val; - p += 4; - len--; - } - } - } + count = 0; + while ((nleft = pixelCount - count) > 0) { + len = stbi__get8(s); + if (len == 128) { + // No-op. + } else if (len < 128) { + // Copy next len+1 bytes literally. + len++; + if (len > nleft) + return 0; // corrupt data + count += len; + while (len) { + *p = stbi__get8(s); + p += 4; + len--; + } + } else if (len > 128) { + stbi_uc val; + // Next -len+1 bytes in the dest are replicated from next source + // byte. (Interpret len as a negative 8-bit int.) + len = 257 - len; + if (len > nleft) + return 0; // corrupt data + val = stbi__get8(s); + count += len; + while (len) { + *p = val; + p += 4; + len--; + } + } + } - return 1; + return 1; } -static void *stbi__psd_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri, int bpc) -{ - int pixelCount; - int channelCount, compression; - int channel, i; - int bitdepth; - int w,h; - stbi_uc *out; - STBI_NOTUSED(ri); +static void* stbi__psd_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri, int bpc) { + int pixelCount; + int channelCount, compression; + int channel, i; + int bitdepth; + int w, h; + stbi_uc* out; + STBI_NOTUSED(ri); - // Check identifier - if (stbi__get32be(s) != 0x38425053) // "8BPS" - return stbi__errpuc("not PSD", "Corrupt PSD image"); + // Check identifier + if (stbi__get32be(s) != 0x38425053) // "8BPS" + return stbi__errpuc("not PSD", "Corrupt PSD image"); - // Check file type version. - if (stbi__get16be(s) != 1) - return stbi__errpuc("wrong version", "Unsupported version of PSD image"); + // Check file type version. + if (stbi__get16be(s) != 1) + return stbi__errpuc("wrong version", + "Unsupported version of PSD image"); - // Skip 6 reserved bytes. - stbi__skip(s, 6 ); + // Skip 6 reserved bytes. + stbi__skip(s, 6); - // Read the number of channels (R, G, B, A, etc). - channelCount = stbi__get16be(s); - if (channelCount < 0 || channelCount > 16) - return stbi__errpuc("wrong channel count", "Unsupported number of channels in PSD image"); + // Read the number of channels (R, G, B, A, etc). + channelCount = stbi__get16be(s); + if (channelCount < 0 || channelCount > 16) + return stbi__errpuc("wrong channel count", + "Unsupported number of channels in PSD image"); - // Read the rows and columns of the image. - h = stbi__get32be(s); - w = stbi__get32be(s); + // Read the rows and columns of the image. + h = stbi__get32be(s); + w = stbi__get32be(s); - if (h > STBI_MAX_DIMENSIONS) return stbi__errpuc("too large","Very large image (corrupt?)"); - if (w > STBI_MAX_DIMENSIONS) return stbi__errpuc("too large","Very large image (corrupt?)"); + if (h > STBI_MAX_DIMENSIONS) + return stbi__errpuc("too large", "Very large image (corrupt?)"); + if (w > STBI_MAX_DIMENSIONS) + return stbi__errpuc("too large", "Very large image (corrupt?)"); - // Make sure the depth is 8 bits. - bitdepth = stbi__get16be(s); - if (bitdepth != 8 && bitdepth != 16) - return stbi__errpuc("unsupported bit depth", "PSD bit depth is not 8 or 16 bit"); + // Make sure the depth is 8 bits. + bitdepth = stbi__get16be(s); + if (bitdepth != 8 && bitdepth != 16) + return stbi__errpuc("unsupported bit depth", + "PSD bit depth is not 8 or 16 bit"); - // Make sure the color mode is RGB. - // Valid options are: - // 0: Bitmap - // 1: Grayscale - // 2: Indexed color - // 3: RGB color - // 4: CMYK color - // 7: Multichannel - // 8: Duotone - // 9: Lab color - if (stbi__get16be(s) != 3) - return stbi__errpuc("wrong color format", "PSD is not in RGB color format"); + // Make sure the color mode is RGB. + // Valid options are: + // 0: Bitmap + // 1: Grayscale + // 2: Indexed color + // 3: RGB color + // 4: CMYK color + // 7: Multichannel + // 8: Duotone + // 9: Lab color + if (stbi__get16be(s) != 3) + return stbi__errpuc("wrong color format", + "PSD is not in RGB color format"); - // Skip the Mode Data. (It's the palette for indexed color; other info for other modes.) - stbi__skip(s,stbi__get32be(s) ); + // Skip the Mode Data. (It's the palette for indexed color; other info for + // other modes.) + stbi__skip(s, stbi__get32be(s)); - // Skip the image resources. (resolution, pen tool paths, etc) - stbi__skip(s, stbi__get32be(s) ); + // Skip the image resources. (resolution, pen tool paths, etc) + stbi__skip(s, stbi__get32be(s)); - // Skip the reserved data. - stbi__skip(s, stbi__get32be(s) ); + // Skip the reserved data. + stbi__skip(s, stbi__get32be(s)); - // Find out if the data is compressed. - // Known values: - // 0: no compression - // 1: RLE compressed - compression = stbi__get16be(s); - if (compression > 1) - return stbi__errpuc("bad compression", "PSD has an unknown compression format"); + // Find out if the data is compressed. + // Known values: + // 0: no compression + // 1: RLE compressed + compression = stbi__get16be(s); + if (compression > 1) + return stbi__errpuc("bad compression", + "PSD has an unknown compression format"); - // Check size - if (!stbi__mad3sizes_valid(4, w, h, 0)) - return stbi__errpuc("too large", "Corrupt PSD"); + // Check size + if (!stbi__mad3sizes_valid(4, w, h, 0)) + return stbi__errpuc("too large", "Corrupt PSD"); - // Create the destination image. + // Create the destination image. - if (!compression && bitdepth == 16 && bpc == 16) { - out = (stbi_uc *) stbi__malloc_mad3(8, w, h, 0); - ri->bits_per_channel = 16; - } else - out = (stbi_uc *) stbi__malloc(4 * w*h); + if (!compression && bitdepth == 16 && bpc == 16) { + out = (stbi_uc*)stbi__malloc_mad3(8, w, h, 0); + ri->bits_per_channel = 16; + } else + out = (stbi_uc*)stbi__malloc(4 * w * h); - if (!out) return stbi__errpuc("outofmem", "Out of memory"); - pixelCount = w*h; + if (!out) + return stbi__errpuc("outofmem", "Out of memory"); + pixelCount = w * h; - // Initialize the data to zero. - //memset( out, 0, pixelCount * 4 ); + // Initialize the data to zero. + // memset( out, 0, pixelCount * 4 ); - // Finally, the image data. - if (compression) { - // RLE as used by .PSD and .TIFF - // Loop until you get the number of unpacked bytes you are expecting: - // Read the next source byte into n. - // If n is between 0 and 127 inclusive, copy the next n+1 bytes literally. - // Else if n is between -127 and -1 inclusive, copy the next byte -n+1 times. - // Else if n is 128, noop. - // Endloop + // Finally, the image data. + if (compression) { + // RLE as used by .PSD and .TIFF + // Loop until you get the number of unpacked bytes you are expecting: + // Read the next source byte into n. + // If n is between 0 and 127 inclusive, copy the next n+1 bytes + // literally. Else if n is between -127 and -1 inclusive, copy the + // next byte -n+1 times. Else if n is 128, noop. + // Endloop - // The RLE-compressed data is preceded by a 2-byte data count for each row in the data, - // which we're going to just skip. - stbi__skip(s, h * channelCount * 2 ); + // The RLE-compressed data is preceded by a 2-byte data count for each + // row in the data, which we're going to just skip. + stbi__skip(s, h * channelCount * 2); - // Read the RLE data by channel. - for (channel = 0; channel < 4; channel++) { - stbi_uc *p; + // Read the RLE data by channel. + for (channel = 0; channel < 4; channel++) { + stbi_uc* p; - p = out+channel; - if (channel >= channelCount) { - // Fill this channel with default data. - for (i = 0; i < pixelCount; i++, p += 4) - *p = (channel == 3 ? 255 : 0); - } else { - // Read the RLE data. - if (!stbi__psd_decode_rle(s, p, pixelCount)) { - STBI_FREE(out); - return stbi__errpuc("corrupt", "bad RLE data"); - } - } - } - - } else { - // We're at the raw image data. It's each channel in order (Red, Green, Blue, Alpha, ...) - // where each channel consists of an 8-bit (or 16-bit) value for each pixel in the image. - - // Read the data by channel. - for (channel = 0; channel < 4; channel++) { - if (channel >= channelCount) { - // Fill this channel with default data. - if (bitdepth == 16 && bpc == 16) { - stbi__uint16 *q = ((stbi__uint16 *) out) + channel; - stbi__uint16 val = channel == 3 ? 65535 : 0; - for (i = 0; i < pixelCount; i++, q += 4) - *q = val; + p = out + channel; + if (channel >= channelCount) { + // Fill this channel with default data. + for (i = 0; i < pixelCount; i++, p += 4) + *p = (channel == 3 ? 255 : 0); } else { - stbi_uc *p = out+channel; - stbi_uc val = channel == 3 ? 255 : 0; - for (i = 0; i < pixelCount; i++, p += 4) - *p = val; + // Read the RLE data. + if (!stbi__psd_decode_rle(s, p, pixelCount)) { + STBI_FREE(out); + return stbi__errpuc("corrupt", "bad RLE data"); + } } - } else { - if (ri->bits_per_channel == 16) { // output bpc - stbi__uint16 *q = ((stbi__uint16 *) out) + channel; - for (i = 0; i < pixelCount; i++, q += 4) - *q = (stbi__uint16) stbi__get16be(s); + } + + } else { + // We're at the raw image data. It's each channel in order (Red, Green, + // Blue, Alpha, ...) where each channel consists of an 8-bit (or 16-bit) + // value for each pixel in the image. + + // Read the data by channel. + for (channel = 0; channel < 4; channel++) { + if (channel >= channelCount) { + // Fill this channel with default data. + if (bitdepth == 16 && bpc == 16) { + stbi__uint16* q = ((stbi__uint16*)out) + channel; + stbi__uint16 val = channel == 3 ? 65535 : 0; + for (i = 0; i < pixelCount; i++, q += 4) + *q = val; + } else { + stbi_uc* p = out + channel; + stbi_uc val = channel == 3 ? 255 : 0; + for (i = 0; i < pixelCount; i++, p += 4) + *p = val; + } } else { - stbi_uc *p = out+channel; - if (bitdepth == 16) { // input bpc - for (i = 0; i < pixelCount; i++, p += 4) - *p = (stbi_uc) (stbi__get16be(s) >> 8); - } else { - for (i = 0; i < pixelCount; i++, p += 4) - *p = stbi__get8(s); - } + if (ri->bits_per_channel == 16) { // output bpc + stbi__uint16* q = ((stbi__uint16*)out) + channel; + for (i = 0; i < pixelCount; i++, q += 4) + *q = (stbi__uint16)stbi__get16be(s); + } else { + stbi_uc* p = out + channel; + if (bitdepth == 16) { // input bpc + for (i = 0; i < pixelCount; i++, p += 4) + *p = (stbi_uc)(stbi__get16be(s) >> 8); + } else { + for (i = 0; i < pixelCount; i++, p += 4) + *p = stbi__get8(s); + } + } } - } - } - } + } + } - // remove weird white matte from PSD - if (channelCount >= 4) { - if (ri->bits_per_channel == 16) { - for (i=0; i < w*h; ++i) { - stbi__uint16 *pixel = (stbi__uint16 *) out + 4*i; - if (pixel[3] != 0 && pixel[3] != 65535) { - float a = pixel[3] / 65535.0f; - float ra = 1.0f / a; - float inv_a = 65535.0f * (1 - ra); - pixel[0] = (stbi__uint16) (pixel[0]*ra + inv_a); - pixel[1] = (stbi__uint16) (pixel[1]*ra + inv_a); - pixel[2] = (stbi__uint16) (pixel[2]*ra + inv_a); + // remove weird white matte from PSD + if (channelCount >= 4) { + if (ri->bits_per_channel == 16) { + for (i = 0; i < w * h; ++i) { + stbi__uint16* pixel = (stbi__uint16*)out + 4 * i; + if (pixel[3] != 0 && pixel[3] != 65535) { + float a = pixel[3] / 65535.0f; + float ra = 1.0f / a; + float inv_a = 65535.0f * (1 - ra); + pixel[0] = (stbi__uint16)(pixel[0] * ra + inv_a); + pixel[1] = (stbi__uint16)(pixel[1] * ra + inv_a); + pixel[2] = (stbi__uint16)(pixel[2] * ra + inv_a); + } } - } - } else { - for (i=0; i < w*h; ++i) { - unsigned char *pixel = out + 4*i; - if (pixel[3] != 0 && pixel[3] != 255) { - float a = pixel[3] / 255.0f; - float ra = 1.0f / a; - float inv_a = 255.0f * (1 - ra); - pixel[0] = (unsigned char) (pixel[0]*ra + inv_a); - pixel[1] = (unsigned char) (pixel[1]*ra + inv_a); - pixel[2] = (unsigned char) (pixel[2]*ra + inv_a); + } else { + for (i = 0; i < w * h; ++i) { + unsigned char* pixel = out + 4 * i; + if (pixel[3] != 0 && pixel[3] != 255) { + float a = pixel[3] / 255.0f; + float ra = 1.0f / a; + float inv_a = 255.0f * (1 - ra); + pixel[0] = (unsigned char)(pixel[0] * ra + inv_a); + pixel[1] = (unsigned char)(pixel[1] * ra + inv_a); + pixel[2] = (unsigned char)(pixel[2] * ra + inv_a); + } } - } - } - } + } + } - // convert to desired output format - if (req_comp && req_comp != 4) { - if (ri->bits_per_channel == 16) - out = (stbi_uc *) stbi__convert_format16((stbi__uint16 *) out, 4, req_comp, w, h); - else - out = stbi__convert_format(out, 4, req_comp, w, h); - if (out == NULL) return out; // stbi__convert_format frees input on failure - } + // convert to desired output format + if (req_comp && req_comp != 4) { + if (ri->bits_per_channel == 16) + out = (stbi_uc*)stbi__convert_format16((stbi__uint16*)out, 4, + req_comp, w, h); + else + out = stbi__convert_format(out, 4, req_comp, w, h); + if (out == NULL) + return out; // stbi__convert_format frees input on failure + } - if (comp) *comp = 4; - *y = h; - *x = w; + if (comp) + *comp = 4; + *y = h; + *x = w; - return out; + return out; } #endif @@ -6332,216 +7106,226 @@ static void *stbi__psd_load(stbi__context *s, int *x, int *y, int *comp, int req // See http://ozviz.wasp.uwa.edu.au/~pbourke/dataformats/softimagepic/ #ifndef STBI_NO_PIC -static int stbi__pic_is4(stbi__context *s,const char *str) -{ - int i; - for (i=0; i<4; ++i) - if (stbi__get8(s) != (stbi_uc)str[i]) - return 0; +static int stbi__pic_is4(stbi__context* s, const char* str) { + int i; + for (i = 0; i < 4; ++i) + if (stbi__get8(s) != (stbi_uc)str[i]) + return 0; - return 1; + return 1; } -static int stbi__pic_test_core(stbi__context *s) -{ - int i; +static int stbi__pic_test_core(stbi__context* s) { + int i; - if (!stbi__pic_is4(s,"\x53\x80\xF6\x34")) - return 0; + if (!stbi__pic_is4(s, "\x53\x80\xF6\x34")) + return 0; - for(i=0;i<84;++i) - stbi__get8(s); + for (i = 0; i < 84; ++i) + stbi__get8(s); - if (!stbi__pic_is4(s,"PICT")) - return 0; + if (!stbi__pic_is4(s, "PICT")) + return 0; - return 1; + return 1; } -typedef struct -{ - stbi_uc size,type,channel; +typedef struct { + stbi_uc size, type, channel; } stbi__pic_packet; -static stbi_uc *stbi__readval(stbi__context *s, int channel, stbi_uc *dest) -{ - int mask=0x80, i; +static stbi_uc* stbi__readval(stbi__context* s, int channel, stbi_uc* dest) { + int mask = 0x80, i; - for (i=0; i<4; ++i, mask>>=1) { - if (channel & mask) { - if (stbi__at_eof(s)) return stbi__errpuc("bad file","PIC file too short"); - dest[i]=stbi__get8(s); - } - } + for (i = 0; i < 4; ++i, mask >>= 1) { + if (channel & mask) { + if (stbi__at_eof(s)) + return stbi__errpuc("bad file", "PIC file too short"); + dest[i] = stbi__get8(s); + } + } - return dest; + return dest; } -static void stbi__copyval(int channel,stbi_uc *dest,const stbi_uc *src) -{ - int mask=0x80,i; +static void stbi__copyval(int channel, stbi_uc* dest, const stbi_uc* src) { + int mask = 0x80, i; - for (i=0;i<4; ++i, mask>>=1) - if (channel&mask) - dest[i]=src[i]; + for (i = 0; i < 4; ++i, mask >>= 1) + if (channel & mask) + dest[i] = src[i]; } -static stbi_uc *stbi__pic_load_core(stbi__context *s,int width,int height,int *comp, stbi_uc *result) -{ - int act_comp=0,num_packets=0,y,chained; - stbi__pic_packet packets[10]; +static stbi_uc* stbi__pic_load_core(stbi__context* s, int width, int height, + int* comp, stbi_uc* result) { + int act_comp = 0, num_packets = 0, y, chained; + stbi__pic_packet packets[10]; - // this will (should...) cater for even some bizarre stuff like having data + // this will (should...) cater for even some bizarre stuff like having data // for the same channel in multiple packets. - do { - stbi__pic_packet *packet; + do { + stbi__pic_packet* packet; - if (num_packets==sizeof(packets)/sizeof(packets[0])) - return stbi__errpuc("bad format","too many packets"); + if (num_packets == sizeof(packets) / sizeof(packets[0])) + return stbi__errpuc("bad format", "too many packets"); - packet = &packets[num_packets++]; + packet = &packets[num_packets++]; - chained = stbi__get8(s); - packet->size = stbi__get8(s); - packet->type = stbi__get8(s); - packet->channel = stbi__get8(s); + chained = stbi__get8(s); + packet->size = stbi__get8(s); + packet->type = stbi__get8(s); + packet->channel = stbi__get8(s); - act_comp |= packet->channel; + act_comp |= packet->channel; - if (stbi__at_eof(s)) return stbi__errpuc("bad file","file too short (reading packets)"); - if (packet->size != 8) return stbi__errpuc("bad format","packet isn't 8bpp"); - } while (chained); + if (stbi__at_eof(s)) + return stbi__errpuc("bad file", "file too short (reading packets)"); + if (packet->size != 8) + return stbi__errpuc("bad format", "packet isn't 8bpp"); + } while (chained); - *comp = (act_comp & 0x10 ? 4 : 3); // has alpha channel? + *comp = (act_comp & 0x10 ? 4 : 3); // has alpha channel? - for(y=0; ytype) { + switch (packet->type) { default: - return stbi__errpuc("bad format","packet has bad compression type"); + return stbi__errpuc("bad format", + "packet has bad compression type"); - case 0: {//uncompressed - int x; + case 0: { // uncompressed + int x; - for(x=0;xchannel,dest)) - return 0; - break; + for (x = 0; x < width; ++x, dest += 4) + if (!stbi__readval(s, packet->channel, dest)) + return 0; + break; } - case 1://Pure RLE - { - int left=width, i; + case 1: // Pure RLE + { + int left = width, i; - while (left>0) { - stbi_uc count,value[4]; + while (left > 0) { + stbi_uc count, value[4]; - count=stbi__get8(s); - if (stbi__at_eof(s)) return stbi__errpuc("bad file","file too short (pure read count)"); + count = stbi__get8(s); + if (stbi__at_eof(s)) + return stbi__errpuc("bad file", + "file too short (pure read count)"); - if (count > left) - count = (stbi_uc) left; + if (count > left) + count = (stbi_uc)left; - if (!stbi__readval(s,packet->channel,value)) return 0; - - for(i=0; ichannel,dest,value); - left -= count; - } - } - break; - - case 2: {//Mixed RLE - int left=width; - while (left>0) { - int count = stbi__get8(s), i; - if (stbi__at_eof(s)) return stbi__errpuc("bad file","file too short (mixed read count)"); - - if (count >= 128) { // Repeated - stbi_uc value[4]; - - if (count==128) - count = stbi__get16be(s); - else - count -= 127; - if (count > left) - return stbi__errpuc("bad file","scanline overrun"); - - if (!stbi__readval(s,packet->channel,value)) + if (!stbi__readval(s, packet->channel, value)) return 0; - for(i=0;ichannel,dest,value); - } else { // Raw - ++count; - if (count>left) return stbi__errpuc("bad file","scanline overrun"); + for (i = 0; i < count; ++i, dest += 4) + stbi__copyval(packet->channel, dest, value); + left -= count; + } + } break; - for(i=0;ichannel,dest)) - return 0; - } - left-=count; - } - break; + case 2: { // Mixed RLE + int left = width; + while (left > 0) { + int count = stbi__get8(s), i; + if (stbi__at_eof(s)) + return stbi__errpuc( + "bad file", "file too short (mixed read count)"); + + if (count >= 128) { // Repeated + stbi_uc value[4]; + + if (count == 128) + count = stbi__get16be(s); + else + count -= 127; + if (count > left) + return stbi__errpuc("bad file", "scanline overrun"); + + if (!stbi__readval(s, packet->channel, value)) + return 0; + + for (i = 0; i < count; ++i, dest += 4) + stbi__copyval(packet->channel, dest, value); + } else { // Raw + ++count; + if (count > left) + return stbi__errpuc("bad file", "scanline overrun"); + + for (i = 0; i < count; ++i, dest += 4) + if (!stbi__readval(s, packet->channel, dest)) + return 0; + } + left -= count; + } + break; } - } - } - } + } + } + } - return result; + return result; } -static void *stbi__pic_load(stbi__context *s,int *px,int *py,int *comp,int req_comp, stbi__result_info *ri) -{ - stbi_uc *result; - int i, x,y, internal_comp; - STBI_NOTUSED(ri); +static void* stbi__pic_load(stbi__context* s, int* px, int* py, int* comp, + int req_comp, stbi__result_info* ri) { + stbi_uc* result; + int i, x, y, internal_comp; + STBI_NOTUSED(ri); - if (!comp) comp = &internal_comp; + if (!comp) + comp = &internal_comp; - for (i=0; i<92; ++i) - stbi__get8(s); + for (i = 0; i < 92; ++i) + stbi__get8(s); - x = stbi__get16be(s); - y = stbi__get16be(s); + x = stbi__get16be(s); + y = stbi__get16be(s); - if (y > STBI_MAX_DIMENSIONS) return stbi__errpuc("too large","Very large image (corrupt?)"); - if (x > STBI_MAX_DIMENSIONS) return stbi__errpuc("too large","Very large image (corrupt?)"); + if (y > STBI_MAX_DIMENSIONS) + return stbi__errpuc("too large", "Very large image (corrupt?)"); + if (x > STBI_MAX_DIMENSIONS) + return stbi__errpuc("too large", "Very large image (corrupt?)"); - if (stbi__at_eof(s)) return stbi__errpuc("bad file","file too short (pic header)"); - if (!stbi__mad3sizes_valid(x, y, 4, 0)) return stbi__errpuc("too large", "PIC image too large to decode"); + if (stbi__at_eof(s)) + return stbi__errpuc("bad file", "file too short (pic header)"); + if (!stbi__mad3sizes_valid(x, y, 4, 0)) + return stbi__errpuc("too large", "PIC image too large to decode"); - stbi__get32be(s); //skip `ratio' - stbi__get16be(s); //skip `fields' - stbi__get16be(s); //skip `pad' + stbi__get32be(s); // skip `ratio' + stbi__get16be(s); // skip `fields' + stbi__get16be(s); // skip `pad' - // intermediate buffer is RGBA - result = (stbi_uc *) stbi__malloc_mad3(x, y, 4, 0); - if (!result) return stbi__errpuc("outofmem", "Out of memory"); - memset(result, 0xff, x*y*4); + // intermediate buffer is RGBA + result = (stbi_uc*)stbi__malloc_mad3(x, y, 4, 0); + if (!result) + return stbi__errpuc("outofmem", "Out of memory"); + memset(result, 0xff, x * y * 4); - if (!stbi__pic_load_core(s,x,y,comp, result)) { - STBI_FREE(result); - result=0; - } - *px = x; - *py = y; - if (req_comp == 0) req_comp = *comp; - result=stbi__convert_format(result,4,req_comp,x,y); + if (!stbi__pic_load_core(s, x, y, comp, result)) { + STBI_FREE(result); + result = 0; + } + *px = x; + *py = y; + if (req_comp == 0) + req_comp = *comp; + result = stbi__convert_format(result, 4, req_comp, x, y); - return result; + return result; } -static int stbi__pic_test(stbi__context *s) -{ - int r = stbi__pic_test_core(s); - stbi__rewind(s); - return r; +static int stbi__pic_test(stbi__context* s) { + int r = stbi__pic_test_core(s); + stbi__rewind(s); + return r; } #endif @@ -6549,533 +7333,572 @@ static int stbi__pic_test(stbi__context *s) // GIF loader -- public domain by Jean-Marc Lienher -- simplified/shrunk by stb #ifndef STBI_NO_GIF -typedef struct -{ - stbi__int16 prefix; - stbi_uc first; - stbi_uc suffix; +typedef struct { + stbi__int16 prefix; + stbi_uc first; + stbi_uc suffix; } stbi__gif_lzw; -typedef struct -{ - int w,h; - stbi_uc *out; // output buffer (always 4 components) - stbi_uc *background; // The current "background" as far as a gif is concerned - stbi_uc *history; - int flags, bgindex, ratio, transparent, eflags; - stbi_uc pal[256][4]; - stbi_uc lpal[256][4]; - stbi__gif_lzw codes[8192]; - stbi_uc *color_table; - int parse, step; - int lflags; - int start_x, start_y; - int max_x, max_y; - int cur_x, cur_y; - int line_size; - int delay; +typedef struct { + int w, h; + stbi_uc* out; // output buffer (always 4 components) + stbi_uc* + background; // The current "background" as far as a gif is concerned + stbi_uc* history; + int flags, bgindex, ratio, transparent, eflags; + stbi_uc pal[256][4]; + stbi_uc lpal[256][4]; + stbi__gif_lzw codes[8192]; + stbi_uc* color_table; + int parse, step; + int lflags; + int start_x, start_y; + int max_x, max_y; + int cur_x, cur_y; + int line_size; + int delay; } stbi__gif; -static int stbi__gif_test_raw(stbi__context *s) -{ - int sz; - if (stbi__get8(s) != 'G' || stbi__get8(s) != 'I' || stbi__get8(s) != 'F' || stbi__get8(s) != '8') return 0; - sz = stbi__get8(s); - if (sz != '9' && sz != '7') return 0; - if (stbi__get8(s) != 'a') return 0; - return 1; +static int stbi__gif_test_raw(stbi__context* s) { + int sz; + if (stbi__get8(s) != 'G' || stbi__get8(s) != 'I' || stbi__get8(s) != 'F' || + stbi__get8(s) != '8') + return 0; + sz = stbi__get8(s); + if (sz != '9' && sz != '7') + return 0; + if (stbi__get8(s) != 'a') + return 0; + return 1; } -static int stbi__gif_test(stbi__context *s) -{ - int r = stbi__gif_test_raw(s); - stbi__rewind(s); - return r; +static int stbi__gif_test(stbi__context* s) { + int r = stbi__gif_test_raw(s); + stbi__rewind(s); + return r; } -static void stbi__gif_parse_colortable(stbi__context *s, stbi_uc pal[256][4], int num_entries, int transp) -{ - int i; - for (i=0; i < num_entries; ++i) { - pal[i][2] = stbi__get8(s); - pal[i][1] = stbi__get8(s); - pal[i][0] = stbi__get8(s); - pal[i][3] = transp == i ? 0 : 255; - } +static void stbi__gif_parse_colortable(stbi__context* s, stbi_uc pal[256][4], + int num_entries, int transp) { + int i; + for (i = 0; i < num_entries; ++i) { + pal[i][2] = stbi__get8(s); + pal[i][1] = stbi__get8(s); + pal[i][0] = stbi__get8(s); + pal[i][3] = transp == i ? 0 : 255; + } } -static int stbi__gif_header(stbi__context *s, stbi__gif *g, int *comp, int is_info) -{ - stbi_uc version; - if (stbi__get8(s) != 'G' || stbi__get8(s) != 'I' || stbi__get8(s) != 'F' || stbi__get8(s) != '8') - return stbi__err("not GIF", "Corrupt GIF"); +static int stbi__gif_header(stbi__context* s, stbi__gif* g, int* comp, + int is_info) { + stbi_uc version; + if (stbi__get8(s) != 'G' || stbi__get8(s) != 'I' || stbi__get8(s) != 'F' || + stbi__get8(s) != '8') + return stbi__err("not GIF", "Corrupt GIF"); - version = stbi__get8(s); - if (version != '7' && version != '9') return stbi__err("not GIF", "Corrupt GIF"); - if (stbi__get8(s) != 'a') return stbi__err("not GIF", "Corrupt GIF"); + version = stbi__get8(s); + if (version != '7' && version != '9') + return stbi__err("not GIF", "Corrupt GIF"); + if (stbi__get8(s) != 'a') + return stbi__err("not GIF", "Corrupt GIF"); - stbi__g_failure_reason = ""; - g->w = stbi__get16le(s); - g->h = stbi__get16le(s); - g->flags = stbi__get8(s); - g->bgindex = stbi__get8(s); - g->ratio = stbi__get8(s); - g->transparent = -1; + stbi__g_failure_reason = ""; + g->w = stbi__get16le(s); + g->h = stbi__get16le(s); + g->flags = stbi__get8(s); + g->bgindex = stbi__get8(s); + g->ratio = stbi__get8(s); + g->transparent = -1; - if (g->w > STBI_MAX_DIMENSIONS) return stbi__err("too large","Very large image (corrupt?)"); - if (g->h > STBI_MAX_DIMENSIONS) return stbi__err("too large","Very large image (corrupt?)"); + if (g->w > STBI_MAX_DIMENSIONS) + return stbi__err("too large", "Very large image (corrupt?)"); + if (g->h > STBI_MAX_DIMENSIONS) + return stbi__err("too large", "Very large image (corrupt?)"); - if (comp != 0) *comp = 4; // can't actually tell whether it's 3 or 4 until we parse the comments + if (comp != 0) + *comp = 4; // can't actually tell whether it's 3 or 4 until we parse the + // comments - if (is_info) return 1; + if (is_info) + return 1; - if (g->flags & 0x80) - stbi__gif_parse_colortable(s,g->pal, 2 << (g->flags & 7), -1); + if (g->flags & 0x80) + stbi__gif_parse_colortable(s, g->pal, 2 << (g->flags & 7), -1); - return 1; + return 1; } -static int stbi__gif_info_raw(stbi__context *s, int *x, int *y, int *comp) -{ - stbi__gif* g = (stbi__gif*) stbi__malloc(sizeof(stbi__gif)); - if (!g) return stbi__err("outofmem", "Out of memory"); - if (!stbi__gif_header(s, g, comp, 1)) { - STBI_FREE(g); - stbi__rewind( s ); - return 0; - } - if (x) *x = g->w; - if (y) *y = g->h; - STBI_FREE(g); - return 1; +static int stbi__gif_info_raw(stbi__context* s, int* x, int* y, int* comp) { + stbi__gif* g = (stbi__gif*)stbi__malloc(sizeof(stbi__gif)); + if (!g) + return stbi__err("outofmem", "Out of memory"); + if (!stbi__gif_header(s, g, comp, 1)) { + STBI_FREE(g); + stbi__rewind(s); + return 0; + } + if (x) + *x = g->w; + if (y) + *y = g->h; + STBI_FREE(g); + return 1; } -static void stbi__out_gif_code(stbi__gif *g, stbi__uint16 code) -{ - stbi_uc *p, *c; - int idx; +static void stbi__out_gif_code(stbi__gif* g, stbi__uint16 code) { + stbi_uc *p, *c; + int idx; - // recurse to decode the prefixes, since the linked-list is backwards, - // and working backwards through an interleaved image would be nasty - if (g->codes[code].prefix >= 0) - stbi__out_gif_code(g, g->codes[code].prefix); + // recurse to decode the prefixes, since the linked-list is backwards, + // and working backwards through an interleaved image would be nasty + if (g->codes[code].prefix >= 0) + stbi__out_gif_code(g, g->codes[code].prefix); - if (g->cur_y >= g->max_y) return; + if (g->cur_y >= g->max_y) + return; - idx = g->cur_x + g->cur_y; - p = &g->out[idx]; - g->history[idx / 4] = 1; + idx = g->cur_x + g->cur_y; + p = &g->out[idx]; + g->history[idx / 4] = 1; - c = &g->color_table[g->codes[code].suffix * 4]; - if (c[3] > 128) { // don't render transparent pixels; - p[0] = c[2]; - p[1] = c[1]; - p[2] = c[0]; - p[3] = c[3]; - } - g->cur_x += 4; + c = &g->color_table[g->codes[code].suffix * 4]; + if (c[3] > 128) { // don't render transparent pixels; + p[0] = c[2]; + p[1] = c[1]; + p[2] = c[0]; + p[3] = c[3]; + } + g->cur_x += 4; - if (g->cur_x >= g->max_x) { - g->cur_x = g->start_x; - g->cur_y += g->step; + if (g->cur_x >= g->max_x) { + g->cur_x = g->start_x; + g->cur_y += g->step; - while (g->cur_y >= g->max_y && g->parse > 0) { - g->step = (1 << g->parse) * g->line_size; - g->cur_y = g->start_y + (g->step >> 1); - --g->parse; - } - } + while (g->cur_y >= g->max_y && g->parse > 0) { + g->step = (1 << g->parse) * g->line_size; + g->cur_y = g->start_y + (g->step >> 1); + --g->parse; + } + } } -static stbi_uc *stbi__process_gif_raster(stbi__context *s, stbi__gif *g) -{ - stbi_uc lzw_cs; - stbi__int32 len, init_code; - stbi__uint32 first; - stbi__int32 codesize, codemask, avail, oldcode, bits, valid_bits, clear; - stbi__gif_lzw *p; +static stbi_uc* stbi__process_gif_raster(stbi__context* s, stbi__gif* g) { + stbi_uc lzw_cs; + stbi__int32 len, init_code; + stbi__uint32 first; + stbi__int32 codesize, codemask, avail, oldcode, bits, valid_bits, clear; + stbi__gif_lzw* p; - lzw_cs = stbi__get8(s); - if (lzw_cs > 12) return NULL; - clear = 1 << lzw_cs; - first = 1; - codesize = lzw_cs + 1; - codemask = (1 << codesize) - 1; - bits = 0; - valid_bits = 0; - for (init_code = 0; init_code < clear; init_code++) { - g->codes[init_code].prefix = -1; - g->codes[init_code].first = (stbi_uc) init_code; - g->codes[init_code].suffix = (stbi_uc) init_code; - } + lzw_cs = stbi__get8(s); + if (lzw_cs > 12) + return NULL; + clear = 1 << lzw_cs; + first = 1; + codesize = lzw_cs + 1; + codemask = (1 << codesize) - 1; + bits = 0; + valid_bits = 0; + for (init_code = 0; init_code < clear; init_code++) { + g->codes[init_code].prefix = -1; + g->codes[init_code].first = (stbi_uc)init_code; + g->codes[init_code].suffix = (stbi_uc)init_code; + } - // support no starting clear code - avail = clear+2; - oldcode = -1; + // support no starting clear code + avail = clear + 2; + oldcode = -1; - len = 0; - for(;;) { - if (valid_bits < codesize) { - if (len == 0) { - len = stbi__get8(s); // start new block - if (len == 0) - return g->out; - } - --len; - bits |= (stbi__int32) stbi__get8(s) << valid_bits; - valid_bits += 8; - } else { - stbi__int32 code = bits & codemask; - bits >>= codesize; - valid_bits -= codesize; - // @OPTIMIZE: is there some way we can accelerate the non-clear path? - if (code == clear) { // clear code - codesize = lzw_cs + 1; - codemask = (1 << codesize) - 1; - avail = clear + 2; - oldcode = -1; - first = 0; - } else if (code == clear + 1) { // end of stream code - stbi__skip(s, len); - while ((len = stbi__get8(s)) > 0) - stbi__skip(s,len); - return g->out; - } else if (code <= avail) { - if (first) { - return stbi__errpuc("no clear code", "Corrupt GIF"); + len = 0; + for (;;) { + if (valid_bits < codesize) { + if (len == 0) { + len = stbi__get8(s); // start new block + if (len == 0) + return g->out; } + --len; + bits |= (stbi__int32)stbi__get8(s) << valid_bits; + valid_bits += 8; + } else { + stbi__int32 code = bits & codemask; + bits >>= codesize; + valid_bits -= codesize; + // @OPTIMIZE: is there some way we can accelerate the non-clear + // path? + if (code == clear) { // clear code + codesize = lzw_cs + 1; + codemask = (1 << codesize) - 1; + avail = clear + 2; + oldcode = -1; + first = 0; + } else if (code == clear + 1) { // end of stream code + stbi__skip(s, len); + while ((len = stbi__get8(s)) > 0) + stbi__skip(s, len); + return g->out; + } else if (code <= avail) { + if (first) { + return stbi__errpuc("no clear code", "Corrupt GIF"); + } - if (oldcode >= 0) { - p = &g->codes[avail++]; - if (avail > 8192) { - return stbi__errpuc("too many codes", "Corrupt GIF"); - } + if (oldcode >= 0) { + p = &g->codes[avail++]; + if (avail > 8192) { + return stbi__errpuc("too many codes", "Corrupt GIF"); + } - p->prefix = (stbi__int16) oldcode; - p->first = g->codes[oldcode].first; - p->suffix = (code == avail) ? p->first : g->codes[code].first; - } else if (code == avail) - return stbi__errpuc("illegal code in raster", "Corrupt GIF"); + p->prefix = (stbi__int16)oldcode; + p->first = g->codes[oldcode].first; + p->suffix = + (code == avail) ? p->first : g->codes[code].first; + } else if (code == avail) + return stbi__errpuc("illegal code in raster", + "Corrupt GIF"); - stbi__out_gif_code(g, (stbi__uint16) code); + stbi__out_gif_code(g, (stbi__uint16)code); - if ((avail & codemask) == 0 && avail <= 0x0FFF) { - codesize++; - codemask = (1 << codesize) - 1; + if ((avail & codemask) == 0 && avail <= 0x0FFF) { + codesize++; + codemask = (1 << codesize) - 1; + } + + oldcode = code; + } else { + return stbi__errpuc("illegal code in raster", "Corrupt GIF"); } - - oldcode = code; - } else { - return stbi__errpuc("illegal code in raster", "Corrupt GIF"); - } - } - } + } + } } -// this function is designed to support animated gifs, although stb_image doesn't support it -// two back is the image from two frames ago, used for a very specific disposal format -static stbi_uc *stbi__gif_load_next(stbi__context *s, stbi__gif *g, int *comp, int req_comp, stbi_uc *two_back) -{ - int dispose; - int first_frame; - int pi; - int pcount; - STBI_NOTUSED(req_comp); +// this function is designed to support animated gifs, although stb_image +// doesn't support it two back is the image from two frames ago, used for a very +// specific disposal format +static stbi_uc* stbi__gif_load_next(stbi__context* s, stbi__gif* g, int* comp, + int req_comp, stbi_uc* two_back) { + int dispose; + int first_frame; + int pi; + int pcount; + STBI_NOTUSED(req_comp); - // on first frame, any non-written pixels get the background colour (non-transparent) - first_frame = 0; - if (g->out == 0) { - if (!stbi__gif_header(s, g, comp,0)) return 0; // stbi__g_failure_reason set by stbi__gif_header - if (!stbi__mad3sizes_valid(4, g->w, g->h, 0)) - return stbi__errpuc("too large", "GIF image is too large"); - pcount = g->w * g->h; - g->out = (stbi_uc *) stbi__malloc(4 * pcount); - g->background = (stbi_uc *) stbi__malloc(4 * pcount); - g->history = (stbi_uc *) stbi__malloc(pcount); - if (!g->out || !g->background || !g->history) - return stbi__errpuc("outofmem", "Out of memory"); + // on first frame, any non-written pixels get the background colour + // (non-transparent) + first_frame = 0; + if (g->out == 0) { + if (!stbi__gif_header(s, g, comp, 0)) + return 0; // stbi__g_failure_reason set by stbi__gif_header + if (!stbi__mad3sizes_valid(4, g->w, g->h, 0)) + return stbi__errpuc("too large", "GIF image is too large"); + pcount = g->w * g->h; + g->out = (stbi_uc*)stbi__malloc(4 * pcount); + g->background = (stbi_uc*)stbi__malloc(4 * pcount); + g->history = (stbi_uc*)stbi__malloc(pcount); + if (!g->out || !g->background || !g->history) + return stbi__errpuc("outofmem", "Out of memory"); - // image is treated as "transparent" at the start - ie, nothing overwrites the current background; - // background colour is only used for pixels that are not rendered first frame, after that "background" - // color refers to the color that was there the previous frame. - memset(g->out, 0x00, 4 * pcount); - memset(g->background, 0x00, 4 * pcount); // state of the background (starts transparent) - memset(g->history, 0x00, pcount); // pixels that were affected previous frame - first_frame = 1; - } else { - // second frame - how do we dispose of the previous one? - dispose = (g->eflags & 0x1C) >> 2; - pcount = g->w * g->h; + // image is treated as "transparent" at the start - ie, nothing + // overwrites the current background; background colour is only used for + // pixels that are not rendered first frame, after that "background" + // color refers to the color that was there the previous frame. + memset(g->out, 0x00, 4 * pcount); + memset(g->background, 0x00, + 4 * pcount); // state of the background (starts transparent) + memset(g->history, 0x00, + pcount); // pixels that were affected previous frame + first_frame = 1; + } else { + // second frame - how do we dispose of the previous one? + dispose = (g->eflags & 0x1C) >> 2; + pcount = g->w * g->h; - if ((dispose == 3) && (two_back == 0)) { - dispose = 2; // if I don't have an image to revert back to, default to the old background - } + if ((dispose == 3) && (two_back == 0)) { + dispose = 2; // if I don't have an image to revert back to, default + // to the old background + } - if (dispose == 3) { // use previous graphic - for (pi = 0; pi < pcount; ++pi) { - if (g->history[pi]) { - memcpy( &g->out[pi * 4], &two_back[pi * 4], 4 ); + if (dispose == 3) { // use previous graphic + for (pi = 0; pi < pcount; ++pi) { + if (g->history[pi]) { + memcpy(&g->out[pi * 4], &two_back[pi * 4], 4); + } } - } - } else if (dispose == 2) { - // restore what was changed last frame to background before that frame; - for (pi = 0; pi < pcount; ++pi) { - if (g->history[pi]) { - memcpy( &g->out[pi * 4], &g->background[pi * 4], 4 ); + } else if (dispose == 2) { + // restore what was changed last frame to background before that + // frame; + for (pi = 0; pi < pcount; ++pi) { + if (g->history[pi]) { + memcpy(&g->out[pi * 4], &g->background[pi * 4], 4); + } } - } - } else { - // This is a non-disposal case eithe way, so just - // leave the pixels as is, and they will become the new background - // 1: do not dispose - // 0: not specified. - } + } else { + // This is a non-disposal case eithe way, so just + // leave the pixels as is, and they will become the new background + // 1: do not dispose + // 0: not specified. + } - // background is what out is after the undoing of the previou frame; - memcpy( g->background, g->out, 4 * g->w * g->h ); - } + // background is what out is after the undoing of the previou frame; + memcpy(g->background, g->out, 4 * g->w * g->h); + } - // clear my history; - memset( g->history, 0x00, g->w * g->h ); // pixels that were affected previous frame + // clear my history; + memset(g->history, 0x00, + g->w * g->h); // pixels that were affected previous frame - for (;;) { - int tag = stbi__get8(s); - switch (tag) { - case 0x2C: /* Image Descriptor */ - { + for (;;) { + int tag = stbi__get8(s); + switch (tag) { + case 0x2C: /* Image Descriptor */ + { stbi__int32 x, y, w, h; - stbi_uc *o; + stbi_uc* o; x = stbi__get16le(s); y = stbi__get16le(s); w = stbi__get16le(s); h = stbi__get16le(s); if (((x + w) > (g->w)) || ((y + h) > (g->h))) - return stbi__errpuc("bad Image Descriptor", "Corrupt GIF"); + return stbi__errpuc("bad Image Descriptor", "Corrupt GIF"); g->line_size = g->w * 4; g->start_x = x * 4; g->start_y = y * g->line_size; - g->max_x = g->start_x + w * 4; - g->max_y = g->start_y + h * g->line_size; - g->cur_x = g->start_x; - g->cur_y = g->start_y; + g->max_x = g->start_x + w * 4; + g->max_y = g->start_y + h * g->line_size; + g->cur_x = g->start_x; + g->cur_y = g->start_y; // if the width of the specified rectangle is 0, that means // we may not see *any* pixels or the image is malformed; // to make sure this is caught, move the current y down to // max_y (which is what out_gif_code checks). if (w == 0) - g->cur_y = g->max_y; + g->cur_y = g->max_y; g->lflags = stbi__get8(s); if (g->lflags & 0x40) { - g->step = 8 * g->line_size; // first interlaced spacing - g->parse = 3; + g->step = 8 * g->line_size; // first interlaced spacing + g->parse = 3; } else { - g->step = g->line_size; - g->parse = 0; + g->step = g->line_size; + g->parse = 0; } if (g->lflags & 0x80) { - stbi__gif_parse_colortable(s,g->lpal, 2 << (g->lflags & 7), g->eflags & 0x01 ? g->transparent : -1); - g->color_table = (stbi_uc *) g->lpal; + stbi__gif_parse_colortable(s, g->lpal, 2 << (g->lflags & 7), + g->eflags & 0x01 ? g->transparent + : -1); + g->color_table = (stbi_uc*)g->lpal; } else if (g->flags & 0x80) { - g->color_table = (stbi_uc *) g->pal; + g->color_table = (stbi_uc*)g->pal; } else - return stbi__errpuc("missing color table", "Corrupt GIF"); + return stbi__errpuc("missing color table", "Corrupt GIF"); o = stbi__process_gif_raster(s, g); - if (!o) return NULL; + if (!o) + return NULL; // if this was the first frame, pcount = g->w * g->h; if (first_frame && (g->bgindex > 0)) { - // if first frame, any pixel not drawn to gets the background color - for (pi = 0; pi < pcount; ++pi) { - if (g->history[pi] == 0) { - g->pal[g->bgindex][3] = 255; // just in case it was made transparent, undo that; It will be reset next frame if need be; - memcpy( &g->out[pi * 4], &g->pal[g->bgindex], 4 ); - } - } + // if first frame, any pixel not drawn to gets the background + // color + for (pi = 0; pi < pcount; ++pi) { + if (g->history[pi] == 0) { + g->pal[g->bgindex][3] = + 255; // just in case it was made transparent, undo + // that; It will be reset next frame if need + // be; + memcpy(&g->out[pi * 4], &g->pal[g->bgindex], 4); + } + } } return o; - } + } - case 0x21: // Comment Extension. - { + case 0x21: // Comment Extension. + { int len; int ext = stbi__get8(s); if (ext == 0xF9) { // Graphic Control Extension. - len = stbi__get8(s); - if (len == 4) { - g->eflags = stbi__get8(s); - g->delay = 10 * stbi__get16le(s); // delay - 1/100th of a second, saving as 1/1000ths. + len = stbi__get8(s); + if (len == 4) { + g->eflags = stbi__get8(s); + g->delay = + 10 * stbi__get16le(s); // delay - 1/100th of a second, + // saving as 1/1000ths. - // unset old transparent - if (g->transparent >= 0) { - g->pal[g->transparent][3] = 255; - } - if (g->eflags & 0x01) { - g->transparent = stbi__get8(s); - if (g->transparent >= 0) { - g->pal[g->transparent][3] = 0; - } - } else { - // don't need transparent - stbi__skip(s, 1); - g->transparent = -1; - } - } else { - stbi__skip(s, len); - break; - } + // unset old transparent + if (g->transparent >= 0) { + g->pal[g->transparent][3] = 255; + } + if (g->eflags & 0x01) { + g->transparent = stbi__get8(s); + if (g->transparent >= 0) { + g->pal[g->transparent][3] = 0; + } + } else { + // don't need transparent + stbi__skip(s, 1); + g->transparent = -1; + } + } else { + stbi__skip(s, len); + break; + } } while ((len = stbi__get8(s)) != 0) { - stbi__skip(s, len); + stbi__skip(s, len); } break; - } + } - case 0x3B: // gif stream termination code - return (stbi_uc *) s; // using '1' causes warning on some compilers + case 0x3B: // gif stream termination code + return (stbi_uc*)s; // using '1' causes warning on some compilers - default: + default: return stbi__errpuc("unknown code", "Corrupt GIF"); - } - } + } + } } -static void *stbi__load_gif_main_outofmem(stbi__gif *g, stbi_uc *out, int **delays) -{ - STBI_FREE(g->out); - STBI_FREE(g->history); - STBI_FREE(g->background); +static void* stbi__load_gif_main_outofmem(stbi__gif* g, stbi_uc* out, + int** delays) { + STBI_FREE(g->out); + STBI_FREE(g->history); + STBI_FREE(g->background); - if (out) STBI_FREE(out); - if (delays && *delays) STBI_FREE(*delays); - return stbi__errpuc("outofmem", "Out of memory"); + if (out) + STBI_FREE(out); + if (delays && *delays) + STBI_FREE(*delays); + return stbi__errpuc("outofmem", "Out of memory"); } -static void *stbi__load_gif_main(stbi__context *s, int **delays, int *x, int *y, int *z, int *comp, int req_comp) -{ - if (stbi__gif_test(s)) { - int layers = 0; - stbi_uc *u = 0; - stbi_uc *out = 0; - stbi_uc *two_back = 0; - stbi__gif g; - int stride; - int out_size = 0; - int delays_size = 0; +static void* stbi__load_gif_main(stbi__context* s, int** delays, int* x, int* y, + int* z, int* comp, int req_comp) { + if (stbi__gif_test(s)) { + int layers = 0; + stbi_uc* u = 0; + stbi_uc* out = 0; + stbi_uc* two_back = 0; + stbi__gif g; + int stride; + int out_size = 0; + int delays_size = 0; - STBI_NOTUSED(out_size); - STBI_NOTUSED(delays_size); + STBI_NOTUSED(out_size); + STBI_NOTUSED(delays_size); - memset(&g, 0, sizeof(g)); - if (delays) { - *delays = 0; - } + memset(&g, 0, sizeof(g)); + if (delays) { + *delays = 0; + } - do { - u = stbi__gif_load_next(s, &g, comp, req_comp, two_back); - if (u == (stbi_uc *) s) u = 0; // end of animated gif marker + do { + u = stbi__gif_load_next(s, &g, comp, req_comp, two_back); + if (u == (stbi_uc*)s) + u = 0; // end of animated gif marker - if (u) { - *x = g.w; - *y = g.h; - ++layers; - stride = g.w * g.h * 4; + if (u) { + *x = g.w; + *y = g.h; + ++layers; + stride = g.w * g.h * 4; - if (out) { - void *tmp = (stbi_uc*) STBI_REALLOC_SIZED( out, out_size, layers * stride ); - if (!tmp) - return stbi__load_gif_main_outofmem(&g, out, delays); - else { - out = (stbi_uc*) tmp; - out_size = layers * stride; - } + if (out) { + void* tmp = (stbi_uc*)STBI_REALLOC_SIZED(out, out_size, + layers * stride); + if (!tmp) + return stbi__load_gif_main_outofmem(&g, out, delays); + else { + out = (stbi_uc*)tmp; + out_size = layers * stride; + } - if (delays) { - int *new_delays = (int*) STBI_REALLOC_SIZED( *delays, delays_size, sizeof(int) * layers ); - if (!new_delays) - return stbi__load_gif_main_outofmem(&g, out, delays); - *delays = new_delays; - delays_size = layers * sizeof(int); - } - } else { - out = (stbi_uc*)stbi__malloc( layers * stride ); - if (!out) - return stbi__load_gif_main_outofmem(&g, out, delays); - out_size = layers * stride; - if (delays) { - *delays = (int*) stbi__malloc( layers * sizeof(int) ); - if (!*delays) - return stbi__load_gif_main_outofmem(&g, out, delays); - delays_size = layers * sizeof(int); - } - } - memcpy( out + ((layers - 1) * stride), u, stride ); - if (layers >= 2) { - two_back = out - 2 * stride; + if (delays) { + int* new_delays = (int*)STBI_REALLOC_SIZED( + *delays, delays_size, sizeof(int) * layers); + if (!new_delays) + return stbi__load_gif_main_outofmem(&g, out, + delays); + *delays = new_delays; + delays_size = layers * sizeof(int); + } + } else { + out = (stbi_uc*)stbi__malloc(layers * stride); + if (!out) + return stbi__load_gif_main_outofmem(&g, out, delays); + out_size = layers * stride; + if (delays) { + *delays = (int*)stbi__malloc(layers * sizeof(int)); + if (!*delays) + return stbi__load_gif_main_outofmem(&g, out, + delays); + delays_size = layers * sizeof(int); + } + } + memcpy(out + ((layers - 1) * stride), u, stride); + if (layers >= 2) { + two_back = out - 2 * stride; + } + + if (delays) { + (*delays)[layers - 1U] = g.delay; + } } + } while (u != 0); - if (delays) { - (*delays)[layers - 1U] = g.delay; - } - } - } while (u != 0); + // free temp buffer; + STBI_FREE(g.out); + STBI_FREE(g.history); + STBI_FREE(g.background); - // free temp buffer; - STBI_FREE(g.out); - STBI_FREE(g.history); - STBI_FREE(g.background); + // do the final conversion after loading everything; + if (req_comp && req_comp != 4) + out = stbi__convert_format(out, 4, req_comp, layers * g.w, g.h); - // do the final conversion after loading everything; - if (req_comp && req_comp != 4) - out = stbi__convert_format(out, 4, req_comp, layers * g.w, g.h); - - *z = layers; - return out; - } else { - return stbi__errpuc("not GIF", "Image was not as a gif type."); - } + *z = layers; + return out; + } else { + return stbi__errpuc("not GIF", "Image was not as a gif type."); + } } -static void *stbi__gif_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri) -{ - stbi_uc *u = 0; - stbi__gif g; - memset(&g, 0, sizeof(g)); - STBI_NOTUSED(ri); +static void* stbi__gif_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri) { + stbi_uc* u = 0; + stbi__gif g; + memset(&g, 0, sizeof(g)); + STBI_NOTUSED(ri); - u = stbi__gif_load_next(s, &g, comp, req_comp, 0); - if (u == (stbi_uc *) s) u = 0; // end of animated gif marker - if (u) { - *x = g.w; - *y = g.h; + u = stbi__gif_load_next(s, &g, comp, req_comp, 0); + if (u == (stbi_uc*)s) + u = 0; // end of animated gif marker + if (u) { + *x = g.w; + *y = g.h; - // moved conversion to after successful load so that the same - // can be done for multiple frames. - if (req_comp && req_comp != 4) - u = stbi__convert_format(u, 4, req_comp, g.w, g.h); - } else if (g.out) { - // if there was an error and we allocated an image buffer, free it! - STBI_FREE(g.out); - } + // moved conversion to after successful load so that the same + // can be done for multiple frames. + if (req_comp && req_comp != 4) + u = stbi__convert_format(u, 4, req_comp, g.w, g.h); + } else if (g.out) { + // if there was an error and we allocated an image buffer, free it! + STBI_FREE(g.out); + } - // free buffers needed for multiple frame loading; - STBI_FREE(g.history); - STBI_FREE(g.background); + // free buffers needed for multiple frame loading; + STBI_FREE(g.history); + STBI_FREE(g.background); - return u; + return u; } -static int stbi__gif_info(stbi__context *s, int *x, int *y, int *comp) -{ - return stbi__gif_info_raw(s,x,y,comp); +static int stbi__gif_info(stbi__context* s, int* x, int* y, int* comp) { + return stbi__gif_info_raw(s, x, y, comp); } #endif @@ -7083,397 +7906,439 @@ static int stbi__gif_info(stbi__context *s, int *x, int *y, int *comp) // Radiance RGBE HDR loader // originally by Nicolas Schulz #ifndef STBI_NO_HDR -static int stbi__hdr_test_core(stbi__context *s, const char *signature) -{ - int i; - for (i=0; signature[i]; ++i) - if (stbi__get8(s) != signature[i]) - return 0; - stbi__rewind(s); - return 1; +static int stbi__hdr_test_core(stbi__context* s, const char* signature) { + int i; + for (i = 0; signature[i]; ++i) + if (stbi__get8(s) != signature[i]) + return 0; + stbi__rewind(s); + return 1; } -static int stbi__hdr_test(stbi__context* s) -{ - int r = stbi__hdr_test_core(s, "#?RADIANCE\n"); - stbi__rewind(s); - if(!r) { - r = stbi__hdr_test_core(s, "#?RGBE\n"); - stbi__rewind(s); - } - return r; +static int stbi__hdr_test(stbi__context* s) { + int r = stbi__hdr_test_core(s, "#?RADIANCE\n"); + stbi__rewind(s); + if (!r) { + r = stbi__hdr_test_core(s, "#?RGBE\n"); + stbi__rewind(s); + } + return r; } -#define STBI__HDR_BUFLEN 1024 -static char *stbi__hdr_gettoken(stbi__context *z, char *buffer) -{ - int len=0; - char c = '\0'; +#define STBI__HDR_BUFLEN 1024 +static char* stbi__hdr_gettoken(stbi__context* z, char* buffer) { + int len = 0; + char c = '\0'; - c = (char) stbi__get8(z); + c = (char)stbi__get8(z); - while (!stbi__at_eof(z) && c != '\n') { - buffer[len++] = c; - if (len == STBI__HDR_BUFLEN-1) { - // flush to end of line - while (!stbi__at_eof(z) && stbi__get8(z) != '\n') - ; - break; - } - c = (char) stbi__get8(z); - } + while (!stbi__at_eof(z) && c != '\n') { + buffer[len++] = c; + if (len == STBI__HDR_BUFLEN - 1) { + // flush to end of line + while (!stbi__at_eof(z) && stbi__get8(z) != '\n') + ; + break; + } + c = (char)stbi__get8(z); + } - buffer[len] = 0; - return buffer; + buffer[len] = 0; + return buffer; } -static void stbi__hdr_convert(float *output, stbi_uc *input, int req_comp) -{ - if ( input[3] != 0 ) { - float f1; - // Exponent - f1 = (float) ldexp(1.0f, input[3] - (int)(128 + 8)); - if (req_comp <= 2) - output[0] = (input[0] + input[1] + input[2]) * f1 / 3; - else { - output[0] = input[0] * f1; - output[1] = input[1] * f1; - output[2] = input[2] * f1; - } - if (req_comp == 2) output[1] = 1; - if (req_comp == 4) output[3] = 1; - } else { - switch (req_comp) { - case 4: output[3] = 1; /* fallthrough */ - case 3: output[0] = output[1] = output[2] = 0; - break; - case 2: output[1] = 1; /* fallthrough */ - case 1: output[0] = 0; - break; - } - } +static void stbi__hdr_convert(float* output, stbi_uc* input, int req_comp) { + if (input[3] != 0) { + float f1; + // Exponent + f1 = (float)ldexp(1.0f, input[3] - (int)(128 + 8)); + if (req_comp <= 2) + output[0] = (input[0] + input[1] + input[2]) * f1 / 3; + else { + output[0] = input[0] * f1; + output[1] = input[1] * f1; + output[2] = input[2] * f1; + } + if (req_comp == 2) + output[1] = 1; + if (req_comp == 4) + output[3] = 1; + } else { + switch (req_comp) { + case 4: + output[3] = 1; /* fallthrough */ + case 3: + output[0] = output[1] = output[2] = 0; + break; + case 2: + output[1] = 1; /* fallthrough */ + case 1: + output[0] = 0; + break; + } + } } -static float *stbi__hdr_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri) -{ - char buffer[STBI__HDR_BUFLEN]; - char *token; - int valid = 0; - int width, height; - stbi_uc *scanline; - float *hdr_data; - int len; - unsigned char count, value; - int i, j, k, c1,c2, z; - const char *headerToken; - STBI_NOTUSED(ri); +static float* stbi__hdr_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri) { + char buffer[STBI__HDR_BUFLEN]; + char* token; + int valid = 0; + int width, height; + stbi_uc* scanline; + float* hdr_data; + int len; + unsigned char count, value; + int i, j, k, c1, c2, z; + const char* headerToken; + STBI_NOTUSED(ri); - // Check identifier - headerToken = stbi__hdr_gettoken(s,buffer); - if (strcmp(headerToken, "#?RADIANCE") != 0 && strcmp(headerToken, "#?RGBE") != 0) - return stbi__errpf("not HDR", "Corrupt HDR image"); + // Check identifier + headerToken = stbi__hdr_gettoken(s, buffer); + if (strcmp(headerToken, "#?RADIANCE") != 0 && + strcmp(headerToken, "#?RGBE") != 0) + return stbi__errpf("not HDR", "Corrupt HDR image"); - // Parse header - for(;;) { - token = stbi__hdr_gettoken(s,buffer); - if (token[0] == 0) break; - if (strcmp(token, "FORMAT=32-bit_rle_rgbe") == 0) valid = 1; - } + // Parse header + for (;;) { + token = stbi__hdr_gettoken(s, buffer); + if (token[0] == 0) + break; + if (strcmp(token, "FORMAT=32-bit_rle_rgbe") == 0) + valid = 1; + } - if (!valid) return stbi__errpf("unsupported format", "Unsupported HDR format"); + if (!valid) + return stbi__errpf("unsupported format", "Unsupported HDR format"); - // Parse width and height - // can't use sscanf() if we're not using stdio! - token = stbi__hdr_gettoken(s,buffer); - if (strncmp(token, "-Y ", 3)) return stbi__errpf("unsupported data layout", "Unsupported HDR format"); - token += 3; - height = (int) strtol(token, &token, 10); - while (*token == ' ') ++token; - if (strncmp(token, "+X ", 3)) return stbi__errpf("unsupported data layout", "Unsupported HDR format"); - token += 3; - width = (int) strtol(token, NULL, 10); + // Parse width and height + // can't use sscanf() if we're not using stdio! + token = stbi__hdr_gettoken(s, buffer); + if (strncmp(token, "-Y ", 3)) + return stbi__errpf("unsupported data layout", "Unsupported HDR format"); + token += 3; + height = (int)strtol(token, &token, 10); + while (*token == ' ') + ++token; + if (strncmp(token, "+X ", 3)) + return stbi__errpf("unsupported data layout", "Unsupported HDR format"); + token += 3; + width = (int)strtol(token, NULL, 10); - if (height > STBI_MAX_DIMENSIONS) return stbi__errpf("too large","Very large image (corrupt?)"); - if (width > STBI_MAX_DIMENSIONS) return stbi__errpf("too large","Very large image (corrupt?)"); + if (height > STBI_MAX_DIMENSIONS) + return stbi__errpf("too large", "Very large image (corrupt?)"); + if (width > STBI_MAX_DIMENSIONS) + return stbi__errpf("too large", "Very large image (corrupt?)"); - *x = width; - *y = height; + *x = width; + *y = height; - if (comp) *comp = 3; - if (req_comp == 0) req_comp = 3; + if (comp) + *comp = 3; + if (req_comp == 0) + req_comp = 3; - if (!stbi__mad4sizes_valid(width, height, req_comp, sizeof(float), 0)) - return stbi__errpf("too large", "HDR image is too large"); + if (!stbi__mad4sizes_valid(width, height, req_comp, sizeof(float), 0)) + return stbi__errpf("too large", "HDR image is too large"); - // Read data - hdr_data = (float *) stbi__malloc_mad4(width, height, req_comp, sizeof(float), 0); - if (!hdr_data) - return stbi__errpf("outofmem", "Out of memory"); + // Read data + hdr_data = + (float*)stbi__malloc_mad4(width, height, req_comp, sizeof(float), 0); + if (!hdr_data) + return stbi__errpf("outofmem", "Out of memory"); - // Load image data - // image data is stored as some number of sca - if ( width < 8 || width >= 32768) { - // Read flat data - for (j=0; j < height; ++j) { - for (i=0; i < width; ++i) { - stbi_uc rgbe[4]; - main_decode_loop: - stbi__getn(s, rgbe, 4); - stbi__hdr_convert(hdr_data + j * width * req_comp + i * req_comp, rgbe, req_comp); - } - } - } else { - // Read RLE-encoded data - scanline = NULL; + // Load image data + // image data is stored as some number of sca + if (width < 8 || width >= 32768) { + // Read flat data + for (j = 0; j < height; ++j) { + for (i = 0; i < width; ++i) { + stbi_uc rgbe[4]; + main_decode_loop: + stbi__getn(s, rgbe, 4); + stbi__hdr_convert(hdr_data + j * width * req_comp + + i * req_comp, + rgbe, req_comp); + } + } + } else { + // Read RLE-encoded data + scanline = NULL; - for (j = 0; j < height; ++j) { - c1 = stbi__get8(s); - c2 = stbi__get8(s); - len = stbi__get8(s); - if (c1 != 2 || c2 != 2 || (len & 0x80)) { - // not run-length encoded, so we have to actually use THIS data as a decoded - // pixel (note this can't be a valid pixel--one of RGB must be >= 128) - stbi_uc rgbe[4]; - rgbe[0] = (stbi_uc) c1; - rgbe[1] = (stbi_uc) c2; - rgbe[2] = (stbi_uc) len; - rgbe[3] = (stbi_uc) stbi__get8(s); - stbi__hdr_convert(hdr_data, rgbe, req_comp); - i = 1; - j = 0; + for (j = 0; j < height; ++j) { + c1 = stbi__get8(s); + c2 = stbi__get8(s); + len = stbi__get8(s); + if (c1 != 2 || c2 != 2 || (len & 0x80)) { + // not run-length encoded, so we have to actually use THIS data + // as a decoded pixel (note this can't be a valid pixel--one of + // RGB must be >= 128) + stbi_uc rgbe[4]; + rgbe[0] = (stbi_uc)c1; + rgbe[1] = (stbi_uc)c2; + rgbe[2] = (stbi_uc)len; + rgbe[3] = (stbi_uc)stbi__get8(s); + stbi__hdr_convert(hdr_data, rgbe, req_comp); + i = 1; + j = 0; + STBI_FREE(scanline); + goto main_decode_loop; // yes, this makes no sense + } + len <<= 8; + len |= stbi__get8(s); + if (len != width) { + STBI_FREE(hdr_data); + STBI_FREE(scanline); + return stbi__errpf("invalid decoded scanline length", + "corrupt HDR"); + } + if (scanline == NULL) { + scanline = (stbi_uc*)stbi__malloc_mad2(width, 4, 0); + if (!scanline) { + STBI_FREE(hdr_data); + return stbi__errpf("outofmem", "Out of memory"); + } + } + + for (k = 0; k < 4; ++k) { + int nleft; + i = 0; + while ((nleft = width - i) > 0) { + count = stbi__get8(s); + if (count > 128) { + // Run + value = stbi__get8(s); + count -= 128; + if ((count == 0) || (count > nleft)) { + STBI_FREE(hdr_data); + STBI_FREE(scanline); + return stbi__errpf("corrupt", + "bad RLE data in HDR"); + } + for (z = 0; z < count; ++z) + scanline[i++ * 4 + k] = value; + } else { + // Dump + if ((count == 0) || (count > nleft)) { + STBI_FREE(hdr_data); + STBI_FREE(scanline); + return stbi__errpf("corrupt", + "bad RLE data in HDR"); + } + for (z = 0; z < count; ++z) + scanline[i++ * 4 + k] = stbi__get8(s); + } + } + } + for (i = 0; i < width; ++i) + stbi__hdr_convert(hdr_data + (j * width + i) * req_comp, + scanline + i * 4, req_comp); + } + if (scanline) STBI_FREE(scanline); - goto main_decode_loop; // yes, this makes no sense - } - len <<= 8; - len |= stbi__get8(s); - if (len != width) { STBI_FREE(hdr_data); STBI_FREE(scanline); return stbi__errpf("invalid decoded scanline length", "corrupt HDR"); } - if (scanline == NULL) { - scanline = (stbi_uc *) stbi__malloc_mad2(width, 4, 0); - if (!scanline) { - STBI_FREE(hdr_data); - return stbi__errpf("outofmem", "Out of memory"); - } - } + } - for (k = 0; k < 4; ++k) { - int nleft; - i = 0; - while ((nleft = width - i) > 0) { - count = stbi__get8(s); - if (count > 128) { - // Run - value = stbi__get8(s); - count -= 128; - if ((count == 0) || (count > nleft)) { STBI_FREE(hdr_data); STBI_FREE(scanline); return stbi__errpf("corrupt", "bad RLE data in HDR"); } - for (z = 0; z < count; ++z) - scanline[i++ * 4 + k] = value; - } else { - // Dump - if ((count == 0) || (count > nleft)) { STBI_FREE(hdr_data); STBI_FREE(scanline); return stbi__errpf("corrupt", "bad RLE data in HDR"); } - for (z = 0; z < count; ++z) - scanline[i++ * 4 + k] = stbi__get8(s); - } - } - } - for (i=0; i < width; ++i) - stbi__hdr_convert(hdr_data+(j*width + i)*req_comp, scanline + i*4, req_comp); - } - if (scanline) - STBI_FREE(scanline); - } - - return hdr_data; + return hdr_data; } -static int stbi__hdr_info(stbi__context *s, int *x, int *y, int *comp) -{ - char buffer[STBI__HDR_BUFLEN]; - char *token; - int valid = 0; - int dummy; +static int stbi__hdr_info(stbi__context* s, int* x, int* y, int* comp) { + char buffer[STBI__HDR_BUFLEN]; + char* token; + int valid = 0; + int dummy; - if (!x) x = &dummy; - if (!y) y = &dummy; - if (!comp) comp = &dummy; + if (!x) + x = &dummy; + if (!y) + y = &dummy; + if (!comp) + comp = &dummy; - if (stbi__hdr_test(s) == 0) { - stbi__rewind( s ); - return 0; - } + if (stbi__hdr_test(s) == 0) { + stbi__rewind(s); + return 0; + } - for(;;) { - token = stbi__hdr_gettoken(s,buffer); - if (token[0] == 0) break; - if (strcmp(token, "FORMAT=32-bit_rle_rgbe") == 0) valid = 1; - } + for (;;) { + token = stbi__hdr_gettoken(s, buffer); + if (token[0] == 0) + break; + if (strcmp(token, "FORMAT=32-bit_rle_rgbe") == 0) + valid = 1; + } - if (!valid) { - stbi__rewind( s ); - return 0; - } - token = stbi__hdr_gettoken(s,buffer); - if (strncmp(token, "-Y ", 3)) { - stbi__rewind( s ); - return 0; - } - token += 3; - *y = (int) strtol(token, &token, 10); - while (*token == ' ') ++token; - if (strncmp(token, "+X ", 3)) { - stbi__rewind( s ); - return 0; - } - token += 3; - *x = (int) strtol(token, NULL, 10); - *comp = 3; - return 1; + if (!valid) { + stbi__rewind(s); + return 0; + } + token = stbi__hdr_gettoken(s, buffer); + if (strncmp(token, "-Y ", 3)) { + stbi__rewind(s); + return 0; + } + token += 3; + *y = (int)strtol(token, &token, 10); + while (*token == ' ') + ++token; + if (strncmp(token, "+X ", 3)) { + stbi__rewind(s); + return 0; + } + token += 3; + *x = (int)strtol(token, NULL, 10); + *comp = 3; + return 1; } #endif // STBI_NO_HDR #ifndef STBI_NO_BMP -static int stbi__bmp_info(stbi__context *s, int *x, int *y, int *comp) -{ - void *p; - stbi__bmp_data info; +static int stbi__bmp_info(stbi__context* s, int* x, int* y, int* comp) { + void* p; + stbi__bmp_data info; - info.all_a = 255; - p = stbi__bmp_parse_header(s, &info); - if (p == NULL) { - stbi__rewind( s ); - return 0; - } - if (x) *x = s->img_x; - if (y) *y = s->img_y; - if (comp) { - if (info.bpp == 24 && info.ma == 0xff000000) - *comp = 3; - else - *comp = info.ma ? 4 : 3; - } - return 1; + info.all_a = 255; + p = stbi__bmp_parse_header(s, &info); + if (p == NULL) { + stbi__rewind(s); + return 0; + } + if (x) + *x = s->img_x; + if (y) + *y = s->img_y; + if (comp) { + if (info.bpp == 24 && info.ma == 0xff000000) + *comp = 3; + else + *comp = info.ma ? 4 : 3; + } + return 1; } #endif #ifndef STBI_NO_PSD -static int stbi__psd_info(stbi__context *s, int *x, int *y, int *comp) -{ - int channelCount, dummy, depth; - if (!x) x = &dummy; - if (!y) y = &dummy; - if (!comp) comp = &dummy; - if (stbi__get32be(s) != 0x38425053) { - stbi__rewind( s ); - return 0; - } - if (stbi__get16be(s) != 1) { - stbi__rewind( s ); - return 0; - } - stbi__skip(s, 6); - channelCount = stbi__get16be(s); - if (channelCount < 0 || channelCount > 16) { - stbi__rewind( s ); - return 0; - } - *y = stbi__get32be(s); - *x = stbi__get32be(s); - depth = stbi__get16be(s); - if (depth != 8 && depth != 16) { - stbi__rewind( s ); - return 0; - } - if (stbi__get16be(s) != 3) { - stbi__rewind( s ); - return 0; - } - *comp = 4; - return 1; +static int stbi__psd_info(stbi__context* s, int* x, int* y, int* comp) { + int channelCount, dummy, depth; + if (!x) + x = &dummy; + if (!y) + y = &dummy; + if (!comp) + comp = &dummy; + if (stbi__get32be(s) != 0x38425053) { + stbi__rewind(s); + return 0; + } + if (stbi__get16be(s) != 1) { + stbi__rewind(s); + return 0; + } + stbi__skip(s, 6); + channelCount = stbi__get16be(s); + if (channelCount < 0 || channelCount > 16) { + stbi__rewind(s); + return 0; + } + *y = stbi__get32be(s); + *x = stbi__get32be(s); + depth = stbi__get16be(s); + if (depth != 8 && depth != 16) { + stbi__rewind(s); + return 0; + } + if (stbi__get16be(s) != 3) { + stbi__rewind(s); + return 0; + } + *comp = 4; + return 1; } -static int stbi__psd_is16(stbi__context *s) -{ - int channelCount, depth; - if (stbi__get32be(s) != 0x38425053) { - stbi__rewind( s ); - return 0; - } - if (stbi__get16be(s) != 1) { - stbi__rewind( s ); - return 0; - } - stbi__skip(s, 6); - channelCount = stbi__get16be(s); - if (channelCount < 0 || channelCount > 16) { - stbi__rewind( s ); - return 0; - } - STBI_NOTUSED(stbi__get32be(s)); - STBI_NOTUSED(stbi__get32be(s)); - depth = stbi__get16be(s); - if (depth != 16) { - stbi__rewind( s ); - return 0; - } - return 1; +static int stbi__psd_is16(stbi__context* s) { + int channelCount, depth; + if (stbi__get32be(s) != 0x38425053) { + stbi__rewind(s); + return 0; + } + if (stbi__get16be(s) != 1) { + stbi__rewind(s); + return 0; + } + stbi__skip(s, 6); + channelCount = stbi__get16be(s); + if (channelCount < 0 || channelCount > 16) { + stbi__rewind(s); + return 0; + } + STBI_NOTUSED(stbi__get32be(s)); + STBI_NOTUSED(stbi__get32be(s)); + depth = stbi__get16be(s); + if (depth != 16) { + stbi__rewind(s); + return 0; + } + return 1; } #endif #ifndef STBI_NO_PIC -static int stbi__pic_info(stbi__context *s, int *x, int *y, int *comp) -{ - int act_comp=0,num_packets=0,chained,dummy; - stbi__pic_packet packets[10]; +static int stbi__pic_info(stbi__context* s, int* x, int* y, int* comp) { + int act_comp = 0, num_packets = 0, chained, dummy; + stbi__pic_packet packets[10]; - if (!x) x = &dummy; - if (!y) y = &dummy; - if (!comp) comp = &dummy; + if (!x) + x = &dummy; + if (!y) + y = &dummy; + if (!comp) + comp = &dummy; - if (!stbi__pic_is4(s,"\x53\x80\xF6\x34")) { - stbi__rewind(s); - return 0; - } + if (!stbi__pic_is4(s, "\x53\x80\xF6\x34")) { + stbi__rewind(s); + return 0; + } - stbi__skip(s, 88); + stbi__skip(s, 88); - *x = stbi__get16be(s); - *y = stbi__get16be(s); - if (stbi__at_eof(s)) { - stbi__rewind( s); - return 0; - } - if ( (*x) != 0 && (1 << 28) / (*x) < (*y)) { - stbi__rewind( s ); - return 0; - } + *x = stbi__get16be(s); + *y = stbi__get16be(s); + if (stbi__at_eof(s)) { + stbi__rewind(s); + return 0; + } + if ((*x) != 0 && (1 << 28) / (*x) < (*y)) { + stbi__rewind(s); + return 0; + } - stbi__skip(s, 8); + stbi__skip(s, 8); - do { - stbi__pic_packet *packet; + do { + stbi__pic_packet* packet; - if (num_packets==sizeof(packets)/sizeof(packets[0])) - return 0; + if (num_packets == sizeof(packets) / sizeof(packets[0])) + return 0; - packet = &packets[num_packets++]; - chained = stbi__get8(s); - packet->size = stbi__get8(s); - packet->type = stbi__get8(s); - packet->channel = stbi__get8(s); - act_comp |= packet->channel; + packet = &packets[num_packets++]; + chained = stbi__get8(s); + packet->size = stbi__get8(s); + packet->type = stbi__get8(s); + packet->channel = stbi__get8(s); + act_comp |= packet->channel; - if (stbi__at_eof(s)) { - stbi__rewind( s ); - return 0; - } - if (packet->size != 8) { - stbi__rewind( s ); - return 0; - } - } while (chained); + if (stbi__at_eof(s)) { + stbi__rewind(s); + return 0; + } + if (packet->size != 8) { + stbi__rewind(s); + return 0; + } + } while (chained); - *comp = (act_comp & 0x10 ? 4 : 3); + *comp = (act_comp & 0x10 ? 4 : 3); - return 1; + return 1; } #endif @@ -7490,282 +8355,301 @@ static int stbi__pic_info(stbi__context *s, int *x, int *y, int *comp) #ifndef STBI_NO_PNM -static int stbi__pnm_test(stbi__context *s) -{ - char p, t; - p = (char) stbi__get8(s); - t = (char) stbi__get8(s); - if (p != 'P' || (t != '5' && t != '6')) { - stbi__rewind( s ); - return 0; - } - return 1; +static int stbi__pnm_test(stbi__context* s) { + char p, t; + p = (char)stbi__get8(s); + t = (char)stbi__get8(s); + if (p != 'P' || (t != '5' && t != '6')) { + stbi__rewind(s); + return 0; + } + return 1; } -static void *stbi__pnm_load(stbi__context *s, int *x, int *y, int *comp, int req_comp, stbi__result_info *ri) -{ - stbi_uc *out; - STBI_NOTUSED(ri); +static void* stbi__pnm_load(stbi__context* s, int* x, int* y, int* comp, + int req_comp, stbi__result_info* ri) { + stbi_uc* out; + STBI_NOTUSED(ri); - ri->bits_per_channel = stbi__pnm_info(s, (int *)&s->img_x, (int *)&s->img_y, (int *)&s->img_n); - if (ri->bits_per_channel == 0) - return 0; + ri->bits_per_channel = + stbi__pnm_info(s, (int*)&s->img_x, (int*)&s->img_y, (int*)&s->img_n); + if (ri->bits_per_channel == 0) + return 0; - if (s->img_y > STBI_MAX_DIMENSIONS) return stbi__errpuc("too large","Very large image (corrupt?)"); - if (s->img_x > STBI_MAX_DIMENSIONS) return stbi__errpuc("too large","Very large image (corrupt?)"); + if (s->img_y > STBI_MAX_DIMENSIONS) + return stbi__errpuc("too large", "Very large image (corrupt?)"); + if (s->img_x > STBI_MAX_DIMENSIONS) + return stbi__errpuc("too large", "Very large image (corrupt?)"); - *x = s->img_x; - *y = s->img_y; - if (comp) *comp = s->img_n; + *x = s->img_x; + *y = s->img_y; + if (comp) + *comp = s->img_n; - if (!stbi__mad4sizes_valid(s->img_n, s->img_x, s->img_y, ri->bits_per_channel / 8, 0)) - return stbi__errpuc("too large", "PNM too large"); + if (!stbi__mad4sizes_valid(s->img_n, s->img_x, s->img_y, + ri->bits_per_channel / 8, 0)) + return stbi__errpuc("too large", "PNM too large"); - out = (stbi_uc *) stbi__malloc_mad4(s->img_n, s->img_x, s->img_y, ri->bits_per_channel / 8, 0); - if (!out) return stbi__errpuc("outofmem", "Out of memory"); - if (!stbi__getn(s, out, s->img_n * s->img_x * s->img_y * (ri->bits_per_channel / 8))) { - STBI_FREE(out); - return stbi__errpuc("bad PNM", "PNM file truncated"); - } + out = (stbi_uc*)stbi__malloc_mad4(s->img_n, s->img_x, s->img_y, + ri->bits_per_channel / 8, 0); + if (!out) + return stbi__errpuc("outofmem", "Out of memory"); + if (!stbi__getn(s, out, + s->img_n * s->img_x * s->img_y * + (ri->bits_per_channel / 8))) { + STBI_FREE(out); + return stbi__errpuc("bad PNM", "PNM file truncated"); + } - if (req_comp && req_comp != s->img_n) { - if (ri->bits_per_channel == 16) { - out = (stbi_uc *) stbi__convert_format16((stbi__uint16 *) out, s->img_n, req_comp, s->img_x, s->img_y); - } else { - out = stbi__convert_format(out, s->img_n, req_comp, s->img_x, s->img_y); - } - if (out == NULL) return out; // stbi__convert_format frees input on failure - } - return out; + if (req_comp && req_comp != s->img_n) { + if (ri->bits_per_channel == 16) { + out = (stbi_uc*)stbi__convert_format16( + (stbi__uint16*)out, s->img_n, req_comp, s->img_x, s->img_y); + } else { + out = stbi__convert_format(out, s->img_n, req_comp, s->img_x, + s->img_y); + } + if (out == NULL) + return out; // stbi__convert_format frees input on failure + } + return out; } -static int stbi__pnm_isspace(char c) -{ - return c == ' ' || c == '\t' || c == '\n' || c == '\v' || c == '\f' || c == '\r'; +static int stbi__pnm_isspace(char c) { + return c == ' ' || c == '\t' || c == '\n' || c == '\v' || c == '\f' || + c == '\r'; } -static void stbi__pnm_skip_whitespace(stbi__context *s, char *c) -{ - for (;;) { - while (!stbi__at_eof(s) && stbi__pnm_isspace(*c)) - *c = (char) stbi__get8(s); +static void stbi__pnm_skip_whitespace(stbi__context* s, char* c) { + for (;;) { + while (!stbi__at_eof(s) && stbi__pnm_isspace(*c)) + *c = (char)stbi__get8(s); - if (stbi__at_eof(s) || *c != '#') - break; + if (stbi__at_eof(s) || *c != '#') + break; - while (!stbi__at_eof(s) && *c != '\n' && *c != '\r' ) - *c = (char) stbi__get8(s); - } + while (!stbi__at_eof(s) && *c != '\n' && *c != '\r') + *c = (char)stbi__get8(s); + } } -static int stbi__pnm_isdigit(char c) -{ - return c >= '0' && c <= '9'; +static int stbi__pnm_isdigit(char c) { return c >= '0' && c <= '9'; } + +static int stbi__pnm_getinteger(stbi__context* s, char* c) { + int value = 0; + + while (!stbi__at_eof(s) && stbi__pnm_isdigit(*c)) { + value = value * 10 + (*c - '0'); + *c = (char)stbi__get8(s); + if ((value > 214748364) || (value == 214748364 && *c > '7')) + return stbi__err( + "integer parse overflow", + "Parsing an integer in the PPM header overflowed a 32-bit int"); + } + + return value; } -static int stbi__pnm_getinteger(stbi__context *s, char *c) -{ - int value = 0; +static int stbi__pnm_info(stbi__context* s, int* x, int* y, int* comp) { + int maxv, dummy; + char c, p, t; - while (!stbi__at_eof(s) && stbi__pnm_isdigit(*c)) { - value = value*10 + (*c - '0'); - *c = (char) stbi__get8(s); - if((value > 214748364) || (value == 214748364 && *c > '7')) - return stbi__err("integer parse overflow", "Parsing an integer in the PPM header overflowed a 32-bit int"); - } + if (!x) + x = &dummy; + if (!y) + y = &dummy; + if (!comp) + comp = &dummy; - return value; + stbi__rewind(s); + + // Get identifier + p = (char)stbi__get8(s); + t = (char)stbi__get8(s); + if (p != 'P' || (t != '5' && t != '6')) { + stbi__rewind(s); + return 0; + } + + *comp = + (t == '6') ? 3 : 1; // '5' is 1-component .pgm; '6' is 3-component .ppm + + c = (char)stbi__get8(s); + stbi__pnm_skip_whitespace(s, &c); + + *x = stbi__pnm_getinteger(s, &c); // read width + if (*x == 0) + return stbi__err("invalid width", + "PPM image header had zero or overflowing width"); + stbi__pnm_skip_whitespace(s, &c); + + *y = stbi__pnm_getinteger(s, &c); // read height + if (*y == 0) + return stbi__err("invalid width", + "PPM image header had zero or overflowing width"); + stbi__pnm_skip_whitespace(s, &c); + + maxv = stbi__pnm_getinteger(s, &c); // read max value + if (maxv > 65535) + return stbi__err("max value > 65535", + "PPM image supports only 8-bit and 16-bit images"); + else if (maxv > 255) + return 16; + else + return 8; } -static int stbi__pnm_info(stbi__context *s, int *x, int *y, int *comp) -{ - int maxv, dummy; - char c, p, t; - - if (!x) x = &dummy; - if (!y) y = &dummy; - if (!comp) comp = &dummy; - - stbi__rewind(s); - - // Get identifier - p = (char) stbi__get8(s); - t = (char) stbi__get8(s); - if (p != 'P' || (t != '5' && t != '6')) { - stbi__rewind(s); - return 0; - } - - *comp = (t == '6') ? 3 : 1; // '5' is 1-component .pgm; '6' is 3-component .ppm - - c = (char) stbi__get8(s); - stbi__pnm_skip_whitespace(s, &c); - - *x = stbi__pnm_getinteger(s, &c); // read width - if(*x == 0) - return stbi__err("invalid width", "PPM image header had zero or overflowing width"); - stbi__pnm_skip_whitespace(s, &c); - - *y = stbi__pnm_getinteger(s, &c); // read height - if (*y == 0) - return stbi__err("invalid width", "PPM image header had zero or overflowing width"); - stbi__pnm_skip_whitespace(s, &c); - - maxv = stbi__pnm_getinteger(s, &c); // read max value - if (maxv > 65535) - return stbi__err("max value > 65535", "PPM image supports only 8-bit and 16-bit images"); - else if (maxv > 255) - return 16; - else - return 8; -} - -static int stbi__pnm_is16(stbi__context *s) -{ - if (stbi__pnm_info(s, NULL, NULL, NULL) == 16) - return 1; - return 0; +static int stbi__pnm_is16(stbi__context* s) { + if (stbi__pnm_info(s, NULL, NULL, NULL) == 16) + return 1; + return 0; } #endif -static int stbi__info_main(stbi__context *s, int *x, int *y, int *comp) -{ - #ifndef STBI_NO_JPEG - if (stbi__jpeg_info(s, x, y, comp)) return 1; - #endif +static int stbi__info_main(stbi__context* s, int* x, int* y, int* comp) { +#ifndef STBI_NO_JPEG + if (stbi__jpeg_info(s, x, y, comp)) + return 1; +#endif - #ifndef STBI_NO_PNG - if (stbi__png_info(s, x, y, comp)) return 1; - #endif +#ifndef STBI_NO_PNG + if (stbi__png_info(s, x, y, comp)) + return 1; +#endif - #ifndef STBI_NO_GIF - if (stbi__gif_info(s, x, y, comp)) return 1; - #endif +#ifndef STBI_NO_GIF + if (stbi__gif_info(s, x, y, comp)) + return 1; +#endif - #ifndef STBI_NO_BMP - if (stbi__bmp_info(s, x, y, comp)) return 1; - #endif +#ifndef STBI_NO_BMP + if (stbi__bmp_info(s, x, y, comp)) + return 1; +#endif - #ifndef STBI_NO_PSD - if (stbi__psd_info(s, x, y, comp)) return 1; - #endif +#ifndef STBI_NO_PSD + if (stbi__psd_info(s, x, y, comp)) + return 1; +#endif - #ifndef STBI_NO_PIC - if (stbi__pic_info(s, x, y, comp)) return 1; - #endif +#ifndef STBI_NO_PIC + if (stbi__pic_info(s, x, y, comp)) + return 1; +#endif - #ifndef STBI_NO_PNM - if (stbi__pnm_info(s, x, y, comp)) return 1; - #endif +#ifndef STBI_NO_PNM + if (stbi__pnm_info(s, x, y, comp)) + return 1; +#endif - #ifndef STBI_NO_HDR - if (stbi__hdr_info(s, x, y, comp)) return 1; - #endif +#ifndef STBI_NO_HDR + if (stbi__hdr_info(s, x, y, comp)) + return 1; +#endif - // test tga last because it's a crappy test! - #ifndef STBI_NO_TGA - if (stbi__tga_info(s, x, y, comp)) - return 1; - #endif - return stbi__err("unknown image type", "Image not of any known type, or corrupt"); +// test tga last because it's a crappy test! +#ifndef STBI_NO_TGA + if (stbi__tga_info(s, x, y, comp)) + return 1; +#endif + return stbi__err("unknown image type", + "Image not of any known type, or corrupt"); } -static int stbi__is_16_main(stbi__context *s) -{ - #ifndef STBI_NO_PNG - if (stbi__png_is16(s)) return 1; - #endif +static int stbi__is_16_main(stbi__context* s) { +#ifndef STBI_NO_PNG + if (stbi__png_is16(s)) + return 1; +#endif - #ifndef STBI_NO_PSD - if (stbi__psd_is16(s)) return 1; - #endif +#ifndef STBI_NO_PSD + if (stbi__psd_is16(s)) + return 1; +#endif - #ifndef STBI_NO_PNM - if (stbi__pnm_is16(s)) return 1; - #endif - return 0; +#ifndef STBI_NO_PNM + if (stbi__pnm_is16(s)) + return 1; +#endif + return 0; } #ifndef STBI_NO_STDIO -STBIDEF int stbi_info(char const *filename, int *x, int *y, int *comp) -{ - FILE *f = stbi__fopen(filename, "rb"); +STBIDEF int stbi_info(char const* filename, int* x, int* y, int* comp) { + FILE* f = stbi__fopen(filename, "rb"); int result; - if (!f) return stbi__err("can't fopen", "Unable to open file"); + if (!f) + return stbi__err("can't fopen", "Unable to open file"); result = stbi_info_from_file(f, x, y, comp); fclose(f); return result; } -STBIDEF int stbi_info_from_file(FILE *f, int *x, int *y, int *comp) -{ - int r; - stbi__context s; - long pos = ftell(f); - stbi__start_file(&s, f); - r = stbi__info_main(&s,x,y,comp); - fseek(f,pos,SEEK_SET); - return r; +STBIDEF int stbi_info_from_file(FILE* f, int* x, int* y, int* comp) { + int r; + stbi__context s; + long pos = ftell(f); + stbi__start_file(&s, f); + r = stbi__info_main(&s, x, y, comp); + fseek(f, pos, SEEK_SET); + return r; } -STBIDEF int stbi_is_16_bit(char const *filename) -{ - FILE *f = stbi__fopen(filename, "rb"); +STBIDEF int stbi_is_16_bit(char const* filename) { + FILE* f = stbi__fopen(filename, "rb"); int result; - if (!f) return stbi__err("can't fopen", "Unable to open file"); + if (!f) + return stbi__err("can't fopen", "Unable to open file"); result = stbi_is_16_bit_from_file(f); fclose(f); return result; } -STBIDEF int stbi_is_16_bit_from_file(FILE *f) -{ - int r; - stbi__context s; - long pos = ftell(f); - stbi__start_file(&s, f); - r = stbi__is_16_main(&s); - fseek(f,pos,SEEK_SET); - return r; +STBIDEF int stbi_is_16_bit_from_file(FILE* f) { + int r; + stbi__context s; + long pos = ftell(f); + stbi__start_file(&s, f); + r = stbi__is_16_main(&s); + fseek(f, pos, SEEK_SET); + return r; } #endif // !STBI_NO_STDIO -STBIDEF int stbi_info_from_memory(stbi_uc const *buffer, int len, int *x, int *y, int *comp) -{ - stbi__context s; - stbi__start_mem(&s,buffer,len); - return stbi__info_main(&s,x,y,comp); +STBIDEF int stbi_info_from_memory(stbi_uc const* buffer, int len, int* x, + int* y, int* comp) { + stbi__context s; + stbi__start_mem(&s, buffer, len); + return stbi__info_main(&s, x, y, comp); } -STBIDEF int stbi_info_from_callbacks(stbi_io_callbacks const *c, void *user, int *x, int *y, int *comp) -{ - stbi__context s; - stbi__start_callbacks(&s, (stbi_io_callbacks *) c, user); - return stbi__info_main(&s,x,y,comp); +STBIDEF int stbi_info_from_callbacks(stbi_io_callbacks const* c, void* user, + int* x, int* y, int* comp) { + stbi__context s; + stbi__start_callbacks(&s, (stbi_io_callbacks*)c, user); + return stbi__info_main(&s, x, y, comp); } -STBIDEF int stbi_is_16_bit_from_memory(stbi_uc const *buffer, int len) -{ - stbi__context s; - stbi__start_mem(&s,buffer,len); - return stbi__is_16_main(&s); +STBIDEF int stbi_is_16_bit_from_memory(stbi_uc const* buffer, int len) { + stbi__context s; + stbi__start_mem(&s, buffer, len); + return stbi__is_16_main(&s); } -STBIDEF int stbi_is_16_bit_from_callbacks(stbi_io_callbacks const *c, void *user) -{ - stbi__context s; - stbi__start_callbacks(&s, (stbi_io_callbacks *) c, user); - return stbi__is_16_main(&s); +STBIDEF int stbi_is_16_bit_from_callbacks(stbi_io_callbacks const* c, + void* user) { + stbi__context s; + stbi__start_callbacks(&s, (stbi_io_callbacks*)c, user); + return stbi__is_16_main(&s); } #endif // STB_IMAGE_IMPLEMENTATION /* revision history: - 2.20 (2019-02-07) support utf8 filenames in Windows; fix warnings and platform ifdefs - 2.19 (2018-02-11) fix warning - 2.18 (2018-01-30) fix warnings - 2.17 (2018-01-29) change sbti__shiftsigned to avoid clang -O2 bug + 2.20 (2019-02-07) support utf8 filenames in Windows; fix warnings and + platform ifdefs 2.19 (2018-02-11) fix warning 2.18 (2018-01-30) fix + warnings 2.17 (2018-01-29) change sbti__shiftsigned to avoid clang -O2 bug 1-bit BMP *_is_16_bit api avoid warnings @@ -7780,13 +8664,11 @@ STBIDEF int stbi_is_16_bit_from_callbacks(stbi_io_callbacks const *c, void *user warning fixes; disable run-time SSE detection on gcc; uniform handling of optional "return" values; thread-safe initialization of zlib tables - 2.14 (2017-03-03) remove deprecated STBI_JPEG_OLD; fixes for Imagenet JPGs - 2.13 (2016-11-29) add 16-bit API, only supported for PNG right now - 2.12 (2016-04-02) fix typo in 2.11 PSD fix that caused crashes - 2.11 (2016-04-02) allocate large structures on the stack - remove white matting for transparent PSD - fix reported channel count for PNG & BMP - re-enable SSE2 in non-gcc 64-bit + 2.14 (2017-03-03) remove deprecated STBI_JPEG_OLD; fixes for Imagenet + JPGs 2.13 (2016-11-29) add 16-bit API, only supported for PNG right now 2.12 + (2016-04-02) fix typo in 2.11 PSD fix that caused crashes 2.11 (2016-04-02) + allocate large structures on the stack remove white matting for transparent + PSD fix reported channel count for PNG & BMP re-enable SSE2 in non-gcc 64-bit support RGB-formatted JPEG read 16-bit PNGs (only as 8-bit) 2.10 (2016-01-22) avoid warning introduced in 2.09 by STBI_REALLOC_SIZED @@ -7794,11 +8676,9 @@ STBIDEF int stbi_is_16_bit_from_callbacks(stbi_io_callbacks const *c, void *user 16-bit-per-pixel TGA (not bit-per-component) info() for TGA could break due to .hdr handling info() for BMP to shares code instead of sloppy parse - can use STBI_REALLOC_SIZED if allocator doesn't support realloc - code cleanup - 2.08 (2015-09-13) fix to 2.07 cleanup, reading RGB PSD as RGBA - 2.07 (2015-09-13) fix compiler warnings - partial animated GIF support + can use STBI_REALLOC_SIZED if allocator doesn't support + realloc code cleanup 2.08 (2015-09-13) fix to 2.07 cleanup, reading RGB PSD + as RGBA 2.07 (2015-09-13) fix compiler warnings partial animated GIF support limited 16-bpc PSD support #ifdef unused functions bug with < 92 byte PIC,PNM,HDR,TGA @@ -7809,23 +8689,18 @@ STBIDEF int stbi_is_16_bit_from_callbacks(stbi_io_callbacks const *c, void *user stbi_set_flip_vertically_on_load (nguillemot) fix NEON support; fix mingw support 2.02 (2015-01-19) fix incorrect assert, fix warning - 2.01 (2015-01-17) fix various warnings; suppress SIMD on gcc 32-bit without -msse2 - 2.00b (2014-12-25) fix STBI_MALLOC in progressive JPEG - 2.00 (2014-12-25) optimize JPG, including x86 SSE2 & NEON SIMD (ryg) - progressive JPEG (stb) - PGM/PPM support (Ken Miller) - STBI_MALLOC,STBI_REALLOC,STBI_FREE + 2.01 (2015-01-17) fix various warnings; suppress SIMD on gcc 32-bit + without -msse2 2.00b (2014-12-25) fix STBI_MALLOC in progressive JPEG 2.00 + (2014-12-25) optimize JPG, including x86 SSE2 & NEON SIMD (ryg) progressive + JPEG (stb) PGM/PPM support (Ken Miller) STBI_MALLOC,STBI_REALLOC,STBI_FREE GIF bugfix -- seemingly never worked STBI_NO_*, STBI_ONLY_* 1.48 (2014-12-14) fix incorrectly-named assert() - 1.47 (2014-12-14) 1/2/4-bit PNG support, both direct and paletted (Omar Cornut & stb) - optimize PNG (ryg) - fix bug in interlaced PNG with user-specified channel count (stb) - 1.46 (2014-08-26) - fix broken tRNS chunk (colorkey-style transparency) in non-paletted PNG - 1.45 (2014-08-16) - fix MSVC-ARM internal compiler error by wrapping malloc - 1.44 (2014-08-07) + 1.47 (2014-12-14) 1/2/4-bit PNG support, both direct and paletted (Omar + Cornut & stb) optimize PNG (ryg) fix bug in interlaced PNG with + user-specified channel count (stb) 1.46 (2014-08-26) fix broken tRNS chunk + (colorkey-style transparency) in non-paletted PNG 1.45 (2014-08-16) fix + MSVC-ARM internal compiler error by wrapping malloc 1.44 (2014-08-07) various warning fixes from Ronny Chevalier 1.43 (2014-07-15) fix MSVC-only compiler problem in code changed in 1.42 @@ -7834,73 +8709,48 @@ STBIDEF int stbi_is_16_bit_from_callbacks(stbi_io_callbacks const *c, void *user fixes to stbi__cleanup_jpeg path added STBI_ASSERT to avoid requiring assert.h 1.41 (2014-06-25) - fix search&replace from 1.36 that messed up comments/error messages - 1.40 (2014-06-22) - fix gcc struct-initialization warning - 1.39 (2014-06-15) - fix to TGA optimization when req_comp != number of components in TGA; - fix to GIF loading because BMP wasn't rewinding (whoops, no GIFs in my test suite) - add support for BMP version 5 (more ignored fields) - 1.38 (2014-06-06) - suppress MSVC warnings on integer casts truncating values - fix accidental rename of 'skip' field of I/O - 1.37 (2014-06-04) - remove duplicate typedef - 1.36 (2014-06-03) - convert to header file single-file library - if de-iphone isn't set, load iphone images color-swapped instead of returning NULL - 1.35 (2014-05-27) - various warnings - fix broken STBI_SIMD path - fix bug where stbi_load_from_file no longer left file pointer in correct place - fix broken non-easy path for 32-bit BMP (possibly never used) - TGA optimization by Arseny Kapoulkine - 1.34 (unknown) - use STBI_NOTUSED in stbi__resample_row_generic(), fix one more leak in tga failure case - 1.33 (2011-07-14) - make stbi_is_hdr work in STBI_NO_HDR (as specified), minor compiler-friendly improvements - 1.32 (2011-07-13) - support for "info" function for all supported filetypes (SpartanJ) - 1.31 (2011-06-20) - a few more leak fixes, bug in PNG handling (SpartanJ) - 1.30 (2011-06-11) - added ability to load files via callbacks to accomidate custom input streams (Ben Wenger) + fix search&replace from 1.36 that messed up comments/error + messages 1.40 (2014-06-22) fix gcc struct-initialization warning 1.39 + (2014-06-15) fix to TGA optimization when req_comp != number of components in + TGA; fix to GIF loading because BMP wasn't rewinding (whoops, no GIFs in my + test suite) add support for BMP version 5 (more ignored fields) 1.38 + (2014-06-06) suppress MSVC warnings on integer casts truncating values fix + accidental rename of 'skip' field of I/O 1.37 (2014-06-04) remove duplicate + typedef 1.36 (2014-06-03) convert to header file single-file library if + de-iphone isn't set, load iphone images color-swapped instead of returning + NULL 1.35 (2014-05-27) various warnings fix broken STBI_SIMD path fix bug + where stbi_load_from_file no longer left file pointer in correct place fix + broken non-easy path for 32-bit BMP (possibly never used) TGA optimization by + Arseny Kapoulkine 1.34 (unknown) use STBI_NOTUSED in + stbi__resample_row_generic(), fix one more leak in tga failure case 1.33 + (2011-07-14) make stbi_is_hdr work in STBI_NO_HDR (as specified), minor + compiler-friendly improvements 1.32 (2011-07-13) support for "info" function + for all supported filetypes (SpartanJ) 1.31 (2011-06-20) a few more leak + fixes, bug in PNG handling (SpartanJ) 1.30 (2011-06-11) added ability to + load files via callbacks to accomidate custom input streams (Ben Wenger) removed deprecated format-specific test/load functions - removed support for installable file formats (stbi_loader) -- would have been broken for IO callbacks anyway - error cases in bmp and tga give messages and don't leak (Raymond Barbiero, grisha) - fix inefficiency in decoding 32-bit BMP (David Woo) - 1.29 (2010-08-16) - various warning fixes from Aurelien Pocheville - 1.28 (2010-08-01) - fix bug in GIF palette transparency (SpartanJ) - 1.27 (2010-08-01) - cast-to-stbi_uc to fix warnings - 1.26 (2010-07-24) - fix bug in file buffering for PNG reported by SpartanJ - 1.25 (2010-07-17) - refix trans_data warning (Won Chun) - 1.24 (2010-07-12) - perf improvements reading from files on platforms with lock-heavy fgetc() - minor perf improvements for jpeg - deprecated type-specific functions so we'll get feedback if they're needed - attempt to fix trans_data warning (Won Chun) - 1.23 fixed bug in iPhone support - 1.22 (2010-07-10) - removed image *writing* support - stbi_info support from Jetro Lauha - GIF support from Jean-Marc Lienher + removed support for installable file formats (stbi_loader) -- + would have been broken for IO callbacks anyway error cases in bmp and tga + give messages and don't leak (Raymond Barbiero, grisha) fix inefficiency in + decoding 32-bit BMP (David Woo) 1.29 (2010-08-16) various warning fixes from + Aurelien Pocheville 1.28 (2010-08-01) fix bug in GIF palette transparency + (SpartanJ) 1.27 (2010-08-01) cast-to-stbi_uc to fix warnings 1.26 + (2010-07-24) fix bug in file buffering for PNG reported by SpartanJ 1.25 + (2010-07-17) refix trans_data warning (Won Chun) 1.24 (2010-07-12) perf + improvements reading from files on platforms with lock-heavy fgetc() minor + perf improvements for jpeg deprecated type-specific functions so we'll get + feedback if they're needed attempt to fix trans_data warning (Won Chun) 1.23 + fixed bug in iPhone support 1.22 (2010-07-10) removed image *writing* + support stbi_info support from Jetro Lauha GIF support from Jean-Marc Lienher iPhone PNG-extensions from James Brown - warning-fixes from Nicolas Schulz and Janez Zemva (i.stbi__err. Janez (U+017D)emva) - 1.21 fix use of 'stbi_uc' in header (reported by jon blow) - 1.20 added support for Softimage PIC, by Tom Seddon - 1.19 bug in interlaced PNG corruption check (found by ryg) - 1.18 (2008-08-02) - fix a threading bug (local mutable static) - 1.17 support interlaced PNG - 1.16 major bugfix - stbi__convert_format converted one too many pixels - 1.15 initialize some fields for thread safety - 1.14 fix threadsafe conversion bug - header-file-only version (#define STBI_HEADER_FILE_ONLY before including) + warning-fixes from Nicolas Schulz and Janez Zemva (i.stbi__err. + Janez (U+017D)emva) 1.21 fix use of 'stbi_uc' in header (reported by jon + blow) 1.20 added support for Softimage PIC, by Tom Seddon 1.19 bug in + interlaced PNG corruption check (found by ryg) 1.18 (2008-08-02) fix a + threading bug (local mutable static) 1.17 support interlaced PNG 1.16 + major bugfix - stbi__convert_format converted one too many pixels 1.15 + initialize some fields for thread safety 1.14 fix threadsafe conversion + bug header-file-only version (#define STBI_HEADER_FILE_ONLY before including) 1.13 threadsafe 1.12 const qualifiers in the API 1.11 Support installable IDCT, colorspace conversion routines @@ -7910,15 +8760,14 @@ STBIDEF int stbi_is_16_bit_from_callbacks(stbi_io_callbacks const *c, void *user 1.08 Thatcher Ulrich's PSD code integrated by Nicolas Schulz 1.07 attempt to fix C++ warning/errors again 1.06 attempt to fix C++ warning/errors again - 1.05 fix TGA loading to return correct *comp and use good luminance calc - 1.04 default float alpha is 1, not 255; use 'void *' for stbi_image_free - 1.03 bugfixes to STBI_NO_STDIO, STBI_NO_HDR - 1.02 support for (subset of) HDR files, float interface for preferred access to them - 1.01 fix bug: possible bug in handling right-side up bmps... not sure - fix bug: the stbi__bmp_load() and stbi__tga_load() functions didn't work at all - 1.00 interface to zlib that skips zlib header - 0.99 correct handling of alpha in palette - 0.98 TGA loader by lonesock; dynamically add loaders (untested) + 1.05 fix TGA loading to return correct *comp and use good luminance + calc 1.04 default float alpha is 1, not 255; use 'void *' for + stbi_image_free 1.03 bugfixes to STBI_NO_STDIO, STBI_NO_HDR 1.02 support + for (subset of) HDR files, float interface for preferred access to them 1.01 + fix bug: possible bug in handling right-side up bmps... not sure fix bug: the + stbi__bmp_load() and stbi__tga_load() functions didn't work at all 1.00 + interface to zlib that skips zlib header 0.99 correct handling of alpha in + palette 0.98 TGA loader by lonesock; dynamically add loaders (untested) 0.97 jpeg errors on too large a file; also catch another malloc failure 0.96 fix detection of invalid v value - particleman@mollyrocket forum 0.95 during header scan, seek to markers in case of padding @@ -7931,8 +8780,8 @@ STBIDEF int stbi_is_16_bit_from_callbacks(stbi_io_callbacks const *c, void *user 0.60 fix compiling as c++ 0.59 fix warnings: merge Dave Moore's -Wall fixes 0.58 fix bug: zlib uncompressed mode len/nlen was wrong endian - 0.57 fix bug: jpg last huffman symbol before marker was >9 bits but less than 16 available - 0.56 fix bug: zlib uncompressed mode len vs. nlen + 0.57 fix bug: jpg last huffman symbol before marker was >9 bits but + less than 16 available 0.56 fix bug: zlib uncompressed mode len vs. nlen 0.55 fix bug: restart_interval not initialized to 0 0.54 allow NULL for 'int *comp' 0.53 fix bug in png 3->4; speedup png decoding @@ -7943,7 +8792,6 @@ STBIDEF int stbi_is_16_bit_from_callbacks(stbi_io_callbacks const *c, void *user first released version */ - /* ------------------------------------------------------------------------------ This software is available under 2 licenses -- choose whichever you prefer. @@ -7984,4 +8832,4 @@ AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ------------------------------------------------------------------------------ -*/ \ No newline at end of file +*/ From 63ed430627a6985fa1463e0326ec8846e17f2de7 Mon Sep 17 00:00:00 2001 From: Hartmut Seichter Date: Tue, 23 Sep 2025 23:02:40 +0200 Subject: [PATCH 2/2] remove erronous folder --- .../index/bitmap.hpp.62887C634633116B.idx | Bin 1676 -> 0 bytes .../index/bitmap.hpp.EEDEB52DF9368726.idx | Bin 1676 -> 0 bytes .../index/bitmap_io.cpp.181EA33891BBC2AF.idx | Bin 2966 -> 0 bytes .../index/bitmap_io.cpp.4AB5E576AFA93983.idx | Bin 2906 -> 0 bytes .../index/bitmap_io.hpp.C3324F345C5DD5D2.idx | Bin 1642 -> 0 bytes .../index/bitmap_io.hpp.E43B2188CF8AB392.idx | Bin 1108 -> 0 bytes .../index/context.c.91BC96CF7BD16B3C.idx | Bin 13008 -> 0 bytes .../index/context.c.ACB36D59D1DFD31C.idx | Bin 13008 -> 0 bytes .../index/context.cpp.4F65C2A62FFB483F.idx | Bin 2924 -> 0 bytes .../index/context.cpp.EECF18BC474ACA88.idx | Bin 2930 -> 0 bytes .../index/context.hpp.0247079C4DA06A0E.idx | Bin 1544 -> 0 bytes .../index/context.hpp.30BB9F8B4501681D.idx | Bin 1544 -> 0 bytes .../index/egl_context.c.225C06C339B7DDA1.idx | Bin 18206 -> 0 bytes .../index/egl_context.c.CD53B506C4A00245.idx | Bin 18214 -> 0 bytes .../index/egl_context.h.04386B6C0A7119A7.idx | Bin 8170 -> 0 bytes .../index/egl_context.h.B2730FCAFD4752C9.idx | Bin 8170 -> 0 bytes .../index/geometry.hpp.5CBEA5776F164981.idx | Bin 1836 -> 0 bytes .../index/geometry.hpp.D38DA0C44333DD06.idx | Bin 1836 -> 0 bytes .../clangd/index/glad.c.6ADEBFBBDDE6583D.idx | Bin 528840 -> 0 bytes .../clangd/index/glad.c.DC115C5ADDB0D90B.idx | Bin 528840 -> 0 bytes .../clangd/index/glad.h.75CCCDA1A3F702AC.idx | Bin 1008432 -> 0 bytes .../clangd/index/glad.h.76E6696D4B8D4E14.idx | Bin 1008432 -> 0 bytes .../clangd/index/glfw3.h.5A7452531BE9304F.idx | Bin 52826 -> 0 bytes .../clangd/index/glfw3.h.AAFA18C8892E0F92.idx | Bin 52826 -> 0 bytes .../index/globals.hpp.24BCAC15858D1B89.idx | Bin 404 -> 0 bytes .../index/globals.hpp.380C15F700EE3EE1.idx | Bin 404 -> 0 bytes .../index/glx_context.c.7EDF51863382D2CB.idx | Bin 16858 -> 0 bytes .../index/glx_context.c.B0ADB84DEBD4B2AA.idx | Bin 16850 -> 0 bytes .../index/glx_context.h.256A85A14326A9DC.idx | Bin 7594 -> 0 bytes .../index/glx_context.h.E85BD630F7223469.idx | Bin 7594 -> 0 bytes .../clangd/index/init.c.55CFCFFC01384B65.idx | Bin 8760 -> 0 bytes .../clangd/index/init.c.A2467C96C1716714.idx | Bin 8878 -> 0 bytes .../clangd/index/input.c.7252BD8769C990CB.idx | Bin 35194 -> 0 bytes .../clangd/index/input.c.DED1B4400041FF44.idx | Bin 35194 -> 0 bytes .../index/internal.h.445CD411983AEDF9.idx | Bin 38154 -> 0 bytes .../index/internal.h.DE6A02CC46470B84.idx | Bin 38156 -> 0 bytes .../index/khrplatform.h.29E603D3A52AEC6A.idx | Bin 2172 -> 0 bytes .../index/khrplatform.h.D6CEFEA22454BFC5.idx | Bin 2172 -> 0 bytes .../linux_joystick.c.0B324179DA9FB60F.idx | Bin 7240 -> 0 bytes .../linux_joystick.c.792A25E4FD082BE3.idx | Bin 7238 -> 0 bytes .../linux_joystick.h.6D80310652F4A3A1.idx | Bin 1648 -> 0 bytes .../linux_joystick.h.F9013A3DE8A76987.idx | Bin 1658 -> 0 bytes .../index/mappings.h.2B5E5627F59980DE.idx | Bin 820 -> 0 bytes .../index/mappings.h.DE572F1D18327736.idx | Bin 820 -> 0 bytes .../index/matrix.hpp.82213AF3AAC74723.idx | Bin 4130 -> 0 bytes .../index/matrix.hpp.B61CADF6F0D53E3B.idx | Bin 4084 -> 0 bytes .../index/matrixbase.hpp.60D06CA21577625A.idx | Bin 3932 -> 0 bytes .../index/matrixbase.hpp.F11E20E9DFADCEFF.idx | Bin 4384 -> 0 bytes .../index/monitor.c.8465A82AF6ED1794.idx | Bin 12734 -> 0 bytes .../index/monitor.c.AEB0C2DC26515679.idx | Bin 12734 -> 0 bytes .../osmesa_context.c.1EE9BEC9D6A3E34A.idx | Bin 7978 -> 0 bytes .../osmesa_context.c.9D0E9B593E3B91C8.idx | Bin 7984 -> 0 bytes .../osmesa_context.h.0C7F09075E273648.idx | Bin 2996 -> 0 bytes .../osmesa_context.h.141748BA6847E054.idx | Bin 2996 -> 0 bytes .../index/pong.cpp.0666B09B2C5A6C2D.idx | Bin 7564 -> 0 bytes .../index/pong.cpp.5E4CD60C67D0940C.idx | Bin 7564 -> 0 bytes .../index/posix_thread.c.3F3583255D9A0824.idx | Bin 2120 -> 0 bytes .../index/posix_thread.c.97BD9159EEF76B84.idx | Bin 2120 -> 0 bytes .../index/posix_thread.h.0D3851D1D9279E82.idx | Bin 894 -> 0 bytes .../index/posix_thread.h.2D23296B7CFBFCA2.idx | Bin 894 -> 0 bytes .../index/posix_time.c.4CBE14BF15C8C278.idx | Bin 1472 -> 0 bytes .../index/posix_time.c.EEC0949F9BB68444.idx | Bin 1472 -> 0 bytes .../index/posix_time.h.690873C37A0312EE.idx | Bin 672 -> 0 bytes .../index/posix_time.h.B922C8D5550AB845.idx | Bin 668 -> 0 bytes .../index/quickwings.cpp.85EA7B40D80DA419.idx | Bin 1086 -> 0 bytes .../index/quickwings.cpp.C395FD54968A1134.idx | Bin 14758 -> 0 bytes .../index/renderer.cpp.740BAA1FB38348C8.idx | Bin 7992 -> 0 bytes .../index/renderer.cpp.C9C31387983FB261.idx | Bin 7980 -> 0 bytes .../index/renderer.hpp.8430C86236A009AE.idx | Bin 856 -> 0 bytes .../index/renderer.hpp.926D47CDCF3C1D01.idx | Bin 856 -> 0 bytes .../index/rgba.hpp.BA781889E6CDBAD7.idx | Bin 1844 -> 0 bytes .../index/rgba.hpp.FC678113A439A522.idx | Bin 1844 -> 0 bytes .../index/shader.cpp.43E3518708249EAE.idx | Bin 6122 -> 0 bytes .../index/shader.cpp.7A00B3A7CCD89C12.idx | Bin 5988 -> 0 bytes .../index/shader.hpp.DF5CE306CA970394.idx | Bin 3134 -> 0 bytes .../index/shader.hpp.E7CD36D8F71952ED.idx | Bin 3134 -> 0 bytes .../shader_sprite.hpp.493F804E562576C3.idx | Bin 328 -> 0 bytes .../shader_sprite.hpp.8B17A178D93F0BE6.idx | Bin 328 -> 0 bytes .../index/simple.cpp.96D892360BBE0299.idx | Bin 2360 -> 0 bytes .../index/simple.cpp.C6B37DEAE25C79D2.idx | Bin 2236 -> 0 bytes .../index/sprite.hpp.A9098C65589F3A19.idx | Bin 1560 -> 0 bytes .../index/sprite.hpp.CC3066F6ABEF70A9.idx | Bin 1536 -> 0 bytes .../index/stb_image.h.66C3FB4B07894FDB.idx | Bin 113950 -> 0 bytes .../index/stb_image.h.A40CF375DB872323.idx | Bin 116022 -> 0 bytes .../index/vector.hpp.3A192E43B974E9B2.idx | Bin 2008 -> 0 bytes .../index/vector.hpp.E320F2C0D8CBC593.idx | Bin 1896 -> 0 bytes .../index/vulkan.c.F1AE9249ACD23954.idx | Bin 6430 -> 0 bytes .../index/vulkan.c.F75EB52C23E5F7F6.idx | Bin 6432 -> 0 bytes .../index/window.c.ACCD05B2BA43D003.idx | Bin 38376 -> 0 bytes .../index/window.c.CE66238555157A64.idx | Bin 38376 -> 0 bytes .../index/window.cpp.75FB94300CFB46BA.idx | Bin 8644 -> 0 bytes .../index/window.cpp.C49665C3E96358E9.idx | Bin 8470 -> 0 bytes .../index/window.hpp.B8A7D1770B434EEC.idx | Bin 2632 -> 0 bytes .../index/window.hpp.F8FA2942270CA4B4.idx | Bin 2630 -> 0 bytes .../index/x11_init.c.5062A2FC3E2A7E6D.idx | Bin 40104 -> 0 bytes .../index/x11_init.c.F00A5A0A2091891E.idx | Bin 40006 -> 0 bytes .../index/x11_monitor.c.271D126498E8CFAE.idx | Bin 15882 -> 0 bytes .../index/x11_monitor.c.EA1D4A157A0E438E.idx | Bin 15876 -> 0 bytes .../index/x11_platform.h.1DDD554B1F22A6A0.idx | Bin 23928 -> 0 bytes .../index/x11_platform.h.56FB194C0C211696.idx | Bin 23898 -> 0 bytes .../index/x11_window.c.241536F32C8627F0.idx | Bin 65048 -> 0 bytes .../index/x11_window.c.8BEA32FE82C65B89.idx | Bin 65036 -> 0 bytes .../index/xkb_unicode.c.31E6598E6573D51F.idx | Bin 900 -> 0 bytes .../index/xkb_unicode.c.757568D7EEC6A2FA.idx | Bin 900 -> 0 bytes .../index/xkb_unicode.h.53CF8CB5C8862029.idx | Bin 322 -> 0 bytes .../index/xkb_unicode.h.93B1782F55B08538.idx | Bin 322 -> 0 bytes 106 files changed, 0 insertions(+), 0 deletions(-) delete mode 100644 .cache/clangd/index/bitmap.hpp.62887C634633116B.idx delete mode 100644 .cache/clangd/index/bitmap.hpp.EEDEB52DF9368726.idx delete mode 100644 .cache/clangd/index/bitmap_io.cpp.181EA33891BBC2AF.idx delete mode 100644 .cache/clangd/index/bitmap_io.cpp.4AB5E576AFA93983.idx delete mode 100644 .cache/clangd/index/bitmap_io.hpp.C3324F345C5DD5D2.idx delete mode 100644 .cache/clangd/index/bitmap_io.hpp.E43B2188CF8AB392.idx delete mode 100644 .cache/clangd/index/context.c.91BC96CF7BD16B3C.idx delete mode 100644 .cache/clangd/index/context.c.ACB36D59D1DFD31C.idx delete mode 100644 .cache/clangd/index/context.cpp.4F65C2A62FFB483F.idx delete mode 100644 .cache/clangd/index/context.cpp.EECF18BC474ACA88.idx delete mode 100644 .cache/clangd/index/context.hpp.0247079C4DA06A0E.idx delete mode 100644 .cache/clangd/index/context.hpp.30BB9F8B4501681D.idx delete mode 100644 .cache/clangd/index/egl_context.c.225C06C339B7DDA1.idx delete mode 100644 .cache/clangd/index/egl_context.c.CD53B506C4A00245.idx delete mode 100644 .cache/clangd/index/egl_context.h.04386B6C0A7119A7.idx delete mode 100644 .cache/clangd/index/egl_context.h.B2730FCAFD4752C9.idx delete mode 100644 .cache/clangd/index/geometry.hpp.5CBEA5776F164981.idx delete mode 100644 .cache/clangd/index/geometry.hpp.D38DA0C44333DD06.idx delete mode 100644 .cache/clangd/index/glad.c.6ADEBFBBDDE6583D.idx delete mode 100644 .cache/clangd/index/glad.c.DC115C5ADDB0D90B.idx delete mode 100644 .cache/clangd/index/glad.h.75CCCDA1A3F702AC.idx delete mode 100644 .cache/clangd/index/glad.h.76E6696D4B8D4E14.idx delete mode 100644 .cache/clangd/index/glfw3.h.5A7452531BE9304F.idx delete mode 100644 .cache/clangd/index/glfw3.h.AAFA18C8892E0F92.idx delete mode 100644 .cache/clangd/index/globals.hpp.24BCAC15858D1B89.idx delete mode 100644 .cache/clangd/index/globals.hpp.380C15F700EE3EE1.idx delete mode 100644 .cache/clangd/index/glx_context.c.7EDF51863382D2CB.idx delete mode 100644 .cache/clangd/index/glx_context.c.B0ADB84DEBD4B2AA.idx delete mode 100644 .cache/clangd/index/glx_context.h.256A85A14326A9DC.idx delete mode 100644 .cache/clangd/index/glx_context.h.E85BD630F7223469.idx delete mode 100644 .cache/clangd/index/init.c.55CFCFFC01384B65.idx delete mode 100644 .cache/clangd/index/init.c.A2467C96C1716714.idx delete mode 100644 .cache/clangd/index/input.c.7252BD8769C990CB.idx delete mode 100644 .cache/clangd/index/input.c.DED1B4400041FF44.idx delete mode 100644 .cache/clangd/index/internal.h.445CD411983AEDF9.idx delete mode 100644 .cache/clangd/index/internal.h.DE6A02CC46470B84.idx delete mode 100644 .cache/clangd/index/khrplatform.h.29E603D3A52AEC6A.idx delete mode 100644 .cache/clangd/index/khrplatform.h.D6CEFEA22454BFC5.idx delete mode 100644 .cache/clangd/index/linux_joystick.c.0B324179DA9FB60F.idx delete mode 100644 .cache/clangd/index/linux_joystick.c.792A25E4FD082BE3.idx delete mode 100644 .cache/clangd/index/linux_joystick.h.6D80310652F4A3A1.idx delete mode 100644 .cache/clangd/index/linux_joystick.h.F9013A3DE8A76987.idx delete mode 100644 .cache/clangd/index/mappings.h.2B5E5627F59980DE.idx delete mode 100644 .cache/clangd/index/mappings.h.DE572F1D18327736.idx delete mode 100644 .cache/clangd/index/matrix.hpp.82213AF3AAC74723.idx delete mode 100644 .cache/clangd/index/matrix.hpp.B61CADF6F0D53E3B.idx delete mode 100644 .cache/clangd/index/matrixbase.hpp.60D06CA21577625A.idx delete mode 100644 .cache/clangd/index/matrixbase.hpp.F11E20E9DFADCEFF.idx delete mode 100644 .cache/clangd/index/monitor.c.8465A82AF6ED1794.idx delete mode 100644 .cache/clangd/index/monitor.c.AEB0C2DC26515679.idx delete mode 100644 .cache/clangd/index/osmesa_context.c.1EE9BEC9D6A3E34A.idx delete mode 100644 .cache/clangd/index/osmesa_context.c.9D0E9B593E3B91C8.idx delete mode 100644 .cache/clangd/index/osmesa_context.h.0C7F09075E273648.idx delete mode 100644 .cache/clangd/index/osmesa_context.h.141748BA6847E054.idx delete mode 100644 .cache/clangd/index/pong.cpp.0666B09B2C5A6C2D.idx delete mode 100644 .cache/clangd/index/pong.cpp.5E4CD60C67D0940C.idx delete mode 100644 .cache/clangd/index/posix_thread.c.3F3583255D9A0824.idx delete mode 100644 .cache/clangd/index/posix_thread.c.97BD9159EEF76B84.idx delete mode 100644 .cache/clangd/index/posix_thread.h.0D3851D1D9279E82.idx delete mode 100644 .cache/clangd/index/posix_thread.h.2D23296B7CFBFCA2.idx delete mode 100644 .cache/clangd/index/posix_time.c.4CBE14BF15C8C278.idx delete mode 100644 .cache/clangd/index/posix_time.c.EEC0949F9BB68444.idx delete mode 100644 .cache/clangd/index/posix_time.h.690873C37A0312EE.idx delete mode 100644 .cache/clangd/index/posix_time.h.B922C8D5550AB845.idx delete mode 100644 .cache/clangd/index/quickwings.cpp.85EA7B40D80DA419.idx delete mode 100644 .cache/clangd/index/quickwings.cpp.C395FD54968A1134.idx delete mode 100644 .cache/clangd/index/renderer.cpp.740BAA1FB38348C8.idx delete mode 100644 .cache/clangd/index/renderer.cpp.C9C31387983FB261.idx delete mode 100644 .cache/clangd/index/renderer.hpp.8430C86236A009AE.idx delete mode 100644 .cache/clangd/index/renderer.hpp.926D47CDCF3C1D01.idx delete mode 100644 .cache/clangd/index/rgba.hpp.BA781889E6CDBAD7.idx delete mode 100644 .cache/clangd/index/rgba.hpp.FC678113A439A522.idx delete mode 100644 .cache/clangd/index/shader.cpp.43E3518708249EAE.idx delete mode 100644 .cache/clangd/index/shader.cpp.7A00B3A7CCD89C12.idx delete mode 100644 .cache/clangd/index/shader.hpp.DF5CE306CA970394.idx delete mode 100644 .cache/clangd/index/shader.hpp.E7CD36D8F71952ED.idx delete mode 100644 .cache/clangd/index/shader_sprite.hpp.493F804E562576C3.idx delete mode 100644 .cache/clangd/index/shader_sprite.hpp.8B17A178D93F0BE6.idx delete mode 100644 .cache/clangd/index/simple.cpp.96D892360BBE0299.idx delete mode 100644 .cache/clangd/index/simple.cpp.C6B37DEAE25C79D2.idx delete mode 100644 .cache/clangd/index/sprite.hpp.A9098C65589F3A19.idx delete mode 100644 .cache/clangd/index/sprite.hpp.CC3066F6ABEF70A9.idx delete mode 100644 .cache/clangd/index/stb_image.h.66C3FB4B07894FDB.idx delete mode 100644 .cache/clangd/index/stb_image.h.A40CF375DB872323.idx delete mode 100644 .cache/clangd/index/vector.hpp.3A192E43B974E9B2.idx delete mode 100644 .cache/clangd/index/vector.hpp.E320F2C0D8CBC593.idx delete mode 100644 .cache/clangd/index/vulkan.c.F1AE9249ACD23954.idx delete mode 100644 .cache/clangd/index/vulkan.c.F75EB52C23E5F7F6.idx delete mode 100644 .cache/clangd/index/window.c.ACCD05B2BA43D003.idx delete mode 100644 .cache/clangd/index/window.c.CE66238555157A64.idx delete mode 100644 .cache/clangd/index/window.cpp.75FB94300CFB46BA.idx delete mode 100644 .cache/clangd/index/window.cpp.C49665C3E96358E9.idx delete mode 100644 .cache/clangd/index/window.hpp.B8A7D1770B434EEC.idx delete mode 100644 .cache/clangd/index/window.hpp.F8FA2942270CA4B4.idx delete mode 100644 .cache/clangd/index/x11_init.c.5062A2FC3E2A7E6D.idx delete mode 100644 .cache/clangd/index/x11_init.c.F00A5A0A2091891E.idx delete mode 100644 .cache/clangd/index/x11_monitor.c.271D126498E8CFAE.idx delete mode 100644 .cache/clangd/index/x11_monitor.c.EA1D4A157A0E438E.idx delete mode 100644 .cache/clangd/index/x11_platform.h.1DDD554B1F22A6A0.idx delete mode 100644 .cache/clangd/index/x11_platform.h.56FB194C0C211696.idx delete mode 100644 .cache/clangd/index/x11_window.c.241536F32C8627F0.idx delete mode 100644 .cache/clangd/index/x11_window.c.8BEA32FE82C65B89.idx delete mode 100644 .cache/clangd/index/xkb_unicode.c.31E6598E6573D51F.idx delete mode 100644 .cache/clangd/index/xkb_unicode.c.757568D7EEC6A2FA.idx delete mode 100644 .cache/clangd/index/xkb_unicode.h.53CF8CB5C8862029.idx delete mode 100644 .cache/clangd/index/xkb_unicode.h.93B1782F55B08538.idx diff --git a/.cache/clangd/index/bitmap.hpp.62887C634633116B.idx b/.cache/clangd/index/bitmap.hpp.62887C634633116B.idx deleted file mode 100644 index 76c67da0cdb218ee3fa5e89c4be87f3b6cfe7e84..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1676 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 diff --git a/.cache/clangd/index/bitmap_io.cpp.181EA33891BBC2AF.idx b/.cache/clangd/index/bitmap_io.cpp.181EA33891BBC2AF.idx deleted file mode 100644 index bf0d13272424ae63875fe4679c049c5d4fc4eaed..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2966 zcmY*b3se(l7M?#43CTd7B$*IE2m}ftf-EK~l4XGi$U{-7?eRqr#b9Jjutu;vy1_;T z7i;Y*QrWWA*5ZTK>QOvCaSJ}`ig;Gi$_kZ`B zJIT*9n>PyxB6Ufo(^gzw=uHrW4F5aI?aSvQg5cu?XY=m-i@BX~q8lyW$~=2w=Z8JI zDxWF5B5027x}}xps`r1``f}Q;zenVYt$UYTJm~Rwg1m}OZx215YB_8$PB=vN{ZRa< z-C4;wBHwm!)|`!&o9UnbC~lqmalPL{@2h7$f9f+IzudoL@XMk0_+4rD-={7&FG~I5 z#o~mjC)Mjkg2g+jIKN9?8uFy3;nKXOP5LV}*K-qhZ@%!!=HS4mk{`E!UH`3vkvs>QUTKUx5czRi*W3A2d2Ily1gXN4U9fvxO2C)%B*>Ha*i0+ zcJiGPZDG)5^B~ty~NLzsU^dFy7 zFQA7U{%8YXnWUUXXVQeQo)I@<);y;S1zJo32`$&pc|s?so6mQi-8JrJzIzN(w6PuIudST{;^qbUIV zoqv`co0;A<2|J>+QIXJJ;0D8|1qP=fDV?`Y3SA!AFuZw4|4p8kjH*SVS|ow~$f!Ex zTZaVDZ@TCdH%fw{Tu0B_clBS-q9J3@01`u%*cle4yz`}F!A)KPMrPOABViMKb5x_U z24rdsK~jt403p2Or`&FF`a&;~!U_rj4oRxSRFVlfNU8>jYfvBrsm=wpokdBkDZAP}9)jMUzjDjmhTi2!O=U-9>mf6IV_ft@#o{WHl`*mL+wNp|wG7&@rlJC( zC}5kUY}0HhP=I^GQ*f?1sT?1?4k_x85@_uFbmmGwGtY%9JHwo@prUu5p1VJ1))N;_ zni!ZE20%#4pf+g0+Mc_1Xlu8!4r|I{w4}i@zF*ZKW= z49FxhNg>veQV{C+nY$6g$%@WOfaUMwxc~JLDmLLt2C;#8QUZ0UymS6VTkvkH&dR8F z_xhJh!#}do%kjMUC`ck7iD`du)2{_D8%%}_SO&tp`J-b8NXGmH+g=0yNKBic4#|Nw z600xCji!V8{&Bq{PrJ*#8%rbl578!&I+ljCB$!Q7O;v}3FhKEK{^&eo>sm>xgblGq zSYueLR9Z^0mYuXSJ8w_ClhIiK@MJ);eu*3K7#C7C~kK^+thb3zv4IW%tQ#5O3g=aBzzsPAB zEdTeLUvbscWXa?J*rcXXgHuCUD=j!}jFldoKE^T!n;8q3$5ZjukOy7maeG8F_7ry0 zPi2DM0GUa=Ey{&-5Jz{6??(R6vEnn2XD2rZ{zZ#dX<-z;?yLSz-Uo&rx{)c-)7eI5 z2W2zDC#hm#F>@l2G)6|hT>#f(%}<}@p+kL`;zV8IRKT_1lS)3%cj`U7yh^-^nNvOY z&X#qUt_@)3vt(IJ?p@}jMT>tf8N%Z*Tbj)XU-o|h@WdM7A2UUj_S@Bb|b=# zcpxZRU_v)ifQ^4StSF>^r8w+Gj@k5$lD@q91i}qL1hKa&<`z*?lAl$~?<)5hr&I*0 kgH(i?@evC4w#c?*g&3QDLLtZ7XB?O3Me;Si0_0Ep52%IoIsgCw diff --git a/.cache/clangd/index/bitmap_io.cpp.4AB5E576AFA93983.idx b/.cache/clangd/index/bitmap_io.cpp.4AB5E576AFA93983.idx deleted file mode 100644 index a6d21675c2ec0a8a1c964c2190402835ef0ba093..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2906 zcmYjT30RZo9sj-@9LYy6$oGaT$d!;K5LB84upCyRNR@~-t5A(XlP88l7HAsmf>I=) zBG1F)IUfr}XYoK=I%h4Lr31ujyLJ?7@v06Gv2Lx`)QN0+gZ(GTle~QY`~Uv_$45b~ zPFKJsh*#dsb(EW`*RlwL5aC}{wQXG?Nf6JN1mW0!s9;HHe=_x5`(?#Q;g!GY-rsZT z>g3wHrgZ;vhTyq!-l^fCjlEjcs*Zz?m}Sjfw>#x8GfO_-Yuk|5@||I*>s8U3FQ43c z`23-Ggrh79HuN?0a8FMPM>z7GkLfczEY)>Atsg9}mZh~7S$DqmdRT{R@57=+nj2*o zI-lR!z>DInxvNMH{EAUEUVb}n_Mz)k`pis&`)mD2(sDYtr)|-$ zD45i5(|o`C%To;NDVr7lnH9MnM z-@IP;W8MDWoN2nct~eddiTq}?@7%`SgYVrf+&OUU<-CZ09ya{2WMaDSQC;V}vjO+h zqYh{IA3x4-8CW@TqI+p;?5-!y>|C;0%+XD+)D-SB{cpAIVB?Cz?|*n?&B=(tuhII^ zZL5o!Q%A6ruU)k}9B2(jij&_~iLFgs z6MyCa>*g;uUG6fx{RbW+7>gBQiujoW#GL4aiBd^k7mpEw#fc$_VKWDahw@4oQ~P+s zB1Qy`?FexoIz}8Lf!N%mL)w@A;Ws8=#9(n9$*&_3Een(hL1EF<%@fZy<^BgJhZUSc zrwLE%d+E4l0wR8WfA~=A>1(< z=-{!j_A0?D1llW>isX~6^Vlp3WePJrYzk$Gv%*1%LixgcADLdP_sG7EeW&T&jOBbB z&YEGJ56D9K8JwBgmy30uXHA7pQ^>Bh&x7i8zcDiBKr>(DwiQ~%V0+>%zlx{hr4r08 z3M-OA7RO%K@P-e3E5kRiBwOZ!wpq0K^1uE6F2`&eZIc4~-LvaI)#sekV75Z0kV8oU z4xE>}=^#xCC9)EOp|Fz9ciMk@6)nKF6_FK6aGCPWho4=!cXlCW8&ixL$m`jb2Q5D( zUCC#%P_3X=1m$C)dNQz{?8#;vKohQs0ap~#MrdP!0%aV)J*aSB7ODxUiGX36xUrz6q5qbP!9rPrtYENZ zA-zEFp{lYC(N#aQx8f`oD;KAL(ye6nBY!^HhS^%7*3-Gm19Q%ln*=SG?IPJOk_*s> zt6m8h;FYvufmvl%!yON~{%elwD0j2x1k6bQ?;ytMyBCQUpIT8Z4b4D5Q+{;!dQdyI zO%;`d2a3hJD$Vf={;P*ZGvbLr}Y&`HO%1r2R z3aKO1K5b$Wn`U`kI>VhZNRGl=D6)=BfB>qd4|;DrA3KVZH42SlNEW7p&6!zu-ek>` zS>*L>jyHQIhC-E8rH{mxMi6lS<)_>W9NVY3F^o#%TyTSD5!FV)4IkVYP3~DL{4<6qGbU38 zN_fl3vOJ3uH%_hDpVC|5W?Nn(k4;`U7aSq zf1%WG?R|G$X`=+JabC1l0!HV0cig+Sr~3hZd)bja0yYVSYPq!nK)^jeEWC^167EP` zyo(_c=;6z`U$$^H_{*V?++Xf9*LK1l;Em+FvTznjc8yo&ARGaJKZP6|hsaCSaBG6S zl+)kIhdkWl$gU%Uy!pCF%0-4izBW_YTKE4NRko6<~rdLJd;$8gUh viDKItp7fC0;{9lGxFj@;5PM`qN%@;)LQDqn`3#o7A3K0aabg3xB#-z%u5X%$ diff --git a/.cache/clangd/index/bitmap_io.hpp.C3324F345C5DD5D2.idx b/.cache/clangd/index/bitmap_io.hpp.C3324F345C5DD5D2.idx deleted file mode 100644 index 0a94598a4da1e18d699865382ddba45647c235d9..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1642 zcmY+De@t6d6vyv-wB@z;l~?+Mwsg>hu7#u(${KJDv~e1-j0wULmw;I;lsU286xh-t z%OH*n#jz;hkBy8moiR*Z7E!}AFvjG^G_l1g;E1BhqW-ZB42}SSc;6+*>PvcZd(J)Q zd+xcPTTxt8R4qg3u|RP+RNLs6AcVB!*U(u1JYo=vvIvEHKdu<98*}o1PXuS$`J+=) zgM&{Q(t>8yGgU9}M}vV#RnGbYtMO3%+~n-FXQ!I(7Z;TU9WU#I)76L54keU#zJB0l zXY0s-_4dhm(@Tr7S5Kb*wlgcL_4sdgw(XV=oqDaH|Ewv}UH-<7eCevA#5~mHTB(hO z(0QERzxRgM6?|n^)*j#cqjQ?s{a=3N=(UXwbS#+zm8Q*)y63JgSM@BNdm@VKOB?U@ zAHJVI*19%4a4B`sb0PhULAK!0X>0CU-oew}XsvQb?%d}5aAmXRxqv@$-{5uSCEcB_ zCqL!B*&K=VdX{RAR0|JMkA42)?TH`0?rU9G^)*C7)h057&rVg3s&@U%saP%rDcc!i zJ7d9l@;nXV$h633FxQ=t77YtBBqbYc$u=F{iFXPRE}6ZY@#c!JRL`1H5H6GyN~wYH z_JemzCzBuFkJ&^LwkzyfY9RbhY2;qlq@hhf5(C0E&ZeaX$%(LD&R}UyY0m|1U0GWS z%MkUjBCN&*k^&y`^H<9K`@YM$PQ%zE@$l3@c(%^ml5s0-LdB+%>=TS|f=R$p`*P%o<614uvC$8VJWqYS{HNN#CnkHOX(%HtBJ;F53X%j^D@Cw_4OcZmD}E zULK1E!gyF#(JWCf35X?!%j7b3)Wi=rG19d-|Mr!?l2{EA@z*+eJT@Q~7rG@{hY&~BnL;h(zCb*KV#}$uxm0leT0$3(z z5kZD#3Bf_XIEIG$nufjN0{>}g>h@2rx5)$rpQK7gg6Q4)l3;;Qa(v0hm#X+u5nuiT DCOhzq diff --git a/.cache/clangd/index/bitmap_io.hpp.E43B2188CF8AB392.idx b/.cache/clangd/index/bitmap_io.hpp.E43B2188CF8AB392.idx deleted file mode 100644 index a68ae99845d042c2a08bd86c75a7a0dc92ae0228..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1108 zcmWIYbaV4zVPJ4h@vO*AElC728H9kixTGj^9*}lmWMHV6vv$HpuEPdAE? zA7-%~%ITKfp|<8|;sd$LqC`8nUsJFAnDf8EaLzuDV%^b@QEFk<%Y7oHQeJ&-ZI~_e63R7gy#cg#%qEA)hsi z)omX?8v_$J(9uA^qQkAj&%goUc;8sBH0isCpEwgAHv@|SivcT`fJs~ZnI3d4J}gLp zi3g@zLqJ0WCav!`b&*Jxf2$Z1BTQPKMV|*IZT3AdG5oy#A+R)yA&Vgon1D%N^iF2_ zJ&W(M5EDC0x00xm1Wda7`7xm@4MNu-x{X+jcvwILOqzSuMGMo1Y>x$)cwxHLIMoDU z(#Q8t{%~jd#!q}q96*ohO6kgj37E9U?+5FCHF*9MVB&=7R^e8G2TQJ~+X08)l7HEl z7`Yf&6xbE`!2|;*IMf(fSQ&~^(~93Ag)b8)I9y>Gd02EsbR}SpfQ2$66F78XieRD3 z$jJfBC4VQ^DhsJnz))0EbL$r#K;AX7?@2p#~vK!m}Y(vXru~@3KvW-EWUv5 z0>u+dH7uThhJfM+CJeI!s2UV6FkzUpfvQ1~0uz36<--1tdw72Ug~d6<Hu50D)&n A$^ZZW diff --git a/.cache/clangd/index/context.c.91BC96CF7BD16B3C.idx b/.cache/clangd/index/context.c.91BC96CF7BD16B3C.idx deleted file mode 100644 index 8429ab327c34bc62408e0d8a492069da29d42d94..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13008 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 r4o7-^u~-Lj4pxZ diff --git a/.cache/clangd/index/context.c.ACB36D59D1DFD31C.idx b/.cache/clangd/index/context.c.ACB36D59D1DFD31C.idx deleted file mode 100644 index 9626157e66a6190e3010ea0626ba5a28b2f1d26c..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 13008 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 Pv9VS*Z?96zZDs!h*v0rb diff --git a/.cache/clangd/index/egl_context.c.CD53B506C4A00245.idx b/.cache/clangd/index/egl_context.c.CD53B506C4A00245.idx deleted file mode 100644 index 3bada125527641f36f3b1b669b33aa03e34945c2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 18214 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 WOoHLZGp1i*fBD6)KlORU*#7|}n+Vwe diff --git a/.cache/clangd/index/egl_context.h.B2730FCAFD4752C9.idx b/.cache/clangd/index/egl_context.h.B2730FCAFD4752C9.idx deleted file mode 100644 index 55853a93ca65b9c3ec49717cd1aed839a287a0da..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8170 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 UoZ-harXQi{n)l~>(-g-34?1TDUH||9 diff --git a/.cache/clangd/index/geometry.hpp.5CBEA5776F164981.idx b/.cache/clangd/index/geometry.hpp.5CBEA5776F164981.idx deleted file mode 100644 index c281eae3f4ebf2dc80eac50569c168e0064096d6..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1836 zcmYjQYfMvT82)-FZNJ0u&>JntrS#N+J+*5qZD9zs>p5~63dUp$!_9_s^;eUN z6+Pl&^Uk*B4@K{D_xqPhbbF7V`+4;9mC+vi7;kG8yDX$Urz)~<9-_Z!UL-FuMg z?46t&y72f^jj?9R^YQa*mpM=4no#`DG;`qW>T<_>1(!5;Z=QIN7~cQN-(;?~n%3Ec z;VF)1tR{q`IJ$uXGLX5+=lp=KZ|$#F^L30a7h$*FokIZ?Ae4oW250wt`^`dYhqIJt z@{I_)@?16wkl%iDXl!7`GkB z4u1bzHP6^ciYM1&r2t{%*mM5gQx{r|3`fF2OVCLH!sCX4w-4Wl?aN{ENNWNsSSdi* zmTG@JH9VBiG1+9aI(?myf-)M}3mMIc-G`E^&0|K!K$?qLVuchSe^9@raNEqSaU-*V zRQFkYP6`mNo3DQB$(Iw?jEtUyy%w*X0)+2abzAEu#%FbmmQ;7@og4+FIzy|YhSW=! zR@Z;xnH**I0*`|N9n^h*& zN-=0LD?YmInXAhY4TlB0Py)t=KWjEp-$Qp0W?1TXb-^yJiw9%CW;85yJ;-=`V?*>S zhkum(Y&Y18|G!xTjgU&p9Y8Y7MSfQN4-M$UKVF>s^xzLn5e}7voX}0x&1z9n8N{6z@EXx zfL~=HcgP2AayV=X+cTIL_Nz>;l_l8Co4qgirlx=SlT7U|@jKylML6IH2*B8L59ewo z*O!TsqFr>r6~mKArkt`mf=BD&!Gs{4ayaCmVN+x^)<~YZ8p$MO9FF9WG7d*7lhSJ= nR}hrahZFC9twT{e5${ac$&Y9E%jd diff --git a/.cache/clangd/index/geometry.hpp.D38DA0C44333DD06.idx b/.cache/clangd/index/geometry.hpp.D38DA0C44333DD06.idx deleted file mode 100644 index a526d5b33289cfeda9b3b08ed5884a1520bdfe8b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 1836 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%0DXZnvs$F6CXGNlR$F$grt-auHQetT`Qu-+ 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

xXM3N06&5rd; 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

=4P9fGQLl zFD6#QN0#Ixi+U6fb^^gpA~Yn@cvX)Yz<|(VHD<9I^}O&=3O-8dXgNyGgirgG&V|rn zn(;7g21P<0H3vt{jZl>#5#L;M&bW9nA)#_ruv``X5*>G+sVC1?;TNtMi>?{FQNHJO zYteOUH}pO4=oxMN2ySUO=0m?0Js&vKw^OLv7+Pf8SBM_ARMJ(qcq`~Uz3l#=;$Ss)#K)p z znzDcQH{6;Bq4yY^dkRtMC+xuqdlsr%5aHfb^>}m%7*MCJ)f$!9#IGiN8&Z%#B_Lp(oY3Cl!pNr;WgA(vVTc zT)yC;>L&P2>RG~i7S)&e#SwfV>&M_6b-92p7d~pExW{pt+9 zI`dHJ+G!4L(Z@Ou!1t^cVbvnGSo}UeclB+;b9mQ>ch|=rNygylH@P#CPe7`l`39dA zDlDAx1gAX3$OEHQ;a{V=<`iUpScN~VP|z>m7~~ssDU-3l8WdP_(PZ?u6V)DEdm2vU zWEz%CWB)yU;evmHZW9so-KM;5Q+tYeB+-MH=wXk{BQLJ^o!gOo6~0Y~Di)%uk9xb| z_a+)J6GDXJk09@Lh+$pJ9hF?gx!G9j8Fvl+Gpw&#H zS~#3T0@jd#dcbe=0*zh_6zBI!C8grw2oA-Gd=+9}h4hLoH)d?;NxXtzX!T~bdYdB| z*0IG}x8zAXgdXN&hxwAISG~`h>v#kM`#q%lJ^YcDzVF7rsu_j7kbzQtajAl`QE3S( zNdufH^xT2uXJZgr!snOpsYd6w9^kD97ftcgXPo0gw||EWoaJC=IimcFx|Lbmj}qhB z6$#voUrPGO!k$Rq0%cC8NjyYkO#@G%dVtOp7?xz!G!n#{><8Ok|& zC@u>=CQer=PM2C>>WhQ&7YD&o)6hd#415TMzQiAtkj3iWHa6SXY%hc_UagN+>kCnN zBOLnNQu5r=3)PsImvGQCGxa`%X3?=Mx&-AN;Lr$bX@s>u3hYi_eBxRMqZD$~tI6-x zq)yZ8rr^3Mm$HGMummS8xo89Tar|K$GolJUCSM!N*QN>cPEB!lW1Ybtb6CPSOzM5< zCyjfu?$^LE+An17SLpry#tXdhVj!DGU#el@fyYgdqx0H=^V-zC;kgNTZo;E*)M^e| z&3WkDVDzs~?E+pKe9Svl`a6ZTltD%y$cTpYgrqekH%3Q0Ahd@k>rrS5)aVWx$)-T| zABUEwgnoe>b*b^X6pC0@8G|Z?$x&?$s>#W5B=?#7yAIV~hz0vaN9l_W)mwAe9~}1Q zqrHCe&95e}<}rRD7VKvg?6V4|d))h&`q%|;{K8u)|E*M>A^P-c&*U;=34}K2V-5OD zlQ&;F%lBsyv6rtcIj=3P(OmFg4@7xXx>5kB z;iO8L;{hWg!}y`2c1$IOj^>IJ^=dtP7N!y-c zx2@?9pB!p72%Rya5QkQ23o6MtG?XYn>^N~QT5&G&^9p|6{Tc|qk{14UAZo&JeQk`;lpgb%UVDDSGjxkPlHe0XMcw;{+@xoX9%V^oODar z7jO-KOr<^k^FRsI#v9u5_&Q2U2;uTjAOBHpAJvwinp8*Dd2j4(KB>Nh5H9Gg5udV!nW5@L-dsxT8(s0YL6 zGVokRr-VOzumd0L=qQ5zUFxT_+W+hz^PjaCpB36VL>hodvV_m-_L7SSWiAjJqe6>O zDA@l*0-liO;Ug}G+>-f$@ICJ;V|SG~sG{z;ijo*7fS@nQ2tF}KV zJ6w6?2mC_HG^G@BZQ~biPn&Ri8f{IJ!TIZ_&i-{cAaITPya>p1kcM8626Z#emVj(B zbYki*-c5Sdame#aI`)z-bY@MR10;OHq#b7?iL>!SMPX3p05M(fnrq!Pm+OxBbRC@r zMyHt|$Lj;Hj7{R>iSXN;RTZ68rJ7IAn}G8s0!lnYmlf#3Dq*$DG)>|R4B^x1bLo3bV9u}d&~M#i$=)6I}Y}aBbxViQQ_BsOPx5?k1hru zU3}1K+R=LK>TmpK5Lzh43dKUluIC%;w9aec(EWar{eE7^ChC8Fx#&Ij4IGjXJ*5x@ zAIW`l<@@IR6$@);s%o5Di{BeL1w>Afd;KI@XCHhx(hDCmriqPd>a`g~`^VD!Z{yHA z68ar-NKnoiA*n903@@>$!5k%ypu|z$8z*-D6t^dPN8ykRX)6tB%N^-B)z|<SgHBx7!8}I77)~D*igj6$C>6r>@bczI|NaWq!L&N6gzx$Q9 zl+YPV)v;1_Zr>!q>)&ozY2X(g%LI=VQkb6G37(TFOmioWz0c0&!^Z?^@q)DE3kSdV zf&^TUa8Ro1yn5|xc*#8otrrXG6%3sTejve*hmLaJj_h-|w;YG!L=w1I0+(NCJLdDQ zD1}(LgRY`MS2tu1FZ9@B6cb|(siuhNDGKo((LNxWjQ6nfb;+yFnF^tC+N?N*9F3!f z;HV)3@%rO5m3fQzt$@%@RYs>mX}CN?kVp1d$Y|<2~S$Iqa>Qt;|JN& zFMY;OA=L&oZi7PYq7zbZLdr%u>Vb~%o}eSckZPVjmZ#5oF|&Pi#m@^WaH@rt{6b4d z6u7jJ`7H+v9EH$wb*x;Su~L^Uj(zY27C4ZypGz$fuZJWDR|l_{u#8wIaq5gXb-Buq zQ+;a$-ja12ei02HTyakcLdR4L##E>VhGr>fmWmP8uilfnhxAk-w3aQXRoIogoIn@3 zD<`ckajN{Awv3o+K@2R2!3i3F9Ill6d^3Kb)|Ovu>xj~1)~LMusq_XDQmqoPs}v+f zfe$DkB?YoR5wCTaZ*W+_Xt>`4?Dr5OdsLXmo;gL$2Fr-8C(=wS(o8-A_}24!8hAa8 zkG7uP%bo!$u2RTAg0516E>)<6P6eS;37ksfrYhK@dQ3r&DVuUWO7Z|n9&B_z+S+EcKJ(k$WrXNxVqr}z!GqR2 z1D(fq?8GnhIpRNg?OgoAunYe4KpRZ{(8#3EJ6A#$Z>Z|uP)HJKm4H^VTFaZSYB{6t z*FtC+gHxtp!H%;Baij%%sf+5;B*8`qt>j56d0v!*#4&ep%w051mTi|iWOX<#Y-h@t z>1O!p3u#y(%>XsW!Fi1~Gm16~Kpt4U9)l#Xb0>seRKYH)=guk|aMbBoQT#)+haO>oA07^Ra9`9kULQhRzpouK>^v^=oI+gX1p>pdz9XVT~3aYRNsft5e_!O5%IP7c0S29o;b9~ z)u71L2US}fPt8tw99IIN5n?PtY_PZ}@yEI5M{nTJE51fod;?ILDKcCWEB7s3_?Au; z=jk>e-G+}$*}02cC((cJ`Tv*JW*%4Q3zsGZX=M4RP^A}+^-qQ%v|Pj~7g42mjt|K3 z!9(3vWr`jN_Ey(^4ceD940%1KfgRIeUplzE_4{8FcjLT%HROFIlY(zHhG@BN9EB@4 zlO@VzQB~0@M^HtUS;OxgcLL*1f+p{Wg7;YiNo!Y3bdSBJxtx%DjWn#0#@b%g8E^h) zg%^I|o*DO^nJpSobr2Hhf}V{MzlZOzV?3A=QgQ?4po+&o=$rbjP*C zG3bD|-~d?)*s)c_oZ)>BQhlT^d8E*f>4_zHLiS_Y6!@ckF|Qm_eI&ph2?Widp3GzK zZxSN%lo$TMcJfHICo$KfSl1u?^tXq+UP9Ev}t%M^5(vMBrY z1rKn+gN63%q zQg0@z0zKu8Z`WxC2Xb^xO?XX>DlQfnn)~jOms-h*;4Q0o&!-#29Vq{Qa zz#=~_2-K^BwP(jSzClmg$Sj6wIcNEdk!z7M(^`NPn6nxpWead_M#0XBdY1bRBa(UPbsSUfauF+XtdX zLg=4Zg)i;3UfNTuMpXxb>Ogtbs09UGGqiUW!8zZlt<!#OJx!2PG*+TKh91Z}7 z$sCaF!I=&VSq~sbqjYSPPTz9(TIaH{U4+f!u`TPdtvNb#H0@Hax;C#0LWdaG5Q97R zQ>~ajE&`q5tS(cT$#h7XR(Y6=y1!qIDHn>Vwm;fjM!V2}(~To*Ox^Kx-FWd5QS z{h~rNc)bkN%V?Bo(`pA=?PzG)tUO=wAk}yPa+E8?a)rExsLRRWo4g8fj^ez9ab%C0 z2X%Mvo;AT%5^H-z9UD>C-8S*+f!K+BVilf{=${~CEv*>bjr-@SuOvqPs;$;lTe;N| zmwyF;pnxm`J9NpXI`lIRBRykCC!^5Qz74UAYBjaUUB&*((KLgh4f`buK% zwd*Ri>r(BgjZ;D6RCznz-=2In9sHdGsV4BT1U{|)#|3Z2dU1T5YLN${$io=<`Wr;< zf2-D5L8>);;~G9SJZZ=S40#x#IB~mMhu2=6X$zs1G(n|;YvQUIxN63;{&!pN_GcmM z?T&2ln4;$ep$%-41~xUIr^gBOILV9E{n*&M3Vfaqp{aUGsd{3{8E13~7@Z|_`00x7P;Iy+gNT_AED&iGT=O6~8p@G&Jqeu+XRLaH}N_2zyAO0Q}2rfg|{<2!V| ze*=6>x+a#cDGVA+@Ba6MBN1yEYa)p?@uFxhkyesOD=$>TR>t4PTC#dG{77l~SeiZy zlQ?>I^8EDhdowM$nU=O_)n9512vw`!2|0??H;h!s8O^r<`4$q?G5GYDDlaYY&;L_Z z$I{f<&t~cMxBOi~sKOyeyb!ViFs(eKT<7S2kZP|$+$*4}mz7?i(o2X6yVO~SW@WkV zUr9*QJ|)vWCAs2oGR;M;!e>8xUY07BrOFwn-(E4)e3Ll#jT`dE4INRvBh(I#SQfQz zTD5L+^BTS^Qm2E|>2kX?DkDHZ$IP_G%&04{bT_Q^cz&bZj|e5m zk?7};t9|239qrd=F0Uk1m@r+XFkR{duJKl`@s^;-9{k=L0pJGd&ebo}UhrsZ8vFz; zD)bf=Y9`BNLvYzpZrHTApB;Bbn*RTR=3rSI4zl3lR8P9_Pr5iFd+phx5v^;d{}0`# zg6&gb9a^(y&KtK?^*A)#h#PKXi;PQ$zVq~_R_8zlDg>Mgg{H!BULekkg*LPg{{EN$ zR4<3`*{!S8tq?0x;H_NXEkHUH{+P4?kVaN1SoUNl-O;)oGXFw^y$~@ko_xmQ#VLj0 z&__O;M?Tg_@f_SWmAf@@;woY|@2DHzQKuTlTa7`h!kOcZHF!gwIbv4#oYeS3c@-g} z-}ABed~WsQ9ka5$PVT}lobVK!AoHD?=Fd$uE>ne%d7`WIL{}aVhC@GkD1Y=YA5Pkl zb>mnVVHN403i_uSBRSM#w=gE(Nf$omq8fHljlI)ocl53lUM&tiWW+l}t}&BEX_2l! z8bD}?8djo4J0QA6pL*>GQ3~Li0pl83l+WWrePGBjDdebGMcAxDRXoRxz?g#KIcx!j zNyYQ?)!dA=lZ@fL$FxMpw5W&YVi_ow2`GDDiZw{F7ND%_ma*Z>i6Y}w#J=)GEPNuS zKKHC2IP1qphMNl(?fcJEn?h*4u2Q`&wbgcpKgb|EYwteq`zS8Z7D7uVDV0o;w;RA; zd|(O~m|`R!&Yk14+E;kOF=`NF4PwEDH&siMHMm_k^nxG$llP~*wZ))4s=^0SeX1{b zs*uyuW(nFXc__}LJQN(~T2EU=>;SK|u-97bB^M7pUxMw)#4nsQ=AAUQM@eG%g-RP< zrH#F%v~=(IKl47`ns++>uE|`;(LOP@Ps|++{oB2;J0}T;9`h9(^L5@7y+>O7@O%^+EQ8RGZ$}1`!(}^OxAtOA2~si4!Ox z^~~I(Gpw)t`sXS_QeB;_b#=1bjf_jG6Vt&7vZ{yn=XfljVK@BrUo^O16gr4^8G|l` zWc@r_kY~#ddfXo{{nXTm!NNNuZ=UUe%*V2@Se7s`_Ko8XpLW8webZ5LlQgb7{yn{y z^Vh$S`LCL^uL>1;3nieCRA;dbmq)_d4?(ISLM%kcJhriC_{Y>D!bSSdi}TLQ8pT#6 zrfuU58Xo=sknow86uKXkdw_DX`%$!CaB%i99EuOg@MNvw$?}sTJ|yR-gY(nnhsw3v zRhI>K|DS5FGP74%K6*F2Z9i^8#^8E~_`p`}Jp_>sVRn`btTuzuR%BF&{sS>o3xU-%) zU1%+~0*bG{%q>LpJ(iZdPJHeq9eo{xL`Rm_y~L*aZ~3@KNEK z>WxP?)x`Egs!#Q?r}})f3~{P$mZCOGH^ltAc{81s?H+_wQ}jhC3Y`K%EkUTI09DSJ zqSCm-VJ&+#A*)~Uuva{T%-U^hR}Z&l;1_b;jdI-sP)~FF53B8TG)1e4(W|60D-{wD zLTx}OnSiiW?6>`}ml=c}qA4AsQ8(0EQ^74V>fNBJwsMcHo>2LHO*_;Tm4 zGcNdrAzRUq!ddx&o#+91R*nkWkr;Z`el;-}51MHmRM1aeO#`n;{bXK<&z#6Bu8^Y} zJlPF}xW2b;;H{e!&60P)o0a}G^oK)IrHNH(vc>7s>CA>i~&Bk$Y&JuB58 z?3o3jB|NNzCzy5b{nJTX@`#@}Nuk5yQ)|PgWQWD3ouh^y?k$0jDd1uST>h?$xBlC_I-Rfrot!K>Ia%(ze7yKA zZPLkA5PFu2o#hHqAQ%qqah3GAdZDnd-=@;a%F@=s(R=Hz_10a!H{eS-e>%t~ThXwL zr|$N+wiQxsrr|M#J$&135!92zRo3zdkF^YnJYETzN0 z9D~pn4%Whv7GD&WY-g|tYkP}}af{20_YAenGj|$~J&ee#=&Ou|&^HY14TFcej1auq z3ybYtQBM)S(laSbSHwYH_tTX2)8v{c4lSJuN=fIJ(I=hE`QQ|UM(Qa=>d9NCn7x_hSofN zW|BTt@V>JE?=0w)l-oo*kZ4Co$FSSY{FJ-%3*lo@G_Vv6ZlvUW?A8vu_xNL?rGjWO z!tm_lz%-9lBM{oHk9F&t&2m1GJ3oI>FAg2Ev>dZsh|12cva}A{-!)+kAv)gEB=2cd z4_b>EXfYE-&syl_q0M`ryRz-y#0vE_gg~m&z^XL#7wyjLGj4rL_$q1)m^EbLLD9(L ztxHrUL8=$|^ox9|l)3K#?t9SC`8wu@lMmI~a41fsMFVTm&rE3Ubc1;Dl zrea`W-eJz%+I$JW@WR;Wg+f!r7HgvxvMJ)W3CxHeW*Wn{dClj(R;XHc*b^KktJXdH z{w4Hr$p4||g}n1Z>UR0v3w-zDpsl@aX8qF3I@a*TA8KI_we&mZcZPkdU2_NLsMUzs zN_rU|yGdM*CVD~UFRNmgRk{B(f4_S|?E~Q_dt@wlq)=s|(ppeS_JfmrjhP}S#qY%j zEksu-M3)*IbJ0QhqJwn73iqUJ)~0nhu^fMp<1devk#=vcbZiNLFTPLTV4p&x`)G3z zZ7xR1OhHcDt$M8v!MAzK$KLX}Mqg9bUszz`j#EA6DL6)+EW+YTVpilHha4qn@)Hyy z*dvWWq_MoZ4}Nd54M?`(q7*;vNim%Hmrg>C^7!05g-`L!13dF!qluMJJzITf><`};i)Iu<=r9Kx=5T%T*jekKI}9fOLYAEV}q{Nz~z?^8pX$=_{Mi*EAHwU z>Nn!hLmp;_Jm#Qa1DP9dtU#)^mRQ@F`kYLCs=&{+1i6+hWI)M}Sf{@QO zorYew=c6@edSm`0cr~EslU3C|Yb>x43oVlg%Ve&U zqtv*KaNNcf6>odAyK(1+5EIBzJA>D*P>QbB9@N@%P@sZN)XSfy<(WZ_MtRsM&uG@j z_B8X#79yy%+ufww{Rd>(7+iL$*-pa}LL)V?NKM9%3u@9&9N2pqhYlOChYc*zZk6oK zZU}OBSxc;j3RQy&RccsCzX|9!5hD!(zjwqOjF^j2{LbZVrsvQ67yw_qObaX1V%@s2 zaqQJFAgl(1#@s<;TS~%Lust`}-WJt*u})9l^K#1q_~KWEysHXwA;KF(c+2GioxaU~ z=FdwYi-W4VgQ^0GluMC;6xk$d14kQh-)7SC+qIKV6~yMxSTSqh)y3^_B!=nOFrEHz zOSi`BcqbxR|B)^05ov4wlzcV&^u2%JW2#m8)v9uf6%IWp0|#YXibLSKEx2yWMRwcc z(%<`R-NWEWB+;-W8XLK(@O!&Vd0h(WYZp9t7s&Lr#;rvWH-C$OEcWrSK0Z(1{RnUO zp(I=U-t(Tq^Pa9KesS!lBrq`J1RS)_bmnITwYI?qG}zFOojLY*+svvM6mdxCo5ki@ z#pZG;hign@)49s#VQmaZ#4z23I)hddVrH;0rE%M z{M^>kO!$~!0TwKwJwE-g@fY7@1m^XU@^Jul*(7g6)sj`)BhK5QhZLg(E3yW8vo zgnksUJ}MM^Yw-asJ`5B>-&pZrZ^YG4YYFpdyOLVF5(CZo&5!a^GtPEHBEfV)u!5tx z*a{SrNwSvTo~`Nd_zGY6DIa^vXPhXoZ2fb`k19CTU{7|irzIN3lT&~8@uv;^f5f%0 zU@i7vvo?NIZ&x9b^+ybOBV^b`{E5*k2AppY`bmg=67n66RArc~T<(uU8@)x1WNx+a zQn=pX#p7@eoYLl;(x%GWdJ|A@!lDS5W^>SN&O*ZF^!9fzhpNCjVyZo2V2>E=#I;uc zl=W)7#V^F$^WyF8QQEGd`-qCce=6$;0sKl6d!;GJX?qy_W_eUNeql(4|2!y$n+gkY zg@p$y?Kkvje{A$Z+B#xOc&(%KT1W2l!tX7Z3JRuLBaP|XuMZP{N~1%Lo`|p~BDR(J z)72*)C>7w)A|GB6nKi4jeSO0Nf3b2hSaU3F=wT{2}w-XuNMU zs>&8=4kFDtNXeNndrjE7%m4_z#pmBrND*!H0F9&qx~1^u;sn!akoh(q*2d!}mz(cC zd)}=9XQ0qsROs%8D(4R`o-|acy$n(v6$wX0R7*psF9`MJS55N!cpx<`1!-!;=p{O6 zB|1>e{`G;No^+fQJKL_@_19*|z%e0qOvv1$vul}iT`VEHzIbuIkVdA3!{!k!JO6{D z_f=2nt3oNkLUZLpa|;wQkKY?U1%#8e1v}jD*S|e~5HkNzll4$j&JhmnGy zkiYv;zT{&wO;8cz0#pB<;PROW3t$EZO-$M_=YQx>S+OXTEOo9jl=P( z;YQ+At37$up7y?FX_FJ*I%)Zxd}^5g_bo^@Tc4Ayppf0M1b0Y8y#?8l8y+`NXqf>Xd5o<7F%|>RDe>xYv zT-jg=p$F9&2NmL(lMO&JsY-;+KV(wA$sIx~l^K=FRM+gF0T?8q?LXek$lEvtLZg|y zXobon!44qUfrFv|wz-w3t-3ZFLXYUPj_6ZYUx5WEuwWp+r+w^n{b^luAhcb?ZdZtB ze(3{Vk_l}O5AA)v$@sVRgfzXYVsKX>_WFV;xL`_Ek}p|+OBQk^dFQOm?RKr3;bU&< zb8ae3@jOeAM^5qfH8-U9$Yrlx@;yl2jQaQ?KJRq8V|WU? zz{Cca0(HmaAj5Nar{k}6!V&+;qojG9w#)Ie&OoXidP*I7LZtTK&?^Dp3fX3ApZQ|O z6|c+io22O|rRm6D3x}4wDwn$&C&(<^OUy%0;TMih1xKgK&0fWNZz_MTy#gO|M_1{N zf(f903aFnVKk=WM7p(H%>;ecaV3`)Mexz{p%n>|uG)5s~FV0Vy`LnbXLf@!y-YC?I zk2V6)WR60)xJc*I=2pmjgN{;z4s}hxw^4p?BSoEoapw2?gZ-op0@V;An@(% zyzA3<_|=NFv0`og=}fC(kIkJ#Jj9rkIVLqlF5%&0?`F3AHE9FEQKh`aj}uWxKFkM%`RE~a z-E{Vd#v42D4aBN1SLKzfQuUxxV^FH#=_#`YWu&L))ZF;%ZEn7h`S+^WdsPN17>YB0 zP{KYak)OcN$D}Qfzcd9xi|JS~UG(?;Unlxv-)7>_QEP)yYab+D6W1Sk6S*`1LTl8p z8Z}z~io(M6lit?h&@w5bOlo`xYncO%chgs2o5!s_^$TRaS)I|WAc@;$pk1aB zfdM;x6yszWzvJA4^&8+A<*DoEsZ+=3odmoiQxhWp-Lb)P%6141*HH>r@I77e2Uo~$ zOQrq4b<6JVhs>YT!p>=l3=+nhUVDef;>;Hq85EH5ixWPomQ)Q!LaO6j-Z+;!@=@Y93Noxfh7|{;m8N|?n)P$q705s$4@=~U_bpgo#IxROg){KT z&G3<%AM%r-+PuW4zd;k-piu?kkSQ246;OgquX=#19s(3(DjXZ=weGz0{~^&+3fH4n z$Vi(C(x%E=G3XxVdUYJT2RVx8V)0yYa97vN;ygdXRq(~t@QbS-@_Foby#&>g<_-c-s;urdj`2A$6FMgrNg5P7|i1bU@mzi#6 z1z+I3Z5mjchB5!1U_sA^4TKH$fXwWGY!2G3@C*Aa&GuQ&LHD8(P{daorHMur#`m~6 zIBqULM~sstf8G1{jq0z27`U#AT~}qgT+e%L^*oa}wYL~?TF6at=IFO~F9mc69TH(f zB3bq#gR@^3*%0^c^EKV)`(sYj_o2T^j&62(smFB21#ap-4n&S!6Ve9Jyo!)RXkl3$6Bl)}JL7y^~C@*ZMGz56K%hEy9|f+Ia&6RRb@4|SS>2g-2q20RZEzvMLnQBGX&2J z`6z_z&6D*#lgh3`=tZ&cqC%|5BVX{ymyc5M7hev0cW!U-uf(Fu!O!rT)UqizjKK|K z9>tuPZVl3{d8mF=U2<&2(GwN$F}a$0xe6_m#>HS-(X1?tRswg5o9dR9rgF>_UTU`)fY_u3nuj-(dz(u9k}Rpuq?G??tkVlA=Se| z?68nOwr!cqxBlo9oNA|+sME_0>C@-9CEb&L!=c37Q`Zku5U;5QAeHPy>ST3z@2}b2 zkZLd+3ubd7qxPS@7O}Vpr<&lzPjHf#C1tnu#ZH%u!&wrmg2k$^7~A^KRo+k|j6HcW zZl27RBJj^zbI)4aqJSRB_S!vDG`~ZRngom{0aX{j>IJTP>HpyIeER#V<=P`-#XDI{ zwciNlzp*9X*i`pehBL@;7OC5IUh;OcNPPb6??aVVnh;ti;?yZ*{S^CvVlwOJ@-E5X zidX3eLl1u;$_#>ot6SyR*gIgvii@Hb*jXNa*3vEWj@>l@XPGemmlM_>Hs zk(88rI5z3H(R#kwlTTMnAhe5%b#b{$;K|l)1x4QSMBzO%y-fxoeCbqb~Dg! zCOZ9j(%;X&KKmS@UwY%HGyrn+MHTy^%0Kt#^MU+Pjg$CeI*ddeMs7%ET5R5wr!{#7 zq}ndFZWsST8Io*2knLxQf~-;x#9Y&hpYt2Ba0(|W6;7h=*Kuabab{9f0R(?cqaSGW zlk2x=%Tj5-YQp2LuI0o*k z8%yrE5E0fDGJb_ZRzZ^;zlqE$Kw^(LY}FZR)fvj|ZunuVd>SYx14a`XiYL3J?uGB! z%)^>_oXuPMwcgn#60zPOaXy$pxqbKyM4_&jF@W#qp&gD=iT$o8>XyTs}2%Y*PEWza+!3Y+kVDHu^u za;|xRYowBs@Z*a=L*nA#WA3n}cN8Minw&rr8JWhuc&4x+A{jD&o{61jaxd3c29Cej z+m17T#6fVxK_0_@D@|6GWSa@0BQ$J;Cg7IPX`wlp?$cmVscI2niSb z-XKd5WGO-lnWu;U(RlNA$k9hl?4u@ai66s8n8|?8$zmzr(7)?}T8wt*mrgp{&te6Xm-mY)ad?oM|A3EPb*}Y0=@> za^>F%X>*B>UE(uP=pTNe+=E?Cru>?2iF^C6zY2slFt7%Ouyg+Smp$QSg!d%VUXp3= zg$k-S{$%la(<$}eiRF^GZLILl2@C!TOGObyOJ@aT0mzOC>+TLt-+u*9Ub8wCnV(y-&#Rvo(extp-5(? z5y&*+qUwWh#*_-BgEo+X&phli&mduvaOw{Ose5q-YTb=$-2+hh!+$S&XvyZczr2jzm!>0^n?yOc88rM zIvC#mMf2*$2Q%TlRq9xky0GE%O`QW1^IP$IPnt+hDkLwoTS(e1ywIFS9n6WjP^~Gg z*7T2P?Bz>I40aN@(ZGUvhLwt#Be{}XlV8zkdzrcI%t7G@oS<5bX z&pT)HobYGom~eAUY$;1R%#9o7W{b|D%UKSZSJ@jOi`PW#YYNuHcpnf?R!0aLnsVP@ z=AZDpj?l3YIvo{>!yi*=%c>-O(k-|D5@hBCL5@DFW1rO-(#Ai|l-!KW!=Yg&>@X8c z%0A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ξ|Ix5>M}?4o3@D>3w%Z%u-7z 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

TO5P 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%0A7mc|Wjjbrwq7XN3h?^C9 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