laag-xz 5.2.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (393) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +57 -0
  3. data/LICENSE.txt +65 -0
  4. data/README.org +34 -0
  5. data/ext/laag/xz/extconf.rb +21 -0
  6. data/laag-xz.gemspec +20 -0
  7. data/lib/laag/xz.rb +29 -0
  8. data/vendor/git.tukaani.org/xz/.gitignore +66 -0
  9. data/vendor/git.tukaani.org/xz/AUTHORS +27 -0
  10. data/vendor/git.tukaani.org/xz/COPYING +65 -0
  11. data/vendor/git.tukaani.org/xz/COPYING.GPLv2 +339 -0
  12. data/vendor/git.tukaani.org/xz/COPYING.GPLv3 +674 -0
  13. data/vendor/git.tukaani.org/xz/COPYING.LGPLv2.1 +502 -0
  14. data/vendor/git.tukaani.org/xz/ChangeLog +7 -0
  15. data/vendor/git.tukaani.org/xz/Doxyfile.in +1234 -0
  16. data/vendor/git.tukaani.org/xz/INSTALL +618 -0
  17. data/vendor/git.tukaani.org/xz/INSTALL.generic +365 -0
  18. data/vendor/git.tukaani.org/xz/Makefile.am +110 -0
  19. data/vendor/git.tukaani.org/xz/NEWS +571 -0
  20. data/vendor/git.tukaani.org/xz/PACKAGERS +231 -0
  21. data/vendor/git.tukaani.org/xz/README +308 -0
  22. data/vendor/git.tukaani.org/xz/THANKS +124 -0
  23. data/vendor/git.tukaani.org/xz/TODO +111 -0
  24. data/vendor/git.tukaani.org/xz/autogen.sh +22 -0
  25. data/vendor/git.tukaani.org/xz/build-aux/manconv.sh +58 -0
  26. data/vendor/git.tukaani.org/xz/build-aux/version.sh +24 -0
  27. data/vendor/git.tukaani.org/xz/configure.ac +900 -0
  28. data/vendor/git.tukaani.org/xz/debug/Makefile.am +30 -0
  29. data/vendor/git.tukaani.org/xz/debug/README +17 -0
  30. data/vendor/git.tukaani.org/xz/debug/crc32.c +39 -0
  31. data/vendor/git.tukaani.org/xz/debug/full_flush.c +103 -0
  32. data/vendor/git.tukaani.org/xz/debug/hex2bin.c +53 -0
  33. data/vendor/git.tukaani.org/xz/debug/known_sizes.c +129 -0
  34. data/vendor/git.tukaani.org/xz/debug/memusage.c +51 -0
  35. data/vendor/git.tukaani.org/xz/debug/repeat.c +36 -0
  36. data/vendor/git.tukaani.org/xz/debug/sync_flush.c +125 -0
  37. data/vendor/git.tukaani.org/xz/debug/translation.bash +100 -0
  38. data/vendor/git.tukaani.org/xz/doc/examples/00_README.txt +31 -0
  39. data/vendor/git.tukaani.org/xz/doc/examples/01_compress_easy.c +297 -0
  40. data/vendor/git.tukaani.org/xz/doc/examples/02_decompress.c +287 -0
  41. data/vendor/git.tukaani.org/xz/doc/examples/03_compress_custom.c +193 -0
  42. data/vendor/git.tukaani.org/xz/doc/examples/04_compress_easy_mt.c +206 -0
  43. data/vendor/git.tukaani.org/xz/doc/examples/Makefile +24 -0
  44. data/vendor/git.tukaani.org/xz/doc/examples_old/xz_pipe_comp.c +127 -0
  45. data/vendor/git.tukaani.org/xz/doc/examples_old/xz_pipe_decomp.c +123 -0
  46. data/vendor/git.tukaani.org/xz/doc/faq.txt +224 -0
  47. data/vendor/git.tukaani.org/xz/doc/history.txt +150 -0
  48. data/vendor/git.tukaani.org/xz/doc/lzma-file-format.txt +166 -0
  49. data/vendor/git.tukaani.org/xz/doc/xz-file-format.txt +1150 -0
  50. data/vendor/git.tukaani.org/xz/dos/INSTALL.txt +79 -0
  51. data/vendor/git.tukaani.org/xz/dos/Makefile +147 -0
  52. data/vendor/git.tukaani.org/xz/dos/README.txt +123 -0
  53. data/vendor/git.tukaani.org/xz/dos/config.h +136 -0
  54. data/vendor/git.tukaani.org/xz/extra/7z2lzma/7z2lzma.bash +115 -0
  55. data/vendor/git.tukaani.org/xz/extra/scanlzma/scanlzma.c +88 -0
  56. data/vendor/git.tukaani.org/xz/lib/Makefile.am +32 -0
  57. data/vendor/git.tukaani.org/xz/lib/getopt.c +1197 -0
  58. data/vendor/git.tukaani.org/xz/lib/getopt.in.h +226 -0
  59. data/vendor/git.tukaani.org/xz/lib/getopt1.c +171 -0
  60. data/vendor/git.tukaani.org/xz/lib/getopt_int.h +131 -0
  61. data/vendor/git.tukaani.org/xz/m4/.gitignore +38 -0
  62. data/vendor/git.tukaani.org/xz/m4/ax_check_capsicum.m4 +85 -0
  63. data/vendor/git.tukaani.org/xz/m4/ax_pthread.m4 +332 -0
  64. data/vendor/git.tukaani.org/xz/m4/getopt.m4 +71 -0
  65. data/vendor/git.tukaani.org/xz/m4/posix-shell.m4 +63 -0
  66. data/vendor/git.tukaani.org/xz/m4/tuklib_common.m4 +22 -0
  67. data/vendor/git.tukaani.org/xz/m4/tuklib_cpucores.m4 +176 -0
  68. data/vendor/git.tukaani.org/xz/m4/tuklib_integer.m4 +74 -0
  69. data/vendor/git.tukaani.org/xz/m4/tuklib_mbstr.m4 +30 -0
  70. data/vendor/git.tukaani.org/xz/m4/tuklib_physmem.m4 +212 -0
  71. data/vendor/git.tukaani.org/xz/m4/tuklib_progname.m4 +25 -0
  72. data/vendor/git.tukaani.org/xz/macosx/build.sh +113 -0
  73. data/vendor/git.tukaani.org/xz/po/.gitignore +31 -0
  74. data/vendor/git.tukaani.org/xz/po/LINGUAS +6 -0
  75. data/vendor/git.tukaani.org/xz/po/Makevars +46 -0
  76. data/vendor/git.tukaani.org/xz/po/POTFILES.in +13 -0
  77. data/vendor/git.tukaani.org/xz/po/cs.po +949 -0
  78. data/vendor/git.tukaani.org/xz/po/de.po +993 -0
  79. data/vendor/git.tukaani.org/xz/po/fr.po +978 -0
  80. data/vendor/git.tukaani.org/xz/po/it.po +1067 -0
  81. data/vendor/git.tukaani.org/xz/po/pl.po +968 -0
  82. data/vendor/git.tukaani.org/xz/po/vi.po +1039 -0
  83. data/vendor/git.tukaani.org/xz/src/Makefile.am +42 -0
  84. data/vendor/git.tukaani.org/xz/src/common/common_w32res.rc +50 -0
  85. data/vendor/git.tukaani.org/xz/src/common/mythread.h +521 -0
  86. data/vendor/git.tukaani.org/xz/src/common/sysdefs.h +202 -0
  87. data/vendor/git.tukaani.org/xz/src/common/tuklib_common.h +71 -0
  88. data/vendor/git.tukaani.org/xz/src/common/tuklib_config.h +7 -0
  89. data/vendor/git.tukaani.org/xz/src/common/tuklib_cpucores.c +100 -0
  90. data/vendor/git.tukaani.org/xz/src/common/tuklib_cpucores.h +23 -0
  91. data/vendor/git.tukaani.org/xz/src/common/tuklib_exit.c +57 -0
  92. data/vendor/git.tukaani.org/xz/src/common/tuklib_exit.h +25 -0
  93. data/vendor/git.tukaani.org/xz/src/common/tuklib_gettext.h +44 -0
  94. data/vendor/git.tukaani.org/xz/src/common/tuklib_integer.h +534 -0
  95. data/vendor/git.tukaani.org/xz/src/common/tuklib_mbstr.h +66 -0
  96. data/vendor/git.tukaani.org/xz/src/common/tuklib_mbstr_fw.c +31 -0
  97. data/vendor/git.tukaani.org/xz/src/common/tuklib_mbstr_width.c +64 -0
  98. data/vendor/git.tukaani.org/xz/src/common/tuklib_open_stdxxx.c +57 -0
  99. data/vendor/git.tukaani.org/xz/src/common/tuklib_open_stdxxx.h +23 -0
  100. data/vendor/git.tukaani.org/xz/src/common/tuklib_physmem.c +216 -0
  101. data/vendor/git.tukaani.org/xz/src/common/tuklib_physmem.h +28 -0
  102. data/vendor/git.tukaani.org/xz/src/common/tuklib_progname.c +50 -0
  103. data/vendor/git.tukaani.org/xz/src/common/tuklib_progname.h +32 -0
  104. data/vendor/git.tukaani.org/xz/src/liblzma/Makefile.am +122 -0
  105. data/vendor/git.tukaani.org/xz/src/liblzma/api/Makefile.am +23 -0
  106. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma.h +325 -0
  107. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/base.h +659 -0
  108. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/bcj.h +90 -0
  109. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/block.h +581 -0
  110. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/check.h +150 -0
  111. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/container.h +632 -0
  112. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/delta.h +77 -0
  113. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/filter.h +425 -0
  114. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/hardware.h +64 -0
  115. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/index.h +686 -0
  116. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/index_hash.h +107 -0
  117. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/lzma12.h +420 -0
  118. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/stream_flags.h +223 -0
  119. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/version.h +121 -0
  120. data/vendor/git.tukaani.org/xz/src/liblzma/api/lzma/vli.h +166 -0
  121. data/vendor/git.tukaani.org/xz/src/liblzma/check/Makefile.inc +53 -0
  122. data/vendor/git.tukaani.org/xz/src/liblzma/check/check.c +174 -0
  123. data/vendor/git.tukaani.org/xz/src/liblzma/check/check.h +172 -0
  124. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_fast.c +82 -0
  125. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_small.c +61 -0
  126. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_table.c +19 -0
  127. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_table_be.h +525 -0
  128. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_table_le.h +525 -0
  129. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_tablegen.c +117 -0
  130. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc32_x86.S +304 -0
  131. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_fast.c +72 -0
  132. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_small.c +53 -0
  133. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_table.c +19 -0
  134. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_table_be.h +521 -0
  135. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_table_le.h +521 -0
  136. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_tablegen.c +88 -0
  137. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc64_x86.S +287 -0
  138. data/vendor/git.tukaani.org/xz/src/liblzma/check/crc_macros.h +30 -0
  139. data/vendor/git.tukaani.org/xz/src/liblzma/check/sha256.c +196 -0
  140. data/vendor/git.tukaani.org/xz/src/liblzma/common/Makefile.inc +79 -0
  141. data/vendor/git.tukaani.org/xz/src/liblzma/common/alone_decoder.c +243 -0
  142. data/vendor/git.tukaani.org/xz/src/liblzma/common/alone_decoder.h +23 -0
  143. data/vendor/git.tukaani.org/xz/src/liblzma/common/alone_encoder.c +163 -0
  144. data/vendor/git.tukaani.org/xz/src/liblzma/common/auto_decoder.c +195 -0
  145. data/vendor/git.tukaani.org/xz/src/liblzma/common/block_buffer_decoder.c +80 -0
  146. data/vendor/git.tukaani.org/xz/src/liblzma/common/block_buffer_encoder.c +337 -0
  147. data/vendor/git.tukaani.org/xz/src/liblzma/common/block_buffer_encoder.h +24 -0
  148. data/vendor/git.tukaani.org/xz/src/liblzma/common/block_decoder.c +257 -0
  149. data/vendor/git.tukaani.org/xz/src/liblzma/common/block_decoder.h +22 -0
  150. data/vendor/git.tukaani.org/xz/src/liblzma/common/block_encoder.c +223 -0
  151. data/vendor/git.tukaani.org/xz/src/liblzma/common/block_encoder.h +47 -0
  152. data/vendor/git.tukaani.org/xz/src/liblzma/common/block_header_decoder.c +124 -0
  153. data/vendor/git.tukaani.org/xz/src/liblzma/common/block_header_encoder.c +132 -0
  154. data/vendor/git.tukaani.org/xz/src/liblzma/common/block_util.c +90 -0
  155. data/vendor/git.tukaani.org/xz/src/liblzma/common/common.c +445 -0
  156. data/vendor/git.tukaani.org/xz/src/liblzma/common/common.h +314 -0
  157. data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_buffer_encoder.c +27 -0
  158. data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_decoder_memusage.c +24 -0
  159. data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_encoder.c +24 -0
  160. data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_encoder_memusage.c +24 -0
  161. data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_preset.c +27 -0
  162. data/vendor/git.tukaani.org/xz/src/liblzma/common/easy_preset.h +32 -0
  163. data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_buffer_decoder.c +88 -0
  164. data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_buffer_encoder.c +55 -0
  165. data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_common.c +337 -0
  166. data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_common.h +48 -0
  167. data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_decoder.c +184 -0
  168. data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_decoder.h +23 -0
  169. data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_encoder.c +286 -0
  170. data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_encoder.h +27 -0
  171. data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_flags_decoder.c +46 -0
  172. data/vendor/git.tukaani.org/xz/src/liblzma/common/filter_flags_encoder.c +56 -0
  173. data/vendor/git.tukaani.org/xz/src/liblzma/common/hardware_cputhreads.c +22 -0
  174. data/vendor/git.tukaani.org/xz/src/liblzma/common/hardware_physmem.c +25 -0
  175. data/vendor/git.tukaani.org/xz/src/liblzma/common/index.c +1250 -0
  176. data/vendor/git.tukaani.org/xz/src/liblzma/common/index.h +73 -0
  177. data/vendor/git.tukaani.org/xz/src/liblzma/common/index_decoder.c +352 -0
  178. data/vendor/git.tukaani.org/xz/src/liblzma/common/index_encoder.c +256 -0
  179. data/vendor/git.tukaani.org/xz/src/liblzma/common/index_encoder.h +23 -0
  180. data/vendor/git.tukaani.org/xz/src/liblzma/common/index_hash.c +334 -0
  181. data/vendor/git.tukaani.org/xz/src/liblzma/common/memcmplen.h +175 -0
  182. data/vendor/git.tukaani.org/xz/src/liblzma/common/outqueue.c +184 -0
  183. data/vendor/git.tukaani.org/xz/src/liblzma/common/outqueue.h +156 -0
  184. data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_buffer_decoder.c +91 -0
  185. data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_buffer_encoder.c +141 -0
  186. data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_decoder.c +467 -0
  187. data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_decoder.h +22 -0
  188. data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_encoder.c +340 -0
  189. data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_encoder_mt.c +1143 -0
  190. data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_flags_common.c +47 -0
  191. data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_flags_common.h +33 -0
  192. data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_flags_decoder.c +82 -0
  193. data/vendor/git.tukaani.org/xz/src/liblzma/common/stream_flags_encoder.c +86 -0
  194. data/vendor/git.tukaani.org/xz/src/liblzma/common/vli_decoder.c +86 -0
  195. data/vendor/git.tukaani.org/xz/src/liblzma/common/vli_encoder.c +69 -0
  196. data/vendor/git.tukaani.org/xz/src/liblzma/common/vli_size.c +30 -0
  197. data/vendor/git.tukaani.org/xz/src/liblzma/delta/Makefile.inc +23 -0
  198. data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_common.c +73 -0
  199. data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_common.h +20 -0
  200. data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_decoder.c +78 -0
  201. data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_decoder.h +26 -0
  202. data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_encoder.c +125 -0
  203. data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_encoder.h +24 -0
  204. data/vendor/git.tukaani.org/xz/src/liblzma/delta/delta_private.h +37 -0
  205. data/vendor/git.tukaani.org/xz/src/liblzma/liblzma.map +108 -0
  206. data/vendor/git.tukaani.org/xz/src/liblzma/liblzma.pc.in +19 -0
  207. data/vendor/git.tukaani.org/xz/src/liblzma/liblzma_w32res.rc +12 -0
  208. data/vendor/git.tukaani.org/xz/src/liblzma/lz/Makefile.inc +22 -0
  209. data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_decoder.c +306 -0
  210. data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_decoder.h +234 -0
  211. data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_encoder.c +616 -0
  212. data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_encoder.h +327 -0
  213. data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_encoder_hash.h +108 -0
  214. data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_encoder_hash_table.h +68 -0
  215. data/vendor/git.tukaani.org/xz/src/liblzma/lz/lz_encoder_mf.c +744 -0
  216. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/Makefile.inc +47 -0
  217. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/fastpos.h +141 -0
  218. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/fastpos_table.c +519 -0
  219. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/fastpos_tablegen.c +56 -0
  220. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma2_decoder.c +310 -0
  221. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma2_decoder.h +29 -0
  222. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma2_encoder.c +410 -0
  223. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma2_encoder.h +43 -0
  224. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_common.h +224 -0
  225. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_decoder.c +1064 -0
  226. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_decoder.h +53 -0
  227. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder.c +677 -0
  228. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder.h +58 -0
  229. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder_optimum_fast.c +170 -0
  230. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder_optimum_normal.c +855 -0
  231. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder_presets.c +64 -0
  232. data/vendor/git.tukaani.org/xz/src/liblzma/lzma/lzma_encoder_private.h +148 -0
  233. data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/Makefile.inc +21 -0
  234. data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/price.h +92 -0
  235. data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/price_table.c +22 -0
  236. data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/price_tablegen.c +87 -0
  237. data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/range_common.h +71 -0
  238. data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/range_decoder.h +185 -0
  239. data/vendor/git.tukaani.org/xz/src/liblzma/rangecoder/range_encoder.h +231 -0
  240. data/vendor/git.tukaani.org/xz/src/liblzma/simple/Makefile.inc +47 -0
  241. data/vendor/git.tukaani.org/xz/src/liblzma/simple/arm.c +71 -0
  242. data/vendor/git.tukaani.org/xz/src/liblzma/simple/armthumb.c +76 -0
  243. data/vendor/git.tukaani.org/xz/src/liblzma/simple/ia64.c +112 -0
  244. data/vendor/git.tukaani.org/xz/src/liblzma/simple/powerpc.c +75 -0
  245. data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_coder.c +282 -0
  246. data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_coder.h +72 -0
  247. data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_decoder.c +40 -0
  248. data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_decoder.h +22 -0
  249. data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_encoder.c +38 -0
  250. data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_encoder.h +23 -0
  251. data/vendor/git.tukaani.org/xz/src/liblzma/simple/simple_private.h +74 -0
  252. data/vendor/git.tukaani.org/xz/src/liblzma/simple/sparc.c +83 -0
  253. data/vendor/git.tukaani.org/xz/src/liblzma/simple/x86.c +159 -0
  254. data/vendor/git.tukaani.org/xz/src/liblzma/validate_map.sh +68 -0
  255. data/vendor/git.tukaani.org/xz/src/lzmainfo/Makefile.am +39 -0
  256. data/vendor/git.tukaani.org/xz/src/lzmainfo/lzmainfo.1 +60 -0
  257. data/vendor/git.tukaani.org/xz/src/lzmainfo/lzmainfo.c +219 -0
  258. data/vendor/git.tukaani.org/xz/src/lzmainfo/lzmainfo_w32res.rc +12 -0
  259. data/vendor/git.tukaani.org/xz/src/scripts/Makefile.am +55 -0
  260. data/vendor/git.tukaani.org/xz/src/scripts/xzdiff.1 +77 -0
  261. data/vendor/git.tukaani.org/xz/src/scripts/xzdiff.in +200 -0
  262. data/vendor/git.tukaani.org/xz/src/scripts/xzgrep.1 +98 -0
  263. data/vendor/git.tukaani.org/xz/src/scripts/xzgrep.in +215 -0
  264. data/vendor/git.tukaani.org/xz/src/scripts/xzless.1 +69 -0
  265. data/vendor/git.tukaani.org/xz/src/scripts/xzless.in +58 -0
  266. data/vendor/git.tukaani.org/xz/src/scripts/xzmore.1 +55 -0
  267. data/vendor/git.tukaani.org/xz/src/scripts/xzmore.in +78 -0
  268. data/vendor/git.tukaani.org/xz/src/xz/Makefile.am +111 -0
  269. data/vendor/git.tukaani.org/xz/src/xz/args.c +700 -0
  270. data/vendor/git.tukaani.org/xz/src/xz/args.h +44 -0
  271. data/vendor/git.tukaani.org/xz/src/xz/coder.c +936 -0
  272. data/vendor/git.tukaani.org/xz/src/xz/coder.h +76 -0
  273. data/vendor/git.tukaani.org/xz/src/xz/file_io.c +1300 -0
  274. data/vendor/git.tukaani.org/xz/src/xz/file_io.h +156 -0
  275. data/vendor/git.tukaani.org/xz/src/xz/hardware.c +150 -0
  276. data/vendor/git.tukaani.org/xz/src/xz/hardware.h +37 -0
  277. data/vendor/git.tukaani.org/xz/src/xz/list.c +1192 -0
  278. data/vendor/git.tukaani.org/xz/src/xz/list.h +18 -0
  279. data/vendor/git.tukaani.org/xz/src/xz/main.c +330 -0
  280. data/vendor/git.tukaani.org/xz/src/xz/main.h +30 -0
  281. data/vendor/git.tukaani.org/xz/src/xz/message.c +1258 -0
  282. data/vendor/git.tukaani.org/xz/src/xz/message.h +167 -0
  283. data/vendor/git.tukaani.org/xz/src/xz/mytime.c +89 -0
  284. data/vendor/git.tukaani.org/xz/src/xz/mytime.h +47 -0
  285. data/vendor/git.tukaani.org/xz/src/xz/options.c +363 -0
  286. data/vendor/git.tukaani.org/xz/src/xz/options.h +31 -0
  287. data/vendor/git.tukaani.org/xz/src/xz/private.h +66 -0
  288. data/vendor/git.tukaani.org/xz/src/xz/signals.c +209 -0
  289. data/vendor/git.tukaani.org/xz/src/xz/signals.h +43 -0
  290. data/vendor/git.tukaani.org/xz/src/xz/suffix.c +399 -0
  291. data/vendor/git.tukaani.org/xz/src/xz/suffix.h +28 -0
  292. data/vendor/git.tukaani.org/xz/src/xz/util.c +288 -0
  293. data/vendor/git.tukaani.org/xz/src/xz/util.h +123 -0
  294. data/vendor/git.tukaani.org/xz/src/xz/xz.1 +2786 -0
  295. data/vendor/git.tukaani.org/xz/src/xz/xz_w32res.rc +12 -0
  296. data/vendor/git.tukaani.org/xz/src/xzdec/Makefile.am +82 -0
  297. data/vendor/git.tukaani.org/xz/src/xzdec/lzmadec_w32res.rc +12 -0
  298. data/vendor/git.tukaani.org/xz/src/xzdec/xzdec.1 +146 -0
  299. data/vendor/git.tukaani.org/xz/src/xzdec/xzdec.c +323 -0
  300. data/vendor/git.tukaani.org/xz/src/xzdec/xzdec_w32res.rc +12 -0
  301. data/vendor/git.tukaani.org/xz/tests/Makefile.am +57 -0
  302. data/vendor/git.tukaani.org/xz/tests/bcj_test.c +65 -0
  303. data/vendor/git.tukaani.org/xz/tests/compress_prepared_bcj_sparc +0 -0
  304. data/vendor/git.tukaani.org/xz/tests/compress_prepared_bcj_x86 +0 -0
  305. data/vendor/git.tukaani.org/xz/tests/create_compress_files.c +158 -0
  306. data/vendor/git.tukaani.org/xz/tests/files/README +240 -0
  307. data/vendor/git.tukaani.org/xz/tests/files/bad-0-backward_size.xz +0 -0
  308. data/vendor/git.tukaani.org/xz/tests/files/bad-0-empty-truncated.xz +0 -0
  309. data/vendor/git.tukaani.org/xz/tests/files/bad-0-footer_magic.xz +0 -0
  310. data/vendor/git.tukaani.org/xz/tests/files/bad-0-header_magic.xz +0 -0
  311. data/vendor/git.tukaani.org/xz/tests/files/bad-0-nonempty_index.xz +0 -0
  312. data/vendor/git.tukaani.org/xz/tests/files/bad-0cat-alone.xz +0 -0
  313. data/vendor/git.tukaani.org/xz/tests/files/bad-0cat-header_magic.xz +0 -0
  314. data/vendor/git.tukaani.org/xz/tests/files/bad-0catpad-empty.xz +0 -0
  315. data/vendor/git.tukaani.org/xz/tests/files/bad-0pad-empty.xz +0 -0
  316. data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-1.xz +0 -0
  317. data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-2.xz +0 -0
  318. data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-3.xz +0 -0
  319. data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-4.xz +0 -0
  320. data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-5.xz +0 -0
  321. data/vendor/git.tukaani.org/xz/tests/files/bad-1-block_header-6.xz +0 -0
  322. data/vendor/git.tukaani.org/xz/tests/files/bad-1-check-crc32.xz +0 -0
  323. data/vendor/git.tukaani.org/xz/tests/files/bad-1-check-crc64.xz +0 -0
  324. data/vendor/git.tukaani.org/xz/tests/files/bad-1-check-sha256.xz +0 -0
  325. data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-1.xz +0 -0
  326. data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-2.xz +0 -0
  327. data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-3.xz +0 -0
  328. data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-4.xz +0 -0
  329. data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-5.xz +0 -0
  330. data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-6.xz +0 -0
  331. data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-7.xz +0 -0
  332. data/vendor/git.tukaani.org/xz/tests/files/bad-1-lzma2-8.xz +0 -0
  333. data/vendor/git.tukaani.org/xz/tests/files/bad-1-stream_flags-1.xz +0 -0
  334. data/vendor/git.tukaani.org/xz/tests/files/bad-1-stream_flags-2.xz +0 -0
  335. data/vendor/git.tukaani.org/xz/tests/files/bad-1-stream_flags-3.xz +0 -0
  336. data/vendor/git.tukaani.org/xz/tests/files/bad-1-vli-1.xz +0 -0
  337. data/vendor/git.tukaani.org/xz/tests/files/bad-1-vli-2.xz +0 -0
  338. data/vendor/git.tukaani.org/xz/tests/files/bad-2-compressed_data_padding.xz +0 -0
  339. data/vendor/git.tukaani.org/xz/tests/files/bad-2-index-1.xz +0 -0
  340. data/vendor/git.tukaani.org/xz/tests/files/bad-2-index-2.xz +0 -0
  341. data/vendor/git.tukaani.org/xz/tests/files/bad-2-index-3.xz +0 -0
  342. data/vendor/git.tukaani.org/xz/tests/files/bad-2-index-4.xz +0 -0
  343. data/vendor/git.tukaani.org/xz/tests/files/bad-2-index-5.xz +0 -0
  344. data/vendor/git.tukaani.org/xz/tests/files/good-0-empty.xz +0 -0
  345. data/vendor/git.tukaani.org/xz/tests/files/good-0cat-empty.xz +0 -0
  346. data/vendor/git.tukaani.org/xz/tests/files/good-0catpad-empty.xz +0 -0
  347. data/vendor/git.tukaani.org/xz/tests/files/good-0pad-empty.xz +0 -0
  348. data/vendor/git.tukaani.org/xz/tests/files/good-1-3delta-lzma2.xz +0 -0
  349. data/vendor/git.tukaani.org/xz/tests/files/good-1-block_header-1.xz +0 -0
  350. data/vendor/git.tukaani.org/xz/tests/files/good-1-block_header-2.xz +0 -0
  351. data/vendor/git.tukaani.org/xz/tests/files/good-1-block_header-3.xz +0 -0
  352. data/vendor/git.tukaani.org/xz/tests/files/good-1-check-crc32.xz +0 -0
  353. data/vendor/git.tukaani.org/xz/tests/files/good-1-check-crc64.xz +0 -0
  354. data/vendor/git.tukaani.org/xz/tests/files/good-1-check-none.xz +0 -0
  355. data/vendor/git.tukaani.org/xz/tests/files/good-1-check-sha256.xz +0 -0
  356. data/vendor/git.tukaani.org/xz/tests/files/good-1-delta-lzma2.tiff.xz +0 -0
  357. data/vendor/git.tukaani.org/xz/tests/files/good-1-lzma2-1.xz +0 -0
  358. data/vendor/git.tukaani.org/xz/tests/files/good-1-lzma2-2.xz +0 -0
  359. data/vendor/git.tukaani.org/xz/tests/files/good-1-lzma2-3.xz +0 -0
  360. data/vendor/git.tukaani.org/xz/tests/files/good-1-lzma2-4.xz +0 -0
  361. data/vendor/git.tukaani.org/xz/tests/files/good-1-lzma2-5.xz +0 -0
  362. data/vendor/git.tukaani.org/xz/tests/files/good-1-sparc-lzma2.xz +0 -0
  363. data/vendor/git.tukaani.org/xz/tests/files/good-1-x86-lzma2.xz +0 -0
  364. data/vendor/git.tukaani.org/xz/tests/files/good-2-lzma2.xz +0 -0
  365. data/vendor/git.tukaani.org/xz/tests/files/unsupported-block_header.xz +0 -0
  366. data/vendor/git.tukaani.org/xz/tests/files/unsupported-check.xz +0 -0
  367. data/vendor/git.tukaani.org/xz/tests/files/unsupported-filter_flags-1.xz +0 -0
  368. data/vendor/git.tukaani.org/xz/tests/files/unsupported-filter_flags-2.xz +0 -0
  369. data/vendor/git.tukaani.org/xz/tests/files/unsupported-filter_flags-3.xz +0 -0
  370. data/vendor/git.tukaani.org/xz/tests/test_bcj_exact_size.c +113 -0
  371. data/vendor/git.tukaani.org/xz/tests/test_block_header.c +240 -0
  372. data/vendor/git.tukaani.org/xz/tests/test_check.c +83 -0
  373. data/vendor/git.tukaani.org/xz/tests/test_compress.sh +142 -0
  374. data/vendor/git.tukaani.org/xz/tests/test_files.sh +57 -0
  375. data/vendor/git.tukaani.org/xz/tests/test_filter_flags.c +258 -0
  376. data/vendor/git.tukaani.org/xz/tests/test_index.c +689 -0
  377. data/vendor/git.tukaani.org/xz/tests/test_scripts.sh +76 -0
  378. data/vendor/git.tukaani.org/xz/tests/test_stream_flags.c +180 -0
  379. data/vendor/git.tukaani.org/xz/tests/tests.h +124 -0
  380. data/vendor/git.tukaani.org/xz/tests/xzgrep_expected_output +39 -0
  381. data/vendor/git.tukaani.org/xz/windows/INSTALL-MSVC.txt +47 -0
  382. data/vendor/git.tukaani.org/xz/windows/INSTALL-MinGW.txt +138 -0
  383. data/vendor/git.tukaani.org/xz/windows/README-Windows.txt +122 -0
  384. data/vendor/git.tukaani.org/xz/windows/build.bash +203 -0
  385. data/vendor/git.tukaani.org/xz/windows/vs2013/config.h +148 -0
  386. data/vendor/git.tukaani.org/xz/windows/vs2013/liblzma.vcxproj +354 -0
  387. data/vendor/git.tukaani.org/xz/windows/vs2013/liblzma_dll.vcxproj +383 -0
  388. data/vendor/git.tukaani.org/xz/windows/vs2013/xz_win.sln +48 -0
  389. data/vendor/git.tukaani.org/xz/windows/vs2017/config.h +148 -0
  390. data/vendor/git.tukaani.org/xz/windows/vs2017/liblzma.vcxproj +355 -0
  391. data/vendor/git.tukaani.org/xz/windows/vs2017/liblzma_dll.vcxproj +384 -0
  392. data/vendor/git.tukaani.org/xz/windows/vs2017/xz_win.sln +48 -0
  393. 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