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,327 @@
1
+ ///////////////////////////////////////////////////////////////////////////////
2
+ //
3
+ /// \file lz_encoder.h
4
+ /// \brief LZ in window and match finder API
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_ENCODER_H
15
+ #define LZMA_LZ_ENCODER_H
16
+
17
+ #include "common.h"
18
+
19
+
20
+ /// A table of these is used by the LZ-based encoder to hold
21
+ /// the length-distance pairs found by the match finder.
22
+ typedef struct {
23
+ uint32_t len;
24
+ uint32_t dist;
25
+ } lzma_match;
26
+
27
+
28
+ typedef struct lzma_mf_s lzma_mf;
29
+ struct lzma_mf_s {
30
+ ///////////////
31
+ // In Window //
32
+ ///////////////
33
+
34
+ /// Pointer to buffer with data to be compressed
35
+ uint8_t *buffer;
36
+
37
+ /// Total size of the allocated buffer (that is, including all
38
+ /// the extra space)
39
+ uint32_t size;
40
+
41
+ /// Number of bytes that must be kept available in our input history.
42
+ /// That is, once keep_size_before bytes have been processed,
43
+ /// buffer[read_pos - keep_size_before] is the oldest byte that
44
+ /// must be available for reading.
45
+ uint32_t keep_size_before;
46
+
47
+ /// Number of bytes that must be kept in buffer after read_pos.
48
+ /// That is, read_pos <= write_pos - keep_size_after as long as
49
+ /// action is LZMA_RUN; when action != LZMA_RUN, read_pos is allowed
50
+ /// to reach write_pos so that the last bytes get encoded too.
51
+ uint32_t keep_size_after;
52
+
53
+ /// Match finders store locations of matches using 32-bit integers.
54
+ /// To avoid adjusting several megabytes of integers every time the
55
+ /// input window is moved with move_window, we only adjust the
56
+ /// offset of the buffer. Thus, buffer[value_in_hash_table - offset]
57
+ /// is the byte pointed by value_in_hash_table.
58
+ uint32_t offset;
59
+
60
+ /// buffer[read_pos] is the next byte to run through the match
61
+ /// finder. This is incremented in the match finder once the byte
62
+ /// has been processed.
63
+ uint32_t read_pos;
64
+
65
+ /// Number of bytes that have been ran through the match finder, but
66
+ /// which haven't been encoded by the LZ-based encoder yet.
67
+ uint32_t read_ahead;
68
+
69
+ /// As long as read_pos is less than read_limit, there is enough
70
+ /// input available in buffer for at least one encoding loop.
71
+ ///
72
+ /// Because of the stateful API, read_limit may and will get greater
73
+ /// than read_pos quite often. This is taken into account when
74
+ /// calculating the value for keep_size_after.
75
+ uint32_t read_limit;
76
+
77
+ /// buffer[write_pos] is the first byte that doesn't contain valid
78
+ /// uncompressed data; that is, the next input byte will be copied
79
+ /// to buffer[write_pos].
80
+ uint32_t write_pos;
81
+
82
+ /// Number of bytes not hashed before read_pos. This is needed to
83
+ /// restart the match finder after LZMA_SYNC_FLUSH.
84
+ uint32_t pending;
85
+
86
+ //////////////////
87
+ // Match Finder //
88
+ //////////////////
89
+
90
+ /// Find matches. Returns the number of distance-length pairs written
91
+ /// to the matches array. This is called only via lzma_mf_find().
92
+ uint32_t (*find)(lzma_mf *mf, lzma_match *matches);
93
+
94
+ /// Skips num bytes. This is like find() but doesn't make the
95
+ /// distance-length pairs available, thus being a little faster.
96
+ /// This is called only via mf_skip().
97
+ void (*skip)(lzma_mf *mf, uint32_t num);
98
+
99
+ uint32_t *hash;
100
+ uint32_t *son;
101
+ uint32_t cyclic_pos;
102
+ uint32_t cyclic_size; // Must be dictionary size + 1.
103
+ uint32_t hash_mask;
104
+
105
+ /// Maximum number of loops in the match finder
106
+ uint32_t depth;
107
+
108
+ /// Maximum length of a match that the match finder will try to find.
109
+ uint32_t nice_len;
110
+
111
+ /// Maximum length of a match supported by the LZ-based encoder.
112
+ /// If the longest match found by the match finder is nice_len,
113
+ /// mf_find() tries to expand it up to match_len_max bytes.
114
+ uint32_t match_len_max;
115
+
116
+ /// When running out of input, binary tree match finders need to know
117
+ /// if it is due to flushing or finishing. The action is used also
118
+ /// by the LZ-based encoders themselves.
119
+ lzma_action action;
120
+
121
+ /// Number of elements in hash[]
122
+ uint32_t hash_count;
123
+
124
+ /// Number of elements in son[]
125
+ uint32_t sons_count;
126
+ };
127
+
128
+
129
+ typedef struct {
130
+ /// Extra amount of data to keep available before the "actual"
131
+ /// dictionary.
132
+ size_t before_size;
133
+
134
+ /// Size of the history buffer
135
+ size_t dict_size;
136
+
137
+ /// Extra amount of data to keep available after the "actual"
138
+ /// dictionary.
139
+ size_t after_size;
140
+
141
+ /// Maximum length of a match that the LZ-based encoder can accept.
142
+ /// This is used to extend matches of length nice_len to the
143
+ /// maximum possible length.
144
+ size_t match_len_max;
145
+
146
+ /// Match finder will search matches up to this length.
147
+ /// This must be less than or equal to match_len_max.
148
+ size_t nice_len;
149
+
150
+ /// Type of the match finder to use
151
+ lzma_match_finder match_finder;
152
+
153
+ /// Maximum search depth
154
+ uint32_t depth;
155
+
156
+ /// TODO: Comment
157
+ const uint8_t *preset_dict;
158
+
159
+ uint32_t preset_dict_size;
160
+
161
+ } lzma_lz_options;
162
+
163
+
164
+ // The total usable buffer space at any moment outside the match finder:
165
+ // before_size + dict_size + after_size + match_len_max
166
+ //
167
+ // In reality, there's some extra space allocated to prevent the number of
168
+ // memmove() calls reasonable. The bigger the dict_size is, the bigger
169
+ // this extra buffer will be since with bigger dictionaries memmove() would
170
+ // also take longer.
171
+ //
172
+ // A single encoder loop in the LZ-based encoder may call the match finder
173
+ // (mf_find() or mf_skip()) at most after_size times. In other words,
174
+ // a single encoder loop may increment lzma_mf.read_pos at most after_size
175
+ // times. Since matches are looked up to
176
+ // lzma_mf.buffer[lzma_mf.read_pos + match_len_max - 1], the total
177
+ // amount of extra buffer needed after dict_size becomes
178
+ // after_size + match_len_max.
179
+ //
180
+ // before_size has two uses. The first one is to keep literals available
181
+ // in cases when the LZ-based encoder has made some read ahead.
182
+ // TODO: Maybe this could be changed by making the LZ-based encoders to
183
+ // store the actual literals as they do with length-distance pairs.
184
+ //
185
+ // Algorithms such as LZMA2 first try to compress a chunk, and then check
186
+ // if the encoded result is smaller than the uncompressed one. If the chunk
187
+ // was uncompressible, it is better to store it in uncompressed form in
188
+ // the output stream. To do this, the whole uncompressed chunk has to be
189
+ // still available in the history buffer. before_size achieves that.
190
+
191
+
192
+ typedef struct {
193
+ /// Data specific to the LZ-based encoder
194
+ void *coder;
195
+
196
+ /// Function to encode from *dict to out[]
197
+ lzma_ret (*code)(void *coder,
198
+ lzma_mf *restrict mf, uint8_t *restrict out,
199
+ size_t *restrict out_pos, size_t out_size);
200
+
201
+ /// Free allocated resources
202
+ void (*end)(void *coder, const lzma_allocator *allocator);
203
+
204
+ /// Update the options in the middle of the encoding.
205
+ lzma_ret (*options_update)(void *coder, const lzma_filter *filter);
206
+
207
+ } lzma_lz_encoder;
208
+
209
+
210
+ // Basic steps:
211
+ // 1. Input gets copied into the dictionary.
212
+ // 2. Data in dictionary gets run through the match finder byte by byte.
213
+ // 3. The literals and matches are encoded using e.g. LZMA.
214
+ //
215
+ // The bytes that have been ran through the match finder, but not encoded yet,
216
+ // are called `read ahead'.
217
+
218
+
219
+ /// Get pointer to the first byte not ran through the match finder
220
+ static inline const uint8_t *
221
+ mf_ptr(const lzma_mf *mf)
222
+ {
223
+ return mf->buffer + mf->read_pos;
224
+ }
225
+
226
+
227
+ /// Get the number of bytes that haven't been ran through the match finder yet.
228
+ static inline uint32_t
229
+ mf_avail(const lzma_mf *mf)
230
+ {
231
+ return mf->write_pos - mf->read_pos;
232
+ }
233
+
234
+
235
+ /// Get the number of bytes that haven't been encoded yet (some of these
236
+ /// bytes may have been ran through the match finder though).
237
+ static inline uint32_t
238
+ mf_unencoded(const lzma_mf *mf)
239
+ {
240
+ return mf->write_pos - mf->read_pos + mf->read_ahead;
241
+ }
242
+
243
+
244
+ /// Calculate the absolute offset from the beginning of the most recent
245
+ /// dictionary reset. Only the lowest four bits are important, so there's no
246
+ /// problem that we don't know the 64-bit size of the data encoded so far.
247
+ ///
248
+ /// NOTE: When moving the input window, we need to do it so that the lowest
249
+ /// bits of dict->read_pos are not modified to keep this macro working
250
+ /// as intended.
251
+ static inline uint32_t
252
+ mf_position(const lzma_mf *mf)
253
+ {
254
+ return mf->read_pos - mf->read_ahead;
255
+ }
256
+
257
+
258
+ /// Since everything else begins with mf_, use it also for lzma_mf_find().
259
+ #define mf_find lzma_mf_find
260
+
261
+
262
+ /// Skip the given number of bytes. This is used when a good match was found.
263
+ /// For example, if mf_find() finds a match of 200 bytes long, the first byte
264
+ /// of that match was already consumed by mf_find(), and the rest 199 bytes
265
+ /// have to be skipped with mf_skip(mf, 199).
266
+ static inline void
267
+ mf_skip(lzma_mf *mf, uint32_t amount)
268
+ {
269
+ if (amount != 0) {
270
+ mf->skip(mf, amount);
271
+ mf->read_ahead += amount;
272
+ }
273
+ }
274
+
275
+
276
+ /// Copies at most *left number of bytes from the history buffer
277
+ /// to out[]. This is needed by LZMA2 to encode uncompressed chunks.
278
+ static inline void
279
+ mf_read(lzma_mf *mf, uint8_t *out, size_t *out_pos, size_t out_size,
280
+ size_t *left)
281
+ {
282
+ const size_t out_avail = out_size - *out_pos;
283
+ const size_t copy_size = my_min(out_avail, *left);
284
+
285
+ assert(mf->read_ahead == 0);
286
+ assert(mf->read_pos >= *left);
287
+
288
+ memcpy(out + *out_pos, mf->buffer + mf->read_pos - *left,
289
+ copy_size);
290
+
291
+ *out_pos += copy_size;
292
+ *left -= copy_size;
293
+ return;
294
+ }
295
+
296
+
297
+ extern lzma_ret lzma_lz_encoder_init(
298
+ lzma_next_coder *next, const lzma_allocator *allocator,
299
+ const lzma_filter_info *filters,
300
+ lzma_ret (*lz_init)(lzma_lz_encoder *lz,
301
+ const lzma_allocator *allocator, const void *options,
302
+ lzma_lz_options *lz_options));
303
+
304
+
305
+ extern uint64_t lzma_lz_encoder_memusage(const lzma_lz_options *lz_options);
306
+
307
+
308
+ // These are only for LZ encoder's internal use.
309
+ extern uint32_t lzma_mf_find(
310
+ lzma_mf *mf, uint32_t *count, lzma_match *matches);
311
+
312
+ extern uint32_t lzma_mf_hc3_find(lzma_mf *dict, lzma_match *matches);
313
+ extern void lzma_mf_hc3_skip(lzma_mf *dict, uint32_t amount);
314
+
315
+ extern uint32_t lzma_mf_hc4_find(lzma_mf *dict, lzma_match *matches);
316
+ extern void lzma_mf_hc4_skip(lzma_mf *dict, uint32_t amount);
317
+
318
+ extern uint32_t lzma_mf_bt2_find(lzma_mf *dict, lzma_match *matches);
319
+ extern void lzma_mf_bt2_skip(lzma_mf *dict, uint32_t amount);
320
+
321
+ extern uint32_t lzma_mf_bt3_find(lzma_mf *dict, lzma_match *matches);
322
+ extern void lzma_mf_bt3_skip(lzma_mf *dict, uint32_t amount);
323
+
324
+ extern uint32_t lzma_mf_bt4_find(lzma_mf *dict, lzma_match *matches);
325
+ extern void lzma_mf_bt4_skip(lzma_mf *dict, uint32_t amount);
326
+
327
+ #endif
@@ -0,0 +1,108 @@
1
+ ///////////////////////////////////////////////////////////////////////////////
2
+ //
3
+ /// \file lz_encoder_hash.h
4
+ /// \brief Hash macros for match finders
5
+ //
6
+ // Author: Igor Pavlov
7
+ //
8
+ // This file has been put into the public domain.
9
+ // You can do whatever you want with this file.
10
+ //
11
+ ///////////////////////////////////////////////////////////////////////////////
12
+
13
+ #ifndef LZMA_LZ_ENCODER_HASH_H
14
+ #define LZMA_LZ_ENCODER_HASH_H
15
+
16
+ #if defined(WORDS_BIGENDIAN) && !defined(HAVE_SMALL)
17
+ // This is to make liblzma produce the same output on big endian
18
+ // systems that it does on little endian systems. lz_encoder.c
19
+ // takes care of including the actual table.
20
+ extern const uint32_t lzma_lz_hash_table[256];
21
+ # define hash_table lzma_lz_hash_table
22
+ #else
23
+ # include "check.h"
24
+ # define hash_table lzma_crc32_table[0]
25
+ #endif
26
+
27
+ #define HASH_2_SIZE (UINT32_C(1) << 10)
28
+ #define HASH_3_SIZE (UINT32_C(1) << 16)
29
+ #define HASH_4_SIZE (UINT32_C(1) << 20)
30
+
31
+ #define HASH_2_MASK (HASH_2_SIZE - 1)
32
+ #define HASH_3_MASK (HASH_3_SIZE - 1)
33
+ #define HASH_4_MASK (HASH_4_SIZE - 1)
34
+
35
+ #define FIX_3_HASH_SIZE (HASH_2_SIZE)
36
+ #define FIX_4_HASH_SIZE (HASH_2_SIZE + HASH_3_SIZE)
37
+ #define FIX_5_HASH_SIZE (HASH_2_SIZE + HASH_3_SIZE + HASH_4_SIZE)
38
+
39
+ // Endianness doesn't matter in hash_2_calc() (no effect on the output).
40
+ #ifdef TUKLIB_FAST_UNALIGNED_ACCESS
41
+ # define hash_2_calc() \
42
+ const uint32_t hash_value = *(const uint16_t *)(cur)
43
+ #else
44
+ # define hash_2_calc() \
45
+ const uint32_t hash_value \
46
+ = (uint32_t)(cur[0]) | ((uint32_t)(cur[1]) << 8)
47
+ #endif
48
+
49
+ #define hash_3_calc() \
50
+ const uint32_t temp = hash_table[cur[0]] ^ cur[1]; \
51
+ const uint32_t hash_2_value = temp & HASH_2_MASK; \
52
+ const uint32_t hash_value \
53
+ = (temp ^ ((uint32_t)(cur[2]) << 8)) & mf->hash_mask
54
+
55
+ #define hash_4_calc() \
56
+ const uint32_t temp = hash_table[cur[0]] ^ cur[1]; \
57
+ const uint32_t hash_2_value = temp & HASH_2_MASK; \
58
+ const uint32_t hash_3_value \
59
+ = (temp ^ ((uint32_t)(cur[2]) << 8)) & HASH_3_MASK; \
60
+ const uint32_t hash_value = (temp ^ ((uint32_t)(cur[2]) << 8) \
61
+ ^ (hash_table[cur[3]] << 5)) & mf->hash_mask
62
+
63
+
64
+ // The following are not currently used.
65
+
66
+ #define hash_5_calc() \
67
+ const uint32_t temp = hash_table[cur[0]] ^ cur[1]; \
68
+ const uint32_t hash_2_value = temp & HASH_2_MASK; \
69
+ const uint32_t hash_3_value \
70
+ = (temp ^ ((uint32_t)(cur[2]) << 8)) & HASH_3_MASK; \
71
+ uint32_t hash_4_value = (temp ^ ((uint32_t)(cur[2]) << 8) ^ \
72
+ ^ hash_table[cur[3]] << 5); \
73
+ const uint32_t hash_value \
74
+ = (hash_4_value ^ (hash_table[cur[4]] << 3)) \
75
+ & mf->hash_mask; \
76
+ hash_4_value &= HASH_4_MASK
77
+
78
+ /*
79
+ #define hash_zip_calc() \
80
+ const uint32_t hash_value \
81
+ = (((uint32_t)(cur[0]) | ((uint32_t)(cur[1]) << 8)) \
82
+ ^ hash_table[cur[2]]) & 0xFFFF
83
+ */
84
+
85
+ #define hash_zip_calc() \
86
+ const uint32_t hash_value \
87
+ = (((uint32_t)(cur[2]) | ((uint32_t)(cur[0]) << 8)) \
88
+ ^ hash_table[cur[1]]) & 0xFFFF
89
+
90
+ #define mt_hash_2_calc() \
91
+ const uint32_t hash_2_value \
92
+ = (hash_table[cur[0]] ^ cur[1]) & HASH_2_MASK
93
+
94
+ #define mt_hash_3_calc() \
95
+ const uint32_t temp = hash_table[cur[0]] ^ cur[1]; \
96
+ const uint32_t hash_2_value = temp & HASH_2_MASK; \
97
+ const uint32_t hash_3_value \
98
+ = (temp ^ ((uint32_t)(cur[2]) << 8)) & HASH_3_MASK
99
+
100
+ #define mt_hash_4_calc() \
101
+ const uint32_t temp = hash_table[cur[0]] ^ cur[1]; \
102
+ const uint32_t hash_2_value = temp & HASH_2_MASK; \
103
+ const uint32_t hash_3_value \
104
+ = (temp ^ ((uint32_t)(cur[2]) << 8)) & HASH_3_MASK; \
105
+ const uint32_t hash_4_value = (temp ^ ((uint32_t)(cur[2]) << 8) ^ \
106
+ (hash_table[cur[3]] << 5)) & HASH_4_MASK
107
+
108
+ #endif
@@ -0,0 +1,68 @@
1
+ /* This file has been automatically generated by crc32_tablegen.c. */
2
+
3
+ const uint32_t lzma_lz_hash_table[256] = {
4
+ 0x00000000, 0x77073096, 0xEE0E612C, 0x990951BA,
5
+ 0x076DC419, 0x706AF48F, 0xE963A535, 0x9E6495A3,
6
+ 0x0EDB8832, 0x79DCB8A4, 0xE0D5E91E, 0x97D2D988,
7
+ 0x09B64C2B, 0x7EB17CBD, 0xE7B82D07, 0x90BF1D91,
8
+ 0x1DB71064, 0x6AB020F2, 0xF3B97148, 0x84BE41DE,
9
+ 0x1ADAD47D, 0x6DDDE4EB, 0xF4D4B551, 0x83D385C7,
10
+ 0x136C9856, 0x646BA8C0, 0xFD62F97A, 0x8A65C9EC,
11
+ 0x14015C4F, 0x63066CD9, 0xFA0F3D63, 0x8D080DF5,
12
+ 0x3B6E20C8, 0x4C69105E, 0xD56041E4, 0xA2677172,
13
+ 0x3C03E4D1, 0x4B04D447, 0xD20D85FD, 0xA50AB56B,
14
+ 0x35B5A8FA, 0x42B2986C, 0xDBBBC9D6, 0xACBCF940,
15
+ 0x32D86CE3, 0x45DF5C75, 0xDCD60DCF, 0xABD13D59,
16
+ 0x26D930AC, 0x51DE003A, 0xC8D75180, 0xBFD06116,
17
+ 0x21B4F4B5, 0x56B3C423, 0xCFBA9599, 0xB8BDA50F,
18
+ 0x2802B89E, 0x5F058808, 0xC60CD9B2, 0xB10BE924,
19
+ 0x2F6F7C87, 0x58684C11, 0xC1611DAB, 0xB6662D3D,
20
+ 0x76DC4190, 0x01DB7106, 0x98D220BC, 0xEFD5102A,
21
+ 0x71B18589, 0x06B6B51F, 0x9FBFE4A5, 0xE8B8D433,
22
+ 0x7807C9A2, 0x0F00F934, 0x9609A88E, 0xE10E9818,
23
+ 0x7F6A0DBB, 0x086D3D2D, 0x91646C97, 0xE6635C01,
24
+ 0x6B6B51F4, 0x1C6C6162, 0x856530D8, 0xF262004E,
25
+ 0x6C0695ED, 0x1B01A57B, 0x8208F4C1, 0xF50FC457,
26
+ 0x65B0D9C6, 0x12B7E950, 0x8BBEB8EA, 0xFCB9887C,
27
+ 0x62DD1DDF, 0x15DA2D49, 0x8CD37CF3, 0xFBD44C65,
28
+ 0x4DB26158, 0x3AB551CE, 0xA3BC0074, 0xD4BB30E2,
29
+ 0x4ADFA541, 0x3DD895D7, 0xA4D1C46D, 0xD3D6F4FB,
30
+ 0x4369E96A, 0x346ED9FC, 0xAD678846, 0xDA60B8D0,
31
+ 0x44042D73, 0x33031DE5, 0xAA0A4C5F, 0xDD0D7CC9,
32
+ 0x5005713C, 0x270241AA, 0xBE0B1010, 0xC90C2086,
33
+ 0x5768B525, 0x206F85B3, 0xB966D409, 0xCE61E49F,
34
+ 0x5EDEF90E, 0x29D9C998, 0xB0D09822, 0xC7D7A8B4,
35
+ 0x59B33D17, 0x2EB40D81, 0xB7BD5C3B, 0xC0BA6CAD,
36
+ 0xEDB88320, 0x9ABFB3B6, 0x03B6E20C, 0x74B1D29A,
37
+ 0xEAD54739, 0x9DD277AF, 0x04DB2615, 0x73DC1683,
38
+ 0xE3630B12, 0x94643B84, 0x0D6D6A3E, 0x7A6A5AA8,
39
+ 0xE40ECF0B, 0x9309FF9D, 0x0A00AE27, 0x7D079EB1,
40
+ 0xF00F9344, 0x8708A3D2, 0x1E01F268, 0x6906C2FE,
41
+ 0xF762575D, 0x806567CB, 0x196C3671, 0x6E6B06E7,
42
+ 0xFED41B76, 0x89D32BE0, 0x10DA7A5A, 0x67DD4ACC,
43
+ 0xF9B9DF6F, 0x8EBEEFF9, 0x17B7BE43, 0x60B08ED5,
44
+ 0xD6D6A3E8, 0xA1D1937E, 0x38D8C2C4, 0x4FDFF252,
45
+ 0xD1BB67F1, 0xA6BC5767, 0x3FB506DD, 0x48B2364B,
46
+ 0xD80D2BDA, 0xAF0A1B4C, 0x36034AF6, 0x41047A60,
47
+ 0xDF60EFC3, 0xA867DF55, 0x316E8EEF, 0x4669BE79,
48
+ 0xCB61B38C, 0xBC66831A, 0x256FD2A0, 0x5268E236,
49
+ 0xCC0C7795, 0xBB0B4703, 0x220216B9, 0x5505262F,
50
+ 0xC5BA3BBE, 0xB2BD0B28, 0x2BB45A92, 0x5CB36A04,
51
+ 0xC2D7FFA7, 0xB5D0CF31, 0x2CD99E8B, 0x5BDEAE1D,
52
+ 0x9B64C2B0, 0xEC63F226, 0x756AA39C, 0x026D930A,
53
+ 0x9C0906A9, 0xEB0E363F, 0x72076785, 0x05005713,
54
+ 0x95BF4A82, 0xE2B87A14, 0x7BB12BAE, 0x0CB61B38,
55
+ 0x92D28E9B, 0xE5D5BE0D, 0x7CDCEFB7, 0x0BDBDF21,
56
+ 0x86D3D2D4, 0xF1D4E242, 0x68DDB3F8, 0x1FDA836E,
57
+ 0x81BE16CD, 0xF6B9265B, 0x6FB077E1, 0x18B74777,
58
+ 0x88085AE6, 0xFF0F6A70, 0x66063BCA, 0x11010B5C,
59
+ 0x8F659EFF, 0xF862AE69, 0x616BFFD3, 0x166CCF45,
60
+ 0xA00AE278, 0xD70DD2EE, 0x4E048354, 0x3903B3C2,
61
+ 0xA7672661, 0xD06016F7, 0x4969474D, 0x3E6E77DB,
62
+ 0xAED16A4A, 0xD9D65ADC, 0x40DF0B66, 0x37D83BF0,
63
+ 0xA9BCAE53, 0xDEBB9EC5, 0x47B2CF7F, 0x30B5FFE9,
64
+ 0xBDBDF21C, 0xCABAC28A, 0x53B39330, 0x24B4A3A6,
65
+ 0xBAD03605, 0xCDD70693, 0x54DE5729, 0x23D967BF,
66
+ 0xB3667A2E, 0xC4614AB8, 0x5D681B02, 0x2A6F2B94,
67
+ 0xB40BBE37, 0xC30C8EA1, 0x5A05DF1B, 0x2D02EF8D
68
+ };