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,19 @@
|
|
1
|
+
#
|
2
|
+
# Author: Lasse Collin
|
3
|
+
#
|
4
|
+
# This file has been put into the public domain.
|
5
|
+
# You can do whatever you want with this file.
|
6
|
+
#
|
7
|
+
|
8
|
+
prefix=@prefix@
|
9
|
+
exec_prefix=@exec_prefix@
|
10
|
+
libdir=@libdir@
|
11
|
+
includedir=@includedir@
|
12
|
+
|
13
|
+
Name: liblzma
|
14
|
+
Description: General purpose data compression library
|
15
|
+
URL: @PACKAGE_URL@
|
16
|
+
Version: @PACKAGE_VERSION@
|
17
|
+
Cflags: -I${includedir}
|
18
|
+
Libs: -L${libdir} -llzma
|
19
|
+
Libs.private: @PTHREAD_CFLAGS@ @LIBS@
|
@@ -0,0 +1,12 @@
|
|
1
|
+
/*
|
2
|
+
* Author: Lasse Collin
|
3
|
+
*
|
4
|
+
* This file has been put into the public domain.
|
5
|
+
* You can do whatever you want with this file.
|
6
|
+
*/
|
7
|
+
|
8
|
+
#define MY_TYPE VFT_DLL
|
9
|
+
#define MY_NAME "liblzma"
|
10
|
+
#define MY_SUFFIX ".dll"
|
11
|
+
#define MY_DESC "liblzma data compression library"
|
12
|
+
#include "common_w32res.rc"
|
@@ -0,0 +1,22 @@
|
|
1
|
+
##
|
2
|
+
## Author: Lasse Collin
|
3
|
+
##
|
4
|
+
## This file has been put into the public domain.
|
5
|
+
## You can do whatever you want with this file.
|
6
|
+
##
|
7
|
+
|
8
|
+
if COND_ENCODER_LZ
|
9
|
+
liblzma_la_SOURCES += \
|
10
|
+
lz/lz_encoder.c \
|
11
|
+
lz/lz_encoder.h \
|
12
|
+
lz/lz_encoder_hash.h \
|
13
|
+
lz/lz_encoder_hash_table.h \
|
14
|
+
lz/lz_encoder_mf.c
|
15
|
+
endif
|
16
|
+
|
17
|
+
|
18
|
+
if COND_DECODER_LZ
|
19
|
+
liblzma_la_SOURCES += \
|
20
|
+
lz/lz_decoder.c \
|
21
|
+
lz/lz_decoder.h
|
22
|
+
endif
|
@@ -0,0 +1,306 @@
|
|
1
|
+
///////////////////////////////////////////////////////////////////////////////
|
2
|
+
//
|
3
|
+
/// \file lz_decoder.c
|
4
|
+
/// \brief LZ out window
|
5
|
+
///
|
6
|
+
// Authors: Igor Pavlov
|
7
|
+
// Lasse Collin
|
8
|
+
//
|
9
|
+
// This file has been put into the public domain.
|
10
|
+
// You can do whatever you want with this file.
|
11
|
+
//
|
12
|
+
///////////////////////////////////////////////////////////////////////////////
|
13
|
+
|
14
|
+
// liblzma supports multiple LZ77-based filters. The LZ part is shared
|
15
|
+
// between these filters. The LZ code takes care of dictionary handling
|
16
|
+
// and passing the data between filters in the chain. The filter-specific
|
17
|
+
// part decodes from the input buffer to the dictionary.
|
18
|
+
|
19
|
+
|
20
|
+
#include "lz_decoder.h"
|
21
|
+
|
22
|
+
|
23
|
+
typedef struct {
|
24
|
+
/// Dictionary (history buffer)
|
25
|
+
lzma_dict dict;
|
26
|
+
|
27
|
+
/// The actual LZ-based decoder e.g. LZMA
|
28
|
+
lzma_lz_decoder lz;
|
29
|
+
|
30
|
+
/// Next filter in the chain, if any. Note that LZMA and LZMA2 are
|
31
|
+
/// only allowed as the last filter, but the long-range filter in
|
32
|
+
/// future can be in the middle of the chain.
|
33
|
+
lzma_next_coder next;
|
34
|
+
|
35
|
+
/// True if the next filter in the chain has returned LZMA_STREAM_END.
|
36
|
+
bool next_finished;
|
37
|
+
|
38
|
+
/// True if the LZ decoder (e.g. LZMA) has detected end of payload
|
39
|
+
/// marker. This may become true before next_finished becomes true.
|
40
|
+
bool this_finished;
|
41
|
+
|
42
|
+
/// Temporary buffer needed when the LZ-based filter is not the last
|
43
|
+
/// filter in the chain. The output of the next filter is first
|
44
|
+
/// decoded into buffer[], which is then used as input for the actual
|
45
|
+
/// LZ-based decoder.
|
46
|
+
struct {
|
47
|
+
size_t pos;
|
48
|
+
size_t size;
|
49
|
+
uint8_t buffer[LZMA_BUFFER_SIZE];
|
50
|
+
} temp;
|
51
|
+
} lzma_coder;
|
52
|
+
|
53
|
+
|
54
|
+
static void
|
55
|
+
lz_decoder_reset(lzma_coder *coder)
|
56
|
+
{
|
57
|
+
coder->dict.pos = 0;
|
58
|
+
coder->dict.full = 0;
|
59
|
+
coder->dict.buf[coder->dict.size - 1] = '\0';
|
60
|
+
coder->dict.need_reset = false;
|
61
|
+
return;
|
62
|
+
}
|
63
|
+
|
64
|
+
|
65
|
+
static lzma_ret
|
66
|
+
decode_buffer(lzma_coder *coder,
|
67
|
+
const uint8_t *restrict in, size_t *restrict in_pos,
|
68
|
+
size_t in_size, uint8_t *restrict out,
|
69
|
+
size_t *restrict out_pos, size_t out_size)
|
70
|
+
{
|
71
|
+
while (true) {
|
72
|
+
// Wrap the dictionary if needed.
|
73
|
+
if (coder->dict.pos == coder->dict.size)
|
74
|
+
coder->dict.pos = 0;
|
75
|
+
|
76
|
+
// Store the current dictionary position. It is needed to know
|
77
|
+
// where to start copying to the out[] buffer.
|
78
|
+
const size_t dict_start = coder->dict.pos;
|
79
|
+
|
80
|
+
// Calculate how much we allow coder->lz.code() to decode.
|
81
|
+
// It must not decode past the end of the dictionary
|
82
|
+
// buffer, and we don't want it to decode more than is
|
83
|
+
// actually needed to fill the out[] buffer.
|
84
|
+
coder->dict.limit = coder->dict.pos
|
85
|
+
+ my_min(out_size - *out_pos,
|
86
|
+
coder->dict.size - coder->dict.pos);
|
87
|
+
|
88
|
+
// Call the coder->lz.code() to do the actual decoding.
|
89
|
+
const lzma_ret ret = coder->lz.code(
|
90
|
+
coder->lz.coder, &coder->dict,
|
91
|
+
in, in_pos, in_size);
|
92
|
+
|
93
|
+
// Copy the decoded data from the dictionary to the out[]
|
94
|
+
// buffer.
|
95
|
+
const size_t copy_size = coder->dict.pos - dict_start;
|
96
|
+
assert(copy_size <= out_size - *out_pos);
|
97
|
+
memcpy(out + *out_pos, coder->dict.buf + dict_start,
|
98
|
+
copy_size);
|
99
|
+
*out_pos += copy_size;
|
100
|
+
|
101
|
+
// Reset the dictionary if so requested by coder->lz.code().
|
102
|
+
if (coder->dict.need_reset) {
|
103
|
+
lz_decoder_reset(coder);
|
104
|
+
|
105
|
+
// Since we reset dictionary, we don't check if
|
106
|
+
// dictionary became full.
|
107
|
+
if (ret != LZMA_OK || *out_pos == out_size)
|
108
|
+
return ret;
|
109
|
+
} else {
|
110
|
+
// Return if everything got decoded or an error
|
111
|
+
// occurred, or if there's no more data to decode.
|
112
|
+
//
|
113
|
+
// Note that detecting if there's something to decode
|
114
|
+
// is done by looking if dictionary become full
|
115
|
+
// instead of looking if *in_pos == in_size. This
|
116
|
+
// is because it is possible that all the input was
|
117
|
+
// consumed already but some data is pending to be
|
118
|
+
// written to the dictionary.
|
119
|
+
if (ret != LZMA_OK || *out_pos == out_size
|
120
|
+
|| coder->dict.pos < coder->dict.size)
|
121
|
+
return ret;
|
122
|
+
}
|
123
|
+
}
|
124
|
+
}
|
125
|
+
|
126
|
+
|
127
|
+
static lzma_ret
|
128
|
+
lz_decode(void *coder_ptr,
|
129
|
+
const lzma_allocator *allocator lzma_attribute((__unused__)),
|
130
|
+
const uint8_t *restrict in, size_t *restrict in_pos,
|
131
|
+
size_t in_size, uint8_t *restrict out,
|
132
|
+
size_t *restrict out_pos, size_t out_size,
|
133
|
+
lzma_action action)
|
134
|
+
{
|
135
|
+
lzma_coder *coder = coder_ptr;
|
136
|
+
|
137
|
+
if (coder->next.code == NULL)
|
138
|
+
return decode_buffer(coder, in, in_pos, in_size,
|
139
|
+
out, out_pos, out_size);
|
140
|
+
|
141
|
+
// We aren't the last coder in the chain, we need to decode
|
142
|
+
// our input to a temporary buffer.
|
143
|
+
while (*out_pos < out_size) {
|
144
|
+
// Fill the temporary buffer if it is empty.
|
145
|
+
if (!coder->next_finished
|
146
|
+
&& coder->temp.pos == coder->temp.size) {
|
147
|
+
coder->temp.pos = 0;
|
148
|
+
coder->temp.size = 0;
|
149
|
+
|
150
|
+
const lzma_ret ret = coder->next.code(
|
151
|
+
coder->next.coder,
|
152
|
+
allocator, in, in_pos, in_size,
|
153
|
+
coder->temp.buffer, &coder->temp.size,
|
154
|
+
LZMA_BUFFER_SIZE, action);
|
155
|
+
|
156
|
+
if (ret == LZMA_STREAM_END)
|
157
|
+
coder->next_finished = true;
|
158
|
+
else if (ret != LZMA_OK || coder->temp.size == 0)
|
159
|
+
return ret;
|
160
|
+
}
|
161
|
+
|
162
|
+
if (coder->this_finished) {
|
163
|
+
if (coder->temp.size != 0)
|
164
|
+
return LZMA_DATA_ERROR;
|
165
|
+
|
166
|
+
if (coder->next_finished)
|
167
|
+
return LZMA_STREAM_END;
|
168
|
+
|
169
|
+
return LZMA_OK;
|
170
|
+
}
|
171
|
+
|
172
|
+
const lzma_ret ret = decode_buffer(coder, coder->temp.buffer,
|
173
|
+
&coder->temp.pos, coder->temp.size,
|
174
|
+
out, out_pos, out_size);
|
175
|
+
|
176
|
+
if (ret == LZMA_STREAM_END)
|
177
|
+
coder->this_finished = true;
|
178
|
+
else if (ret != LZMA_OK)
|
179
|
+
return ret;
|
180
|
+
else if (coder->next_finished && *out_pos < out_size)
|
181
|
+
return LZMA_DATA_ERROR;
|
182
|
+
}
|
183
|
+
|
184
|
+
return LZMA_OK;
|
185
|
+
}
|
186
|
+
|
187
|
+
|
188
|
+
static void
|
189
|
+
lz_decoder_end(void *coder_ptr, const lzma_allocator *allocator)
|
190
|
+
{
|
191
|
+
lzma_coder *coder = coder_ptr;
|
192
|
+
|
193
|
+
lzma_next_end(&coder->next, allocator);
|
194
|
+
lzma_free(coder->dict.buf, allocator);
|
195
|
+
|
196
|
+
if (coder->lz.end != NULL)
|
197
|
+
coder->lz.end(coder->lz.coder, allocator);
|
198
|
+
else
|
199
|
+
lzma_free(coder->lz.coder, allocator);
|
200
|
+
|
201
|
+
lzma_free(coder, allocator);
|
202
|
+
return;
|
203
|
+
}
|
204
|
+
|
205
|
+
|
206
|
+
extern lzma_ret
|
207
|
+
lzma_lz_decoder_init(lzma_next_coder *next, const lzma_allocator *allocator,
|
208
|
+
const lzma_filter_info *filters,
|
209
|
+
lzma_ret (*lz_init)(lzma_lz_decoder *lz,
|
210
|
+
const lzma_allocator *allocator, const void *options,
|
211
|
+
lzma_lz_options *lz_options))
|
212
|
+
{
|
213
|
+
// Allocate the base structure if it isn't already allocated.
|
214
|
+
lzma_coder *coder = next->coder;
|
215
|
+
if (coder == NULL) {
|
216
|
+
coder = lzma_alloc(sizeof(lzma_coder), allocator);
|
217
|
+
if (coder == NULL)
|
218
|
+
return LZMA_MEM_ERROR;
|
219
|
+
|
220
|
+
next->coder = coder;
|
221
|
+
next->code = &lz_decode;
|
222
|
+
next->end = &lz_decoder_end;
|
223
|
+
|
224
|
+
coder->dict.buf = NULL;
|
225
|
+
coder->dict.size = 0;
|
226
|
+
coder->lz = LZMA_LZ_DECODER_INIT;
|
227
|
+
coder->next = LZMA_NEXT_CODER_INIT;
|
228
|
+
}
|
229
|
+
|
230
|
+
// Allocate and initialize the LZ-based decoder. It will also give
|
231
|
+
// us the dictionary size.
|
232
|
+
lzma_lz_options lz_options;
|
233
|
+
return_if_error(lz_init(&coder->lz, allocator,
|
234
|
+
filters[0].options, &lz_options));
|
235
|
+
|
236
|
+
// If the dictionary size is very small, increase it to 4096 bytes.
|
237
|
+
// This is to prevent constant wrapping of the dictionary, which
|
238
|
+
// would slow things down. The downside is that since we don't check
|
239
|
+
// separately for the real dictionary size, we may happily accept
|
240
|
+
// corrupt files.
|
241
|
+
if (lz_options.dict_size < 4096)
|
242
|
+
lz_options.dict_size = 4096;
|
243
|
+
|
244
|
+
// Make dictionary size a multipe of 16. Some LZ-based decoders like
|
245
|
+
// LZMA use the lowest bits lzma_dict.pos to know the alignment of the
|
246
|
+
// data. Aligned buffer is also good when memcpying from the
|
247
|
+
// dictionary to the output buffer, since applications are
|
248
|
+
// recommended to give aligned buffers to liblzma.
|
249
|
+
//
|
250
|
+
// Avoid integer overflow.
|
251
|
+
if (lz_options.dict_size > SIZE_MAX - 15)
|
252
|
+
return LZMA_MEM_ERROR;
|
253
|
+
|
254
|
+
lz_options.dict_size = (lz_options.dict_size + 15) & ~((size_t)(15));
|
255
|
+
|
256
|
+
// Allocate and initialize the dictionary.
|
257
|
+
if (coder->dict.size != lz_options.dict_size) {
|
258
|
+
lzma_free(coder->dict.buf, allocator);
|
259
|
+
coder->dict.buf
|
260
|
+
= lzma_alloc(lz_options.dict_size, allocator);
|
261
|
+
if (coder->dict.buf == NULL)
|
262
|
+
return LZMA_MEM_ERROR;
|
263
|
+
|
264
|
+
coder->dict.size = lz_options.dict_size;
|
265
|
+
}
|
266
|
+
|
267
|
+
lz_decoder_reset(next->coder);
|
268
|
+
|
269
|
+
// Use the preset dictionary if it was given to us.
|
270
|
+
if (lz_options.preset_dict != NULL
|
271
|
+
&& lz_options.preset_dict_size > 0) {
|
272
|
+
// If the preset dictionary is bigger than the actual
|
273
|
+
// dictionary, copy only the tail.
|
274
|
+
const size_t copy_size = my_min(lz_options.preset_dict_size,
|
275
|
+
lz_options.dict_size);
|
276
|
+
const size_t offset = lz_options.preset_dict_size - copy_size;
|
277
|
+
memcpy(coder->dict.buf, lz_options.preset_dict + offset,
|
278
|
+
copy_size);
|
279
|
+
coder->dict.pos = copy_size;
|
280
|
+
coder->dict.full = copy_size;
|
281
|
+
}
|
282
|
+
|
283
|
+
// Miscellaneous initializations
|
284
|
+
coder->next_finished = false;
|
285
|
+
coder->this_finished = false;
|
286
|
+
coder->temp.pos = 0;
|
287
|
+
coder->temp.size = 0;
|
288
|
+
|
289
|
+
// Initialize the next filter in the chain, if any.
|
290
|
+
return lzma_next_filter_init(&coder->next, allocator, filters + 1);
|
291
|
+
}
|
292
|
+
|
293
|
+
|
294
|
+
extern uint64_t
|
295
|
+
lzma_lz_decoder_memusage(size_t dictionary_size)
|
296
|
+
{
|
297
|
+
return sizeof(lzma_coder) + (uint64_t)(dictionary_size);
|
298
|
+
}
|
299
|
+
|
300
|
+
|
301
|
+
extern void
|
302
|
+
lzma_lz_decoder_uncompressed(void *coder_ptr, lzma_vli uncompressed_size)
|
303
|
+
{
|
304
|
+
lzma_coder *coder = coder_ptr;
|
305
|
+
coder->lz.set_uncompressed(coder->lz.coder, uncompressed_size);
|
306
|
+
}
|
@@ -0,0 +1,234 @@
|
|
1
|
+
///////////////////////////////////////////////////////////////////////////////
|
2
|
+
//
|
3
|
+
/// \file lz_decoder.h
|
4
|
+
/// \brief LZ out window
|
5
|
+
///
|
6
|
+
// Authors: Igor Pavlov
|
7
|
+
// Lasse Collin
|
8
|
+
//
|
9
|
+
// This file has been put into the public domain.
|
10
|
+
// You can do whatever you want with this file.
|
11
|
+
//
|
12
|
+
///////////////////////////////////////////////////////////////////////////////
|
13
|
+
|
14
|
+
#ifndef LZMA_LZ_DECODER_H
|
15
|
+
#define LZMA_LZ_DECODER_H
|
16
|
+
|
17
|
+
#include "common.h"
|
18
|
+
|
19
|
+
|
20
|
+
typedef struct {
|
21
|
+
/// Pointer to the dictionary buffer. It can be an allocated buffer
|
22
|
+
/// internal to liblzma, or it can a be a buffer given by the
|
23
|
+
/// application when in single-call mode (not implemented yet).
|
24
|
+
uint8_t *buf;
|
25
|
+
|
26
|
+
/// Write position in dictionary. The next byte will be written to
|
27
|
+
/// buf[pos].
|
28
|
+
size_t pos;
|
29
|
+
|
30
|
+
/// Indicates how full the dictionary is. This is used by
|
31
|
+
/// dict_is_distance_valid() to detect corrupt files that would
|
32
|
+
/// read beyond the beginning of the dictionary.
|
33
|
+
size_t full;
|
34
|
+
|
35
|
+
/// Write limit
|
36
|
+
size_t limit;
|
37
|
+
|
38
|
+
/// Size of the dictionary
|
39
|
+
size_t size;
|
40
|
+
|
41
|
+
/// True when dictionary should be reset before decoding more data.
|
42
|
+
bool need_reset;
|
43
|
+
|
44
|
+
} lzma_dict;
|
45
|
+
|
46
|
+
|
47
|
+
typedef struct {
|
48
|
+
size_t dict_size;
|
49
|
+
const uint8_t *preset_dict;
|
50
|
+
size_t preset_dict_size;
|
51
|
+
} lzma_lz_options;
|
52
|
+
|
53
|
+
|
54
|
+
typedef struct {
|
55
|
+
/// Data specific to the LZ-based decoder
|
56
|
+
void *coder;
|
57
|
+
|
58
|
+
/// Function to decode from in[] to *dict
|
59
|
+
lzma_ret (*code)(void *coder,
|
60
|
+
lzma_dict *restrict dict, const uint8_t *restrict in,
|
61
|
+
size_t *restrict in_pos, size_t in_size);
|
62
|
+
|
63
|
+
void (*reset)(void *coder, const void *options);
|
64
|
+
|
65
|
+
/// Set the uncompressed size
|
66
|
+
void (*set_uncompressed)(void *coder, lzma_vli uncompressed_size);
|
67
|
+
|
68
|
+
/// Free allocated resources
|
69
|
+
void (*end)(void *coder, const lzma_allocator *allocator);
|
70
|
+
|
71
|
+
} lzma_lz_decoder;
|
72
|
+
|
73
|
+
|
74
|
+
#define LZMA_LZ_DECODER_INIT \
|
75
|
+
(lzma_lz_decoder){ \
|
76
|
+
.coder = NULL, \
|
77
|
+
.code = NULL, \
|
78
|
+
.reset = NULL, \
|
79
|
+
.set_uncompressed = NULL, \
|
80
|
+
.end = NULL, \
|
81
|
+
}
|
82
|
+
|
83
|
+
|
84
|
+
extern lzma_ret lzma_lz_decoder_init(lzma_next_coder *next,
|
85
|
+
const lzma_allocator *allocator,
|
86
|
+
const lzma_filter_info *filters,
|
87
|
+
lzma_ret (*lz_init)(lzma_lz_decoder *lz,
|
88
|
+
const lzma_allocator *allocator, const void *options,
|
89
|
+
lzma_lz_options *lz_options));
|
90
|
+
|
91
|
+
extern uint64_t lzma_lz_decoder_memusage(size_t dictionary_size);
|
92
|
+
|
93
|
+
extern void lzma_lz_decoder_uncompressed(
|
94
|
+
void *coder, lzma_vli uncompressed_size);
|
95
|
+
|
96
|
+
|
97
|
+
//////////////////////
|
98
|
+
// Inline functions //
|
99
|
+
//////////////////////
|
100
|
+
|
101
|
+
/// Get a byte from the history buffer.
|
102
|
+
static inline uint8_t
|
103
|
+
dict_get(const lzma_dict *const dict, const uint32_t distance)
|
104
|
+
{
|
105
|
+
return dict->buf[dict->pos - distance - 1
|
106
|
+
+ (distance < dict->pos ? 0 : dict->size)];
|
107
|
+
}
|
108
|
+
|
109
|
+
|
110
|
+
/// Test if dictionary is empty.
|
111
|
+
static inline bool
|
112
|
+
dict_is_empty(const lzma_dict *const dict)
|
113
|
+
{
|
114
|
+
return dict->full == 0;
|
115
|
+
}
|
116
|
+
|
117
|
+
|
118
|
+
/// Validate the match distance
|
119
|
+
static inline bool
|
120
|
+
dict_is_distance_valid(const lzma_dict *const dict, const size_t distance)
|
121
|
+
{
|
122
|
+
return dict->full > distance;
|
123
|
+
}
|
124
|
+
|
125
|
+
|
126
|
+
/// Repeat *len bytes at distance.
|
127
|
+
static inline bool
|
128
|
+
dict_repeat(lzma_dict *dict, uint32_t distance, uint32_t *len)
|
129
|
+
{
|
130
|
+
// Don't write past the end of the dictionary.
|
131
|
+
const size_t dict_avail = dict->limit - dict->pos;
|
132
|
+
uint32_t left = my_min(dict_avail, *len);
|
133
|
+
*len -= left;
|
134
|
+
|
135
|
+
// Repeat a block of data from the history. Because memcpy() is faster
|
136
|
+
// than copying byte by byte in a loop, the copying process gets split
|
137
|
+
// into three cases.
|
138
|
+
if (distance < left) {
|
139
|
+
// Source and target areas overlap, thus we can't use
|
140
|
+
// memcpy() nor even memmove() safely.
|
141
|
+
do {
|
142
|
+
dict->buf[dict->pos] = dict_get(dict, distance);
|
143
|
+
++dict->pos;
|
144
|
+
} while (--left > 0);
|
145
|
+
|
146
|
+
} else if (distance < dict->pos) {
|
147
|
+
// The easiest and fastest case
|
148
|
+
memcpy(dict->buf + dict->pos,
|
149
|
+
dict->buf + dict->pos - distance - 1,
|
150
|
+
left);
|
151
|
+
dict->pos += left;
|
152
|
+
|
153
|
+
} else {
|
154
|
+
// The bigger the dictionary, the more rare this
|
155
|
+
// case occurs. We need to "wrap" the dict, thus
|
156
|
+
// we might need two memcpy() to copy all the data.
|
157
|
+
assert(dict->full == dict->size);
|
158
|
+
const uint32_t copy_pos
|
159
|
+
= dict->pos - distance - 1 + dict->size;
|
160
|
+
uint32_t copy_size = dict->size - copy_pos;
|
161
|
+
|
162
|
+
if (copy_size < left) {
|
163
|
+
memmove(dict->buf + dict->pos, dict->buf + copy_pos,
|
164
|
+
copy_size);
|
165
|
+
dict->pos += copy_size;
|
166
|
+
copy_size = left - copy_size;
|
167
|
+
memcpy(dict->buf + dict->pos, dict->buf, copy_size);
|
168
|
+
dict->pos += copy_size;
|
169
|
+
} else {
|
170
|
+
memmove(dict->buf + dict->pos, dict->buf + copy_pos,
|
171
|
+
left);
|
172
|
+
dict->pos += left;
|
173
|
+
}
|
174
|
+
}
|
175
|
+
|
176
|
+
// Update how full the dictionary is.
|
177
|
+
if (dict->full < dict->pos)
|
178
|
+
dict->full = dict->pos;
|
179
|
+
|
180
|
+
return unlikely(*len != 0);
|
181
|
+
}
|
182
|
+
|
183
|
+
|
184
|
+
/// Puts one byte into the dictionary. Returns true if the dictionary was
|
185
|
+
/// already full and the byte couldn't be added.
|
186
|
+
static inline bool
|
187
|
+
dict_put(lzma_dict *dict, uint8_t byte)
|
188
|
+
{
|
189
|
+
if (unlikely(dict->pos == dict->limit))
|
190
|
+
return true;
|
191
|
+
|
192
|
+
dict->buf[dict->pos++] = byte;
|
193
|
+
|
194
|
+
if (dict->pos > dict->full)
|
195
|
+
dict->full = dict->pos;
|
196
|
+
|
197
|
+
return false;
|
198
|
+
}
|
199
|
+
|
200
|
+
|
201
|
+
/// Copies arbitrary amount of data into the dictionary.
|
202
|
+
static inline void
|
203
|
+
dict_write(lzma_dict *restrict dict, const uint8_t *restrict in,
|
204
|
+
size_t *restrict in_pos, size_t in_size,
|
205
|
+
size_t *restrict left)
|
206
|
+
{
|
207
|
+
// NOTE: If we are being given more data than the size of the
|
208
|
+
// dictionary, it could be possible to optimize the LZ decoder
|
209
|
+
// so that not everything needs to go through the dictionary.
|
210
|
+
// This shouldn't be very common thing in practice though, and
|
211
|
+
// the slowdown of one extra memcpy() isn't bad compared to how
|
212
|
+
// much time it would have taken if the data were compressed.
|
213
|
+
|
214
|
+
if (in_size - *in_pos > *left)
|
215
|
+
in_size = *in_pos + *left;
|
216
|
+
|
217
|
+
*left -= lzma_bufcpy(in, in_pos, in_size,
|
218
|
+
dict->buf, &dict->pos, dict->limit);
|
219
|
+
|
220
|
+
if (dict->pos > dict->full)
|
221
|
+
dict->full = dict->pos;
|
222
|
+
|
223
|
+
return;
|
224
|
+
}
|
225
|
+
|
226
|
+
|
227
|
+
static inline void
|
228
|
+
dict_reset(lzma_dict *dict)
|
229
|
+
{
|
230
|
+
dict->need_reset = true;
|
231
|
+
return;
|
232
|
+
}
|
233
|
+
|
234
|
+
#endif
|