mirror of
				https://github.com/eledio-devices/thirdparty-miniz.git
				synced 2025-10-31 16:14:16 +01:00 
			
		
		
		
	Compare commits
	
		
			69 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | a4264837ae | ||
|  | b4936524bc | ||
|  | e9020723b3 | ||
|  | 5ba89c135d | ||
|  | 25de35faec | ||
|  | 4d1d5b6771 | ||
|  | 034f0228eb | ||
|  | 4b8c4f432c | ||
|  | 9d79ea2245 | ||
|  | 6db3c0d290 | ||
|  | 96f0da1db9 | ||
|  | 93c6567773 | ||
|  | 2b45f89867 | ||
|  | 5c62e23e04 | ||
|  | f3461d636a | ||
|  | 45a080c050 | ||
|  | 2e15a3ff77 | ||
|  | d31e119d4d | ||
|  | 3a884afaa7 | ||
|  | ae423e65b4 | ||
|  | 336fca3bd4 | ||
|  | a3ca94f833 | ||
|  | 9ce0d0ddff | ||
|  | f8600923fc | ||
|  | 306edd2022 | ||
|  | 407d298c14 | ||
|  | 53bfef515c | ||
|  | 91fa285a27 | ||
|  | df65d5a1de | ||
|  | 46cdde2ac5 | ||
|  | 3616bf804b | ||
|  | 76237898c0 | ||
|  | 3af5c82fd3 | ||
|  | 55f4dfe1d2 | ||
|  | b344eaf775 | ||
|  | 36b6c99f62 | ||
|  | 04f2169b8a | ||
|  | 14a5a1397b | ||
|  | fef12d34f1 | ||
|  | b01930542e | ||
|  | 9c88e826a2 | ||
|  | 22e4ef1b1d | ||
|  | 7a7d0b423b | ||
|  | c17cc20c80 | ||
|  | 0f6b199e5b | ||
|  | 0b7d3070b9 | ||
|  | aadc405b1c | ||
|  | 02c51d3662 | ||
|  | 9393a95f26 | ||
|  | 82e5b184e4 | ||
|  | 81df2df0f6 | ||
|  | 64d92e19ad | ||
|  | 404c574eba | ||
|  | c1f791f81b | ||
|  | c93e4d804c | ||
|  | 84e8458de0 | ||
|  | 78cdcb0fce | ||
|  | 0d13890f4b | ||
|  | 7ecd1b3677 | ||
|  | a0786b126d | ||
|  | 9b1ddf6861 | ||
|  | 149b34c254 | ||
|  | 6e915ef7fc | ||
|  | 11f795a19c | ||
|  | ec028ffe66 | ||
|  | a6a989cc18 | ||
|  | 3d51050db5 | ||
|  | 3c7177c0cb | ||
|  | 35c2d67bcf | 
| @@ -1,13 +1,19 @@ | ||||
| PROJECT(miniz) | ||||
| PROJECT(miniz C) | ||||
| cmake_minimum_required(VERSION 2.8) | ||||
| set(CMAKE_BUILD_TYPE Release) | ||||
| set(CMAKE_CONFIGURATION_TYPES Release) | ||||
| if(CMAKE_BUILD_TYPE STREQUAL "") | ||||
|   # CMake defaults to leaving CMAKE_BUILD_TYPE empty. This screws up | ||||
|   # differentiation between debug and release builds. | ||||
|   set(CMAKE_BUILD_TYPE "Release" CACHE STRING | ||||
|     "Choose the type of build, options are: None (CMAKE_CXX_FLAGS or \ | ||||
| CMAKE_C_FLAGS used) Debug Release RelWithDebInfo MinSizeRel." FORCE) | ||||
| endif () | ||||
|  | ||||
| set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_SOURCE_DIR}/bin) | ||||
|  | ||||
| set(miniz_SOURCE miniz.c miniz_zip.c miniz_tinfl.c miniz_tdef.c) | ||||
|  | ||||
| add_library(miniz ${miniz_SOURCE}) | ||||
| target_include_directories(miniz PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}") | ||||
|  | ||||
| set(EXAMPLE1_SRC_LIST "${CMAKE_CURRENT_SOURCE_DIR}/examples/example1.c") | ||||
| set(EXAMPLE2_SRC_LIST "${CMAKE_CURRENT_SOURCE_DIR}/examples/example2.c") | ||||
| @@ -19,7 +25,6 @@ set(MINIZ_TESTER_SRC_LIST | ||||
|     "${CMAKE_CURRENT_SOURCE_DIR}/tests/miniz_tester.cpp" | ||||
|     "${CMAKE_CURRENT_SOURCE_DIR}/tests/timer.cpp") | ||||
|  | ||||
| include_directories(${CMAKE_CURRENT_SOURCE_DIR}) | ||||
| add_executable(example1 ${EXAMPLE1_SRC_LIST}) | ||||
| target_link_libraries(example1 miniz) | ||||
| add_executable(example2 ${EXAMPLE2_SRC_LIST}) | ||||
| @@ -38,3 +43,10 @@ endif() | ||||
|  | ||||
| # add_executable(miniz_tester ${MINIZ_TESTER_SRC_LIST}) | ||||
| # target_link_libraries(miniz_tester miniz) | ||||
|  | ||||
| install(TARGETS ${PROJECT_NAME} EXPORT ${PROJECT_NAME}Targets | ||||
|     ARCHIVE  DESTINATION lib | ||||
|     LIBRARY DESTINATION lib | ||||
|     ) | ||||
| file(GLOB INSTALL_HEADERS ${CMAKE_CURRENT_SOURCE_DIR}/*.h) | ||||
| install(FILES ${INSTALL_HEADERS} DESTINATION include/${PROJECT_NAME}) | ||||
							
								
								
									
										50
									
								
								ChangeLog.md
									
									
									
									
									
								
							
							
						
						
									
										50
									
								
								ChangeLog.md
									
									
									
									
									
								
							| @@ -1,5 +1,50 @@ | ||||
| ## Changelog | ||||
|  | ||||
| ### 2.1.0 | ||||
|  | ||||
|  - More instances of memcpy instead of cast and use memcpy per default | ||||
|  - Remove inline for c90 support | ||||
|  - New function to read files via callback functions when adding them | ||||
|  - Fix out of bounds read while reading Zip64 extended information | ||||
|  - guard memcpy when n == 0 because buffer may be NULL | ||||
|  - Implement inflateReset() function | ||||
|  - Move comp/decomp alloc/free  prototypes under guarding #ifndef MZ_NO_MALLOC | ||||
|  - Fix large file support under Windows | ||||
|  - Don't warn if _LARGEFILE64_SOURCE is not defined to 1 | ||||
|  - Fixes for MSVC warnings | ||||
|  - Remove check that path of file added to archive contains ':' or '\' | ||||
|  - Add !defined check on MINIZ_USE_ALIGNED_LOADS_AND_STORES | ||||
|  | ||||
| ### 2.0.8 | ||||
|  | ||||
|  - Remove unimplemented functions (mz_zip_locate_file and mz_zip_locate_file_v2) | ||||
|  - Add license, changelog, readme and example files to release zip | ||||
|  - Fix heap overflow to user buffer in tinfl_status tinfl_decompress | ||||
|  - Fix corrupt archive if uncompressed file smaller than 4 byte and the file is added by mz_zip_writer_add_mem* | ||||
|  | ||||
| ### 2.0.7 | ||||
|  | ||||
|  - Removed need in C++ compiler in cmake build | ||||
|  - Fixed a lot of uninitialized value errors found with Valgrind by memsetting m_dict to 0 in tdefl_init | ||||
|  - Fix resource leak in mz_zip_reader_init_file_v2 | ||||
|  - Fix assert with mz_zip_writer_add_mem* w/MZ_DEFAULT_COMPRESSION | ||||
|  - cmake build: install library and headers | ||||
|  - Remove _LARGEFILE64_SOURCE requirement from apple defines for large files | ||||
|  | ||||
| ### 2.0.6 | ||||
|  | ||||
|  - Improve MZ_ZIP_FLAG_WRITE_ZIP64 documentation | ||||
|  - Remove check for cur_archive_file_ofs > UINT_MAX because cur_archive_file_ofs is not used after this point | ||||
|  - Add cmake debug configuration | ||||
|  - Fix PNG height when creating png files | ||||
|  - Add "iterative" file extraction method based on mz_zip_reader_extract_to_callback. | ||||
|  - Option to use memcpy for unaligned data access | ||||
|  - Define processor/arch macros as zero if not set to one | ||||
|  | ||||
| ### 2.0.4/2.0.5 | ||||
|  | ||||
|  - Fix compilation with the various omission compile definitions | ||||
|  | ||||
| ### 2.0.3 | ||||
|  | ||||
| - Fix GCC/clang compile warnings | ||||
| @@ -19,11 +64,12 @@ | ||||
|  | ||||
| ### 2.0.0 beta | ||||
|  | ||||
| - Matthew Sitton merged to vogl ZIP64 changes. Miniz is now licensed as MIT since the vogl code base is MIT licensed | ||||
| - Matthew Sitton merged miniz 1.x to Rich Geldreich's vogl ZIP64 changes. Miniz is now licensed as MIT since the vogl code base is MIT licensed | ||||
| - Miniz is now split into several files | ||||
| - Miniz does now not seek backwards when creating ZIP files. That is the ZIP files can be streamed | ||||
| - Miniz automatically switches to the ZIP64 format the created ZIP files goes over ZIP file limits | ||||
| - Miniz automatically switches to the ZIP64 format when the created ZIP files goes over ZIP file limits | ||||
| - Similar to [SQLite](https://www.sqlite.org/amalgamation.html) the Miniz source code is amalgamated into one miniz.c/miniz.h pair in a build step (amalgamate.sh). Please use miniz.c/miniz.h in your projects | ||||
| - Miniz 2 is only source back-compatible with miniz 1.x. It breaks binary compatibility because structures changed | ||||
|  | ||||
| ### v1.16 BETA Oct 19, 2013 | ||||
|  | ||||
|   | ||||
							
								
								
									
										20
									
								
								amalgamate.sh
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										20
									
								
								amalgamate.sh
									
									
									
									
									
										
										
										Normal file → Executable file
									
								
							| @@ -41,9 +41,27 @@ done | ||||
| rm test.out | ||||
| rm main.c | ||||
|  | ||||
| cp ChangeLog.md amalgamation/ | ||||
| cp LICENSE amalgamation/ | ||||
| cp readme.md amalgamation/ | ||||
| mkdir -p amalgamation/examples | ||||
| cp examples/* amalgamation/examples/ | ||||
|  | ||||
| cd amalgamation | ||||
| ! test -e miniz.zip || rm miniz.zip | ||||
| echo -e "miniz.c\nminiz.h" | zip -@ miniz | ||||
| cat << EOF | zip -@ miniz | ||||
| miniz.c | ||||
| miniz.h | ||||
| ChangeLog.md | ||||
| LICENSE | ||||
| readme.md | ||||
| examples/example1.c | ||||
| examples/example2.c | ||||
| examples/example3.c | ||||
| examples/example4.c | ||||
| examples/example5.c | ||||
| examples/example6.c | ||||
| EOF | ||||
| cd .. | ||||
|  | ||||
| echo "Amalgamation created." | ||||
|   | ||||
							
								
								
									
										111
									
								
								miniz.c
									
									
									
									
									
								
							
							
						
						
									
										111
									
								
								miniz.c
									
									
									
									
									
								
							| @@ -89,43 +89,43 @@ mz_ulong mz_crc32(mz_ulong crc, const mz_uint8 *ptr, size_t buf_len) | ||||
| { | ||||
|     static const mz_uint32 s_crc_table[256] = | ||||
|         { | ||||
|             0x00000000, 0x77073096, 0xEE0E612C, 0x990951BA, 0x076DC419, 0x706AF48F, 0xE963A535, | ||||
|             0x9E6495A3, 0x0EDB8832, 0x79DCB8A4, 0xE0D5E91E, 0x97D2D988, 0x09B64C2B, 0x7EB17CBD, | ||||
|             0xE7B82D07, 0x90BF1D91, 0x1DB71064, 0x6AB020F2, 0xF3B97148, 0x84BE41DE, 0x1ADAD47D, | ||||
|             0x6DDDE4EB, 0xF4D4B551, 0x83D385C7, 0x136C9856, 0x646BA8C0, 0xFD62F97A, 0x8A65C9EC, | ||||
|             0x14015C4F, 0x63066CD9, 0xFA0F3D63, 0x8D080DF5, 0x3B6E20C8, 0x4C69105E, 0xD56041E4, | ||||
|             0xA2677172, 0x3C03E4D1, 0x4B04D447, 0xD20D85FD, 0xA50AB56B, 0x35B5A8FA, 0x42B2986C, | ||||
|             0xDBBBC9D6, 0xACBCF940, 0x32D86CE3, 0x45DF5C75, 0xDCD60DCF, 0xABD13D59, 0x26D930AC, | ||||
|             0x51DE003A, 0xC8D75180, 0xBFD06116, 0x21B4F4B5, 0x56B3C423, 0xCFBA9599, 0xB8BDA50F, | ||||
|             0x2802B89E, 0x5F058808, 0xC60CD9B2, 0xB10BE924, 0x2F6F7C87, 0x58684C11, 0xC1611DAB, | ||||
|             0xB6662D3D, 0x76DC4190, 0x01DB7106, 0x98D220BC, 0xEFD5102A, 0x71B18589, 0x06B6B51F, | ||||
|             0x9FBFE4A5, 0xE8B8D433, 0x7807C9A2, 0x0F00F934, 0x9609A88E, 0xE10E9818, 0x7F6A0DBB, | ||||
|             0x086D3D2D, 0x91646C97, 0xE6635C01, 0x6B6B51F4, 0x1C6C6162, 0x856530D8, 0xF262004E, | ||||
|             0x6C0695ED, 0x1B01A57B, 0x8208F4C1, 0xF50FC457, 0x65B0D9C6, 0x12B7E950, 0x8BBEB8EA, | ||||
|             0xFCB9887C, 0x62DD1DDF, 0x15DA2D49, 0x8CD37CF3, 0xFBD44C65, 0x4DB26158, 0x3AB551CE, | ||||
|             0xA3BC0074, 0xD4BB30E2, 0x4ADFA541, 0x3DD895D7, 0xA4D1C46D, 0xD3D6F4FB, 0x4369E96A, | ||||
|             0x346ED9FC, 0xAD678846, 0xDA60B8D0, 0x44042D73, 0x33031DE5, 0xAA0A4C5F, 0xDD0D7CC9, | ||||
|             0x5005713C, 0x270241AA, 0xBE0B1010, 0xC90C2086, 0x5768B525, 0x206F85B3, 0xB966D409, | ||||
|             0xCE61E49F, 0x5EDEF90E, 0x29D9C998, 0xB0D09822, 0xC7D7A8B4, 0x59B33D17, 0x2EB40D81, | ||||
|             0xB7BD5C3B, 0xC0BA6CAD, 0xEDB88320, 0x9ABFB3B6, 0x03B6E20C, 0x74B1D29A, 0xEAD54739, | ||||
|             0x9DD277AF, 0x04DB2615, 0x73DC1683, 0xE3630B12, 0x94643B84, 0x0D6D6A3E, 0x7A6A5AA8, | ||||
|             0xE40ECF0B, 0x9309FF9D, 0x0A00AE27, 0x7D079EB1, 0xF00F9344, 0x8708A3D2, 0x1E01F268, | ||||
|             0x6906C2FE, 0xF762575D, 0x806567CB, 0x196C3671, 0x6E6B06E7, 0xFED41B76, 0x89D32BE0, | ||||
|             0x10DA7A5A, 0x67DD4ACC, 0xF9B9DF6F, 0x8EBEEFF9, 0x17B7BE43, 0x60B08ED5, 0xD6D6A3E8, | ||||
|             0xA1D1937E, 0x38D8C2C4, 0x4FDFF252, 0xD1BB67F1, 0xA6BC5767, 0x3FB506DD, 0x48B2364B, | ||||
|             0xD80D2BDA, 0xAF0A1B4C, 0x36034AF6, 0x41047A60, 0xDF60EFC3, 0xA867DF55, 0x316E8EEF, | ||||
|             0x4669BE79, 0xCB61B38C, 0xBC66831A, 0x256FD2A0, 0x5268E236, 0xCC0C7795, 0xBB0B4703, | ||||
|             0x220216B9, 0x5505262F, 0xC5BA3BBE, 0xB2BD0B28, 0x2BB45A92, 0x5CB36A04, 0xC2D7FFA7, | ||||
|             0xB5D0CF31, 0x2CD99E8B, 0x5BDEAE1D, 0x9B64C2B0, 0xEC63F226, 0x756AA39C, 0x026D930A, | ||||
|             0x9C0906A9, 0xEB0E363F, 0x72076785, 0x05005713, 0x95BF4A82, 0xE2B87A14, 0x7BB12BAE, | ||||
|             0x0CB61B38, 0x92D28E9B, 0xE5D5BE0D, 0x7CDCEFB7, 0x0BDBDF21, 0x86D3D2D4, 0xF1D4E242, | ||||
|             0x68DDB3F8, 0x1FDA836E, 0x81BE16CD, 0xF6B9265B, 0x6FB077E1, 0x18B74777, 0x88085AE6, | ||||
|             0xFF0F6A70, 0x66063BCA, 0x11010B5C, 0x8F659EFF, 0xF862AE69, 0x616BFFD3, 0x166CCF45, | ||||
|             0xA00AE278, 0xD70DD2EE, 0x4E048354, 0x3903B3C2, 0xA7672661, 0xD06016F7, 0x4969474D, | ||||
|             0x3E6E77DB, 0xAED16A4A, 0xD9D65ADC, 0x40DF0B66, 0x37D83BF0, 0xA9BCAE53, 0xDEBB9EC5, | ||||
|             0x47B2CF7F, 0x30B5FFE9, 0xBDBDF21C, 0xCABAC28A, 0x53B39330, 0x24B4A3A6, 0xBAD03605, | ||||
|             0xCDD70693, 0x54DE5729, 0x23D967BF, 0xB3667A2E, 0xC4614AB8, 0x5D681B02, 0x2A6F2B94, | ||||
|             0xB40BBE37, 0xC30C8EA1, 0x5A05DF1B, 0x2D02EF8D | ||||
|           0x00000000, 0x77073096, 0xEE0E612C, 0x990951BA, 0x076DC419, 0x706AF48F, 0xE963A535, | ||||
|           0x9E6495A3, 0x0EDB8832, 0x79DCB8A4, 0xE0D5E91E, 0x97D2D988, 0x09B64C2B, 0x7EB17CBD, | ||||
|           0xE7B82D07, 0x90BF1D91, 0x1DB71064, 0x6AB020F2, 0xF3B97148, 0x84BE41DE, 0x1ADAD47D, | ||||
|           0x6DDDE4EB, 0xF4D4B551, 0x83D385C7, 0x136C9856, 0x646BA8C0, 0xFD62F97A, 0x8A65C9EC, | ||||
|           0x14015C4F, 0x63066CD9, 0xFA0F3D63, 0x8D080DF5, 0x3B6E20C8, 0x4C69105E, 0xD56041E4, | ||||
|           0xA2677172, 0x3C03E4D1, 0x4B04D447, 0xD20D85FD, 0xA50AB56B, 0x35B5A8FA, 0x42B2986C, | ||||
|           0xDBBBC9D6, 0xACBCF940, 0x32D86CE3, 0x45DF5C75, 0xDCD60DCF, 0xABD13D59, 0x26D930AC, | ||||
|           0x51DE003A, 0xC8D75180, 0xBFD06116, 0x21B4F4B5, 0x56B3C423, 0xCFBA9599, 0xB8BDA50F, | ||||
|           0x2802B89E, 0x5F058808, 0xC60CD9B2, 0xB10BE924, 0x2F6F7C87, 0x58684C11, 0xC1611DAB, | ||||
|           0xB6662D3D, 0x76DC4190, 0x01DB7106, 0x98D220BC, 0xEFD5102A, 0x71B18589, 0x06B6B51F, | ||||
|           0x9FBFE4A5, 0xE8B8D433, 0x7807C9A2, 0x0F00F934, 0x9609A88E, 0xE10E9818, 0x7F6A0DBB, | ||||
|           0x086D3D2D, 0x91646C97, 0xE6635C01, 0x6B6B51F4, 0x1C6C6162, 0x856530D8, 0xF262004E, | ||||
|           0x6C0695ED, 0x1B01A57B, 0x8208F4C1, 0xF50FC457, 0x65B0D9C6, 0x12B7E950, 0x8BBEB8EA, | ||||
|           0xFCB9887C, 0x62DD1DDF, 0x15DA2D49, 0x8CD37CF3, 0xFBD44C65, 0x4DB26158, 0x3AB551CE, | ||||
|           0xA3BC0074, 0xD4BB30E2, 0x4ADFA541, 0x3DD895D7, 0xA4D1C46D, 0xD3D6F4FB, 0x4369E96A, | ||||
|           0x346ED9FC, 0xAD678846, 0xDA60B8D0, 0x44042D73, 0x33031DE5, 0xAA0A4C5F, 0xDD0D7CC9, | ||||
|           0x5005713C, 0x270241AA, 0xBE0B1010, 0xC90C2086, 0x5768B525, 0x206F85B3, 0xB966D409, | ||||
|           0xCE61E49F, 0x5EDEF90E, 0x29D9C998, 0xB0D09822, 0xC7D7A8B4, 0x59B33D17, 0x2EB40D81, | ||||
|           0xB7BD5C3B, 0xC0BA6CAD, 0xEDB88320, 0x9ABFB3B6, 0x03B6E20C, 0x74B1D29A, 0xEAD54739, | ||||
|           0x9DD277AF, 0x04DB2615, 0x73DC1683, 0xE3630B12, 0x94643B84, 0x0D6D6A3E, 0x7A6A5AA8, | ||||
|           0xE40ECF0B, 0x9309FF9D, 0x0A00AE27, 0x7D079EB1, 0xF00F9344, 0x8708A3D2, 0x1E01F268, | ||||
|           0x6906C2FE, 0xF762575D, 0x806567CB, 0x196C3671, 0x6E6B06E7, 0xFED41B76, 0x89D32BE0, | ||||
|           0x10DA7A5A, 0x67DD4ACC, 0xF9B9DF6F, 0x8EBEEFF9, 0x17B7BE43, 0x60B08ED5, 0xD6D6A3E8, | ||||
|           0xA1D1937E, 0x38D8C2C4, 0x4FDFF252, 0xD1BB67F1, 0xA6BC5767, 0x3FB506DD, 0x48B2364B, | ||||
|           0xD80D2BDA, 0xAF0A1B4C, 0x36034AF6, 0x41047A60, 0xDF60EFC3, 0xA867DF55, 0x316E8EEF, | ||||
|           0x4669BE79, 0xCB61B38C, 0xBC66831A, 0x256FD2A0, 0x5268E236, 0xCC0C7795, 0xBB0B4703, | ||||
|           0x220216B9, 0x5505262F, 0xC5BA3BBE, 0xB2BD0B28, 0x2BB45A92, 0x5CB36A04, 0xC2D7FFA7, | ||||
|           0xB5D0CF31, 0x2CD99E8B, 0x5BDEAE1D, 0x9B64C2B0, 0xEC63F226, 0x756AA39C, 0x026D930A, | ||||
|           0x9C0906A9, 0xEB0E363F, 0x72076785, 0x05005713, 0x95BF4A82, 0xE2B87A14, 0x7BB12BAE, | ||||
|           0x0CB61B38, 0x92D28E9B, 0xE5D5BE0D, 0x7CDCEFB7, 0x0BDBDF21, 0x86D3D2D4, 0xF1D4E242, | ||||
|           0x68DDB3F8, 0x1FDA836E, 0x81BE16CD, 0xF6B9265B, 0x6FB077E1, 0x18B74777, 0x88085AE6, | ||||
|           0xFF0F6A70, 0x66063BCA, 0x11010B5C, 0x8F659EFF, 0xF862AE69, 0x616BFFD3, 0x166CCF45, | ||||
|           0xA00AE278, 0xD70DD2EE, 0x4E048354, 0x3903B3C2, 0xA7672661, 0xD06016F7, 0x4969474D, | ||||
|           0x3E6E77DB, 0xAED16A4A, 0xD9D65ADC, 0x40DF0B66, 0x37D83BF0, 0xA9BCAE53, 0xDEBB9EC5, | ||||
|           0x47B2CF7F, 0x30B5FFE9, 0xBDBDF21C, 0xCABAC28A, 0x53B39330, 0x24B4A3A6, 0xBAD03605, | ||||
|           0xCDD70693, 0x54DE5729, 0x23D967BF, 0xB3667A2E, 0xC4614AB8, 0x5D681B02, 0x2A6F2B94, | ||||
|           0xB40BBE37, 0xC30C8EA1, 0x5A05DF1B, 0x2D02EF8D | ||||
|         }; | ||||
|  | ||||
|     mz_uint32 crc32 = (mz_uint32)crc ^ 0xFFFFFFFF; | ||||
| @@ -320,7 +320,7 @@ int mz_compress2(unsigned char *pDest, mz_ulong *pDest_len, const unsigned char | ||||
|     stream.next_in = pSource; | ||||
|     stream.avail_in = (mz_uint32)source_len; | ||||
|     stream.next_out = pDest; | ||||
|     stream.avail_out = (mz_uint32) * pDest_len; | ||||
|     stream.avail_out = (mz_uint32)*pDest_len; | ||||
|  | ||||
|     status = mz_deflateInit(&stream, level); | ||||
|     if (status != MZ_OK) | ||||
| @@ -397,6 +397,32 @@ int mz_inflateInit(mz_streamp pStream) | ||||
|     return mz_inflateInit2(pStream, MZ_DEFAULT_WINDOW_BITS); | ||||
| } | ||||
|  | ||||
| int mz_inflateReset(mz_streamp pStream) | ||||
| { | ||||
|     inflate_state *pDecomp; | ||||
|     if (!pStream) | ||||
|         return MZ_STREAM_ERROR; | ||||
|  | ||||
|     pStream->data_type = 0; | ||||
|     pStream->adler = 0; | ||||
|     pStream->msg = NULL; | ||||
|     pStream->total_in = 0; | ||||
|     pStream->total_out = 0; | ||||
|     pStream->reserved = 0; | ||||
|  | ||||
|     pDecomp = (inflate_state *)pStream->state; | ||||
|  | ||||
|     tinfl_init(&pDecomp->m_decomp); | ||||
|     pDecomp->m_dict_ofs = 0; | ||||
|     pDecomp->m_dict_avail = 0; | ||||
|     pDecomp->m_last_status = TINFL_STATUS_NEEDS_MORE_INPUT; | ||||
|     pDecomp->m_first_call = 1; | ||||
|     pDecomp->m_has_flushed = 0; | ||||
|     /* pDecomp->m_window_bits = window_bits */; | ||||
|  | ||||
|     return MZ_OK; | ||||
| } | ||||
|  | ||||
| int mz_inflate(mz_streamp pStream, int flush) | ||||
| { | ||||
|     inflate_state *pState; | ||||
| @@ -534,7 +560,7 @@ int mz_uncompress(unsigned char *pDest, mz_ulong *pDest_len, const unsigned char | ||||
|     stream.next_in = pSource; | ||||
|     stream.avail_in = (mz_uint32)source_len; | ||||
|     stream.next_out = pDest; | ||||
|     stream.avail_out = (mz_uint32) * pDest_len; | ||||
|     stream.avail_out = (mz_uint32)*pDest_len; | ||||
|  | ||||
|     status = mz_inflateInit(&stream); | ||||
|     if (status != MZ_OK) | ||||
| @@ -558,10 +584,9 @@ const char *mz_error(int err) | ||||
|         int m_err; | ||||
|         const char *m_pDesc; | ||||
|     } s_error_descs[] = | ||||
|           { | ||||
|               { MZ_OK, "" }, { MZ_STREAM_END, "stream end" }, { MZ_NEED_DICT, "need dictionary" }, { MZ_ERRNO, "file error" }, { MZ_STREAM_ERROR, "stream error" }, | ||||
|               { MZ_DATA_ERROR, "data error" }, { MZ_MEM_ERROR, "out of memory" }, { MZ_BUF_ERROR, "buf error" }, { MZ_VERSION_ERROR, "version error" }, { MZ_PARAM_ERROR, "parameter error" } | ||||
|           }; | ||||
|         { | ||||
|           { MZ_OK, "" }, { MZ_STREAM_END, "stream end" }, { MZ_NEED_DICT, "need dictionary" }, { MZ_ERRNO, "file error" }, { MZ_STREAM_ERROR, "stream error" }, { MZ_DATA_ERROR, "data error" }, { MZ_MEM_ERROR, "out of memory" }, { MZ_BUF_ERROR, "buf error" }, { MZ_VERSION_ERROR, "version error" }, { MZ_PARAM_ERROR, "parameter error" } | ||||
|         }; | ||||
|     mz_uint i; | ||||
|     for (i = 0; i < sizeof(s_error_descs) / sizeof(s_error_descs[0]); ++i) | ||||
|         if (s_error_descs[i].m_err == err) | ||||
|   | ||||
							
								
								
									
										40
									
								
								miniz.h
									
									
									
									
									
								
							
							
						
						
									
										40
									
								
								miniz.h
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| /* miniz.c v1.16 beta r1 - public domain deflate/inflate, zlib-subset, ZIP reading/writing/appending, PNG writing | ||||
| /* miniz.c 2.1.0 - public domain deflate/inflate, zlib-subset, ZIP reading/writing/appending, PNG writing | ||||
|    See "unlicense" statement at the end of this file. | ||||
|    Rich Geldreich <richgel99@gmail.com>, last updated Oct. 13, 2013 | ||||
|    Implements RFC 1950: http://www.ietf.org/rfc/rfc1950.txt and RFC 1951: http://www.ietf.org/rfc/rfc1951.txt | ||||
| @@ -24,7 +24,7 @@ | ||||
|      zlib replacement in many apps: | ||||
|         The z_stream struct, optional memory allocation callbacks | ||||
|         deflateInit/deflateInit2/deflate/deflateReset/deflateEnd/deflateBound | ||||
|         inflateInit/inflateInit2/inflate/inflateEnd | ||||
|         inflateInit/inflateInit2/inflate/inflateReset/inflateEnd | ||||
|         compress, compress2, compressBound, uncompress | ||||
|         CRC-32, Adler-32 - Using modern, minimal code size, CPU cache friendly routines. | ||||
|         Supports raw deflate streams or standard zlib streams with adler-32 checking. | ||||
| @@ -159,21 +159,33 @@ | ||||
| #if defined(_M_IX86) || defined(_M_X64) || defined(__i386__) || defined(__i386) || defined(__i486__) || defined(__i486) || defined(i386) || defined(__ia64__) || defined(__x86_64__) | ||||
| /* MINIZ_X86_OR_X64_CPU is only used to help set the below macros. */ | ||||
| #define MINIZ_X86_OR_X64_CPU 1 | ||||
| #else | ||||
| #define MINIZ_X86_OR_X64_CPU 0 | ||||
| #endif | ||||
|  | ||||
| #if (__BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__) || MINIZ_X86_OR_X64_CPU | ||||
| /* Set MINIZ_LITTLE_ENDIAN to 1 if the processor is little endian. */ | ||||
| #define MINIZ_LITTLE_ENDIAN 1 | ||||
| #else | ||||
| #define MINIZ_LITTLE_ENDIAN 0 | ||||
| #endif | ||||
|  | ||||
| /* Set MINIZ_USE_UNALIGNED_LOADS_AND_STORES only if not set */ | ||||
| #if !defined(MINIZ_USE_UNALIGNED_LOADS_AND_STORES) | ||||
| #if MINIZ_X86_OR_X64_CPU | ||||
| /* Set MINIZ_USE_UNALIGNED_LOADS_AND_STORES to 1 on CPU's that permit efficient integer loads and stores from unaligned addresses. */ | ||||
| #define MINIZ_USE_UNALIGNED_LOADS_AND_STORES 1 | ||||
| #define MINIZ_UNALIGNED_USE_MEMCPY | ||||
| #else | ||||
| #define MINIZ_USE_UNALIGNED_LOADS_AND_STORES 0 | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #if defined(_M_X64) || defined(_WIN64) || defined(__MINGW64__) || defined(_LP64) || defined(__LP64__) || defined(__ia64__) || defined(__x86_64__) | ||||
| /* Set MINIZ_HAS_64BIT_REGISTERS to 1 if operations on 64-bit integers are reasonably fast (and don't involve compiler generated calls to helper functions). */ | ||||
| #define MINIZ_HAS_64BIT_REGISTERS 1 | ||||
| #else | ||||
| #define MINIZ_HAS_64BIT_REGISTERS 0 | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| @@ -212,24 +224,24 @@ enum | ||||
| /* Heap allocation callbacks. | ||||
| Note that mz_alloc_func parameter types purpsosely differ from zlib's: items/size is size_t, not unsigned long. */ | ||||
| typedef void *(*mz_alloc_func)(void *opaque, size_t items, size_t size); | ||||
| typedef void(*mz_free_func)(void *opaque, void *address); | ||||
| typedef void (*mz_free_func)(void *opaque, void *address); | ||||
| typedef void *(*mz_realloc_func)(void *opaque, void *address, size_t items, size_t size); | ||||
|  | ||||
| /* Compression levels: 0-9 are the standard zlib-style levels, 10 is best possible compression (not zlib compatible, and may be very slow), MZ_DEFAULT_COMPRESSION=MZ_DEFAULT_LEVEL. */ | ||||
| enum | ||||
| { | ||||
| 	MZ_NO_COMPRESSION = 0, | ||||
| 	MZ_BEST_SPEED = 1, | ||||
| 	MZ_BEST_COMPRESSION = 9, | ||||
| 	MZ_UBER_COMPRESSION = 10, | ||||
| 	MZ_DEFAULT_LEVEL = 6, | ||||
| 	MZ_DEFAULT_COMPRESSION = -1 | ||||
|     MZ_NO_COMPRESSION = 0, | ||||
|     MZ_BEST_SPEED = 1, | ||||
|     MZ_BEST_COMPRESSION = 9, | ||||
|     MZ_UBER_COMPRESSION = 10, | ||||
|     MZ_DEFAULT_LEVEL = 6, | ||||
|     MZ_DEFAULT_COMPRESSION = -1 | ||||
| }; | ||||
|  | ||||
| #define MZ_VERSION "10.0.0" | ||||
| #define MZ_VERNUM 0xA000 | ||||
| #define MZ_VERSION "10.1.0" | ||||
| #define MZ_VERNUM 0xA100 | ||||
| #define MZ_VER_MAJOR 10 | ||||
| #define MZ_VER_MINOR 0 | ||||
| #define MZ_VER_MINOR 1 | ||||
| #define MZ_VER_REVISION 0 | ||||
| #define MZ_VER_SUBREVISION 0 | ||||
|  | ||||
| @@ -353,6 +365,9 @@ int mz_inflateInit(mz_streamp pStream); | ||||
| /* window_bits must be MZ_DEFAULT_WINDOW_BITS (to parse zlib header/footer) or -MZ_DEFAULT_WINDOW_BITS (raw deflate). */ | ||||
| int mz_inflateInit2(mz_streamp pStream, int window_bits); | ||||
|  | ||||
| /* Quickly resets a compressor without having to reallocate anything. Same as calling mz_inflateEnd() followed by mz_inflateInit()/mz_inflateInit2(). */ | ||||
| int mz_inflateReset(mz_streamp pStream); | ||||
|  | ||||
| /* Decompresses the input stream to the output, consuming only as much of the input as needed, and writing as much to the output as possible. */ | ||||
| /* Parameters: */ | ||||
| /*   pStream is the stream to read from and write to. You must initialize/update the next_in, avail_in, next_out, and avail_out members. */ | ||||
| @@ -436,6 +451,7 @@ typedef void *const voidpc; | ||||
| #define compressBound mz_compressBound | ||||
| #define inflateInit mz_inflateInit | ||||
| #define inflateInit2 mz_inflateInit2 | ||||
| #define inflateReset mz_inflateReset | ||||
| #define inflate mz_inflate | ||||
| #define inflateEnd mz_inflateEnd | ||||
| #define uncompress mz_uncompress | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| #pragma once | ||||
| #include <assert.h> | ||||
| #include <stdint.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| #include <stdint.h> | ||||
|  | ||||
| /* ------------------- Types and macros */ | ||||
| typedef unsigned char mz_uint8; | ||||
| @@ -45,7 +45,7 @@ typedef struct mz_dummy_time_t_tag | ||||
|  | ||||
| #ifdef MINIZ_NO_MALLOC | ||||
| #define MZ_MALLOC(x) NULL | ||||
| #define MZ_FREE(x) (void) x, ((void)0) | ||||
| #define MZ_FREE(x) (void)x, ((void)0) | ||||
| #define MZ_REALLOC(p, x) NULL | ||||
| #else | ||||
| #define MZ_MALLOC(x) malloc(x) | ||||
| @@ -57,7 +57,7 @@ typedef struct mz_dummy_time_t_tag | ||||
| #define MZ_MIN(a, b) (((a) < (b)) ? (a) : (b)) | ||||
| #define MZ_CLEAR_OBJ(obj) memset(&(obj), 0, sizeof(obj)) | ||||
|  | ||||
| #if MINIZ_USE_UNALIGNED_LOADS_AND_STORES &&MINIZ_LITTLE_ENDIAN | ||||
| #if MINIZ_USE_UNALIGNED_LOADS_AND_STORES && MINIZ_LITTLE_ENDIAN | ||||
| #define MZ_READ_LE16(p) *((const mz_uint16 *)(p)) | ||||
| #define MZ_READ_LE32(p) *((const mz_uint32 *)(p)) | ||||
| #else | ||||
|   | ||||
							
								
								
									
										168
									
								
								miniz_tdef.c
									
									
									
									
									
								
							
							
						
						
									
										168
									
								
								miniz_tdef.c
									
									
									
									
									
								
							| @@ -36,64 +36,64 @@ extern "C" { | ||||
| /* Purposely making these tables static for faster init and thread safety. */ | ||||
| static const mz_uint16 s_tdefl_len_sym[256] = | ||||
|     { | ||||
|         257, 258, 259, 260, 261, 262, 263, 264, 265, 265, 266, 266, 267, 267, 268, 268, 269, 269, 269, 269, 270, 270, 270, 270, 271, 271, 271, 271, 272, 272, 272, 272, | ||||
|         273, 273, 273, 273, 273, 273, 273, 273, 274, 274, 274, 274, 274, 274, 274, 274, 275, 275, 275, 275, 275, 275, 275, 275, 276, 276, 276, 276, 276, 276, 276, 276, | ||||
|         277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, | ||||
|         279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, | ||||
|         281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, | ||||
|         282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, | ||||
|         283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, | ||||
|         284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 285 | ||||
|       257, 258, 259, 260, 261, 262, 263, 264, 265, 265, 266, 266, 267, 267, 268, 268, 269, 269, 269, 269, 270, 270, 270, 270, 271, 271, 271, 271, 272, 272, 272, 272, | ||||
|       273, 273, 273, 273, 273, 273, 273, 273, 274, 274, 274, 274, 274, 274, 274, 274, 275, 275, 275, 275, 275, 275, 275, 275, 276, 276, 276, 276, 276, 276, 276, 276, | ||||
|       277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 277, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, | ||||
|       279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 279, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, 280, | ||||
|       281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, 281, | ||||
|       282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, 282, | ||||
|       283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, 283, | ||||
|       284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 284, 285 | ||||
|     }; | ||||
|  | ||||
| static const mz_uint8 s_tdefl_len_extra[256] = | ||||
|     { | ||||
|         0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, | ||||
|         4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, | ||||
|         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, 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, | ||||
|         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, 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, 0 | ||||
|       0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, | ||||
|       4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, | ||||
|       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, 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, | ||||
|       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, 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, 0 | ||||
|     }; | ||||
|  | ||||
| static const mz_uint8 s_tdefl_small_dist_sym[512] = | ||||
|     { | ||||
|         0, 1, 2, 3, 4, 4, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 8, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, | ||||
|         11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13, | ||||
|         13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, | ||||
|         14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, | ||||
|         14, 14, 14, 14, 14, 14, 14, 14, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, | ||||
|         15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, | ||||
|         16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, | ||||
|         16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, | ||||
|         16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, | ||||
|         17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, | ||||
|         17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, | ||||
|         17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17 | ||||
|       0, 1, 2, 3, 4, 4, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8, 8, 8, 8, 8, 8, 9, 9, 9, 9, 9, 9, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, | ||||
|       11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13, | ||||
|       13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, | ||||
|       14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, 14, | ||||
|       14, 14, 14, 14, 14, 14, 14, 14, 14, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, | ||||
|       15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, | ||||
|       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, | ||||
|       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, | ||||
|       16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, | ||||
|       17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, | ||||
|       17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, | ||||
|       17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17 | ||||
|     }; | ||||
|  | ||||
| static const mz_uint8 s_tdefl_small_dist_extra[512] = | ||||
|     { | ||||
|         0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 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, 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, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, | ||||
|         6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, | ||||
|         6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, | ||||
|         7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, | ||||
|         7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, | ||||
|         7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, | ||||
|         7, 7, 7, 7, 7, 7, 7, 7 | ||||
|       0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 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, 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, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, | ||||
|       6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, | ||||
|       6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, | ||||
|       7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, | ||||
|       7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, | ||||
|       7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, | ||||
|       7, 7, 7, 7, 7, 7, 7, 7 | ||||
|     }; | ||||
|  | ||||
| static const mz_uint8 s_tdefl_large_dist_sym[128] = | ||||
|     { | ||||
|         0, 0, 18, 19, 20, 20, 21, 21, 22, 22, 22, 22, 23, 23, 23, 23, 24, 24, 24, 24, 24, 24, 24, 24, 25, 25, 25, 25, 25, 25, 25, 25, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, | ||||
|         26, 26, 26, 26, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, | ||||
|         28, 28, 28, 28, 28, 28, 28, 28, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29 | ||||
|       0, 0, 18, 19, 20, 20, 21, 21, 22, 22, 22, 22, 23, 23, 23, 23, 24, 24, 24, 24, 24, 24, 24, 24, 25, 25, 25, 25, 25, 25, 25, 25, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, 26, | ||||
|       26, 26, 26, 26, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, | ||||
|       28, 28, 28, 28, 28, 28, 28, 28, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29 | ||||
|     }; | ||||
|  | ||||
| static const mz_uint8 s_tdefl_large_dist_extra[128] = | ||||
|     { | ||||
|         0, 0, 8, 8, 9, 9, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, | ||||
|         12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, | ||||
|         13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13 | ||||
|       0, 0, 8, 8, 9, 9, 9, 9, 10, 10, 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, | ||||
|       12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, | ||||
|       13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13 | ||||
|     }; | ||||
|  | ||||
| /* Radix sorts tdefl_sym_freq[] array by 16-bit key m_key. Returns ptr to sorted values. */ | ||||
| @@ -449,7 +449,7 @@ static void tdefl_start_static_block(tdefl_compressor *d) | ||||
|  | ||||
| static const mz_uint mz_bitmasks[17] = { 0x0000, 0x0001, 0x0003, 0x0007, 0x000F, 0x001F, 0x003F, 0x007F, 0x00FF, 0x01FF, 0x03FF, 0x07FF, 0x0FFF, 0x1FFF, 0x3FFF, 0x7FFF, 0xFFFF }; | ||||
|  | ||||
| #if MINIZ_USE_UNALIGNED_LOADS_AND_STORES &&MINIZ_LITTLE_ENDIAN &&MINIZ_HAS_64BIT_REGISTERS | ||||
| #if MINIZ_USE_UNALIGNED_LOADS_AND_STORES && MINIZ_LITTLE_ENDIAN && MINIZ_HAS_64BIT_REGISTERS | ||||
| static mz_bool tdefl_compress_lz_codes(tdefl_compressor *d) | ||||
| { | ||||
|     mz_uint flags; | ||||
| @@ -737,13 +737,29 @@ static int tdefl_flush_block(tdefl_compressor *d, int flush) | ||||
| } | ||||
|  | ||||
| #if MINIZ_USE_UNALIGNED_LOADS_AND_STORES | ||||
| #ifdef MINIZ_UNALIGNED_USE_MEMCPY | ||||
| static mz_uint16 TDEFL_READ_UNALIGNED_WORD(const mz_uint8* p) | ||||
| { | ||||
| 	mz_uint16 ret; | ||||
| 	memcpy(&ret, p, sizeof(mz_uint16)); | ||||
| 	return ret; | ||||
| } | ||||
| static mz_uint16 TDEFL_READ_UNALIGNED_WORD2(const mz_uint16* p) | ||||
| { | ||||
| 	mz_uint16 ret; | ||||
| 	memcpy(&ret, p, sizeof(mz_uint16)); | ||||
| 	return ret; | ||||
| } | ||||
| #else | ||||
| #define TDEFL_READ_UNALIGNED_WORD(p) *(const mz_uint16 *)(p) | ||||
| #define TDEFL_READ_UNALIGNED_WORD2(p) *(const mz_uint16 *)(p) | ||||
| #endif | ||||
| static MZ_FORCEINLINE void tdefl_find_match(tdefl_compressor *d, mz_uint lookahead_pos, mz_uint max_dist, mz_uint max_match_len, mz_uint *pMatch_dist, mz_uint *pMatch_len) | ||||
| { | ||||
|     mz_uint dist, pos = lookahead_pos & TDEFL_LZ_DICT_SIZE_MASK, match_len = *pMatch_len, probe_pos = pos, next_probe_pos, probe_len; | ||||
|     mz_uint num_probes_left = d->m_max_probes[match_len >= 32]; | ||||
|     const mz_uint16 *s = (const mz_uint16 *)(d->m_dict + pos), *p, *q; | ||||
|     mz_uint16 c01 = TDEFL_READ_UNALIGNED_WORD(&d->m_dict[pos + match_len - 1]), s01 = TDEFL_READ_UNALIGNED_WORD(s); | ||||
|     mz_uint16 c01 = TDEFL_READ_UNALIGNED_WORD(&d->m_dict[pos + match_len - 1]), s01 = TDEFL_READ_UNALIGNED_WORD2(s); | ||||
|     MZ_ASSERT(max_match_len <= TDEFL_MAX_MATCH_LEN); | ||||
|     if (max_match_len <= match_len) | ||||
|         return; | ||||
| @@ -767,14 +783,14 @@ static MZ_FORCEINLINE void tdefl_find_match(tdefl_compressor *d, mz_uint lookahe | ||||
|         if (!dist) | ||||
|             break; | ||||
|         q = (const mz_uint16 *)(d->m_dict + probe_pos); | ||||
|         if (TDEFL_READ_UNALIGNED_WORD(q) != s01) | ||||
|         if (TDEFL_READ_UNALIGNED_WORD2(q) != s01) | ||||
|             continue; | ||||
|         p = s; | ||||
|         probe_len = 32; | ||||
|         do | ||||
|         { | ||||
|         } while ((TDEFL_READ_UNALIGNED_WORD(++p) == TDEFL_READ_UNALIGNED_WORD(++q)) && (TDEFL_READ_UNALIGNED_WORD(++p) == TDEFL_READ_UNALIGNED_WORD(++q)) && | ||||
|                  (TDEFL_READ_UNALIGNED_WORD(++p) == TDEFL_READ_UNALIGNED_WORD(++q)) && (TDEFL_READ_UNALIGNED_WORD(++p) == TDEFL_READ_UNALIGNED_WORD(++q)) && (--probe_len > 0)); | ||||
|         } while ((TDEFL_READ_UNALIGNED_WORD2(++p) == TDEFL_READ_UNALIGNED_WORD2(++q)) && (TDEFL_READ_UNALIGNED_WORD2(++p) == TDEFL_READ_UNALIGNED_WORD2(++q)) && | ||||
|                  (TDEFL_READ_UNALIGNED_WORD2(++p) == TDEFL_READ_UNALIGNED_WORD2(++q)) && (TDEFL_READ_UNALIGNED_WORD2(++p) == TDEFL_READ_UNALIGNED_WORD2(++q)) && (--probe_len > 0)); | ||||
|         if (!probe_len) | ||||
|         { | ||||
|             *pMatch_dist = dist; | ||||
| @@ -836,7 +852,17 @@ static MZ_FORCEINLINE void tdefl_find_match(tdefl_compressor *d, mz_uint lookahe | ||||
| } | ||||
| #endif /* #if MINIZ_USE_UNALIGNED_LOADS_AND_STORES */ | ||||
|  | ||||
| #if MINIZ_USE_UNALIGNED_LOADS_AND_STORES &&MINIZ_LITTLE_ENDIAN | ||||
| #if MINIZ_USE_UNALIGNED_LOADS_AND_STORES && MINIZ_LITTLE_ENDIAN | ||||
| #ifdef MINIZ_UNALIGNED_USE_MEMCPY | ||||
| static mz_uint32 TDEFL_READ_UNALIGNED_WORD32(const mz_uint8* p) | ||||
| { | ||||
| 	mz_uint32 ret; | ||||
| 	memcpy(&ret, p, sizeof(mz_uint32)); | ||||
| 	return ret; | ||||
| } | ||||
| #else | ||||
| #define TDEFL_READ_UNALIGNED_WORD32(p) *(const mz_uint32 *)(p) | ||||
| #endif | ||||
| static mz_bool tdefl_compress_fast(tdefl_compressor *d) | ||||
| { | ||||
|     /* Faster, minimally featured LZRW1-style match+parse loop with better register utilization. Intended for applications where raw throughput is valued more highly than ratio. */ | ||||
| @@ -871,20 +897,20 @@ static mz_bool tdefl_compress_fast(tdefl_compressor *d) | ||||
|         { | ||||
|             mz_uint cur_match_dist, cur_match_len = 1; | ||||
|             mz_uint8 *pCur_dict = d->m_dict + cur_pos; | ||||
|             mz_uint first_trigram = (*(const mz_uint32 *)pCur_dict) & 0xFFFFFF; | ||||
|             mz_uint first_trigram = TDEFL_READ_UNALIGNED_WORD32(pCur_dict) & 0xFFFFFF; | ||||
|             mz_uint hash = (first_trigram ^ (first_trigram >> (24 - (TDEFL_LZ_HASH_BITS - 8)))) & TDEFL_LEVEL1_HASH_SIZE_MASK; | ||||
|             mz_uint probe_pos = d->m_hash[hash]; | ||||
|             d->m_hash[hash] = (mz_uint16)lookahead_pos; | ||||
|  | ||||
|             if (((cur_match_dist = (mz_uint16)(lookahead_pos - probe_pos)) <= dict_size) && ((*(const mz_uint32 *)(d->m_dict + (probe_pos &= TDEFL_LZ_DICT_SIZE_MASK)) & 0xFFFFFF) == first_trigram)) | ||||
|             if (((cur_match_dist = (mz_uint16)(lookahead_pos - probe_pos)) <= dict_size) && ((TDEFL_READ_UNALIGNED_WORD32(d->m_dict + (probe_pos &= TDEFL_LZ_DICT_SIZE_MASK)) & 0xFFFFFF) == first_trigram)) | ||||
|             { | ||||
|                 const mz_uint16 *p = (const mz_uint16 *)pCur_dict; | ||||
|                 const mz_uint16 *q = (const mz_uint16 *)(d->m_dict + probe_pos); | ||||
|                 mz_uint32 probe_len = 32; | ||||
|                 do | ||||
|                 { | ||||
|                 } while ((TDEFL_READ_UNALIGNED_WORD(++p) == TDEFL_READ_UNALIGNED_WORD(++q)) && (TDEFL_READ_UNALIGNED_WORD(++p) == TDEFL_READ_UNALIGNED_WORD(++q)) && | ||||
|                          (TDEFL_READ_UNALIGNED_WORD(++p) == TDEFL_READ_UNALIGNED_WORD(++q)) && (TDEFL_READ_UNALIGNED_WORD(++p) == TDEFL_READ_UNALIGNED_WORD(++q)) && (--probe_len > 0)); | ||||
|                 } while ((TDEFL_READ_UNALIGNED_WORD2(++p) == TDEFL_READ_UNALIGNED_WORD2(++q)) && (TDEFL_READ_UNALIGNED_WORD2(++p) == TDEFL_READ_UNALIGNED_WORD2(++q)) && | ||||
|                          (TDEFL_READ_UNALIGNED_WORD2(++p) == TDEFL_READ_UNALIGNED_WORD2(++q)) && (TDEFL_READ_UNALIGNED_WORD2(++p) == TDEFL_READ_UNALIGNED_WORD2(++q)) && (--probe_len > 0)); | ||||
|                 cur_match_len = ((mz_uint)(p - (const mz_uint16 *)pCur_dict) * 2) + (mz_uint)(*(const mz_uint8 *)p == *(const mz_uint8 *)q); | ||||
|                 if (!probe_len) | ||||
|                     cur_match_len = cur_match_dist ? TDEFL_MAX_MATCH_LEN : 0; | ||||
| @@ -906,7 +932,11 @@ static mz_bool tdefl_compress_fast(tdefl_compressor *d) | ||||
|                     cur_match_dist--; | ||||
|  | ||||
|                     pLZ_code_buf[0] = (mz_uint8)(cur_match_len - TDEFL_MIN_MATCH_LEN); | ||||
| #ifdef MINIZ_UNALIGNED_USE_MEMCPY | ||||
| 					memcpy(&pLZ_code_buf[1], &cur_match_dist, sizeof(cur_match_dist)); | ||||
| #else | ||||
|                     *(mz_uint16 *)(&pLZ_code_buf[1]) = (mz_uint16)cur_match_dist; | ||||
| #endif | ||||
|                     pLZ_code_buf += 3; | ||||
|                     *pLZ_flags = (mz_uint8)((*pLZ_flags >> 1) | 0x80); | ||||
|  | ||||
| @@ -1250,7 +1280,7 @@ tdefl_status tdefl_compress(tdefl_compressor *d, const void *pIn_buf, size_t *pI | ||||
|     if ((d->m_output_flush_remaining) || (d->m_finished)) | ||||
|         return (d->m_prev_return_status = tdefl_flush_output_buffer(d)); | ||||
|  | ||||
| #if MINIZ_USE_UNALIGNED_LOADS_AND_STORES &&MINIZ_LITTLE_ENDIAN | ||||
| #if MINIZ_USE_UNALIGNED_LOADS_AND_STORES && MINIZ_LITTLE_ENDIAN | ||||
|     if (((d->m_flags & TDEFL_MAX_PROBES_MASK) == 1) && | ||||
|         ((d->m_flags & TDEFL_GREEDY_PARSING_FLAG) != 0) && | ||||
|         ((d->m_flags & (TDEFL_FILTER_MATCHES | TDEFL_FORCE_ALL_RAW_BLOCKS | TDEFL_RLE_MATCHES)) == 0)) | ||||
| @@ -1318,6 +1348,8 @@ tdefl_status tdefl_init(tdefl_compressor *d, tdefl_put_buf_func_ptr pPut_buf_fun | ||||
|     d->m_pSrc = NULL; | ||||
|     d->m_src_buf_left = 0; | ||||
|     d->m_out_buf_ofs = 0; | ||||
|     if (!(flags & TDEFL_NONDETERMINISTIC_PARSING_FLAG)) | ||||
|         MZ_CLEAR_OBJ(d->m_dict); | ||||
|     memset(&d->m_huff_count[0][0], 0, sizeof(d->m_huff_count[0][0]) * TDEFL_MAX_HUFF_SYMBOLS_0); | ||||
|     memset(&d->m_huff_count[1][0], 0, sizeof(d->m_huff_count[1][0]) * TDEFL_MAX_HUFF_SYMBOLS_1); | ||||
|     return TDEFL_STATUS_OKAY; | ||||
| @@ -1478,24 +1510,24 @@ void *tdefl_write_image_to_png_file_in_memory_ex(const void *pImage, int w, int | ||||
|     *pLen_out = out_buf.m_size - 41; | ||||
|     { | ||||
|         static const mz_uint8 chans[] = { 0x00, 0x00, 0x04, 0x02, 0x06 }; | ||||
|         mz_uint8 pnghdr[41] = { 0x89, 0x50, 0x4e, 0x47, 0x0d,  | ||||
| 								0x0a, 0x1a, 0x0a, 0x00, 0x00,  | ||||
| 								0x00, 0x0d, 0x49, 0x48, 0x44,  | ||||
| 								0x52, 0x00, 0x00, 0x00, 0x00,  | ||||
| 								0x00, 0x00, 0x00, 0x00, 0x08,  | ||||
| 								0x00, 0x00, 0x00, 0x00, 0x00,  | ||||
| 								0x00, 0x00, 0x00, 0x00, 0x00,  | ||||
| 								0x00, 0x00, 0x49, 0x44, 0x41,  | ||||
| 								0x54 }; | ||||
| 		pnghdr[18] = (mz_uint8)(w >> 8); | ||||
| 		pnghdr[19] = (mz_uint8)w; | ||||
| 		pnghdr[22] = (mz_uint8)(h >> 8); | ||||
| 		pnghdr[22] = (mz_uint8)h; | ||||
| 		pnghdr[25] = chans[num_chans]; | ||||
| 		pnghdr[33] = (mz_uint8)(*pLen_out >> 24); | ||||
| 		pnghdr[34] = (mz_uint8)(*pLen_out >> 16); | ||||
| 		pnghdr[35] = (mz_uint8)(*pLen_out >> 8); | ||||
| 		pnghdr[36] = (mz_uint8)*pLen_out; | ||||
|         mz_uint8 pnghdr[41] = { 0x89, 0x50, 0x4e, 0x47, 0x0d, | ||||
|                                 0x0a, 0x1a, 0x0a, 0x00, 0x00, | ||||
|                                 0x00, 0x0d, 0x49, 0x48, 0x44, | ||||
|                                 0x52, 0x00, 0x00, 0x00, 0x00, | ||||
|                                 0x00, 0x00, 0x00, 0x00, 0x08, | ||||
|                                 0x00, 0x00, 0x00, 0x00, 0x00, | ||||
|                                 0x00, 0x00, 0x00, 0x00, 0x00, | ||||
|                                 0x00, 0x00, 0x49, 0x44, 0x41, | ||||
|                                 0x54 }; | ||||
|         pnghdr[18] = (mz_uint8)(w >> 8); | ||||
|         pnghdr[19] = (mz_uint8)w; | ||||
|         pnghdr[22] = (mz_uint8)(h >> 8); | ||||
|         pnghdr[23] = (mz_uint8)h; | ||||
|         pnghdr[25] = chans[num_chans]; | ||||
|         pnghdr[33] = (mz_uint8)(*pLen_out >> 24); | ||||
|         pnghdr[34] = (mz_uint8)(*pLen_out >> 16); | ||||
|         pnghdr[35] = (mz_uint8)(*pLen_out >> 8); | ||||
|         pnghdr[36] = (mz_uint8)*pLen_out; | ||||
|         c = (mz_uint32)mz_crc32(MZ_CRC32_INIT, pnghdr + 12, 17); | ||||
|         for (i = 0; i < 4; ++i, c <<= 8) | ||||
|             ((mz_uint8 *)(pnghdr + 29))[i] = (mz_uint8)(c >> 24); | ||||
| @@ -1523,6 +1555,7 @@ void *tdefl_write_image_to_png_file_in_memory(const void *pImage, int w, int h, | ||||
|     return tdefl_write_image_to_png_file_in_memory_ex(pImage, w, h, num_chans, pLen_out, 6, MZ_FALSE); | ||||
| } | ||||
|  | ||||
| #ifndef MINIZ_NO_MALLOC | ||||
| /* Allocate the tdefl_compressor and tinfl_decompressor structures in C so that */ | ||||
| /* non-C language bindings to tdefL_ and tinfl_ API don't need to worry about */ | ||||
| /* structure size and allocation mechanism. */ | ||||
| @@ -1535,6 +1568,7 @@ void tdefl_compressor_free(tdefl_compressor *pComp) | ||||
| { | ||||
|     MZ_FREE(pComp); | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #ifdef _MSC_VER | ||||
| #pragma warning(pop) | ||||
|   | ||||
							
								
								
									
										10
									
								
								miniz_tdef.h
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								miniz_tdef.h
									
									
									
									
									
								
							| @@ -111,8 +111,7 @@ enum | ||||
| #endif | ||||
|  | ||||
| /* The low-level tdefl functions below may be used directly if the above helper functions aren't flexible enough. The low-level functions don't make any heap allocations, unlike the above helper functions. */ | ||||
| typedef enum | ||||
| { | ||||
| typedef enum { | ||||
|     TDEFL_STATUS_BAD_PARAM = -2, | ||||
|     TDEFL_STATUS_PUT_BUF_FAILED = -1, | ||||
|     TDEFL_STATUS_OKAY = 0, | ||||
| @@ -120,8 +119,7 @@ typedef enum | ||||
| } tdefl_status; | ||||
|  | ||||
| /* Must map to MZ_NO_FLUSH, MZ_SYNC_FLUSH, etc. enums */ | ||||
| typedef enum | ||||
| { | ||||
| typedef enum { | ||||
|     TDEFL_NO_FLUSH = 0, | ||||
|     TDEFL_SYNC_FLUSH = 2, | ||||
|     TDEFL_FULL_FLUSH = 3, | ||||
| @@ -179,11 +177,13 @@ mz_uint32 tdefl_get_adler32(tdefl_compressor *d); | ||||
| /* strategy may be either MZ_DEFAULT_STRATEGY, MZ_FILTERED, MZ_HUFFMAN_ONLY, MZ_RLE, or MZ_FIXED */ | ||||
| mz_uint tdefl_create_comp_flags_from_zip_params(int level, int window_bits, int strategy); | ||||
|  | ||||
| #ifndef MINIZ_NO_MALLOC | ||||
| /* Allocate the tdefl_compressor structure in C so that */ | ||||
| /* non-C language bindings to tdefl_ API don't need to worry about */ | ||||
| /* structure size and allocation mechanism. */ | ||||
| tdefl_compressor *tdefl_compressor_alloc(); | ||||
| tdefl_compressor *tdefl_compressor_alloc(void); | ||||
| void tdefl_compressor_free(tdefl_compressor *pComp); | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
|   | ||||
| @@ -45,8 +45,7 @@ extern "C" { | ||||
|         status = result;                     \ | ||||
|         r->m_state = state_index;            \ | ||||
|         goto common_exit;                    \ | ||||
|         case state_index:                    \ | ||||
|             ;                                \ | ||||
|         case state_index:;                   \ | ||||
|     }                                        \ | ||||
|     MZ_MACRO_END | ||||
| #define TINFL_CR_RETURN_FOREVER(state_index, result) \ | ||||
| @@ -60,15 +59,15 @@ extern "C" { | ||||
|     MZ_MACRO_END | ||||
| #define TINFL_CR_FINISH } | ||||
|  | ||||
| #define TINFL_GET_BYTE(state_index, c)                                                                                                                          \ | ||||
|     do                                                                                                                                                          \ | ||||
|     {                                                                                                                                                           \ | ||||
|         while (pIn_buf_cur >= pIn_buf_end)                                                                                                                      \ | ||||
|         {                                                                                                                                                       \ | ||||
|             TINFL_CR_RETURN(state_index, (decomp_flags &TINFL_FLAG_HAS_MORE_INPUT) ? TINFL_STATUS_NEEDS_MORE_INPUT : TINFL_STATUS_FAILED_CANNOT_MAKE_PROGRESS); \ | ||||
|         }                                                                                                                                                       \ | ||||
|         c = *pIn_buf_cur++;                                                                                                                                     \ | ||||
|     }                                                                                                                                                           \ | ||||
| #define TINFL_GET_BYTE(state_index, c)                                                                                                                           \ | ||||
|     do                                                                                                                                                           \ | ||||
|     {                                                                                                                                                            \ | ||||
|         while (pIn_buf_cur >= pIn_buf_end)                                                                                                                       \ | ||||
|         {                                                                                                                                                        \ | ||||
|             TINFL_CR_RETURN(state_index, (decomp_flags & TINFL_FLAG_HAS_MORE_INPUT) ? TINFL_STATUS_NEEDS_MORE_INPUT : TINFL_STATUS_FAILED_CANNOT_MAKE_PROGRESS); \ | ||||
|         }                                                                                                                                                        \ | ||||
|         c = *pIn_buf_cur++;                                                                                                                                      \ | ||||
|     }                                                                                                                                                            \ | ||||
|     MZ_MACRO_END | ||||
|  | ||||
| #define TINFL_NEED_BITS(state_index, n)                \ | ||||
| @@ -186,7 +185,7 @@ tinfl_status tinfl_decompress(tinfl_decompressor *r, const mz_uint8 *pIn_buf_nex | ||||
|     tinfl_bit_buf_t bit_buf; | ||||
|     const mz_uint8 *pIn_buf_cur = pIn_buf_next, *const pIn_buf_end = pIn_buf_next + *pIn_buf_size; | ||||
|     mz_uint8 *pOut_buf_cur = pOut_buf_next, *const pOut_buf_end = pOut_buf_next + *pOut_buf_size; | ||||
|     size_t out_buf_size_mask = (decomp_flags & TINFL_FLAG_USING_NON_WRAPPING_OUTPUT_BUF) ? (size_t) - 1 : ((pOut_buf_next - pOut_buf_start) + *pOut_buf_size) - 1, dist_from_out_buf_start; | ||||
|     size_t out_buf_size_mask = (decomp_flags & TINFL_FLAG_USING_NON_WRAPPING_OUTPUT_BUF) ? (size_t)-1 : ((pOut_buf_next - pOut_buf_start) + *pOut_buf_size) - 1, dist_from_out_buf_start; | ||||
|  | ||||
|     /* Ensure the output buffer's size is a power of 2, unless the output buffer is large enough to hold the entire output file (in which case it doesn't matter). */ | ||||
|     if (((out_buf_size_mask + 1) & out_buf_size_mask) || (pOut_buf_next < pOut_buf_start)) | ||||
| @@ -524,8 +523,12 @@ tinfl_status tinfl_decompress(tinfl_decompressor *r, const mz_uint8 *pIn_buf_nex | ||||
|                     const mz_uint8 *pSrc_end = pSrc + (counter & ~7); | ||||
|                     do | ||||
|                     { | ||||
| #ifdef MINIZ_UNALIGNED_USE_MEMCPY | ||||
| 						memcpy(pOut_buf_cur, pSrc, sizeof(mz_uint32)*2); | ||||
| #else | ||||
|                         ((mz_uint32 *)pOut_buf_cur)[0] = ((const mz_uint32 *)pSrc)[0]; | ||||
|                         ((mz_uint32 *)pOut_buf_cur)[1] = ((const mz_uint32 *)pSrc)[1]; | ||||
| #endif | ||||
|                         pOut_buf_cur += 8; | ||||
|                     } while ((pSrc += 8) < pSrc_end); | ||||
|                     if ((counter &= 7) < 3) | ||||
| @@ -541,18 +544,19 @@ tinfl_status tinfl_decompress(tinfl_decompressor *r, const mz_uint8 *pIn_buf_nex | ||||
|                     } | ||||
|                 } | ||||
| #endif | ||||
|                 do | ||||
|                 while(counter>2) | ||||
|                 { | ||||
|                     pOut_buf_cur[0] = pSrc[0]; | ||||
|                     pOut_buf_cur[1] = pSrc[1]; | ||||
|                     pOut_buf_cur[2] = pSrc[2]; | ||||
|                     pOut_buf_cur += 3; | ||||
|                     pSrc += 3; | ||||
|                 } while ((int)(counter -= 3) > 2); | ||||
|                 if ((int)counter > 0) | ||||
| 					counter -= 3; | ||||
|                 } | ||||
|                 if (counter > 0) | ||||
|                 { | ||||
|                     pOut_buf_cur[0] = pSrc[0]; | ||||
|                     if ((int)counter > 1) | ||||
|                     if (counter > 1) | ||||
|                         pOut_buf_cur[1] = pSrc[1]; | ||||
|                     pOut_buf_cur += counter; | ||||
|                 } | ||||
| @@ -568,7 +572,7 @@ tinfl_status tinfl_decompress(tinfl_decompressor *r, const mz_uint8 *pIn_buf_nex | ||||
|         --pIn_buf_cur; | ||||
|         num_bits -= 8; | ||||
|     } | ||||
|     bit_buf &= (tinfl_bit_buf_t)(( ((mz_uint64)1) << num_bits) - (mz_uint64)1); | ||||
|     bit_buf &= (tinfl_bit_buf_t)((((mz_uint64)1) << num_bits) - (mz_uint64)1); | ||||
|     MZ_ASSERT(!num_bits); /* if this assert fires then we've read beyond the end of non-deflate/zlib streams with following data (such as gzip streams). */ | ||||
|  | ||||
|     if (decomp_flags & TINFL_FLAG_PARSE_ZLIB_HEADER) | ||||
| @@ -600,7 +604,7 @@ common_exit: | ||||
|         } | ||||
|     } | ||||
|     r->m_num_bits = num_bits; | ||||
|     r->m_bit_buf = bit_buf & (tinfl_bit_buf_t)(( ((mz_uint64)1) << num_bits) - (mz_uint64)1); | ||||
|     r->m_bit_buf = bit_buf & (tinfl_bit_buf_t)((((mz_uint64)1) << num_bits) - (mz_uint64)1); | ||||
|     r->m_dist = dist; | ||||
|     r->m_counter = counter; | ||||
|     r->m_num_extra = num_extra; | ||||
| @@ -716,6 +720,7 @@ int tinfl_decompress_mem_to_callback(const void *pIn_buf, size_t *pIn_buf_size, | ||||
|     return result; | ||||
| } | ||||
|  | ||||
| #ifndef MINIZ_NO_MALLOC | ||||
| tinfl_decompressor *tinfl_decompressor_alloc() | ||||
| { | ||||
|     tinfl_decompressor *pDecomp = (tinfl_decompressor *)MZ_MALLOC(sizeof(tinfl_decompressor)); | ||||
| @@ -728,6 +733,7 @@ void tinfl_decompressor_free(tinfl_decompressor *pDecomp) | ||||
| { | ||||
|     MZ_FREE(pDecomp); | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
|   | ||||
| @@ -41,19 +41,19 @@ int tinfl_decompress_mem_to_callback(const void *pIn_buf, size_t *pIn_buf_size, | ||||
| struct tinfl_decompressor_tag; | ||||
| typedef struct tinfl_decompressor_tag tinfl_decompressor; | ||||
|  | ||||
| #ifndef MINIZ_NO_MALLOC | ||||
| /* Allocate the tinfl_decompressor structure in C so that */ | ||||
| /* non-C language bindings to tinfl_ API don't need to worry about */ | ||||
| /* structure size and allocation mechanism. */ | ||||
|  | ||||
| tinfl_decompressor *tinfl_decompressor_alloc(); | ||||
| tinfl_decompressor *tinfl_decompressor_alloc(void); | ||||
| void tinfl_decompressor_free(tinfl_decompressor *pDecomp); | ||||
| #endif | ||||
|  | ||||
| /* Max size of LZ dictionary. */ | ||||
| #define TINFL_LZ_DICT_SIZE 32768 | ||||
|  | ||||
| /* Return status. */ | ||||
| typedef enum | ||||
| { | ||||
| typedef enum { | ||||
|     /* This flags indicates the inflator needs 1 or more input bytes to make forward progress, but the caller is indicating that no more are available. The compressed data */ | ||||
|     /* is probably corrupted. If you call the inflator again with more bytes it'll try to continue processing the input but this is a BAD sign (either the data is corrupted or you called it incorrectly). */ | ||||
|     /* If you call it again with no input you'll just get TINFL_STATUS_FAILED_CANNOT_MAKE_PROGRESS again. */ | ||||
| @@ -118,6 +118,8 @@ typedef struct | ||||
|  | ||||
| #if MINIZ_HAS_64BIT_REGISTERS | ||||
| #define TINFL_USE_64BIT_BITBUF 1 | ||||
| #else | ||||
| #define TINFL_USE_64BIT_BITBUF 0 | ||||
| #endif | ||||
|  | ||||
| #if TINFL_USE_64BIT_BITBUF | ||||
|   | ||||
							
								
								
									
										575
									
								
								miniz_zip.c
									
									
									
									
									
								
							
							
						
						
									
										575
									
								
								miniz_zip.c
									
									
									
									
									
								
							| @@ -62,8 +62,8 @@ static FILE *mz_freopen(const char *pPath, const char *pMode, FILE *pStream) | ||||
| #define MZ_FWRITE fwrite | ||||
| #define MZ_FTELL64 _ftelli64 | ||||
| #define MZ_FSEEK64 _fseeki64 | ||||
| #define MZ_FILE_STAT_STRUCT _stat | ||||
| #define MZ_FILE_STAT _stat | ||||
| #define MZ_FILE_STAT_STRUCT _stat64 | ||||
| #define MZ_FILE_STAT _stat64 | ||||
| #define MZ_FFLUSH fflush | ||||
| #define MZ_FREOPEN mz_freopen | ||||
| #define MZ_DELETE_FILE remove | ||||
| @@ -97,7 +97,7 @@ static FILE *mz_freopen(const char *pPath, const char *pMode, FILE *pStream) | ||||
| #define MZ_FFLUSH fflush | ||||
| #define MZ_FREOPEN(f, m, s) freopen(f, m, s) | ||||
| #define MZ_DELETE_FILE remove | ||||
| #elif defined(__GNUC__) && _LARGEFILE64_SOURCE | ||||
| #elif defined(__GNUC__) && defined(_LARGEFILE64_SOURCE) | ||||
| #ifndef MINIZ_NO_TIME | ||||
| #include <utime.h> | ||||
| #endif | ||||
| @@ -112,7 +112,7 @@ static FILE *mz_freopen(const char *pPath, const char *pMode, FILE *pStream) | ||||
| #define MZ_FFLUSH fflush | ||||
| #define MZ_FREOPEN(p, m, s) freopen64(p, m, s) | ||||
| #define MZ_DELETE_FILE remove | ||||
| #elif defined(__APPLE__) && _LARGEFILE64_SOURCE | ||||
| #elif defined(__APPLE__) | ||||
| #ifndef MINIZ_NO_TIME | ||||
| #include <utime.h> | ||||
| #endif | ||||
| @@ -137,12 +137,12 @@ static FILE *mz_freopen(const char *pPath, const char *pMode, FILE *pStream) | ||||
| #define MZ_FCLOSE fclose | ||||
| #define MZ_FREAD fread | ||||
| #define MZ_FWRITE fwrite | ||||
| #ifdef __STRICT_ANSI__ | ||||
| #define MZ_FTELL64 ftell | ||||
| #define MZ_FSEEK64 fseek | ||||
| #else | ||||
| #define MZ_FTELL64 ftello | ||||
| #define MZ_FSEEK64 fseeko | ||||
| #ifdef __STRICT_ANSI__ | ||||
| #define MZ_FTELL64 ftell | ||||
| #define MZ_FSEEK64 fseek | ||||
| #else | ||||
| #define MZ_FTELL64 ftello | ||||
| #define MZ_FSEEK64 fseeko | ||||
| #endif | ||||
| #define MZ_FILE_STAT_STRUCT stat | ||||
| #define MZ_FILE_STAT stat | ||||
| @@ -351,7 +351,8 @@ static MZ_FORCEINLINE mz_bool mz_zip_array_push_back(mz_zip_archive *pZip, mz_zi | ||||
|     size_t orig_size = pArray->m_size; | ||||
|     if (!mz_zip_array_resize(pZip, pArray, orig_size + n, MZ_TRUE)) | ||||
|         return MZ_FALSE; | ||||
|     memcpy((mz_uint8 *)pArray->m_p + orig_size * pArray->m_element_size, pElements, n * pArray->m_element_size); | ||||
|     if (n > 0) | ||||
|         memcpy((mz_uint8 *)pArray->m_p + orig_size * pArray->m_element_size, pElements, n * pArray->m_element_size); | ||||
|     return MZ_TRUE; | ||||
| } | ||||
|  | ||||
| @@ -748,21 +749,47 @@ static mz_bool mz_zip_reader_read_central_dir(mz_zip_archive *pZip, mz_uint flag | ||||
|  | ||||
|                 if (extra_size_remaining) | ||||
|                 { | ||||
|                     const mz_uint8 *pExtra_data = p + MZ_ZIP_CENTRAL_DIR_HEADER_SIZE + filename_size; | ||||
| 					const mz_uint8 *pExtra_data; | ||||
| 					void* buf = NULL; | ||||
|  | ||||
| 					if (MZ_ZIP_CENTRAL_DIR_HEADER_SIZE + filename_size + ext_data_size > n) | ||||
| 					{ | ||||
| 						buf = MZ_MALLOC(ext_data_size); | ||||
| 						if(buf==NULL) | ||||
| 							return mz_zip_set_error(pZip, MZ_ZIP_ALLOC_FAILED); | ||||
|  | ||||
| 						if (pZip->m_pRead(pZip->m_pIO_opaque, cdir_ofs + MZ_ZIP_CENTRAL_DIR_HEADER_SIZE + filename_size, buf, ext_data_size) != ext_data_size) | ||||
| 						{ | ||||
| 							MZ_FREE(buf); | ||||
| 							return mz_zip_set_error(pZip, MZ_ZIP_FILE_READ_FAILED); | ||||
| 						} | ||||
|  | ||||
| 						pExtra_data = (mz_uint8*)buf; | ||||
| 					} | ||||
| 					else | ||||
| 					{ | ||||
| 						pExtra_data = p + MZ_ZIP_CENTRAL_DIR_HEADER_SIZE + filename_size; | ||||
| 					} | ||||
|  | ||||
|                     do | ||||
|                     { | ||||
| 						mz_uint32 field_id; | ||||
| 						mz_uint32 field_data_size; | ||||
|                         mz_uint32 field_id; | ||||
|                         mz_uint32 field_data_size; | ||||
|  | ||||
|                         if (extra_size_remaining < (sizeof(mz_uint16) * 2)) | ||||
|                             return mz_zip_set_error(pZip, MZ_ZIP_INVALID_HEADER_OR_CORRUPTED); | ||||
| 						if (extra_size_remaining < (sizeof(mz_uint16) * 2)) | ||||
| 						{ | ||||
| 							MZ_FREE(buf); | ||||
| 							return mz_zip_set_error(pZip, MZ_ZIP_INVALID_HEADER_OR_CORRUPTED); | ||||
| 						} | ||||
|  | ||||
|                         field_id = MZ_READ_LE16(pExtra_data); | ||||
|                         field_data_size = MZ_READ_LE16(pExtra_data + sizeof(mz_uint16)); | ||||
|  | ||||
|                         if ((field_data_size + sizeof(mz_uint16) * 2) > extra_size_remaining) | ||||
|                             return mz_zip_set_error(pZip, MZ_ZIP_INVALID_HEADER_OR_CORRUPTED); | ||||
| 						if ((field_data_size + sizeof(mz_uint16) * 2) > extra_size_remaining) | ||||
| 						{ | ||||
| 							MZ_FREE(buf); | ||||
| 							return mz_zip_set_error(pZip, MZ_ZIP_INVALID_HEADER_OR_CORRUPTED); | ||||
| 						} | ||||
|  | ||||
|                         if (field_id == MZ_ZIP64_EXTENDED_INFORMATION_FIELD_HEADER_ID) | ||||
|                         { | ||||
| @@ -775,6 +802,8 @@ static mz_bool mz_zip_reader_read_central_dir(mz_zip_archive *pZip, mz_uint flag | ||||
|                         pExtra_data += sizeof(mz_uint16) * 2 + field_data_size; | ||||
|                         extra_size_remaining = extra_size_remaining - sizeof(mz_uint16) * 2 - field_data_size; | ||||
|                     } while (extra_size_remaining); | ||||
|  | ||||
| 					MZ_FREE(buf); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
| @@ -913,7 +942,7 @@ mz_bool mz_zip_reader_init_mem(mz_zip_archive *pZip, const void *pMem, size_t si | ||||
|     pZip->m_archive_size = size; | ||||
|     pZip->m_pRead = mz_zip_mem_read_func; | ||||
|     pZip->m_pIO_opaque = pZip; | ||||
| 	pZip->m_pNeeds_keepalive = NULL; | ||||
|     pZip->m_pNeeds_keepalive = NULL; | ||||
|  | ||||
| #ifdef __cplusplus | ||||
|     pZip->m_pState->m_pMem = const_cast<void *>(pMem); | ||||
| @@ -953,13 +982,13 @@ mz_bool mz_zip_reader_init_file(mz_zip_archive *pZip, const char *pFilename, mz_ | ||||
|  | ||||
| mz_bool mz_zip_reader_init_file_v2(mz_zip_archive *pZip, const char *pFilename, mz_uint flags, mz_uint64 file_start_ofs, mz_uint64 archive_size) | ||||
| { | ||||
| 	mz_uint64 file_size; | ||||
| 	MZ_FILE *pFile; | ||||
|     mz_uint64 file_size; | ||||
|     MZ_FILE *pFile; | ||||
|  | ||||
|     if ((!pZip) || (!pFilename) || ((archive_size) && (archive_size < MZ_ZIP_END_OF_CENTRAL_DIR_HEADER_SIZE))) | ||||
|         return mz_zip_set_error(pZip, MZ_ZIP_INVALID_PARAMETER); | ||||
|  | ||||
| 	pFile = MZ_FOPEN(pFilename, "rb"); | ||||
|     pFile = MZ_FOPEN(pFilename, "rb"); | ||||
|     if (!pFile) | ||||
|         return mz_zip_set_error(pZip, MZ_ZIP_FILE_OPEN_FAILED); | ||||
|  | ||||
| @@ -978,7 +1007,10 @@ mz_bool mz_zip_reader_init_file_v2(mz_zip_archive *pZip, const char *pFilename, | ||||
|     /* TODO: Better sanity check archive_size and the # of actual remaining bytes */ | ||||
|  | ||||
|     if (file_size < MZ_ZIP_END_OF_CENTRAL_DIR_HEADER_SIZE) | ||||
|     { | ||||
| 	MZ_FCLOSE(pFile); | ||||
|         return mz_zip_set_error(pZip, MZ_ZIP_NOT_AN_ARCHIVE); | ||||
|     } | ||||
|  | ||||
|     if (!mz_zip_reader_init_internal(pZip, flags)) | ||||
|     { | ||||
| @@ -1191,8 +1223,8 @@ static mz_bool mz_zip_file_stat_internal(mz_zip_archive *pZip, mz_uint file_inde | ||||
|  | ||||
|             do | ||||
|             { | ||||
| 				mz_uint32 field_id; | ||||
| 				mz_uint32 field_data_size; | ||||
|                 mz_uint32 field_id; | ||||
|                 mz_uint32 field_data_size; | ||||
|  | ||||
|                 if (extra_size_remaining < (sizeof(mz_uint16) * 2)) | ||||
|                     return mz_zip_set_error(pZip, MZ_ZIP_INVALID_HEADER_OR_CORRUPTED); | ||||
| @@ -1817,6 +1849,304 @@ mz_bool mz_zip_reader_extract_file_to_callback(mz_zip_archive *pZip, const char | ||||
|     return mz_zip_reader_extract_to_callback(pZip, file_index, pCallback, pOpaque, flags); | ||||
| } | ||||
|  | ||||
| mz_zip_reader_extract_iter_state* mz_zip_reader_extract_iter_new(mz_zip_archive *pZip, mz_uint file_index, mz_uint flags) | ||||
| { | ||||
|     mz_zip_reader_extract_iter_state *pState; | ||||
|     mz_uint32 local_header_u32[(MZ_ZIP_LOCAL_DIR_HEADER_SIZE + sizeof(mz_uint32) - 1) / sizeof(mz_uint32)]; | ||||
|     mz_uint8 *pLocal_header = (mz_uint8 *)local_header_u32; | ||||
|  | ||||
|     /* Argument sanity check */ | ||||
|     if ((!pZip) || (!pZip->m_pState)) | ||||
|         return NULL; | ||||
|  | ||||
|     /* Allocate an iterator status structure */ | ||||
|     pState = (mz_zip_reader_extract_iter_state*)pZip->m_pAlloc(pZip->m_pAlloc_opaque, 1, sizeof(mz_zip_reader_extract_iter_state)); | ||||
|     if (!pState) | ||||
|     { | ||||
|         mz_zip_set_error(pZip, MZ_ZIP_ALLOC_FAILED); | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     /* Fetch file details */ | ||||
|     if (!mz_zip_reader_file_stat(pZip, file_index, &pState->file_stat)) | ||||
|     { | ||||
|         pZip->m_pFree(pZip->m_pAlloc_opaque, pState); | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     /* Encryption and patch files are not supported. */ | ||||
|     if (pState->file_stat.m_bit_flag & (MZ_ZIP_GENERAL_PURPOSE_BIT_FLAG_IS_ENCRYPTED | MZ_ZIP_GENERAL_PURPOSE_BIT_FLAG_USES_STRONG_ENCRYPTION | MZ_ZIP_GENERAL_PURPOSE_BIT_FLAG_COMPRESSED_PATCH_FLAG)) | ||||
|     { | ||||
|         mz_zip_set_error(pZip, MZ_ZIP_UNSUPPORTED_ENCRYPTION); | ||||
|         pZip->m_pFree(pZip->m_pAlloc_opaque, pState); | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     /* This function only supports decompressing stored and deflate. */ | ||||
|     if ((!(flags & MZ_ZIP_FLAG_COMPRESSED_DATA)) && (pState->file_stat.m_method != 0) && (pState->file_stat.m_method != MZ_DEFLATED)) | ||||
|     { | ||||
|         mz_zip_set_error(pZip, MZ_ZIP_UNSUPPORTED_METHOD); | ||||
|         pZip->m_pFree(pZip->m_pAlloc_opaque, pState); | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     /* Init state - save args */ | ||||
|     pState->pZip = pZip; | ||||
|     pState->flags = flags; | ||||
|  | ||||
|     /* Init state - reset variables to defaults */ | ||||
|     pState->status = TINFL_STATUS_DONE; | ||||
| #ifndef MINIZ_DISABLE_ZIP_READER_CRC32_CHECKS | ||||
|     pState->file_crc32 = MZ_CRC32_INIT; | ||||
| #endif | ||||
|     pState->read_buf_ofs = 0; | ||||
|     pState->out_buf_ofs = 0; | ||||
|     pState->pRead_buf = NULL; | ||||
|     pState->pWrite_buf = NULL; | ||||
|     pState->out_blk_remain = 0; | ||||
|  | ||||
|     /* Read and parse the local directory entry. */ | ||||
|     pState->cur_file_ofs = pState->file_stat.m_local_header_ofs; | ||||
|     if (pZip->m_pRead(pZip->m_pIO_opaque, pState->cur_file_ofs, pLocal_header, MZ_ZIP_LOCAL_DIR_HEADER_SIZE) != MZ_ZIP_LOCAL_DIR_HEADER_SIZE) | ||||
|     { | ||||
|         mz_zip_set_error(pZip, MZ_ZIP_FILE_READ_FAILED); | ||||
|         pZip->m_pFree(pZip->m_pAlloc_opaque, pState); | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     if (MZ_READ_LE32(pLocal_header) != MZ_ZIP_LOCAL_DIR_HEADER_SIG) | ||||
|     { | ||||
|         mz_zip_set_error(pZip, MZ_ZIP_INVALID_HEADER_OR_CORRUPTED); | ||||
|         pZip->m_pFree(pZip->m_pAlloc_opaque, pState); | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     pState->cur_file_ofs += MZ_ZIP_LOCAL_DIR_HEADER_SIZE + MZ_READ_LE16(pLocal_header + MZ_ZIP_LDH_FILENAME_LEN_OFS) + MZ_READ_LE16(pLocal_header + MZ_ZIP_LDH_EXTRA_LEN_OFS); | ||||
|     if ((pState->cur_file_ofs + pState->file_stat.m_comp_size) > pZip->m_archive_size) | ||||
|     { | ||||
|         mz_zip_set_error(pZip, MZ_ZIP_INVALID_HEADER_OR_CORRUPTED); | ||||
|         pZip->m_pFree(pZip->m_pAlloc_opaque, pState); | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     /* Decompress the file either directly from memory or from a file input buffer. */ | ||||
|     if (pZip->m_pState->m_pMem) | ||||
|     { | ||||
|         pState->pRead_buf = (mz_uint8 *)pZip->m_pState->m_pMem + pState->cur_file_ofs; | ||||
|         pState->read_buf_size = pState->read_buf_avail = pState->file_stat.m_comp_size; | ||||
|         pState->comp_remaining = pState->file_stat.m_comp_size; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         if (!((flags & MZ_ZIP_FLAG_COMPRESSED_DATA) || (!pState->file_stat.m_method))) | ||||
|         { | ||||
|             /* Decompression required, therefore intermediate read buffer required */ | ||||
|             pState->read_buf_size = MZ_MIN(pState->file_stat.m_comp_size, MZ_ZIP_MAX_IO_BUF_SIZE); | ||||
|             if (NULL == (pState->pRead_buf = pZip->m_pAlloc(pZip->m_pAlloc_opaque, 1, (size_t)pState->read_buf_size))) | ||||
|             { | ||||
|                 mz_zip_set_error(pZip, MZ_ZIP_ALLOC_FAILED); | ||||
|                 pZip->m_pFree(pZip->m_pAlloc_opaque, pState); | ||||
|                 return NULL; | ||||
|             } | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             /* Decompression not required - we will be reading directly into user buffer, no temp buf required */ | ||||
|             pState->read_buf_size = 0; | ||||
|         } | ||||
|         pState->read_buf_avail = 0; | ||||
|         pState->comp_remaining = pState->file_stat.m_comp_size; | ||||
|     } | ||||
|  | ||||
|     if (!((flags & MZ_ZIP_FLAG_COMPRESSED_DATA) || (!pState->file_stat.m_method))) | ||||
|     { | ||||
|         /* Decompression required, init decompressor */ | ||||
|         tinfl_init( &pState->inflator ); | ||||
|  | ||||
|         /* Allocate write buffer */ | ||||
|         if (NULL == (pState->pWrite_buf = pZip->m_pAlloc(pZip->m_pAlloc_opaque, 1, TINFL_LZ_DICT_SIZE))) | ||||
|         { | ||||
|             mz_zip_set_error(pZip, MZ_ZIP_ALLOC_FAILED); | ||||
|             if (pState->pRead_buf) | ||||
|                 pZip->m_pFree(pZip->m_pAlloc_opaque, pState->pRead_buf); | ||||
|             pZip->m_pFree(pZip->m_pAlloc_opaque, pState); | ||||
|             return NULL; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return pState; | ||||
| } | ||||
|  | ||||
| mz_zip_reader_extract_iter_state* mz_zip_reader_extract_file_iter_new(mz_zip_archive *pZip, const char *pFilename, mz_uint flags) | ||||
| { | ||||
|     mz_uint32 file_index; | ||||
|  | ||||
|     /* Locate file index by name */ | ||||
|     if (!mz_zip_reader_locate_file_v2(pZip, pFilename, NULL, flags, &file_index)) | ||||
|         return NULL; | ||||
|  | ||||
|     /* Construct iterator */ | ||||
|     return mz_zip_reader_extract_iter_new(pZip, file_index, flags); | ||||
| } | ||||
|  | ||||
| size_t mz_zip_reader_extract_iter_read(mz_zip_reader_extract_iter_state* pState, void* pvBuf, size_t buf_size) | ||||
| { | ||||
|     size_t copied_to_caller = 0; | ||||
|  | ||||
|     /* Argument sanity check */ | ||||
|     if ((!pState) || (!pState->pZip) || (!pState->pZip->m_pState) || (!pvBuf)) | ||||
|         return 0; | ||||
|  | ||||
|     if ((pState->flags & MZ_ZIP_FLAG_COMPRESSED_DATA) || (!pState->file_stat.m_method)) | ||||
|     { | ||||
|         /* The file is stored or the caller has requested the compressed data, calc amount to return. */ | ||||
|         copied_to_caller = (size_t)MZ_MIN( buf_size, pState->comp_remaining ); | ||||
|  | ||||
|         /* Zip is in memory....or requires reading from a file? */ | ||||
|         if (pState->pZip->m_pState->m_pMem) | ||||
|         { | ||||
|             /* Copy data to caller's buffer */ | ||||
|             memcpy( pvBuf, pState->pRead_buf, copied_to_caller ); | ||||
|             pState->pRead_buf = ((mz_uint8*)pState->pRead_buf) + copied_to_caller; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             /* Read directly into caller's buffer */ | ||||
|             if (pState->pZip->m_pRead(pState->pZip->m_pIO_opaque, pState->cur_file_ofs, pvBuf, copied_to_caller) != copied_to_caller) | ||||
|             { | ||||
|                 /* Failed to read all that was asked for, flag failure and alert user */ | ||||
|                 mz_zip_set_error(pState->pZip, MZ_ZIP_FILE_READ_FAILED); | ||||
|                 pState->status = TINFL_STATUS_FAILED; | ||||
|                 copied_to_caller = 0; | ||||
|             } | ||||
|         } | ||||
|  | ||||
| #ifndef MINIZ_DISABLE_ZIP_READER_CRC32_CHECKS | ||||
|         /* Compute CRC if not returning compressed data only */ | ||||
|         if (!(pState->flags & MZ_ZIP_FLAG_COMPRESSED_DATA)) | ||||
|             pState->file_crc32 = (mz_uint32)mz_crc32(pState->file_crc32, (const mz_uint8 *)pvBuf, copied_to_caller); | ||||
| #endif | ||||
|  | ||||
|         /* Advance offsets, dec counters */ | ||||
|         pState->cur_file_ofs += copied_to_caller; | ||||
|         pState->out_buf_ofs += copied_to_caller; | ||||
|         pState->comp_remaining -= copied_to_caller; | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|         do | ||||
|         { | ||||
|             /* Calc ptr to write buffer - given current output pos and block size */ | ||||
|             mz_uint8 *pWrite_buf_cur = (mz_uint8 *)pState->pWrite_buf + (pState->out_buf_ofs & (TINFL_LZ_DICT_SIZE - 1)); | ||||
|  | ||||
|             /* Calc max output size - given current output pos and block size */ | ||||
|             size_t in_buf_size, out_buf_size = TINFL_LZ_DICT_SIZE - (pState->out_buf_ofs & (TINFL_LZ_DICT_SIZE - 1)); | ||||
|  | ||||
|             if (!pState->out_blk_remain) | ||||
|             { | ||||
|                 /* Read more data from file if none available (and reading from file) */ | ||||
|                 if ((!pState->read_buf_avail) && (!pState->pZip->m_pState->m_pMem)) | ||||
|                 { | ||||
|                     /* Calc read size */ | ||||
|                     pState->read_buf_avail = MZ_MIN(pState->read_buf_size, pState->comp_remaining); | ||||
|                     if (pState->pZip->m_pRead(pState->pZip->m_pIO_opaque, pState->cur_file_ofs, pState->pRead_buf, (size_t)pState->read_buf_avail) != pState->read_buf_avail) | ||||
|                     { | ||||
|                         mz_zip_set_error(pState->pZip, MZ_ZIP_FILE_READ_FAILED); | ||||
|                         pState->status = TINFL_STATUS_FAILED; | ||||
|                         break; | ||||
|                     } | ||||
|  | ||||
|                     /* Advance offsets, dec counters */ | ||||
|                     pState->cur_file_ofs += pState->read_buf_avail; | ||||
|                     pState->comp_remaining -= pState->read_buf_avail; | ||||
|                     pState->read_buf_ofs = 0; | ||||
|                 } | ||||
|  | ||||
|                 /* Perform decompression */ | ||||
|                 in_buf_size = (size_t)pState->read_buf_avail; | ||||
|                 pState->status = tinfl_decompress(&pState->inflator, (const mz_uint8 *)pState->pRead_buf + pState->read_buf_ofs, &in_buf_size, (mz_uint8 *)pState->pWrite_buf, pWrite_buf_cur, &out_buf_size, pState->comp_remaining ? TINFL_FLAG_HAS_MORE_INPUT : 0); | ||||
|                 pState->read_buf_avail -= in_buf_size; | ||||
|                 pState->read_buf_ofs += in_buf_size; | ||||
|  | ||||
|                 /* Update current output block size remaining */ | ||||
|                 pState->out_blk_remain = out_buf_size; | ||||
|             } | ||||
|  | ||||
|             if (pState->out_blk_remain) | ||||
|             { | ||||
|                 /* Calc amount to return. */ | ||||
|                 size_t to_copy = MZ_MIN( (buf_size - copied_to_caller), pState->out_blk_remain ); | ||||
|  | ||||
|                 /* Copy data to caller's buffer */ | ||||
|                 memcpy( (uint8_t*)pvBuf + copied_to_caller, pWrite_buf_cur, to_copy ); | ||||
|  | ||||
| #ifndef MINIZ_DISABLE_ZIP_READER_CRC32_CHECKS | ||||
|                 /* Perform CRC */ | ||||
|                 pState->file_crc32 = (mz_uint32)mz_crc32(pState->file_crc32, pWrite_buf_cur, to_copy); | ||||
| #endif | ||||
|  | ||||
|                 /* Decrement data consumed from block */ | ||||
|                 pState->out_blk_remain -= to_copy; | ||||
|  | ||||
|                 /* Inc output offset, while performing sanity check */ | ||||
|                 if ((pState->out_buf_ofs += to_copy) > pState->file_stat.m_uncomp_size) | ||||
|                 { | ||||
|                     mz_zip_set_error(pState->pZip, MZ_ZIP_DECOMPRESSION_FAILED); | ||||
|                     pState->status = TINFL_STATUS_FAILED; | ||||
|                     break; | ||||
|                 } | ||||
|  | ||||
|                 /* Increment counter of data copied to caller */ | ||||
|                 copied_to_caller += to_copy; | ||||
|             } | ||||
|         } while ( (copied_to_caller < buf_size) && ((pState->status == TINFL_STATUS_NEEDS_MORE_INPUT) || (pState->status == TINFL_STATUS_HAS_MORE_OUTPUT)) ); | ||||
|     } | ||||
|  | ||||
|     /* Return how many bytes were copied into user buffer */ | ||||
|     return copied_to_caller; | ||||
| } | ||||
|  | ||||
| mz_bool mz_zip_reader_extract_iter_free(mz_zip_reader_extract_iter_state* pState) | ||||
| { | ||||
|     int status; | ||||
|  | ||||
|     /* Argument sanity check */ | ||||
|     if ((!pState) || (!pState->pZip) || (!pState->pZip->m_pState)) | ||||
|         return MZ_FALSE; | ||||
|  | ||||
|     /* Was decompression completed and requested? */ | ||||
|     if ((pState->status == TINFL_STATUS_DONE) && (!(pState->flags & MZ_ZIP_FLAG_COMPRESSED_DATA))) | ||||
|     { | ||||
|         /* Make sure the entire file was decompressed, and check its CRC. */ | ||||
|         if (pState->out_buf_ofs != pState->file_stat.m_uncomp_size) | ||||
|         { | ||||
|             mz_zip_set_error(pState->pZip, MZ_ZIP_UNEXPECTED_DECOMPRESSED_SIZE); | ||||
|             pState->status = TINFL_STATUS_FAILED; | ||||
|         } | ||||
| #ifndef MINIZ_DISABLE_ZIP_READER_CRC32_CHECKS | ||||
|         else if (pState->file_crc32 != pState->file_stat.m_crc32) | ||||
|         { | ||||
|             mz_zip_set_error(pState->pZip, MZ_ZIP_DECOMPRESSION_FAILED); | ||||
|             pState->status = TINFL_STATUS_FAILED; | ||||
|         } | ||||
| #endif | ||||
|     } | ||||
|  | ||||
|     /* Free buffers */ | ||||
|     if (!pState->pZip->m_pState->m_pMem) | ||||
|         pState->pZip->m_pFree(pState->pZip->m_pAlloc_opaque, pState->pRead_buf); | ||||
|     if (pState->pWrite_buf) | ||||
|         pState->pZip->m_pFree(pState->pZip->m_pAlloc_opaque, pState->pWrite_buf); | ||||
|  | ||||
|     /* Save status */ | ||||
|     status = pState->status; | ||||
|  | ||||
|     /* Free context */ | ||||
|     pState->pZip->m_pFree(pState->pZip->m_pAlloc_opaque, pState); | ||||
|  | ||||
|     return status == TINFL_STATUS_DONE; | ||||
| } | ||||
|  | ||||
| #ifndef MINIZ_NO_STDIO | ||||
| static size_t mz_zip_file_write_callback(void *pOpaque, mz_uint64 ofs, const void *pBuf, size_t n) | ||||
| { | ||||
| @@ -1989,8 +2319,8 @@ mz_bool mz_zip_validate_file(mz_zip_archive *pZip, mz_uint file_index, mz_uint f | ||||
|  | ||||
|     if ((local_header_extra_len) && ((local_header_comp_size == MZ_UINT32_MAX) || (local_header_uncomp_size == MZ_UINT32_MAX))) | ||||
|     { | ||||
| 		mz_uint32 extra_size_remaining = local_header_extra_len; | ||||
| 		const mz_uint8 *pExtra_data = (const mz_uint8 *)file_data_array.m_p; | ||||
|         mz_uint32 extra_size_remaining = local_header_extra_len; | ||||
|         const mz_uint8 *pExtra_data = (const mz_uint8 *)file_data_array.m_p; | ||||
|  | ||||
|         if (pZip->m_pRead(pZip->m_pIO_opaque, local_header_ofs + MZ_ZIP_LOCAL_DIR_HEADER_SIZE + local_header_filename_len, file_data_array.m_p, local_header_extra_len) != local_header_extra_len) | ||||
|         { | ||||
| @@ -2039,10 +2369,10 @@ mz_bool mz_zip_validate_file(mz_zip_archive *pZip, mz_uint file_index, mz_uint f | ||||
|     if ((has_data_descriptor) && (!local_header_comp_size) && (!local_header_crc32)) | ||||
|     { | ||||
|         mz_uint8 descriptor_buf[32]; | ||||
| 		mz_bool has_id; | ||||
| 		const mz_uint8 *pSrc; | ||||
| 		mz_uint32 file_crc32; | ||||
| 		mz_uint64 comp_size = 0, uncomp_size = 0; | ||||
|         mz_bool has_id; | ||||
|         const mz_uint8 *pSrc; | ||||
|         mz_uint32 file_crc32; | ||||
|         mz_uint64 comp_size = 0, uncomp_size = 0; | ||||
|  | ||||
|         mz_uint32 num_descriptor_uint32s = ((pState->m_zip64) || (found_zip64_ext_data_in_ldir)) ? 6 : 4; | ||||
|  | ||||
| @@ -2053,9 +2383,9 @@ mz_bool mz_zip_validate_file(mz_zip_archive *pZip, mz_uint file_index, mz_uint f | ||||
|         } | ||||
|  | ||||
|         has_id = (MZ_READ_LE32(descriptor_buf) == MZ_ZIP_DATA_DESCRIPTOR_ID); | ||||
| 		pSrc = has_id ? (descriptor_buf + sizeof(mz_uint32)) : descriptor_buf; | ||||
|         pSrc = has_id ? (descriptor_buf + sizeof(mz_uint32)) : descriptor_buf; | ||||
|  | ||||
|         file_crc32 = MZ_READ_LE32(pSrc);         | ||||
|         file_crc32 = MZ_READ_LE32(pSrc); | ||||
|  | ||||
|         if ((pState->m_zip64) || (found_zip64_ext_data_in_ldir)) | ||||
|         { | ||||
| @@ -2409,7 +2739,7 @@ mz_bool mz_zip_writer_init(mz_zip_archive *pZip, mz_uint64 existing_size) | ||||
| mz_bool mz_zip_writer_init_heap_v2(mz_zip_archive *pZip, size_t size_to_reserve_at_beginning, size_t initial_allocation_size, mz_uint flags) | ||||
| { | ||||
|     pZip->m_pWrite = mz_zip_heap_write_func; | ||||
| 	pZip->m_pNeeds_keepalive = NULL; | ||||
|     pZip->m_pNeeds_keepalive = NULL; | ||||
|  | ||||
|     if (flags & MZ_ZIP_FLAG_WRITE_ALLOW_READING) | ||||
|         pZip->m_pRead = mz_zip_mem_read_func; | ||||
| @@ -2466,7 +2796,7 @@ mz_bool mz_zip_writer_init_file_v2(mz_zip_archive *pZip, const char *pFilename, | ||||
|     MZ_FILE *pFile; | ||||
|  | ||||
|     pZip->m_pWrite = mz_zip_file_write_func; | ||||
| 	pZip->m_pNeeds_keepalive = NULL; | ||||
|     pZip->m_pNeeds_keepalive = NULL; | ||||
|  | ||||
|     if (flags & MZ_ZIP_FLAG_WRITE_ALLOW_READING) | ||||
|         pZip->m_pRead = mz_zip_file_read_func; | ||||
| @@ -2511,7 +2841,7 @@ mz_bool mz_zip_writer_init_file_v2(mz_zip_archive *pZip, const char *pFilename, | ||||
| mz_bool mz_zip_writer_init_cfile(mz_zip_archive *pZip, MZ_FILE *pFile, mz_uint flags) | ||||
| { | ||||
|     pZip->m_pWrite = mz_zip_file_write_func; | ||||
| 	pZip->m_pNeeds_keepalive = NULL; | ||||
|     pZip->m_pNeeds_keepalive = NULL; | ||||
|  | ||||
|     if (flags & MZ_ZIP_FLAG_WRITE_ALLOW_READING) | ||||
|         pZip->m_pRead = mz_zip_file_read_func; | ||||
| @@ -2584,7 +2914,7 @@ mz_bool mz_zip_writer_init_from_reader_v2(mz_zip_archive *pZip, const char *pFil | ||||
|         } | ||||
|  | ||||
|         pZip->m_pWrite = mz_zip_file_write_func; | ||||
| 		pZip->m_pNeeds_keepalive = NULL; | ||||
|         pZip->m_pNeeds_keepalive = NULL; | ||||
| #endif /* #ifdef MINIZ_NO_STDIO */ | ||||
|     } | ||||
|     else if (pState->m_pMem) | ||||
| @@ -2595,7 +2925,7 @@ mz_bool mz_zip_writer_init_from_reader_v2(mz_zip_archive *pZip, const char *pFil | ||||
|  | ||||
|         pState->m_mem_capacity = pState->m_mem_size; | ||||
|         pZip->m_pWrite = mz_zip_heap_write_func; | ||||
| 		pZip->m_pNeeds_keepalive = NULL; | ||||
|         pZip->m_pNeeds_keepalive = NULL; | ||||
|     } | ||||
|     /* Archive is being read via a user provided read function - make sure the user has specified a write function too. */ | ||||
|     else if (!pZip->m_pWrite) | ||||
| @@ -2650,7 +2980,7 @@ static mz_bool mz_zip_writer_add_put_buf_callback(const void *pBuf, int len, voi | ||||
| static mz_uint32 mz_zip_writer_create_zip64_extra_data(mz_uint8 *pBuf, mz_uint64 *pUncomp_size, mz_uint64 *pComp_size, mz_uint64 *pLocal_header_ofs) | ||||
| { | ||||
|     mz_uint8 *pDst = pBuf; | ||||
| 	mz_uint32 field_size = 0; | ||||
|     mz_uint32 field_size = 0; | ||||
|  | ||||
|     MZ_WRITE_LE16(pDst + 0, MZ_ZIP64_EXTENDED_INFORMATION_FIELD_HEADER_ID); | ||||
|     MZ_WRITE_LE16(pDst + 2, 0); | ||||
| @@ -2747,7 +3077,7 @@ static mz_bool mz_zip_writer_add_to_central_dir(mz_zip_archive *pZip, const char | ||||
|     if (((mz_uint64)pState->m_central_dir.m_size + MZ_ZIP_CENTRAL_DIR_HEADER_SIZE + filename_size + extra_size + user_extra_data_len + comment_size) >= MZ_UINT32_MAX) | ||||
|         return mz_zip_set_error(pZip, MZ_ZIP_UNSUPPORTED_CDIR_SIZE); | ||||
|  | ||||
|     if (!mz_zip_writer_create_central_dir_header(pZip, central_dir_header, filename_size, extra_size + user_extra_data_len, comment_size, uncomp_size, comp_size, uncomp_crc32, method, bit_flags, dos_time, dos_date, local_header_ofs, ext_attributes)) | ||||
|     if (!mz_zip_writer_create_central_dir_header(pZip, central_dir_header, filename_size, (mz_uint16)(extra_size + user_extra_data_len), comment_size, uncomp_size, comp_size, uncomp_crc32, method, bit_flags, dos_time, dos_date, local_header_ofs, ext_attributes)) | ||||
|         return mz_zip_set_error(pZip, MZ_ZIP_INTERNAL_ERROR); | ||||
|  | ||||
|     if ((!mz_zip_array_push_back(pZip, &pState->m_central_dir, central_dir_header, MZ_ZIP_CENTRAL_DIR_HEADER_SIZE)) || | ||||
| @@ -2771,13 +3101,7 @@ static mz_bool mz_zip_writer_validate_archive_name(const char *pArchive_name) | ||||
|     if (*pArchive_name == '/') | ||||
|         return MZ_FALSE; | ||||
|  | ||||
|     while (*pArchive_name) | ||||
|     { | ||||
|         if ((*pArchive_name == '\\') || (*pArchive_name == ':')) | ||||
|             return MZ_FALSE; | ||||
|  | ||||
|         pArchive_name++; | ||||
|     } | ||||
|     /* Making sure the name does not contain drive letters or DOS style backward slashes is the responsibility of the program using miniz*/ | ||||
|  | ||||
|     return MZ_TRUE; | ||||
| } | ||||
| @@ -2830,14 +3154,15 @@ mz_bool mz_zip_writer_add_mem_ex_v2(mz_zip_archive *pZip, const char *pArchive_n | ||||
|     mz_uint8 extra_data[MZ_ZIP64_MAX_CENTRAL_EXTRA_FIELD_SIZE]; | ||||
|     mz_uint16 bit_flags = 0; | ||||
|  | ||||
|     if ((int)level_and_flags < 0) | ||||
|         level_and_flags = MZ_DEFAULT_LEVEL; | ||||
|  | ||||
|     if (uncomp_size || (buf_size && !(level_and_flags & MZ_ZIP_FLAG_COMPRESSED_DATA))) | ||||
|         bit_flags |= MZ_ZIP_LDH_BIT_FLAG_HAS_LOCATOR; | ||||
|  | ||||
|     if (!(level_and_flags & MZ_ZIP_FLAG_ASCII_FILENAME)) | ||||
|         bit_flags |= MZ_ZIP_GENERAL_PURPOSE_BIT_FLAG_UTF8; | ||||
|  | ||||
|     if ((int)level_and_flags < 0) | ||||
|         level_and_flags = MZ_DEFAULT_LEVEL; | ||||
|     level = level_and_flags & 0xF; | ||||
|     store_data_uncompressed = ((!level) || (level_and_flags & MZ_ZIP_FLAG_COMPRESSED_DATA)); | ||||
|  | ||||
| @@ -2878,12 +3203,23 @@ mz_bool mz_zip_writer_add_mem_ex_v2(mz_zip_archive *pZip, const char *pArchive_n | ||||
|     } | ||||
|     else | ||||
|     { | ||||
| 		MZ_TIME_T cur_time; | ||||
| 		time(&cur_time); | ||||
| 		mz_zip_time_t_to_dos_time(cur_time, &dos_time, &dos_date); | ||||
|         MZ_TIME_T cur_time; | ||||
|         time(&cur_time); | ||||
|         mz_zip_time_t_to_dos_time(cur_time, &dos_time, &dos_date); | ||||
|     } | ||||
| #endif /* #ifndef MINIZ_NO_TIME */ | ||||
|  | ||||
| 	if (!(level_and_flags & MZ_ZIP_FLAG_COMPRESSED_DATA)) | ||||
| 	{ | ||||
| 		uncomp_crc32 = (mz_uint32)mz_crc32(MZ_CRC32_INIT, (const mz_uint8 *)pBuf, buf_size); | ||||
| 		uncomp_size = buf_size; | ||||
| 		if (uncomp_size <= 3) | ||||
| 		{ | ||||
| 			level = 0; | ||||
| 			store_data_uncompressed = MZ_TRUE; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
|     archive_name_size = strlen(pArchive_name); | ||||
|     if (archive_name_size > MZ_UINT16_MAX) | ||||
|         return mz_zip_set_error(pZip, MZ_ZIP_INVALID_FILENAME); | ||||
| @@ -2897,7 +3233,10 @@ mz_bool mz_zip_writer_add_mem_ex_v2(mz_zip_archive *pZip, const char *pArchive_n | ||||
|     if (!pState->m_zip64) | ||||
|     { | ||||
|         /* Bail early if the archive would obviously become too large */ | ||||
|         if ((pZip->m_archive_size + num_alignment_padding_bytes + MZ_ZIP_LOCAL_DIR_HEADER_SIZE + archive_name_size + MZ_ZIP_CENTRAL_DIR_HEADER_SIZE + archive_name_size + comment_size + pState->m_central_dir.m_size + MZ_ZIP_END_OF_CENTRAL_DIR_HEADER_SIZE) > 0xFFFFFFFF) | ||||
|         if ((pZip->m_archive_size + num_alignment_padding_bytes + MZ_ZIP_LOCAL_DIR_HEADER_SIZE + archive_name_size  | ||||
| 			+ MZ_ZIP_CENTRAL_DIR_HEADER_SIZE + archive_name_size + comment_size + user_extra_data_len +  | ||||
| 			pState->m_central_dir.m_size + MZ_ZIP_END_OF_CENTRAL_DIR_HEADER_SIZE + user_extra_data_central_len | ||||
| 			+ MZ_ZIP_DATA_DESCRIPTER_SIZE32) > 0xFFFFFFFF) | ||||
|         { | ||||
|             pState->m_zip64 = MZ_TRUE; | ||||
|             /*return mz_zip_set_error(pZip, MZ_ZIP_ARCHIVE_TOO_LARGE); */ | ||||
| @@ -2953,7 +3292,7 @@ mz_bool mz_zip_writer_add_mem_ex_v2(mz_zip_archive *pZip, const char *pArchive_n | ||||
|                                                                (uncomp_size >= MZ_UINT32_MAX) ? &comp_size : NULL, (local_dir_header_ofs >= MZ_UINT32_MAX) ? &local_dir_header_ofs : NULL); | ||||
|         } | ||||
|  | ||||
|         if (!mz_zip_writer_create_local_dir_header(pZip, local_dir_header, (mz_uint16)archive_name_size, extra_size + user_extra_data_len, 0, 0, 0, method, bit_flags, dos_time, dos_date)) | ||||
|         if (!mz_zip_writer_create_local_dir_header(pZip, local_dir_header, (mz_uint16)archive_name_size, (mz_uint16)(extra_size + user_extra_data_len), 0, 0, 0, method, bit_flags, dos_time, dos_date)) | ||||
|             return mz_zip_set_error(pZip, MZ_ZIP_INTERNAL_ERROR); | ||||
|  | ||||
|         if (pZip->m_pWrite(pZip->m_pIO_opaque, local_dir_header_ofs, local_dir_header, sizeof(local_dir_header)) != sizeof(local_dir_header)) | ||||
| @@ -2980,7 +3319,7 @@ mz_bool mz_zip_writer_add_mem_ex_v2(mz_zip_archive *pZip, const char *pArchive_n | ||||
|     { | ||||
|         if ((comp_size > MZ_UINT32_MAX) || (cur_archive_file_ofs > MZ_UINT32_MAX)) | ||||
|             return mz_zip_set_error(pZip, MZ_ZIP_ARCHIVE_TOO_LARGE); | ||||
|         if (!mz_zip_writer_create_local_dir_header(pZip, local_dir_header, (mz_uint16)archive_name_size, user_extra_data_len, 0, 0, 0, method, bit_flags, dos_time, dos_date)) | ||||
|         if (!mz_zip_writer_create_local_dir_header(pZip, local_dir_header, (mz_uint16)archive_name_size, (mz_uint16)user_extra_data_len, 0, 0, 0, method, bit_flags, dos_time, dos_date)) | ||||
|             return mz_zip_set_error(pZip, MZ_ZIP_INTERNAL_ERROR); | ||||
|  | ||||
|         if (pZip->m_pWrite(pZip->m_pIO_opaque, local_dir_header_ofs, local_dir_header, sizeof(local_dir_header)) != sizeof(local_dir_header)) | ||||
| @@ -2996,24 +3335,13 @@ mz_bool mz_zip_writer_add_mem_ex_v2(mz_zip_archive *pZip, const char *pArchive_n | ||||
|         cur_archive_file_ofs += archive_name_size; | ||||
|     } | ||||
|  | ||||
|     if (user_extra_data_len > 0) | ||||
|     { | ||||
|         if (pZip->m_pWrite(pZip->m_pIO_opaque, cur_archive_file_ofs, user_extra_data, user_extra_data_len) != user_extra_data_len) | ||||
|             return mz_zip_set_error(pZip, MZ_ZIP_FILE_WRITE_FAILED); | ||||
| 	if (user_extra_data_len > 0) | ||||
| 	{ | ||||
| 		if (pZip->m_pWrite(pZip->m_pIO_opaque, cur_archive_file_ofs, user_extra_data, user_extra_data_len) != user_extra_data_len) | ||||
| 			return mz_zip_set_error(pZip, MZ_ZIP_FILE_WRITE_FAILED); | ||||
|  | ||||
|         cur_archive_file_ofs += user_extra_data_len; | ||||
|     } | ||||
|  | ||||
|     if (!(level_and_flags & MZ_ZIP_FLAG_COMPRESSED_DATA)) | ||||
|     { | ||||
|         uncomp_crc32 = (mz_uint32)mz_crc32(MZ_CRC32_INIT, (const mz_uint8 *)pBuf, buf_size); | ||||
|         uncomp_size = buf_size; | ||||
|         if (uncomp_size <= 3) | ||||
|         { | ||||
|             level = 0; | ||||
|             store_data_uncompressed = MZ_TRUE; | ||||
|         } | ||||
|     } | ||||
| 		cur_archive_file_ofs += user_extra_data_len; | ||||
| 	} | ||||
|  | ||||
|     if (store_data_uncompressed) | ||||
|     { | ||||
| @@ -3050,8 +3378,8 @@ mz_bool mz_zip_writer_add_mem_ex_v2(mz_zip_archive *pZip, const char *pArchive_n | ||||
|  | ||||
|     if (uncomp_size) | ||||
|     { | ||||
| 		mz_uint8 local_dir_footer[MZ_ZIP_DATA_DESCRIPTER_SIZE64]; | ||||
| 		mz_uint32 local_dir_footer_size = MZ_ZIP_DATA_DESCRIPTER_SIZE32; | ||||
|         mz_uint8 local_dir_footer[MZ_ZIP_DATA_DESCRIPTER_SIZE64]; | ||||
|         mz_uint32 local_dir_footer_size = MZ_ZIP_DATA_DESCRIPTER_SIZE32; | ||||
|  | ||||
|         MZ_ASSERT(bit_flags & MZ_ZIP_LDH_BIT_FLAG_HAS_LOCATOR); | ||||
|  | ||||
| @@ -3059,7 +3387,7 @@ mz_bool mz_zip_writer_add_mem_ex_v2(mz_zip_archive *pZip, const char *pArchive_n | ||||
|         MZ_WRITE_LE32(local_dir_footer + 4, uncomp_crc32); | ||||
|         if (pExtra_data == NULL) | ||||
|         { | ||||
|             if ((comp_size > MZ_UINT32_MAX) || (cur_archive_file_ofs > MZ_UINT32_MAX)) | ||||
|             if (comp_size > MZ_UINT32_MAX) | ||||
|                 return mz_zip_set_error(pZip, MZ_ZIP_ARCHIVE_TOO_LARGE); | ||||
|  | ||||
|             MZ_WRITE_LE32(local_dir_footer + 8, comp_size); | ||||
| @@ -3084,7 +3412,7 @@ mz_bool mz_zip_writer_add_mem_ex_v2(mz_zip_archive *pZip, const char *pArchive_n | ||||
|                                                            (uncomp_size >= MZ_UINT32_MAX) ? &comp_size : NULL, (local_dir_header_ofs >= MZ_UINT32_MAX) ? &local_dir_header_ofs : NULL); | ||||
|     } | ||||
|  | ||||
|     if (!mz_zip_writer_add_to_central_dir(pZip, pArchive_name, (mz_uint16)archive_name_size, pExtra_data, extra_size, pComment, | ||||
|     if (!mz_zip_writer_add_to_central_dir(pZip, pArchive_name, (mz_uint16)archive_name_size, pExtra_data, (mz_uint16)extra_size, pComment, | ||||
|                                           comment_size, uncomp_size, comp_size, uncomp_crc32, method, bit_flags, dos_time, dos_date, local_dir_header_ofs, ext_attributes, | ||||
|                                           user_extra_data_central, user_extra_data_central_len)) | ||||
|         return MZ_FALSE; | ||||
| @@ -3095,8 +3423,7 @@ mz_bool mz_zip_writer_add_mem_ex_v2(mz_zip_archive *pZip, const char *pArchive_n | ||||
|     return MZ_TRUE; | ||||
| } | ||||
|  | ||||
| #ifndef MINIZ_NO_STDIO | ||||
| mz_bool mz_zip_writer_add_cfile(mz_zip_archive *pZip, const char *pArchive_name, MZ_FILE *pSrc_file, mz_uint64 size_to_add, const MZ_TIME_T *pFile_time, const void *pComment, mz_uint16 comment_size, mz_uint level_and_flags, | ||||
| mz_bool mz_zip_writer_add_read_buf_callback(mz_zip_archive *pZip, const char *pArchive_name, mz_file_read_func read_callback, void* callback_opaque, mz_uint64 size_to_add, const MZ_TIME_T *pFile_time, const void *pComment, mz_uint16 comment_size, mz_uint level_and_flags, | ||||
|                                 const char *user_extra_data, mz_uint user_extra_data_len, const char *user_extra_data_central, mz_uint user_extra_data_central_len) | ||||
| { | ||||
|     mz_uint16 gen_flags = MZ_ZIP_LDH_BIT_FLAG_HAS_LOCATOR; | ||||
| @@ -3109,6 +3436,7 @@ mz_bool mz_zip_writer_add_cfile(mz_zip_archive *pZip, const char *pArchive_name, | ||||
|     mz_uint32 extra_size = 0; | ||||
|     mz_uint8 extra_data[MZ_ZIP64_MAX_CENTRAL_EXTRA_FIELD_SIZE]; | ||||
|     mz_zip_internal_state *pState; | ||||
| 	mz_uint64 file_ofs = 0; | ||||
|  | ||||
|     if (!(level_and_flags & MZ_ZIP_FLAG_ASCII_FILENAME)) | ||||
|         gen_flags |= MZ_ZIP_GENERAL_PURPOSE_BIT_FLAG_UTF8; | ||||
| @@ -3164,7 +3492,9 @@ mz_bool mz_zip_writer_add_cfile(mz_zip_archive *pZip, const char *pArchive_name, | ||||
|     if (!pState->m_zip64) | ||||
|     { | ||||
|         /* Bail early if the archive would obviously become too large */ | ||||
|         if ((pZip->m_archive_size + num_alignment_padding_bytes + MZ_ZIP_LOCAL_DIR_HEADER_SIZE + archive_name_size + MZ_ZIP_CENTRAL_DIR_HEADER_SIZE + archive_name_size + comment_size + pState->m_central_dir.m_size + MZ_ZIP_END_OF_CENTRAL_DIR_HEADER_SIZE + 1024) > 0xFFFFFFFF) | ||||
|         if ((pZip->m_archive_size + num_alignment_padding_bytes + MZ_ZIP_LOCAL_DIR_HEADER_SIZE + archive_name_size + MZ_ZIP_CENTRAL_DIR_HEADER_SIZE | ||||
| 			+ archive_name_size + comment_size + user_extra_data_len + pState->m_central_dir.m_size + MZ_ZIP_END_OF_CENTRAL_DIR_HEADER_SIZE + 1024 | ||||
| 			+ MZ_ZIP_DATA_DESCRIPTER_SIZE32 + user_extra_data_central_len) > 0xFFFFFFFF) | ||||
|         { | ||||
|             pState->m_zip64 = MZ_TRUE; | ||||
|             /*return mz_zip_set_error(pZip, MZ_ZIP_ARCHIVE_TOO_LARGE); */ | ||||
| @@ -3209,7 +3539,7 @@ mz_bool mz_zip_writer_add_cfile(mz_zip_archive *pZip, const char *pArchive_name, | ||||
|                                                                (uncomp_size >= MZ_UINT32_MAX) ? &comp_size : NULL, (local_dir_header_ofs >= MZ_UINT32_MAX) ? &local_dir_header_ofs : NULL); | ||||
|         } | ||||
|  | ||||
|         if (!mz_zip_writer_create_local_dir_header(pZip, local_dir_header, (mz_uint16)archive_name_size, extra_size + user_extra_data_len, 0, 0, 0, method, gen_flags, dos_time, dos_date)) | ||||
|         if (!mz_zip_writer_create_local_dir_header(pZip, local_dir_header, (mz_uint16)archive_name_size, (mz_uint16)(extra_size + user_extra_data_len), 0, 0, 0, method, gen_flags, dos_time, dos_date)) | ||||
|             return mz_zip_set_error(pZip, MZ_ZIP_INTERNAL_ERROR); | ||||
|  | ||||
|         if (pZip->m_pWrite(pZip->m_pIO_opaque, cur_archive_file_ofs, local_dir_header, sizeof(local_dir_header)) != sizeof(local_dir_header)) | ||||
| @@ -3233,7 +3563,7 @@ mz_bool mz_zip_writer_add_cfile(mz_zip_archive *pZip, const char *pArchive_name, | ||||
|     { | ||||
|         if ((comp_size > MZ_UINT32_MAX) || (cur_archive_file_ofs > MZ_UINT32_MAX)) | ||||
|             return mz_zip_set_error(pZip, MZ_ZIP_ARCHIVE_TOO_LARGE); | ||||
|         if (!mz_zip_writer_create_local_dir_header(pZip, local_dir_header, (mz_uint16)archive_name_size, user_extra_data_len, 0, 0, 0, method, gen_flags, dos_time, dos_date)) | ||||
|         if (!mz_zip_writer_create_local_dir_header(pZip, local_dir_header, (mz_uint16)archive_name_size, (mz_uint16)user_extra_data_len, 0, 0, 0, method, gen_flags, dos_time, dos_date)) | ||||
|             return mz_zip_set_error(pZip, MZ_ZIP_INTERNAL_ERROR); | ||||
|  | ||||
|         if (pZip->m_pWrite(pZip->m_pIO_opaque, cur_archive_file_ofs, local_dir_header, sizeof(local_dir_header)) != sizeof(local_dir_header)) | ||||
| @@ -3271,11 +3601,12 @@ mz_bool mz_zip_writer_add_cfile(mz_zip_archive *pZip, const char *pArchive_name, | ||||
|             while (uncomp_remaining) | ||||
|             { | ||||
|                 mz_uint n = (mz_uint)MZ_MIN((mz_uint64)MZ_ZIP_MAX_IO_BUF_SIZE, uncomp_remaining); | ||||
|                 if ((MZ_FREAD(pRead_buf, 1, n, pSrc_file) != n) || (pZip->m_pWrite(pZip->m_pIO_opaque, cur_archive_file_ofs, pRead_buf, n) != n)) | ||||
|                 if ((read_callback(callback_opaque, file_ofs, pRead_buf, n) != n) || (pZip->m_pWrite(pZip->m_pIO_opaque, cur_archive_file_ofs, pRead_buf, n) != n)) | ||||
|                 { | ||||
|                     pZip->m_pFree(pZip->m_pAlloc_opaque, pRead_buf); | ||||
|                     return mz_zip_set_error(pZip, MZ_ZIP_FILE_READ_FAILED); | ||||
|                 } | ||||
| 				file_ofs += n; | ||||
|                 uncomp_crc32 = (mz_uint32)mz_crc32(uncomp_crc32, (const mz_uint8 *)pRead_buf, n); | ||||
|                 uncomp_remaining -= n; | ||||
|                 cur_archive_file_ofs += n; | ||||
| @@ -3308,19 +3639,20 @@ mz_bool mz_zip_writer_add_cfile(mz_zip_archive *pZip, const char *pArchive_name, | ||||
|             { | ||||
|                 size_t in_buf_size = (mz_uint32)MZ_MIN(uncomp_remaining, (mz_uint64)MZ_ZIP_MAX_IO_BUF_SIZE); | ||||
|                 tdefl_status status; | ||||
| 				tdefl_flush flush = TDEFL_NO_FLUSH; | ||||
|                 tdefl_flush flush = TDEFL_NO_FLUSH; | ||||
|  | ||||
|                 if (MZ_FREAD(pRead_buf, 1, in_buf_size, pSrc_file) != in_buf_size) | ||||
|                 if (read_callback(callback_opaque, file_ofs, pRead_buf, in_buf_size)!= in_buf_size) | ||||
|                 { | ||||
|                     mz_zip_set_error(pZip, MZ_ZIP_FILE_READ_FAILED); | ||||
|                     break; | ||||
|                 } | ||||
|  | ||||
| 				file_ofs += in_buf_size; | ||||
|                 uncomp_crc32 = (mz_uint32)mz_crc32(uncomp_crc32, (const mz_uint8 *)pRead_buf, in_buf_size); | ||||
|                 uncomp_remaining -= in_buf_size; | ||||
|  | ||||
| 				if (pZip->m_pNeeds_keepalive != NULL && pZip->m_pNeeds_keepalive(pZip->m_pIO_opaque)) | ||||
| 					flush = TDEFL_FULL_FLUSH; | ||||
|                 if (pZip->m_pNeeds_keepalive != NULL && pZip->m_pNeeds_keepalive(pZip->m_pIO_opaque)) | ||||
|                     flush = TDEFL_FULL_FLUSH; | ||||
|  | ||||
|                 status = tdefl_compress_buffer(pComp, pRead_buf, in_buf_size, uncomp_remaining ? flush : TDEFL_FINISH); | ||||
|                 if (status == TDEFL_STATUS_DONE) | ||||
| @@ -3350,32 +3682,32 @@ mz_bool mz_zip_writer_add_cfile(mz_zip_archive *pZip, const char *pArchive_name, | ||||
|         pZip->m_pFree(pZip->m_pAlloc_opaque, pRead_buf); | ||||
|     } | ||||
|  | ||||
| 	{ | ||||
| 		mz_uint8 local_dir_footer[MZ_ZIP_DATA_DESCRIPTER_SIZE64]; | ||||
| 		mz_uint32 local_dir_footer_size = MZ_ZIP_DATA_DESCRIPTER_SIZE32; | ||||
|     { | ||||
|         mz_uint8 local_dir_footer[MZ_ZIP_DATA_DESCRIPTER_SIZE64]; | ||||
|         mz_uint32 local_dir_footer_size = MZ_ZIP_DATA_DESCRIPTER_SIZE32; | ||||
|  | ||||
| 		MZ_WRITE_LE32(local_dir_footer + 0, MZ_ZIP_DATA_DESCRIPTOR_ID); | ||||
| 		MZ_WRITE_LE32(local_dir_footer + 4, uncomp_crc32); | ||||
| 		if (pExtra_data == NULL) | ||||
| 		{ | ||||
| 			if (comp_size > MZ_UINT32_MAX) | ||||
| 				return mz_zip_set_error(pZip, MZ_ZIP_ARCHIVE_TOO_LARGE); | ||||
|         MZ_WRITE_LE32(local_dir_footer + 0, MZ_ZIP_DATA_DESCRIPTOR_ID); | ||||
|         MZ_WRITE_LE32(local_dir_footer + 4, uncomp_crc32); | ||||
|         if (pExtra_data == NULL) | ||||
|         { | ||||
|             if (comp_size > MZ_UINT32_MAX) | ||||
|                 return mz_zip_set_error(pZip, MZ_ZIP_ARCHIVE_TOO_LARGE); | ||||
|  | ||||
| 			MZ_WRITE_LE32(local_dir_footer + 8, comp_size); | ||||
| 			MZ_WRITE_LE32(local_dir_footer + 12, uncomp_size); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			MZ_WRITE_LE64(local_dir_footer + 8, comp_size); | ||||
| 			MZ_WRITE_LE64(local_dir_footer + 16, uncomp_size); | ||||
| 			local_dir_footer_size = MZ_ZIP_DATA_DESCRIPTER_SIZE64; | ||||
| 		} | ||||
|             MZ_WRITE_LE32(local_dir_footer + 8, comp_size); | ||||
|             MZ_WRITE_LE32(local_dir_footer + 12, uncomp_size); | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             MZ_WRITE_LE64(local_dir_footer + 8, comp_size); | ||||
|             MZ_WRITE_LE64(local_dir_footer + 16, uncomp_size); | ||||
|             local_dir_footer_size = MZ_ZIP_DATA_DESCRIPTER_SIZE64; | ||||
|         } | ||||
|  | ||||
| 		if (pZip->m_pWrite(pZip->m_pIO_opaque, cur_archive_file_ofs, local_dir_footer, local_dir_footer_size) != local_dir_footer_size) | ||||
| 			return MZ_FALSE; | ||||
|         if (pZip->m_pWrite(pZip->m_pIO_opaque, cur_archive_file_ofs, local_dir_footer, local_dir_footer_size) != local_dir_footer_size) | ||||
|             return MZ_FALSE; | ||||
|  | ||||
| 		cur_archive_file_ofs += local_dir_footer_size; | ||||
| 	} | ||||
|         cur_archive_file_ofs += local_dir_footer_size; | ||||
|     } | ||||
|  | ||||
|     if (pExtra_data != NULL) | ||||
|     { | ||||
| @@ -3383,7 +3715,7 @@ mz_bool mz_zip_writer_add_cfile(mz_zip_archive *pZip, const char *pArchive_name, | ||||
|                                                            (uncomp_size >= MZ_UINT32_MAX) ? &comp_size : NULL, (local_dir_header_ofs >= MZ_UINT32_MAX) ? &local_dir_header_ofs : NULL); | ||||
|     } | ||||
|  | ||||
|     if (!mz_zip_writer_add_to_central_dir(pZip, pArchive_name, (mz_uint16)archive_name_size, pExtra_data, extra_size, pComment, comment_size, | ||||
|     if (!mz_zip_writer_add_to_central_dir(pZip, pArchive_name, (mz_uint16)archive_name_size, pExtra_data, (mz_uint16)extra_size, pComment, comment_size, | ||||
|                                           uncomp_size, comp_size, uncomp_crc32, method, gen_flags, dos_time, dos_date, local_dir_header_ofs, ext_attributes, | ||||
|                                           user_extra_data_central, user_extra_data_central_len)) | ||||
|         return MZ_FALSE; | ||||
| @@ -3394,13 +3726,33 @@ mz_bool mz_zip_writer_add_cfile(mz_zip_archive *pZip, const char *pArchive_name, | ||||
|     return MZ_TRUE; | ||||
| } | ||||
|  | ||||
| #ifndef MINIZ_NO_STDIO | ||||
|  | ||||
| static size_t mz_file_read_func_stdio(void *pOpaque, mz_uint64 file_ofs, void *pBuf, size_t n) | ||||
| { | ||||
| 	MZ_FILE *pSrc_file = (MZ_FILE *)pOpaque; | ||||
| 	mz_int64 cur_ofs = MZ_FTELL64(pSrc_file); | ||||
|  | ||||
| 	if (((mz_int64)file_ofs < 0) || (((cur_ofs != (mz_int64)file_ofs)) && (MZ_FSEEK64(pSrc_file, (mz_int64)file_ofs, SEEK_SET)))) | ||||
| 		return 0; | ||||
|  | ||||
| 	return MZ_FREAD(pBuf, 1, n, pSrc_file); | ||||
| } | ||||
|  | ||||
| mz_bool mz_zip_writer_add_cfile(mz_zip_archive *pZip, const char *pArchive_name, MZ_FILE *pSrc_file, mz_uint64 size_to_add, const MZ_TIME_T *pFile_time, const void *pComment, mz_uint16 comment_size, mz_uint level_and_flags, | ||||
| 	const char *user_extra_data, mz_uint user_extra_data_len, const char *user_extra_data_central, mz_uint user_extra_data_central_len) | ||||
| { | ||||
| 	return mz_zip_writer_add_read_buf_callback(pZip, pArchive_name, mz_file_read_func_stdio, pSrc_file, size_to_add, pFile_time, pComment, comment_size, level_and_flags, | ||||
| 		user_extra_data, user_extra_data_len, user_extra_data_central, user_extra_data_central_len); | ||||
| } | ||||
|  | ||||
| mz_bool mz_zip_writer_add_file(mz_zip_archive *pZip, const char *pArchive_name, const char *pSrc_filename, const void *pComment, mz_uint16 comment_size, mz_uint level_and_flags) | ||||
| { | ||||
|     MZ_FILE *pSrc_file = NULL; | ||||
|     mz_uint64 uncomp_size = 0; | ||||
|     MZ_TIME_T file_modified_time; | ||||
|     MZ_TIME_T *pFile_time = NULL; | ||||
| 	mz_bool status; | ||||
|     mz_bool status; | ||||
|  | ||||
|     memset(&file_modified_time, 0, sizeof(file_modified_time)); | ||||
|  | ||||
| @@ -3590,8 +3942,8 @@ mz_bool mz_zip_writer_add_from_zip_reader(mz_zip_archive *pZip, mz_zip_archive * | ||||
|     if ((local_header_extra_len) && ((local_header_comp_size == MZ_UINT32_MAX) || (local_header_uncomp_size == MZ_UINT32_MAX))) | ||||
|     { | ||||
|         mz_zip_array file_data_array; | ||||
| 		const mz_uint8 *pExtra_data; | ||||
| 		mz_uint32 extra_size_remaining = local_header_extra_len; | ||||
|         const mz_uint8 *pExtra_data; | ||||
|         mz_uint32 extra_size_remaining = local_header_extra_len; | ||||
|  | ||||
|         mz_zip_array_init(&file_data_array, 1); | ||||
|         if (!mz_zip_array_resize(pZip, &file_data_array, local_header_extra_len, MZ_FALSE)) | ||||
| @@ -4356,4 +4708,3 @@ mz_bool mz_zip_end(mz_zip_archive *pZip) | ||||
| #endif | ||||
|  | ||||
| #endif /*#ifndef MINIZ_NO_ARCHIVE_APIS*/ | ||||
|  | ||||
|   | ||||
							
								
								
									
										62
									
								
								miniz_zip.h
									
									
									
									
									
								
							
							
						
						
									
										62
									
								
								miniz_zip.h
									
									
									
									
									
								
							| @@ -4,6 +4,8 @@ | ||||
|  | ||||
| /* ------------------- ZIP archive reading/writing */ | ||||
|  | ||||
| #ifndef MINIZ_NO_ARCHIVE_APIS | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| @@ -79,29 +81,26 @@ typedef mz_bool (*mz_file_needs_keepalive)(void *pOpaque); | ||||
| struct mz_zip_internal_state_tag; | ||||
| typedef struct mz_zip_internal_state_tag mz_zip_internal_state; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
| typedef enum { | ||||
|     MZ_ZIP_MODE_INVALID = 0, | ||||
|     MZ_ZIP_MODE_READING = 1, | ||||
|     MZ_ZIP_MODE_WRITING = 2, | ||||
|     MZ_ZIP_MODE_WRITING_HAS_BEEN_FINALIZED = 3 | ||||
| } mz_zip_mode; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
| typedef enum { | ||||
|     MZ_ZIP_FLAG_CASE_SENSITIVE = 0x0100, | ||||
|     MZ_ZIP_FLAG_IGNORE_PATH = 0x0200, | ||||
|     MZ_ZIP_FLAG_COMPRESSED_DATA = 0x0400, | ||||
|     MZ_ZIP_FLAG_DO_NOT_SORT_CENTRAL_DIRECTORY = 0x0800, | ||||
|     MZ_ZIP_FLAG_VALIDATE_LOCATE_FILE_FLAG = 0x1000, /* if enabled, mz_zip_reader_locate_file() will be called on each file as its validated to ensure the func finds the file in the central dir (intended for testing) */ | ||||
|     MZ_ZIP_FLAG_VALIDATE_HEADERS_ONLY = 0x2000,     /* validate the local headers, but don't decompress the entire file and check the crc32 */ | ||||
|     MZ_ZIP_FLAG_WRITE_ZIP64 = 0x4000,               /* use the zip64 file format, instead of the original zip file format */ | ||||
|     MZ_ZIP_FLAG_WRITE_ZIP64 = 0x4000,               /* always use the zip64 file format, instead of the original zip file format with automatic switch to zip64. Use as flags parameter with mz_zip_writer_init*_v2 */ | ||||
|     MZ_ZIP_FLAG_WRITE_ALLOW_READING = 0x8000, | ||||
|     MZ_ZIP_FLAG_ASCII_FILENAME = 0x10000 | ||||
| } mz_zip_flags; | ||||
|  | ||||
| typedef enum | ||||
| { | ||||
| typedef enum { | ||||
|     MZ_ZIP_TYPE_INVALID = 0, | ||||
|     MZ_ZIP_TYPE_USER, | ||||
|     MZ_ZIP_TYPE_MEMORY, | ||||
| @@ -112,8 +111,7 @@ typedef enum | ||||
| } mz_zip_type; | ||||
|  | ||||
| /* miniz error codes. Be sure to update mz_zip_get_error_string() if you add or modify this enum. */ | ||||
| typedef enum | ||||
| { | ||||
| typedef enum { | ||||
|     MZ_ZIP_NO_ERROR = 0, | ||||
|     MZ_ZIP_UNDEFINED_ERROR, | ||||
|     MZ_ZIP_TOO_MANY_FILES, | ||||
| @@ -169,13 +167,33 @@ typedef struct | ||||
|  | ||||
|     mz_file_read_func m_pRead; | ||||
|     mz_file_write_func m_pWrite; | ||||
| 	mz_file_needs_keepalive m_pNeeds_keepalive; | ||||
|     mz_file_needs_keepalive m_pNeeds_keepalive; | ||||
|     void *m_pIO_opaque; | ||||
|  | ||||
|     mz_zip_internal_state *m_pState; | ||||
|  | ||||
| } mz_zip_archive; | ||||
|  | ||||
| typedef struct | ||||
| { | ||||
|     mz_zip_archive *pZip; | ||||
|     mz_uint flags; | ||||
|  | ||||
|     int status; | ||||
| #ifndef MINIZ_DISABLE_ZIP_READER_CRC32_CHECKS | ||||
|     mz_uint file_crc32; | ||||
| #endif | ||||
|     mz_uint64 read_buf_size, read_buf_ofs, read_buf_avail, comp_remaining, out_buf_ofs, cur_file_ofs; | ||||
|     mz_zip_archive_file_stat file_stat; | ||||
|     void *pRead_buf; | ||||
|     void *pWrite_buf; | ||||
|  | ||||
|     size_t out_blk_remain; | ||||
|  | ||||
|     tinfl_decompressor inflator; | ||||
|  | ||||
| } mz_zip_reader_extract_iter_state; | ||||
|  | ||||
| /* -------- ZIP reading */ | ||||
|  | ||||
| /* Inits a ZIP archive reader. */ | ||||
| @@ -219,13 +237,6 @@ MZ_FILE *mz_zip_get_cfile(mz_zip_archive *pZip); | ||||
| /* Reads n bytes of raw archive data, starting at file offset file_ofs, to pBuf. */ | ||||
| size_t mz_zip_read_archive_data(mz_zip_archive *pZip, mz_uint64 file_ofs, void *pBuf, size_t n); | ||||
|  | ||||
| /* Attempts to locates a file in the archive's central directory. */ | ||||
| /* Valid flags: MZ_ZIP_FLAG_CASE_SENSITIVE, MZ_ZIP_FLAG_IGNORE_PATH */ | ||||
| /* Returns -1 if the file cannot be found. */ | ||||
| int mz_zip_locate_file(mz_zip_archive *pZip, const char *pName, const char *pComment, mz_uint flags); | ||||
| /* Returns MZ_FALSE if the file cannot be found. */ | ||||
| mz_bool mz_zip_locate_file_v2(mz_zip_archive *pZip, const char *pName, const char *pComment, mz_uint flags, mz_uint32 *pIndex); | ||||
|  | ||||
| /* All mz_zip funcs set the m_last_error field in the mz_zip_archive struct. These functions retrieve/manipulate this field. */ | ||||
| /* Note that the m_last_error functionality is not thread safe. */ | ||||
| mz_zip_error mz_zip_set_last_error(mz_zip_archive *pZip, mz_zip_error err_num); | ||||
| @@ -283,6 +294,12 @@ void *mz_zip_reader_extract_file_to_heap(mz_zip_archive *pZip, const char *pFile | ||||
| mz_bool mz_zip_reader_extract_to_callback(mz_zip_archive *pZip, mz_uint file_index, mz_file_write_func pCallback, void *pOpaque, mz_uint flags); | ||||
| mz_bool mz_zip_reader_extract_file_to_callback(mz_zip_archive *pZip, const char *pFilename, mz_file_write_func pCallback, void *pOpaque, mz_uint flags); | ||||
|  | ||||
| /* Extract a file iteratively */ | ||||
| mz_zip_reader_extract_iter_state* mz_zip_reader_extract_iter_new(mz_zip_archive *pZip, mz_uint file_index, mz_uint flags); | ||||
| mz_zip_reader_extract_iter_state* mz_zip_reader_extract_file_iter_new(mz_zip_archive *pZip, const char *pFilename, mz_uint flags); | ||||
| size_t mz_zip_reader_extract_iter_read(mz_zip_reader_extract_iter_state* pState, void* pvBuf, size_t buf_size); | ||||
| mz_bool mz_zip_reader_extract_iter_free(mz_zip_reader_extract_iter_state* pState); | ||||
|  | ||||
| #ifndef MINIZ_NO_STDIO | ||||
| /* Extracts a archive file to a disk file and sets its last accessed and modified times. */ | ||||
| /* This function only extracts files, not archive directory records. */ | ||||
| @@ -324,8 +341,11 @@ mz_bool mz_zip_end(mz_zip_archive *pZip); | ||||
| #ifndef MINIZ_NO_ARCHIVE_WRITING_APIS | ||||
|  | ||||
| /* Inits a ZIP archive writer. */ | ||||
| /*Set pZip->m_pWrite (and pZip->m_pIO_opaque) before calling mz_zip_writer_init or mz_zip_writer_init_v2*/ | ||||
| /*The output is streamable, i.e. file_ofs in mz_file_write_func always increases only by n*/ | ||||
| mz_bool mz_zip_writer_init(mz_zip_archive *pZip, mz_uint64 existing_size); | ||||
| mz_bool mz_zip_writer_init_v2(mz_zip_archive *pZip, mz_uint64 existing_size, mz_uint flags); | ||||
|  | ||||
| mz_bool mz_zip_writer_init_heap(mz_zip_archive *pZip, size_t size_to_reserve_at_beginning, size_t initial_allocation_size); | ||||
| mz_bool mz_zip_writer_init_heap_v2(mz_zip_archive *pZip, size_t size_to_reserve_at_beginning, size_t initial_allocation_size, mz_uint flags); | ||||
|  | ||||
| @@ -358,6 +378,12 @@ mz_bool mz_zip_writer_add_mem_ex_v2(mz_zip_archive *pZip, const char *pArchive_n | ||||
|                                     mz_uint64 uncomp_size, mz_uint32 uncomp_crc32, MZ_TIME_T *last_modified, const char *user_extra_data_local, mz_uint user_extra_data_local_len, | ||||
|                                     const char *user_extra_data_central, mz_uint user_extra_data_central_len); | ||||
|  | ||||
| /* Adds the contents of a file to an archive. This function also records the disk file's modified time into the archive. */ | ||||
| /* File data is supplied via a read callback function. User mz_zip_writer_add_(c)file to add a file directly.*/ | ||||
| mz_bool mz_zip_writer_add_read_buf_callback(mz_zip_archive *pZip, const char *pArchive_name, mz_file_read_func read_callback, void* callback_opaque, mz_uint64 size_to_add, | ||||
| 	const MZ_TIME_T *pFile_time, const void *pComment, mz_uint16 comment_size, mz_uint level_and_flags, const char *user_extra_data_local, mz_uint user_extra_data_local_len, | ||||
| 	const char *user_extra_data_central, mz_uint user_extra_data_central_len); | ||||
|  | ||||
| #ifndef MINIZ_NO_STDIO | ||||
| /* Adds the contents of a disk file to an archive. This function also records the disk file's modified time into the archive. */ | ||||
| /* level_and_flags - compression level (0-10, see MZ_BEST_SPEED, MZ_BEST_COMPRESSION, etc.) logically OR'd with zero or more mz_zip_flags, or just set to MZ_DEFAULT_COMPRESSION. */ | ||||
| @@ -406,3 +432,5 @@ void *mz_zip_extract_archive_file_to_heap_v2(const char *pZip_filename, const ch | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* MINIZ_NO_ARCHIVE_APIS */ | ||||
|   | ||||
| @@ -14,13 +14,13 @@ Please use the files from the [releases page](https://github.com/richgel999/mini | ||||
| * A drop-in replacement for zlib's most used API's (tested in several open source projects that use zlib, such as libpng and libzip). | ||||
| * Fills a single threaded performance vs. compression ratio gap between several popular real-time compressors and zlib. For example, at level 1, miniz.c compresses around 5-9% better than minilzo, but is approx. 35% slower. At levels 2-9, miniz.c is designed to compare favorably against zlib's ratio and speed. See the miniz performance comparison page for example timings. | ||||
| * Not a block based compressor: miniz.c fully supports stream based processing using a coroutine-style implementation. The zlib-style API functions can be called a single byte at a time if that's all you've got. | ||||
| * Easy to use. The low-level compressor (tinfl) and decompressor (tdefl) have simple state structs which can be saved/restored as needed with simple memcpy's. The low-level codec API's don't use the heap in any way. | ||||
| * Easy to use. The low-level compressor (tdefl) and decompressor (tinfl) have simple state structs which can be saved/restored as needed with simple memcpy's. The low-level codec API's don't use the heap in any way. | ||||
| * Entire inflater (including optional zlib header parsing and Adler-32 checking) is implemented in a single function as a coroutine, which is separately available in a small (~550 line) source file: miniz_tinfl.c | ||||
| * A fairly complete (but totally optional) set of .ZIP archive manipulation and extraction API's. The archive functionality is intended to solve common problems encountered in embedded, mobile, or game development situations. (The archive API's are purposely just powerful enough to write an entire archiver given a bit of additional higher-level logic.) | ||||
|  | ||||
| ## Known Problems | ||||
|  | ||||
| * No support for encrypted archives. Not sure how useful this stuff is in practice. Zip encryption is very weak. | ||||
| * No support for encrypted archives. Not sure how useful this stuff is in practice. | ||||
| * Minimal documentation. The assumption is that the user is already familiar with the basic zlib API. I need to write an API wiki - for now I've tried to place key comments before each enum/API, and I've included 6 examples that demonstrate how to use the module's major features. | ||||
|  | ||||
| ## Special Thanks | ||||
|   | ||||
| @@ -993,6 +993,71 @@ static bool zip_extract(const char *pZip_filename, const char *pDst_filename) | ||||
|         } | ||||
|         free(p); | ||||
|     } | ||||
|  | ||||
|     if (stat.m_uncomp_size<100*1024*1024) | ||||
|     { | ||||
|         /* Use iterative reader to read onto heap in one big chunk */ | ||||
|         mz_zip_reader_extract_iter_state *pIter = mz_zip_reader_extract_iter_new(&zip, i, 0); | ||||
|         void *p = malloc(stat.m_uncomp_size); | ||||
|         if ((!pIter) && (0 != stat.m_uncomp_size)) | ||||
|         { | ||||
|             print_error("Failed testing archive -4 \"%s\" err: %s!\n", pZip_filename, mz_zip_get_error_string(mz_zip_get_last_error(&zip))); | ||||
|             free(p); | ||||
|             mz_zip_reader_end(&zip); | ||||
|             return false; | ||||
|         } | ||||
|         if (pIter) | ||||
|         { | ||||
|             if (stat.m_uncomp_size != mz_zip_reader_extract_iter_read(pIter, p, stat.m_uncomp_size) ) | ||||
|             { | ||||
|                 print_error("Failed testing archive -5 \"%s\" err: %s!\n", pZip_filename, mz_zip_get_error_string(mz_zip_get_last_error(&zip))); | ||||
|                 free(p); | ||||
|                 mz_zip_reader_extract_iter_free(pIter); | ||||
|                 mz_zip_reader_end(&zip); | ||||
|                 return false; | ||||
|             } | ||||
|             if (MZ_TRUE != mz_zip_reader_extract_iter_free(pIter)) | ||||
|             { | ||||
|                 print_error("Failed testing archive -6 \"%s\" err: %s!\n", pZip_filename, mz_zip_get_error_string(mz_zip_get_last_error(&zip))); | ||||
|                 free(p); | ||||
|                 mz_zip_reader_end(&zip); | ||||
|                 return false; | ||||
|             } | ||||
|         } | ||||
|         free(p); | ||||
|     } | ||||
|  | ||||
|     if (stat.m_uncomp_size<100*1024) | ||||
|     { | ||||
|         /* Use iterative reader to read file one byte at a time */ | ||||
|         mz_zip_reader_extract_iter_state *pIter = mz_zip_reader_extract_iter_new(&zip, i, 0); | ||||
|         uint8_t byBuffer; | ||||
|         if ((!pIter) && (0 != stat.m_uncomp_size)) | ||||
|         { | ||||
|             print_error("Failed testing archive -7 \"%s\" err: %s!\n", pZip_filename, mz_zip_get_error_string(mz_zip_get_last_error(&zip))); | ||||
|             mz_zip_reader_end(&zip); | ||||
|             return false; | ||||
|         } | ||||
|         if (pIter) | ||||
|         { | ||||
|             for ( uint64_t uiIndex = 0; uiIndex < stat.m_uncomp_size; uiIndex++ ) | ||||
|             { | ||||
|                 if (sizeof(byBuffer) != mz_zip_reader_extract_iter_read(pIter, &byBuffer, sizeof(byBuffer))) | ||||
|                 { | ||||
|                     print_error("Failed testing archive -8 \"%s\" err: %s!\n", pZip_filename, mz_zip_get_error_string(mz_zip_get_last_error(&zip))); | ||||
|                     mz_zip_reader_extract_iter_free(pIter); | ||||
|                     mz_zip_reader_end(&zip); | ||||
|                     return false; | ||||
|                 } | ||||
|             } | ||||
|             if (MZ_TRUE != mz_zip_reader_extract_iter_free(pIter)) | ||||
|             { | ||||
|                 print_error("Failed testing archive -9 \"%s\" err: %s!\n", pZip_filename, mz_zip_get_error_string(mz_zip_get_last_error(&zip))); | ||||
|                 mz_zip_reader_end(&zip); | ||||
|                 return false; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|   } | ||||
|   printf("Verified %u files\n",  mz_zip_reader_get_num_files(&zip)); | ||||
|  | ||||
| @@ -1446,6 +1511,15 @@ static bool test_archives(const char *pPath, comp_options options) | ||||
|         if (mz_crc32(MZ_CRC32_INIT, (const uint8*)p, extracted_size) != extracted_crc32) | ||||
|           status = false; | ||||
|  | ||||
|         mz_zip_reader_extract_iter_state *pIter = mz_zip_reader_extract_file_iter_new(&src_archive, name, 0); | ||||
|         void *q = malloc(extracted_size); | ||||
|         mz_zip_reader_extract_iter_read(pIter, q, extracted_size); | ||||
|         mz_zip_reader_extract_iter_free(pIter); | ||||
|  | ||||
|         if (mz_crc32(MZ_CRC32_INIT, (const uint8*)q, extracted_size) != extracted_crc32) | ||||
|             status = false; | ||||
|  | ||||
|         free(q); | ||||
|         free(p); | ||||
|  | ||||
|         if (options.m_write_archives) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user