laag-xz 5.2.4.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +57 -0
- data/LICENSE.txt +65 -0
- data/README.org +34 -0
- data/ext/laag/xz/extconf.rb +21 -0
- data/laag-xz.gemspec +20 -0
- data/lib/laag/xz.rb +29 -0
- data/vendor/git.tukaani.org/xz/.gitignore +66 -0
- data/vendor/git.tukaani.org/xz/AUTHORS +27 -0
- data/vendor/git.tukaani.org/xz/COPYING +65 -0
- data/vendor/git.tukaani.org/xz/COPYING.GPLv2 +339 -0
- data/vendor/git.tukaani.org/xz/COPYING.GPLv3 +674 -0
- data/vendor/git.tukaani.org/xz/COPYING.LGPLv2.1 +502 -0
- data/vendor/git.tukaani.org/xz/ChangeLog +7 -0
- data/vendor/git.tukaani.org/xz/Doxyfile.in +1234 -0
- data/vendor/git.tukaani.org/xz/INSTALL +618 -0
- data/vendor/git.tukaani.org/xz/INSTALL.generic +365 -0
- data/vendor/git.tukaani.org/xz/Makefile.am +110 -0
- data/vendor/git.tukaani.org/xz/NEWS +571 -0
- data/vendor/git.tukaani.org/xz/PACKAGERS +231 -0
- data/vendor/git.tukaani.org/xz/README +308 -0
- data/vendor/git.tukaani.org/xz/THANKS +124 -0
- data/vendor/git.tukaani.org/xz/TODO +111 -0
- data/vendor/git.tukaani.org/xz/autogen.sh +22 -0
- data/vendor/git.tukaani.org/xz/build-aux/manconv.sh +58 -0
- data/vendor/git.tukaani.org/xz/build-aux/version.sh +24 -0
- data/vendor/git.tukaani.org/xz/configure.ac +900 -0
- data/vendor/git.tukaani.org/xz/debug/Makefile.am +30 -0
- data/vendor/git.tukaani.org/xz/debug/README +17 -0
- data/vendor/git.tukaani.org/xz/debug/crc32.c +39 -0
- data/vendor/git.tukaani.org/xz/debug/full_flush.c +103 -0
- data/vendor/git.tukaani.org/xz/debug/hex2bin.c +53 -0
- data/vendor/git.tukaani.org/xz/debug/known_sizes.c +129 -0
- data/vendor/git.tukaani.org/xz/debug/memusage.c +51 -0
- data/vendor/git.tukaani.org/xz/debug/repeat.c +36 -0
- data/vendor/git.tukaani.org/xz/debug/sync_flush.c +125 -0
- data/vendor/git.tukaani.org/xz/debug/translation.bash +100 -0
- data/vendor/git.tukaani.org/xz/doc/examples/00_README.txt +31 -0
- data/vendor/git.tukaani.org/xz/doc/examples/01_compress_easy.c +297 -0
- data/vendor/git.tukaani.org/xz/doc/examples/02_decompress.c +287 -0
- data/vendor/git.tukaani.org/xz/doc/examples/03_compress_custom.c +193 -0
- data/vendor/git.tukaani.org/xz/doc/examples/04_compress_easy_mt.c +206 -0
- data/vendor/git.tukaani.org/xz/doc/examples/Makefile +24 -0
- data/vendor/git.tukaani.org/xz/doc/examples_old/xz_pipe_comp.c +127 -0
- data/vendor/git.tukaani.org/xz/doc/examples_old/xz_pipe_decomp.c +123 -0
- data/vendor/git.tukaani.org/xz/doc/faq.txt +224 -0
- data/vendor/git.tukaani.org/xz/doc/history.txt +150 -0
- data/vendor/git.tukaani.org/xz/doc/lzma-file-format.txt +166 -0
- data/vendor/git.tukaani.org/xz/doc/xz-file-format.txt +1150 -0
- data/vendor/git.tukaani.org/xz/dos/INSTALL.txt +79 -0
- data/vendor/git.tukaani.org/xz/dos/Makefile +147 -0
- data/vendor/git.tukaani.org/xz/dos/README.txt +123 -0
- data/vendor/git.tukaani.org/xz/dos/config.h +136 -0
- data/vendor/git.tukaani.org/xz/extra/7z2lzma/7z2lzma.bash +115 -0
- data/vendor/git.tukaani.org/xz/extra/scanlzma/scanlzma.c +88 -0
- data/vendor/git.tukaani.org/xz/lib/Makefile.am +32 -0
- data/vendor/git.tukaani.org/xz/lib/getopt.c +1197 -0
- data/vendor/git.tukaani.org/xz/lib/getopt.in.h +226 -0
- data/vendor/git.tukaani.org/xz/lib/getopt1.c +171 -0
- data/vendor/git.tukaani.org/xz/lib/getopt_int.h +131 -0
- data/vendor/git.tukaani.org/xz/m4/.gitignore +38 -0
- data/vendor/git.tukaani.org/xz/m4/ax_check_capsicum.m4 +85 -0
- data/vendor/git.tukaani.org/xz/m4/ax_pthread.m4 +332 -0
- data/vendor/git.tukaani.org/xz/m4/getopt.m4 +71 -0
- data/vendor/git.tukaani.org/xz/m4/posix-shell.m4 +63 -0
- data/vendor/git.tukaani.org/xz/m4/tuklib_common.m4 +22 -0
- data/vendor/git.tukaani.org/xz/m4/tuklib_cpucores.m4 +176 -0
- data/vendor/git.tukaani.org/xz/m4/tuklib_integer.m4 +74 -0
- data/vendor/git.tukaani.org/xz/m4/tuklib_mbstr.m4 +30 -0
- data/vendor/git.tukaani.org/xz/m4/tuklib_physmem.m4 +212 -0
- data/vendor/git.tukaani.org/xz/m4/tuklib_progname.m4 +25 -0
- data/vendor/git.tukaani.org/xz/macosx/build.sh +113 -0
- data/vendor/git.tukaani.org/xz/po/.gitignore +31 -0
- data/vendor/git.tukaani.org/xz/po/LINGUAS +6 -0
- data/vendor/git.tukaani.org/xz/po/Makevars +46 -0
- data/vendor/git.tukaani.org/xz/po/POTFILES.in +13 -0
- data/vendor/git.tukaani.org/xz/po/cs.po +949 -0
- data/vendor/git.tukaani.org/xz/po/de.po +993 -0
- data/vendor/git.tukaani.org/xz/po/fr.po +978 -0
- data/vendor/git.tukaani.org/xz/po/it.po +1067 -0
- data/vendor/git.tukaani.org/xz/po/pl.po +968 -0
- data/vendor/git.tukaani.org/xz/po/vi.po +1039 -0
- data/vendor/git.tukaani.org/xz/src/Makefile.am +42 -0
- data/vendor/git.tukaani.org/xz/src/common/common_w32res.rc +50 -0
- data/vendor/git.tukaani.org/xz/src/common/mythread.h +521 -0
- data/vendor/git.tukaani.org/xz/src/common/sysdefs.h +202 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_common.h +71 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_config.h +7 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_cpucores.c +100 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_cpucores.h +23 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_exit.c +57 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_exit.h +25 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_gettext.h +44 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_integer.h +534 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_mbstr.h +66 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_mbstr_fw.c +31 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_mbstr_width.c +64 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_open_stdxxx.c +57 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_open_stdxxx.h +23 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_physmem.c +216 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_physmem.h +28 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_progname.c +50 -0
- data/vendor/git.tukaani.org/xz/src/common/tuklib_progname.h +32 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/Makefile.am +122 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/Makefile.am +23 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma.h +325 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/base.h +659 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/bcj.h +90 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/block.h +581 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/check.h +150 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/container.h +632 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/delta.h +77 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/filter.h +425 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/hardware.h +64 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/index.h +686 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/index_hash.h +107 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/lzma12.h +420 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/stream_flags.h +223 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/version.h +121 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/vli.h +166 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/Makefile.inc +53 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/check.c +174 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/check.h +172 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_fast.c +82 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_small.c +61 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_table.c +19 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_table_be.h +525 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_table_le.h +525 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_tablegen.c +117 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_x86.S +304 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_fast.c +72 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_small.c +53 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_table.c +19 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_table_be.h +521 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_table_le.h +521 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_tablegen.c +88 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_x86.S +287 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/crc_macros.h +30 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/check/sha256.c +196 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/Makefile.inc +79 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/alone_decoder.c +243 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/alone_decoder.h +23 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/alone_encoder.c +163 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/auto_decoder.c +195 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/block_buffer_decoder.c +80 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/block_buffer_encoder.c +337 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/block_buffer_encoder.h +24 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/block_decoder.c +257 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/block_decoder.h +22 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/block_encoder.c +223 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/block_encoder.h +47 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/block_header_decoder.c +124 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/block_header_encoder.c +132 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/block_util.c +90 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/common.c +445 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/common.h +314 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_buffer_encoder.c +27 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_decoder_memusage.c +24 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_encoder.c +24 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_encoder_memusage.c +24 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_preset.c +27 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_preset.h +32 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_buffer_decoder.c +88 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_buffer_encoder.c +55 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_common.c +337 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_common.h +48 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_decoder.c +184 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_decoder.h +23 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_encoder.c +286 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_encoder.h +27 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_flags_decoder.c +46 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_flags_encoder.c +56 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/hardware_cputhreads.c +22 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/hardware_physmem.c +25 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/index.c +1250 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/index.h +73 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/index_decoder.c +352 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/index_encoder.c +256 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/index_encoder.h +23 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/index_hash.c +334 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/memcmplen.h +175 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/outqueue.c +184 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/outqueue.h +156 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_buffer_decoder.c +91 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_buffer_encoder.c +141 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_decoder.c +467 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_decoder.h +22 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_encoder.c +340 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_encoder_mt.c +1143 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_flags_common.c +47 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_flags_common.h +33 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_flags_decoder.c +82 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_flags_encoder.c +86 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/vli_decoder.c +86 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/vli_encoder.c +69 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/common/vli_size.c +30 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/delta/Makefile.inc +23 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_common.c +73 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_common.h +20 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_decoder.c +78 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_decoder.h +26 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_encoder.c +125 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_encoder.h +24 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_private.h +37 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/liblzma.map +108 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/liblzma.pc.in +19 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/liblzma_w32res.rc +12 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lz/Makefile.inc +22 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_decoder.c +306 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_decoder.h +234 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_encoder.c +616 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_encoder.h +327 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_encoder_hash.h +108 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_encoder_hash_table.h +68 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_encoder_mf.c +744 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/Makefile.inc +47 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/fastpos.h +141 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/fastpos_table.c +519 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/fastpos_tablegen.c +56 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma2_decoder.c +310 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma2_decoder.h +29 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma2_encoder.c +410 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma2_encoder.h +43 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_common.h +224 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_decoder.c +1064 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_decoder.h +53 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder.c +677 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder.h +58 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder_optimum_fast.c +170 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder_optimum_normal.c +855 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder_presets.c +64 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder_private.h +148 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/Makefile.inc +21 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/price.h +92 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/price_table.c +22 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/price_tablegen.c +87 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/range_common.h +71 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/range_decoder.h +185 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/range_encoder.h +231 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/Makefile.inc +47 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/arm.c +71 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/armthumb.c +76 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/ia64.c +112 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/powerpc.c +75 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_coder.c +282 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_coder.h +72 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_decoder.c +40 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_decoder.h +22 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_encoder.c +38 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_encoder.h +23 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_private.h +74 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/sparc.c +83 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/simple/x86.c +159 -0
- data/vendor/git.tukaani.org/xz/src/liblzma/validate_map.sh +68 -0
- data/vendor/git.tukaani.org/xz/src/lzmainfo/Makefile.am +39 -0
- data/vendor/git.tukaani.org/xz/src/lzmainfo/lzmainfo.1 +60 -0
- data/vendor/git.tukaani.org/xz/src/lzmainfo/lzmainfo.c +219 -0
- data/vendor/git.tukaani.org/xz/src/lzmainfo/lzmainfo_w32res.rc +12 -0
- data/vendor/git.tukaani.org/xz/src/scripts/Makefile.am +55 -0
- data/vendor/git.tukaani.org/xz/src/scripts/xzdiff.1 +77 -0
- data/vendor/git.tukaani.org/xz/src/scripts/xzdiff.in +200 -0
- data/vendor/git.tukaani.org/xz/src/scripts/xzgrep.1 +98 -0
- data/vendor/git.tukaani.org/xz/src/scripts/xzgrep.in +215 -0
- data/vendor/git.tukaani.org/xz/src/scripts/xzless.1 +69 -0
- data/vendor/git.tukaani.org/xz/src/scripts/xzless.in +58 -0
- data/vendor/git.tukaani.org/xz/src/scripts/xzmore.1 +55 -0
- data/vendor/git.tukaani.org/xz/src/scripts/xzmore.in +78 -0
- data/vendor/git.tukaani.org/xz/src/xz/Makefile.am +111 -0
- data/vendor/git.tukaani.org/xz/src/xz/args.c +700 -0
- data/vendor/git.tukaani.org/xz/src/xz/args.h +44 -0
- data/vendor/git.tukaani.org/xz/src/xz/coder.c +936 -0
- data/vendor/git.tukaani.org/xz/src/xz/coder.h +76 -0
- data/vendor/git.tukaani.org/xz/src/xz/file_io.c +1300 -0
- data/vendor/git.tukaani.org/xz/src/xz/file_io.h +156 -0
- data/vendor/git.tukaani.org/xz/src/xz/hardware.c +150 -0
- data/vendor/git.tukaani.org/xz/src/xz/hardware.h +37 -0
- data/vendor/git.tukaani.org/xz/src/xz/list.c +1192 -0
- data/vendor/git.tukaani.org/xz/src/xz/list.h +18 -0
- data/vendor/git.tukaani.org/xz/src/xz/main.c +330 -0
- data/vendor/git.tukaani.org/xz/src/xz/main.h +30 -0
- data/vendor/git.tukaani.org/xz/src/xz/message.c +1258 -0
- data/vendor/git.tukaani.org/xz/src/xz/message.h +167 -0
- data/vendor/git.tukaani.org/xz/src/xz/mytime.c +89 -0
- data/vendor/git.tukaani.org/xz/src/xz/mytime.h +47 -0
- data/vendor/git.tukaani.org/xz/src/xz/options.c +363 -0
- data/vendor/git.tukaani.org/xz/src/xz/options.h +31 -0
- data/vendor/git.tukaani.org/xz/src/xz/private.h +66 -0
- data/vendor/git.tukaani.org/xz/src/xz/signals.c +209 -0
- data/vendor/git.tukaani.org/xz/src/xz/signals.h +43 -0
- data/vendor/git.tukaani.org/xz/src/xz/suffix.c +399 -0
- data/vendor/git.tukaani.org/xz/src/xz/suffix.h +28 -0
- data/vendor/git.tukaani.org/xz/src/xz/util.c +288 -0
- data/vendor/git.tukaani.org/xz/src/xz/util.h +123 -0
- data/vendor/git.tukaani.org/xz/src/xz/xz.1 +2786 -0
- data/vendor/git.tukaani.org/xz/src/xz/xz_w32res.rc +12 -0
- data/vendor/git.tukaani.org/xz/src/xzdec/Makefile.am +82 -0
- data/vendor/git.tukaani.org/xz/src/xzdec/lzmadec_w32res.rc +12 -0
- data/vendor/git.tukaani.org/xz/src/xzdec/xzdec.1 +146 -0
- data/vendor/git.tukaani.org/xz/src/xzdec/xzdec.c +323 -0
- data/vendor/git.tukaani.org/xz/src/xzdec/xzdec_w32res.rc +12 -0
- data/vendor/git.tukaani.org/xz/tests/Makefile.am +57 -0
- data/vendor/git.tukaani.org/xz/tests/bcj_test.c +65 -0
- data/vendor/git.tukaani.org/xz/tests/compress_prepared_bcj_sparc +0 -0
- data/vendor/git.tukaani.org/xz/tests/compress_prepared_bcj_x86 +0 -0
- data/vendor/git.tukaani.org/xz/tests/create_compress_files.c +158 -0
- data/vendor/git.tukaani.org/xz/tests/files/README +240 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-0-backward_size.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-0-empty-truncated.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-0-footer_magic.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-0-header_magic.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-0-nonempty_index.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-0cat-alone.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-0cat-header_magic.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-0catpad-empty.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-0pad-empty.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-1.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-3.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-4.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-5.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-6.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-check-crc32.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-check-crc64.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-check-sha256.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-1.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-3.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-4.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-5.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-6.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-7.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-8.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-stream_flags-1.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-stream_flags-2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-stream_flags-3.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-vli-1.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-1-vli-2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-2-compressed_data_padding.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-2-index-1.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-2-index-2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-2-index-3.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-2-index-4.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/bad-2-index-5.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-0-empty.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-0cat-empty.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-0catpad-empty.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-0pad-empty.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-3delta-lzma2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-block_header-1.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-block_header-2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-block_header-3.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-check-crc32.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-check-crc64.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-check-none.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-check-sha256.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-delta-lzma2.tiff.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-lzma2-1.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-lzma2-2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-lzma2-3.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-lzma2-4.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-lzma2-5.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-sparc-lzma2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-1-x86-lzma2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/good-2-lzma2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/unsupported-block_header.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/unsupported-check.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/unsupported-filter_flags-1.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/unsupported-filter_flags-2.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/files/unsupported-filter_flags-3.xz +0 -0
- data/vendor/git.tukaani.org/xz/tests/test_bcj_exact_size.c +113 -0
- data/vendor/git.tukaani.org/xz/tests/test_block_header.c +240 -0
- data/vendor/git.tukaani.org/xz/tests/test_check.c +83 -0
- data/vendor/git.tukaani.org/xz/tests/test_compress.sh +142 -0
- data/vendor/git.tukaani.org/xz/tests/test_files.sh +57 -0
- data/vendor/git.tukaani.org/xz/tests/test_filter_flags.c +258 -0
- data/vendor/git.tukaani.org/xz/tests/test_index.c +689 -0
- data/vendor/git.tukaani.org/xz/tests/test_scripts.sh +76 -0
- data/vendor/git.tukaani.org/xz/tests/test_stream_flags.c +180 -0
- data/vendor/git.tukaani.org/xz/tests/tests.h +124 -0
- data/vendor/git.tukaani.org/xz/tests/xzgrep_expected_output +39 -0
- data/vendor/git.tukaani.org/xz/windows/INSTALL-MSVC.txt +47 -0
- data/vendor/git.tukaani.org/xz/windows/INSTALL-MinGW.txt +138 -0
- data/vendor/git.tukaani.org/xz/windows/README-Windows.txt +122 -0
- data/vendor/git.tukaani.org/xz/windows/build.bash +203 -0
- data/vendor/git.tukaani.org/xz/windows/vs2013/config.h +148 -0
- data/vendor/git.tukaani.org/xz/windows/vs2013/liblzma.vcxproj +354 -0
- data/vendor/git.tukaani.org/xz/windows/vs2013/liblzma_dll.vcxproj +383 -0
- data/vendor/git.tukaani.org/xz/windows/vs2013/xz_win.sln +48 -0
- data/vendor/git.tukaani.org/xz/windows/vs2017/config.h +148 -0
- data/vendor/git.tukaani.org/xz/windows/vs2017/liblzma.vcxproj +355 -0
- data/vendor/git.tukaani.org/xz/windows/vs2017/liblzma_dll.vcxproj +384 -0
- data/vendor/git.tukaani.org/xz/windows/vs2017/xz_win.sln +48 -0
- metadata +457 -0
@@ -0,0 +1,73 @@
|
|
1
|
+
///////////////////////////////////////////////////////////////////////////////
|
2
|
+
//
|
3
|
+
/// \file index.h
|
4
|
+
/// \brief Handling of Index
|
5
|
+
//
|
6
|
+
// Author: Lasse Collin
|
7
|
+
//
|
8
|
+
// This file has been put into the public domain.
|
9
|
+
// You can do whatever you want with this file.
|
10
|
+
//
|
11
|
+
///////////////////////////////////////////////////////////////////////////////
|
12
|
+
|
13
|
+
#ifndef LZMA_INDEX_H
|
14
|
+
#define LZMA_INDEX_H
|
15
|
+
|
16
|
+
#include "common.h"
|
17
|
+
|
18
|
+
|
19
|
+
/// Minimum Unpadded Size
|
20
|
+
#define UNPADDED_SIZE_MIN LZMA_VLI_C(5)
|
21
|
+
|
22
|
+
/// Maximum Unpadded Size
|
23
|
+
#define UNPADDED_SIZE_MAX (LZMA_VLI_MAX & ~LZMA_VLI_C(3))
|
24
|
+
|
25
|
+
|
26
|
+
/// Get the size of the Index Padding field. This is needed by Index encoder
|
27
|
+
/// and decoder, but applications should have no use for this.
|
28
|
+
extern uint32_t lzma_index_padding_size(const lzma_index *i);
|
29
|
+
|
30
|
+
|
31
|
+
/// Set for how many Records to allocate memory the next time
|
32
|
+
/// lzma_index_append() needs to allocate space for a new Record.
|
33
|
+
/// This is used only by the Index decoder.
|
34
|
+
extern void lzma_index_prealloc(lzma_index *i, lzma_vli records);
|
35
|
+
|
36
|
+
|
37
|
+
/// Round the variable-length integer to the next multiple of four.
|
38
|
+
static inline lzma_vli
|
39
|
+
vli_ceil4(lzma_vli vli)
|
40
|
+
{
|
41
|
+
assert(vli <= LZMA_VLI_MAX);
|
42
|
+
return (vli + 3) & ~LZMA_VLI_C(3);
|
43
|
+
}
|
44
|
+
|
45
|
+
|
46
|
+
/// Calculate the size of the Index field excluding Index Padding
|
47
|
+
static inline lzma_vli
|
48
|
+
index_size_unpadded(lzma_vli count, lzma_vli index_list_size)
|
49
|
+
{
|
50
|
+
// Index Indicator + Number of Records + List of Records + CRC32
|
51
|
+
return 1 + lzma_vli_size(count) + index_list_size + 4;
|
52
|
+
}
|
53
|
+
|
54
|
+
|
55
|
+
/// Calculate the size of the Index field including Index Padding
|
56
|
+
static inline lzma_vli
|
57
|
+
index_size(lzma_vli count, lzma_vli index_list_size)
|
58
|
+
{
|
59
|
+
return vli_ceil4(index_size_unpadded(count, index_list_size));
|
60
|
+
}
|
61
|
+
|
62
|
+
|
63
|
+
/// Calculate the total size of the Stream
|
64
|
+
static inline lzma_vli
|
65
|
+
index_stream_size(lzma_vli blocks_size,
|
66
|
+
lzma_vli count, lzma_vli index_list_size)
|
67
|
+
{
|
68
|
+
return LZMA_STREAM_HEADER_SIZE + blocks_size
|
69
|
+
+ index_size(count, index_list_size)
|
70
|
+
+ LZMA_STREAM_HEADER_SIZE;
|
71
|
+
}
|
72
|
+
|
73
|
+
#endif
|
@@ -0,0 +1,352 @@
|
|
1
|
+
///////////////////////////////////////////////////////////////////////////////
|
2
|
+
//
|
3
|
+
/// \file index_decoder.c
|
4
|
+
/// \brief Decodes the Index field
|
5
|
+
//
|
6
|
+
// Author: Lasse Collin
|
7
|
+
//
|
8
|
+
// This file has been put into the public domain.
|
9
|
+
// You can do whatever you want with this file.
|
10
|
+
//
|
11
|
+
///////////////////////////////////////////////////////////////////////////////
|
12
|
+
|
13
|
+
#include "index.h"
|
14
|
+
#include "check.h"
|
15
|
+
|
16
|
+
|
17
|
+
typedef struct {
|
18
|
+
enum {
|
19
|
+
SEQ_INDICATOR,
|
20
|
+
SEQ_COUNT,
|
21
|
+
SEQ_MEMUSAGE,
|
22
|
+
SEQ_UNPADDED,
|
23
|
+
SEQ_UNCOMPRESSED,
|
24
|
+
SEQ_PADDING_INIT,
|
25
|
+
SEQ_PADDING,
|
26
|
+
SEQ_CRC32,
|
27
|
+
} sequence;
|
28
|
+
|
29
|
+
/// Memory usage limit
|
30
|
+
uint64_t memlimit;
|
31
|
+
|
32
|
+
/// Target Index
|
33
|
+
lzma_index *index;
|
34
|
+
|
35
|
+
/// Pointer give by the application, which is set after
|
36
|
+
/// successful decoding.
|
37
|
+
lzma_index **index_ptr;
|
38
|
+
|
39
|
+
/// Number of Records left to decode.
|
40
|
+
lzma_vli count;
|
41
|
+
|
42
|
+
/// The most recent Unpadded Size field
|
43
|
+
lzma_vli unpadded_size;
|
44
|
+
|
45
|
+
/// The most recent Uncompressed Size field
|
46
|
+
lzma_vli uncompressed_size;
|
47
|
+
|
48
|
+
/// Position in integers
|
49
|
+
size_t pos;
|
50
|
+
|
51
|
+
/// CRC32 of the List of Records field
|
52
|
+
uint32_t crc32;
|
53
|
+
} lzma_index_coder;
|
54
|
+
|
55
|
+
|
56
|
+
static lzma_ret
|
57
|
+
index_decode(void *coder_ptr, const lzma_allocator *allocator,
|
58
|
+
const uint8_t *restrict in, size_t *restrict in_pos,
|
59
|
+
size_t in_size,
|
60
|
+
uint8_t *restrict out lzma_attribute((__unused__)),
|
61
|
+
size_t *restrict out_pos lzma_attribute((__unused__)),
|
62
|
+
size_t out_size lzma_attribute((__unused__)),
|
63
|
+
lzma_action action lzma_attribute((__unused__)))
|
64
|
+
{
|
65
|
+
lzma_index_coder *coder = coder_ptr;
|
66
|
+
|
67
|
+
// Similar optimization as in index_encoder.c
|
68
|
+
const size_t in_start = *in_pos;
|
69
|
+
lzma_ret ret = LZMA_OK;
|
70
|
+
|
71
|
+
while (*in_pos < in_size)
|
72
|
+
switch (coder->sequence) {
|
73
|
+
case SEQ_INDICATOR:
|
74
|
+
// Return LZMA_DATA_ERROR instead of e.g. LZMA_PROG_ERROR or
|
75
|
+
// LZMA_FORMAT_ERROR, because a typical usage case for Index
|
76
|
+
// decoder is when parsing the Stream backwards. If seeking
|
77
|
+
// backward from the Stream Footer gives us something that
|
78
|
+
// doesn't begin with Index Indicator, the file is considered
|
79
|
+
// corrupt, not "programming error" or "unrecognized file
|
80
|
+
// format". One could argue that the application should
|
81
|
+
// verify the Index Indicator before trying to decode the
|
82
|
+
// Index, but well, I suppose it is simpler this way.
|
83
|
+
if (in[(*in_pos)++] != 0x00)
|
84
|
+
return LZMA_DATA_ERROR;
|
85
|
+
|
86
|
+
coder->sequence = SEQ_COUNT;
|
87
|
+
break;
|
88
|
+
|
89
|
+
case SEQ_COUNT:
|
90
|
+
ret = lzma_vli_decode(&coder->count, &coder->pos,
|
91
|
+
in, in_pos, in_size);
|
92
|
+
if (ret != LZMA_STREAM_END)
|
93
|
+
goto out;
|
94
|
+
|
95
|
+
coder->pos = 0;
|
96
|
+
coder->sequence = SEQ_MEMUSAGE;
|
97
|
+
|
98
|
+
// Fall through
|
99
|
+
|
100
|
+
case SEQ_MEMUSAGE:
|
101
|
+
if (lzma_index_memusage(1, coder->count) > coder->memlimit) {
|
102
|
+
ret = LZMA_MEMLIMIT_ERROR;
|
103
|
+
goto out;
|
104
|
+
}
|
105
|
+
|
106
|
+
// Tell the Index handling code how many Records this
|
107
|
+
// Index has to allow it to allocate memory more efficiently.
|
108
|
+
lzma_index_prealloc(coder->index, coder->count);
|
109
|
+
|
110
|
+
ret = LZMA_OK;
|
111
|
+
coder->sequence = coder->count == 0
|
112
|
+
? SEQ_PADDING_INIT : SEQ_UNPADDED;
|
113
|
+
break;
|
114
|
+
|
115
|
+
case SEQ_UNPADDED:
|
116
|
+
case SEQ_UNCOMPRESSED: {
|
117
|
+
lzma_vli *size = coder->sequence == SEQ_UNPADDED
|
118
|
+
? &coder->unpadded_size
|
119
|
+
: &coder->uncompressed_size;
|
120
|
+
|
121
|
+
ret = lzma_vli_decode(size, &coder->pos,
|
122
|
+
in, in_pos, in_size);
|
123
|
+
if (ret != LZMA_STREAM_END)
|
124
|
+
goto out;
|
125
|
+
|
126
|
+
ret = LZMA_OK;
|
127
|
+
coder->pos = 0;
|
128
|
+
|
129
|
+
if (coder->sequence == SEQ_UNPADDED) {
|
130
|
+
// Validate that encoded Unpadded Size isn't too small
|
131
|
+
// or too big.
|
132
|
+
if (coder->unpadded_size < UNPADDED_SIZE_MIN
|
133
|
+
|| coder->unpadded_size
|
134
|
+
> UNPADDED_SIZE_MAX)
|
135
|
+
return LZMA_DATA_ERROR;
|
136
|
+
|
137
|
+
coder->sequence = SEQ_UNCOMPRESSED;
|
138
|
+
} else {
|
139
|
+
// Add the decoded Record to the Index.
|
140
|
+
return_if_error(lzma_index_append(
|
141
|
+
coder->index, allocator,
|
142
|
+
coder->unpadded_size,
|
143
|
+
coder->uncompressed_size));
|
144
|
+
|
145
|
+
// Check if this was the last Record.
|
146
|
+
coder->sequence = --coder->count == 0
|
147
|
+
? SEQ_PADDING_INIT
|
148
|
+
: SEQ_UNPADDED;
|
149
|
+
}
|
150
|
+
|
151
|
+
break;
|
152
|
+
}
|
153
|
+
|
154
|
+
case SEQ_PADDING_INIT:
|
155
|
+
coder->pos = lzma_index_padding_size(coder->index);
|
156
|
+
coder->sequence = SEQ_PADDING;
|
157
|
+
|
158
|
+
// Fall through
|
159
|
+
|
160
|
+
case SEQ_PADDING:
|
161
|
+
if (coder->pos > 0) {
|
162
|
+
--coder->pos;
|
163
|
+
if (in[(*in_pos)++] != 0x00)
|
164
|
+
return LZMA_DATA_ERROR;
|
165
|
+
|
166
|
+
break;
|
167
|
+
}
|
168
|
+
|
169
|
+
// Finish the CRC32 calculation.
|
170
|
+
coder->crc32 = lzma_crc32(in + in_start,
|
171
|
+
*in_pos - in_start, coder->crc32);
|
172
|
+
|
173
|
+
coder->sequence = SEQ_CRC32;
|
174
|
+
|
175
|
+
// Fall through
|
176
|
+
|
177
|
+
case SEQ_CRC32:
|
178
|
+
do {
|
179
|
+
if (*in_pos == in_size)
|
180
|
+
return LZMA_OK;
|
181
|
+
|
182
|
+
if (((coder->crc32 >> (coder->pos * 8)) & 0xFF)
|
183
|
+
!= in[(*in_pos)++])
|
184
|
+
return LZMA_DATA_ERROR;
|
185
|
+
|
186
|
+
} while (++coder->pos < 4);
|
187
|
+
|
188
|
+
// Decoding was successful, now we can let the application
|
189
|
+
// see the decoded Index.
|
190
|
+
*coder->index_ptr = coder->index;
|
191
|
+
|
192
|
+
// Make index NULL so we don't free it unintentionally.
|
193
|
+
coder->index = NULL;
|
194
|
+
|
195
|
+
return LZMA_STREAM_END;
|
196
|
+
|
197
|
+
default:
|
198
|
+
assert(0);
|
199
|
+
return LZMA_PROG_ERROR;
|
200
|
+
}
|
201
|
+
|
202
|
+
out:
|
203
|
+
// Update the CRC32,
|
204
|
+
coder->crc32 = lzma_crc32(in + in_start,
|
205
|
+
*in_pos - in_start, coder->crc32);
|
206
|
+
|
207
|
+
return ret;
|
208
|
+
}
|
209
|
+
|
210
|
+
|
211
|
+
static void
|
212
|
+
index_decoder_end(void *coder_ptr, const lzma_allocator *allocator)
|
213
|
+
{
|
214
|
+
lzma_index_coder *coder = coder_ptr;
|
215
|
+
lzma_index_end(coder->index, allocator);
|
216
|
+
lzma_free(coder, allocator);
|
217
|
+
return;
|
218
|
+
}
|
219
|
+
|
220
|
+
|
221
|
+
static lzma_ret
|
222
|
+
index_decoder_memconfig(void *coder_ptr, uint64_t *memusage,
|
223
|
+
uint64_t *old_memlimit, uint64_t new_memlimit)
|
224
|
+
{
|
225
|
+
lzma_index_coder *coder = coder_ptr;
|
226
|
+
|
227
|
+
*memusage = lzma_index_memusage(1, coder->count);
|
228
|
+
*old_memlimit = coder->memlimit;
|
229
|
+
|
230
|
+
if (new_memlimit != 0) {
|
231
|
+
if (new_memlimit < *memusage)
|
232
|
+
return LZMA_MEMLIMIT_ERROR;
|
233
|
+
|
234
|
+
coder->memlimit = new_memlimit;
|
235
|
+
}
|
236
|
+
|
237
|
+
return LZMA_OK;
|
238
|
+
}
|
239
|
+
|
240
|
+
|
241
|
+
static lzma_ret
|
242
|
+
index_decoder_reset(lzma_index_coder *coder, const lzma_allocator *allocator,
|
243
|
+
lzma_index **i, uint64_t memlimit)
|
244
|
+
{
|
245
|
+
// Remember the pointer given by the application. We will set it
|
246
|
+
// to point to the decoded Index only if decoding is successful.
|
247
|
+
// Before that, keep it NULL so that applications can always safely
|
248
|
+
// pass it to lzma_index_end() no matter did decoding succeed or not.
|
249
|
+
coder->index_ptr = i;
|
250
|
+
*i = NULL;
|
251
|
+
|
252
|
+
// We always allocate a new lzma_index.
|
253
|
+
coder->index = lzma_index_init(allocator);
|
254
|
+
if (coder->index == NULL)
|
255
|
+
return LZMA_MEM_ERROR;
|
256
|
+
|
257
|
+
// Initialize the rest.
|
258
|
+
coder->sequence = SEQ_INDICATOR;
|
259
|
+
coder->memlimit = my_max(1, memlimit);
|
260
|
+
coder->count = 0; // Needs to be initialized due to _memconfig().
|
261
|
+
coder->pos = 0;
|
262
|
+
coder->crc32 = 0;
|
263
|
+
|
264
|
+
return LZMA_OK;
|
265
|
+
}
|
266
|
+
|
267
|
+
|
268
|
+
static lzma_ret
|
269
|
+
index_decoder_init(lzma_next_coder *next, const lzma_allocator *allocator,
|
270
|
+
lzma_index **i, uint64_t memlimit)
|
271
|
+
{
|
272
|
+
lzma_next_coder_init(&index_decoder_init, next, allocator);
|
273
|
+
|
274
|
+
if (i == NULL)
|
275
|
+
return LZMA_PROG_ERROR;
|
276
|
+
|
277
|
+
lzma_index_coder *coder = next->coder;
|
278
|
+
if (coder == NULL) {
|
279
|
+
coder = lzma_alloc(sizeof(lzma_index_coder), allocator);
|
280
|
+
if (coder == NULL)
|
281
|
+
return LZMA_MEM_ERROR;
|
282
|
+
|
283
|
+
next->coder = coder;
|
284
|
+
next->code = &index_decode;
|
285
|
+
next->end = &index_decoder_end;
|
286
|
+
next->memconfig = &index_decoder_memconfig;
|
287
|
+
coder->index = NULL;
|
288
|
+
} else {
|
289
|
+
lzma_index_end(coder->index, allocator);
|
290
|
+
}
|
291
|
+
|
292
|
+
return index_decoder_reset(coder, allocator, i, memlimit);
|
293
|
+
}
|
294
|
+
|
295
|
+
|
296
|
+
extern LZMA_API(lzma_ret)
|
297
|
+
lzma_index_decoder(lzma_stream *strm, lzma_index **i, uint64_t memlimit)
|
298
|
+
{
|
299
|
+
lzma_next_strm_init(index_decoder_init, strm, i, memlimit);
|
300
|
+
|
301
|
+
strm->internal->supported_actions[LZMA_RUN] = true;
|
302
|
+
strm->internal->supported_actions[LZMA_FINISH] = true;
|
303
|
+
|
304
|
+
return LZMA_OK;
|
305
|
+
}
|
306
|
+
|
307
|
+
|
308
|
+
extern LZMA_API(lzma_ret)
|
309
|
+
lzma_index_buffer_decode(lzma_index **i, uint64_t *memlimit,
|
310
|
+
const lzma_allocator *allocator,
|
311
|
+
const uint8_t *in, size_t *in_pos, size_t in_size)
|
312
|
+
{
|
313
|
+
// Sanity checks
|
314
|
+
if (i == NULL || memlimit == NULL
|
315
|
+
|| in == NULL || in_pos == NULL || *in_pos > in_size)
|
316
|
+
return LZMA_PROG_ERROR;
|
317
|
+
|
318
|
+
// Initialize the decoder.
|
319
|
+
lzma_index_coder coder;
|
320
|
+
return_if_error(index_decoder_reset(&coder, allocator, i, *memlimit));
|
321
|
+
|
322
|
+
// Store the input start position so that we can restore it in case
|
323
|
+
// of an error.
|
324
|
+
const size_t in_start = *in_pos;
|
325
|
+
|
326
|
+
// Do the actual decoding.
|
327
|
+
lzma_ret ret = index_decode(&coder, allocator, in, in_pos, in_size,
|
328
|
+
NULL, NULL, 0, LZMA_RUN);
|
329
|
+
|
330
|
+
if (ret == LZMA_STREAM_END) {
|
331
|
+
ret = LZMA_OK;
|
332
|
+
} else {
|
333
|
+
// Something went wrong, free the Index structure and restore
|
334
|
+
// the input position.
|
335
|
+
lzma_index_end(coder.index, allocator);
|
336
|
+
*in_pos = in_start;
|
337
|
+
|
338
|
+
if (ret == LZMA_OK) {
|
339
|
+
// The input is truncated or otherwise corrupt.
|
340
|
+
// Use LZMA_DATA_ERROR instead of LZMA_BUF_ERROR
|
341
|
+
// like lzma_vli_decode() does in single-call mode.
|
342
|
+
ret = LZMA_DATA_ERROR;
|
343
|
+
|
344
|
+
} else if (ret == LZMA_MEMLIMIT_ERROR) {
|
345
|
+
// Tell the caller how much memory would have
|
346
|
+
// been needed.
|
347
|
+
*memlimit = lzma_index_memusage(1, coder.count);
|
348
|
+
}
|
349
|
+
}
|
350
|
+
|
351
|
+
return ret;
|
352
|
+
}
|
@@ -0,0 +1,256 @@
|
|
1
|
+
///////////////////////////////////////////////////////////////////////////////
|
2
|
+
//
|
3
|
+
/// \file index_encoder.c
|
4
|
+
/// \brief Encodes the Index field
|
5
|
+
//
|
6
|
+
// Author: Lasse Collin
|
7
|
+
//
|
8
|
+
// This file has been put into the public domain.
|
9
|
+
// You can do whatever you want with this file.
|
10
|
+
//
|
11
|
+
///////////////////////////////////////////////////////////////////////////////
|
12
|
+
|
13
|
+
#include "index_encoder.h"
|
14
|
+
#include "index.h"
|
15
|
+
#include "check.h"
|
16
|
+
|
17
|
+
|
18
|
+
typedef struct {
|
19
|
+
enum {
|
20
|
+
SEQ_INDICATOR,
|
21
|
+
SEQ_COUNT,
|
22
|
+
SEQ_UNPADDED,
|
23
|
+
SEQ_UNCOMPRESSED,
|
24
|
+
SEQ_NEXT,
|
25
|
+
SEQ_PADDING,
|
26
|
+
SEQ_CRC32,
|
27
|
+
} sequence;
|
28
|
+
|
29
|
+
/// Index being encoded
|
30
|
+
const lzma_index *index;
|
31
|
+
|
32
|
+
/// Iterator for the Index being encoded
|
33
|
+
lzma_index_iter iter;
|
34
|
+
|
35
|
+
/// Position in integers
|
36
|
+
size_t pos;
|
37
|
+
|
38
|
+
/// CRC32 of the List of Records field
|
39
|
+
uint32_t crc32;
|
40
|
+
} lzma_index_coder;
|
41
|
+
|
42
|
+
|
43
|
+
static lzma_ret
|
44
|
+
index_encode(void *coder_ptr,
|
45
|
+
const lzma_allocator *allocator lzma_attribute((__unused__)),
|
46
|
+
const uint8_t *restrict in lzma_attribute((__unused__)),
|
47
|
+
size_t *restrict in_pos lzma_attribute((__unused__)),
|
48
|
+
size_t in_size lzma_attribute((__unused__)),
|
49
|
+
uint8_t *restrict out, size_t *restrict out_pos,
|
50
|
+
size_t out_size,
|
51
|
+
lzma_action action lzma_attribute((__unused__)))
|
52
|
+
{
|
53
|
+
lzma_index_coder *coder = coder_ptr;
|
54
|
+
|
55
|
+
// Position where to start calculating CRC32. The idea is that we
|
56
|
+
// need to call lzma_crc32() only once per call to index_encode().
|
57
|
+
const size_t out_start = *out_pos;
|
58
|
+
|
59
|
+
// Return value to use if we return at the end of this function.
|
60
|
+
// We use "goto out" to jump out of the while-switch construct
|
61
|
+
// instead of returning directly, because that way we don't need
|
62
|
+
// to copypaste the lzma_crc32() call to many places.
|
63
|
+
lzma_ret ret = LZMA_OK;
|
64
|
+
|
65
|
+
while (*out_pos < out_size)
|
66
|
+
switch (coder->sequence) {
|
67
|
+
case SEQ_INDICATOR:
|
68
|
+
out[*out_pos] = 0x00;
|
69
|
+
++*out_pos;
|
70
|
+
coder->sequence = SEQ_COUNT;
|
71
|
+
break;
|
72
|
+
|
73
|
+
case SEQ_COUNT: {
|
74
|
+
const lzma_vli count = lzma_index_block_count(coder->index);
|
75
|
+
ret = lzma_vli_encode(count, &coder->pos,
|
76
|
+
out, out_pos, out_size);
|
77
|
+
if (ret != LZMA_STREAM_END)
|
78
|
+
goto out;
|
79
|
+
|
80
|
+
ret = LZMA_OK;
|
81
|
+
coder->pos = 0;
|
82
|
+
coder->sequence = SEQ_NEXT;
|
83
|
+
break;
|
84
|
+
}
|
85
|
+
|
86
|
+
case SEQ_NEXT:
|
87
|
+
if (lzma_index_iter_next(
|
88
|
+
&coder->iter, LZMA_INDEX_ITER_BLOCK)) {
|
89
|
+
// Get the size of the Index Padding field.
|
90
|
+
coder->pos = lzma_index_padding_size(coder->index);
|
91
|
+
assert(coder->pos <= 3);
|
92
|
+
coder->sequence = SEQ_PADDING;
|
93
|
+
break;
|
94
|
+
}
|
95
|
+
|
96
|
+
coder->sequence = SEQ_UNPADDED;
|
97
|
+
|
98
|
+
// Fall through
|
99
|
+
|
100
|
+
case SEQ_UNPADDED:
|
101
|
+
case SEQ_UNCOMPRESSED: {
|
102
|
+
const lzma_vli size = coder->sequence == SEQ_UNPADDED
|
103
|
+
? coder->iter.block.unpadded_size
|
104
|
+
: coder->iter.block.uncompressed_size;
|
105
|
+
|
106
|
+
ret = lzma_vli_encode(size, &coder->pos,
|
107
|
+
out, out_pos, out_size);
|
108
|
+
if (ret != LZMA_STREAM_END)
|
109
|
+
goto out;
|
110
|
+
|
111
|
+
ret = LZMA_OK;
|
112
|
+
coder->pos = 0;
|
113
|
+
|
114
|
+
// Advance to SEQ_UNCOMPRESSED or SEQ_NEXT.
|
115
|
+
++coder->sequence;
|
116
|
+
break;
|
117
|
+
}
|
118
|
+
|
119
|
+
case SEQ_PADDING:
|
120
|
+
if (coder->pos > 0) {
|
121
|
+
--coder->pos;
|
122
|
+
out[(*out_pos)++] = 0x00;
|
123
|
+
break;
|
124
|
+
}
|
125
|
+
|
126
|
+
// Finish the CRC32 calculation.
|
127
|
+
coder->crc32 = lzma_crc32(out + out_start,
|
128
|
+
*out_pos - out_start, coder->crc32);
|
129
|
+
|
130
|
+
coder->sequence = SEQ_CRC32;
|
131
|
+
|
132
|
+
// Fall through
|
133
|
+
|
134
|
+
case SEQ_CRC32:
|
135
|
+
// We don't use the main loop, because we don't want
|
136
|
+
// coder->crc32 to be touched anymore.
|
137
|
+
do {
|
138
|
+
if (*out_pos == out_size)
|
139
|
+
return LZMA_OK;
|
140
|
+
|
141
|
+
out[*out_pos] = (coder->crc32 >> (coder->pos * 8))
|
142
|
+
& 0xFF;
|
143
|
+
++*out_pos;
|
144
|
+
|
145
|
+
} while (++coder->pos < 4);
|
146
|
+
|
147
|
+
return LZMA_STREAM_END;
|
148
|
+
|
149
|
+
default:
|
150
|
+
assert(0);
|
151
|
+
return LZMA_PROG_ERROR;
|
152
|
+
}
|
153
|
+
|
154
|
+
out:
|
155
|
+
// Update the CRC32.
|
156
|
+
coder->crc32 = lzma_crc32(out + out_start,
|
157
|
+
*out_pos - out_start, coder->crc32);
|
158
|
+
|
159
|
+
return ret;
|
160
|
+
}
|
161
|
+
|
162
|
+
|
163
|
+
static void
|
164
|
+
index_encoder_end(void *coder, const lzma_allocator *allocator)
|
165
|
+
{
|
166
|
+
lzma_free(coder, allocator);
|
167
|
+
return;
|
168
|
+
}
|
169
|
+
|
170
|
+
|
171
|
+
static void
|
172
|
+
index_encoder_reset(lzma_index_coder *coder, const lzma_index *i)
|
173
|
+
{
|
174
|
+
lzma_index_iter_init(&coder->iter, i);
|
175
|
+
|
176
|
+
coder->sequence = SEQ_INDICATOR;
|
177
|
+
coder->index = i;
|
178
|
+
coder->pos = 0;
|
179
|
+
coder->crc32 = 0;
|
180
|
+
|
181
|
+
return;
|
182
|
+
}
|
183
|
+
|
184
|
+
|
185
|
+
extern lzma_ret
|
186
|
+
lzma_index_encoder_init(lzma_next_coder *next, const lzma_allocator *allocator,
|
187
|
+
const lzma_index *i)
|
188
|
+
{
|
189
|
+
lzma_next_coder_init(&lzma_index_encoder_init, next, allocator);
|
190
|
+
|
191
|
+
if (i == NULL)
|
192
|
+
return LZMA_PROG_ERROR;
|
193
|
+
|
194
|
+
if (next->coder == NULL) {
|
195
|
+
next->coder = lzma_alloc(sizeof(lzma_index_coder), allocator);
|
196
|
+
if (next->coder == NULL)
|
197
|
+
return LZMA_MEM_ERROR;
|
198
|
+
|
199
|
+
next->code = &index_encode;
|
200
|
+
next->end = &index_encoder_end;
|
201
|
+
}
|
202
|
+
|
203
|
+
index_encoder_reset(next->coder, i);
|
204
|
+
|
205
|
+
return LZMA_OK;
|
206
|
+
}
|
207
|
+
|
208
|
+
|
209
|
+
extern LZMA_API(lzma_ret)
|
210
|
+
lzma_index_encoder(lzma_stream *strm, const lzma_index *i)
|
211
|
+
{
|
212
|
+
lzma_next_strm_init(lzma_index_encoder_init, strm, i);
|
213
|
+
|
214
|
+
strm->internal->supported_actions[LZMA_RUN] = true;
|
215
|
+
strm->internal->supported_actions[LZMA_FINISH] = true;
|
216
|
+
|
217
|
+
return LZMA_OK;
|
218
|
+
}
|
219
|
+
|
220
|
+
|
221
|
+
extern LZMA_API(lzma_ret)
|
222
|
+
lzma_index_buffer_encode(const lzma_index *i,
|
223
|
+
uint8_t *out, size_t *out_pos, size_t out_size)
|
224
|
+
{
|
225
|
+
// Validate the arguments.
|
226
|
+
if (i == NULL || out == NULL || out_pos == NULL || *out_pos > out_size)
|
227
|
+
return LZMA_PROG_ERROR;
|
228
|
+
|
229
|
+
// Don't try to encode if there's not enough output space.
|
230
|
+
if (out_size - *out_pos < lzma_index_size(i))
|
231
|
+
return LZMA_BUF_ERROR;
|
232
|
+
|
233
|
+
// The Index encoder needs just one small data structure so we can
|
234
|
+
// allocate it on stack.
|
235
|
+
lzma_index_coder coder;
|
236
|
+
index_encoder_reset(&coder, i);
|
237
|
+
|
238
|
+
// Do the actual encoding. This should never fail, but store
|
239
|
+
// the original *out_pos just in case.
|
240
|
+
const size_t out_start = *out_pos;
|
241
|
+
lzma_ret ret = index_encode(&coder, NULL, NULL, NULL, 0,
|
242
|
+
out, out_pos, out_size, LZMA_RUN);
|
243
|
+
|
244
|
+
if (ret == LZMA_STREAM_END) {
|
245
|
+
ret = LZMA_OK;
|
246
|
+
} else {
|
247
|
+
// We should never get here, but just in case, restore the
|
248
|
+
// output position and set the error accordingly if something
|
249
|
+
// goes wrong and debugging isn't enabled.
|
250
|
+
assert(0);
|
251
|
+
*out_pos = out_start;
|
252
|
+
ret = LZMA_PROG_ERROR;
|
253
|
+
}
|
254
|
+
|
255
|
+
return ret;
|
256
|
+
}
|