seven-zip 1.4.2 → 1.7.0.rc1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (887) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/rake.yml +49 -0
  3. data/.github/workflows/release.yml +21 -0
  4. data/README.md +13 -2
  5. data/Rakefile +2 -0
  6. data/ext/p7zip/C/7zBuf.h +4 -8
  7. data/ext/p7zip/C/7zBuf2.c +9 -3
  8. data/ext/p7zip/C/7zCrc.c +84 -32
  9. data/ext/p7zip/C/7zCrc.h +2 -2
  10. data/ext/p7zip/C/7zCrcOpt.c +89 -8
  11. data/ext/p7zip/C/7zStream.c +4 -2
  12. data/ext/p7zip/C/{Types.h → 7zTypes.h} +8 -6
  13. data/ext/p7zip/C/7zVersion.h +21 -6
  14. data/ext/p7zip/C/Aes.c +28 -15
  15. data/ext/p7zip/C/Aes.h +2 -2
  16. data/ext/p7zip/C/Alloc.c +60 -12
  17. data/ext/p7zip/C/Alloc.h +6 -7
  18. data/ext/p7zip/C/Bcj2.c +256 -0
  19. data/ext/p7zip/C/Bcj2.h +146 -0
  20. data/ext/p7zip/C/Bcj2Enc.c +312 -0
  21. data/ext/p7zip/C/Blake2.h +48 -0
  22. data/ext/p7zip/C/Blake2s.c +244 -0
  23. data/ext/p7zip/C/Bra.c +2 -0
  24. data/ext/p7zip/C/Bra.h +4 -8
  25. data/ext/p7zip/C/Bra86.c +48 -51
  26. data/ext/p7zip/C/BraIA64.c +3 -1
  27. data/ext/p7zip/C/BwtSort.c +3 -4
  28. data/ext/p7zip/C/BwtSort.h +4 -8
  29. data/ext/p7zip/C/Compiler.h +32 -0
  30. data/ext/p7zip/C/CpuArch.c +50 -7
  31. data/ext/p7zip/C/CpuArch.h +112 -41
  32. data/ext/p7zip/C/Delta.c +2 -0
  33. data/ext/p7zip/C/Delta.h +4 -8
  34. data/ext/p7zip/C/HuffEnc.c +8 -6
  35. data/ext/p7zip/C/HuffEnc.h +4 -8
  36. data/ext/p7zip/C/LzFind.c +391 -108
  37. data/ext/p7zip/C/LzFind.h +20 -18
  38. data/ext/p7zip/C/LzFindMt.c +100 -90
  39. data/ext/p7zip/C/LzFindMt.h +4 -8
  40. data/ext/p7zip/C/LzHash.h +23 -20
  41. data/ext/p7zip/C/Lzma2Dec.c +48 -26
  42. data/ext/p7zip/C/Lzma2Dec.h +4 -8
  43. data/ext/p7zip/C/Lzma2Enc.c +58 -15
  44. data/ext/p7zip/C/Lzma2Enc.h +3 -7
  45. data/ext/p7zip/C/{LzmaUtil/Lzma86Enc.h → Lzma86.h} +47 -14
  46. data/ext/p7zip/C/{LzmaUtil/Lzma86Dec.c → Lzma86Dec.c} +6 -13
  47. data/ext/p7zip/C/{LzmaUtil/Lzma86Enc.c → Lzma86Enc.c} +8 -15
  48. data/ext/p7zip/C/LzmaDec.c +180 -79
  49. data/ext/p7zip/C/LzmaDec.h +4 -8
  50. data/ext/p7zip/C/LzmaEnc.c +230 -147
  51. data/ext/p7zip/C/LzmaEnc.h +6 -8
  52. data/ext/p7zip/C/MtCoder.c +3 -3
  53. data/ext/p7zip/C/Ppmd.h +5 -5
  54. data/ext/p7zip/C/Ppmd7.c +9 -7
  55. data/ext/p7zip/C/Ppmd7.h +3 -3
  56. data/ext/p7zip/C/Ppmd7Dec.c +2 -0
  57. data/ext/p7zip/C/Ppmd7Enc.c +4 -2
  58. data/ext/p7zip/C/Ppmd8.c +34 -31
  59. data/ext/p7zip/C/Ppmd8.h +5 -1
  60. data/ext/p7zip/C/Ppmd8Dec.c +2 -0
  61. data/ext/p7zip/C/Ppmd8Enc.c +2 -0
  62. data/ext/p7zip/C/Precomp.h +10 -0
  63. data/ext/p7zip/C/RotateDefs.h +11 -1
  64. data/ext/p7zip/C/Sha1.c +340 -0
  65. data/ext/p7zip/C/Sha1.h +38 -0
  66. data/ext/p7zip/C/Sha256.c +107 -63
  67. data/ext/p7zip/C/Sha256.h +2 -2
  68. data/ext/p7zip/C/Sort.c +59 -11
  69. data/ext/p7zip/C/Sort.h +8 -10
  70. data/ext/p7zip/C/Threads.h +1 -1
  71. data/ext/p7zip/C/Xz.c +7 -5
  72. data/ext/p7zip/C/Xz.h +40 -17
  73. data/ext/p7zip/C/XzCrc64.c +69 -16
  74. data/ext/p7zip/C/XzCrc64.h +2 -2
  75. data/ext/p7zip/C/XzCrc64Opt.c +69 -0
  76. data/ext/p7zip/C/XzDec.c +93 -55
  77. data/ext/p7zip/C/XzEnc.c +206 -165
  78. data/ext/p7zip/C/XzEnc.h +23 -9
  79. data/ext/p7zip/C/XzIn.c +50 -43
  80. data/ext/p7zip/CPP/7zip/Archive/7z/7zCompressionMode.h +37 -13
  81. data/ext/p7zip/CPP/7zip/Archive/7z/7zDecode.cpp +392 -181
  82. data/ext/p7zip/CPP/7zip/Archive/7z/7zDecode.h +29 -29
  83. data/ext/p7zip/CPP/7zip/Archive/7z/7zEncode.cpp +424 -212
  84. data/ext/p7zip/CPP/7zip/Archive/7z/7zEncode.h +53 -16
  85. data/ext/p7zip/CPP/7zip/Archive/7z/7zExtract.cpp +312 -174
  86. data/ext/p7zip/CPP/7zip/Archive/7z/7zFolderInStream.cpp +74 -61
  87. data/ext/p7zip/CPP/7zip/Archive/7z/7zFolderInStream.h +22 -19
  88. data/ext/p7zip/CPP/7zip/Archive/7z/7zHandler.cpp +505 -232
  89. data/ext/p7zip/CPP/7zip/Archive/7z/7zHandler.h +70 -16
  90. data/ext/p7zip/CPP/7zip/Archive/7z/7zHandlerOut.cpp +602 -172
  91. data/ext/p7zip/CPP/7zip/Archive/7z/7zHeader.cpp +5 -0
  92. data/ext/p7zip/CPP/7zip/Archive/7z/7zHeader.h +54 -3
  93. data/ext/p7zip/CPP/7zip/Archive/7z/7zIn.cpp +981 -616
  94. data/ext/p7zip/CPP/7zip/Archive/7z/7zIn.h +275 -89
  95. data/ext/p7zip/CPP/7zip/Archive/7z/7zItem.h +77 -162
  96. data/ext/p7zip/CPP/7zip/Archive/7z/7zOut.cpp +288 -238
  97. data/ext/p7zip/CPP/7zip/Archive/7z/7zOut.h +189 -20
  98. data/ext/p7zip/CPP/7zip/Archive/7z/7zProperties.cpp +59 -49
  99. data/ext/p7zip/CPP/7zip/Archive/7z/7zRegister.cpp +12 -9
  100. data/ext/p7zip/CPP/7zip/Archive/7z/7zSpecStream.cpp +4 -6
  101. data/ext/p7zip/CPP/7zip/Archive/7z/7zSpecStream.h +5 -5
  102. data/ext/p7zip/CPP/7zip/Archive/7z/7zUpdate.cpp +1743 -447
  103. data/ext/p7zip/CPP/7zip/Archive/7z/7zUpdate.h +61 -10
  104. data/ext/p7zip/CPP/7zip/Archive/ApmHandler.cpp +84 -120
  105. data/ext/p7zip/CPP/7zip/Archive/ArHandler.cpp +854 -0
  106. data/ext/p7zip/CPP/7zip/Archive/ArchiveExports.cpp +48 -32
  107. data/ext/p7zip/CPP/7zip/Archive/ArjHandler.cpp +519 -340
  108. data/ext/p7zip/CPP/7zip/Archive/Bz2Handler.cpp +223 -203
  109. data/ext/p7zip/CPP/7zip/Archive/Cab/CabBlockInStream.cpp +50 -139
  110. data/ext/p7zip/CPP/7zip/Archive/Cab/CabBlockInStream.h +17 -18
  111. data/ext/p7zip/CPP/7zip/Archive/Cab/CabHandler.cpp +566 -234
  112. data/ext/p7zip/CPP/7zip/Archive/Cab/CabHandler.h +10 -1
  113. data/ext/p7zip/CPP/7zip/Archive/Cab/CabHeader.cpp +2 -2
  114. data/ext/p7zip/CPP/7zip/Archive/Cab/CabHeader.h +12 -15
  115. data/ext/p7zip/CPP/7zip/Archive/Cab/CabIn.cpp +341 -122
  116. data/ext/p7zip/CPP/7zip/Archive/Cab/CabIn.h +81 -66
  117. data/ext/p7zip/CPP/7zip/Archive/Cab/CabItem.h +17 -14
  118. data/ext/p7zip/CPP/7zip/Archive/Cab/CabRegister.cpp +10 -4
  119. data/ext/p7zip/CPP/7zip/Archive/Chm/ChmHandler.cpp +190 -83
  120. data/ext/p7zip/CPP/7zip/Archive/Chm/ChmHandler.h +7 -1
  121. data/ext/p7zip/CPP/7zip/Archive/Chm/ChmIn.cpp +292 -174
  122. data/ext/p7zip/CPP/7zip/Archive/Chm/ChmIn.h +73 -47
  123. data/ext/p7zip/CPP/7zip/Archive/ComHandler.cpp +886 -0
  124. data/ext/p7zip/CPP/7zip/Archive/Common/CoderMixer2.cpp +994 -71
  125. data/ext/p7zip/CPP/7zip/Archive/Common/CoderMixer2.h +364 -101
  126. data/ext/p7zip/CPP/7zip/Archive/Common/DummyOutStream.cpp +7 -12
  127. data/ext/p7zip/CPP/7zip/Archive/Common/DummyOutStream.h +4 -3
  128. data/ext/p7zip/CPP/7zip/Archive/Common/FindSignature.cpp +6 -6
  129. data/ext/p7zip/CPP/7zip/Archive/Common/FindSignature.h +2 -2
  130. data/ext/p7zip/CPP/7zip/Archive/Common/HandlerOut.cpp +77 -543
  131. data/ext/p7zip/CPP/7zip/Archive/Common/HandlerOut.h +31 -51
  132. data/ext/p7zip/CPP/7zip/Archive/Common/InStreamWithCRC.cpp +18 -14
  133. data/ext/p7zip/CPP/7zip/Archive/Common/ItemNameUtils.cpp +34 -7
  134. data/ext/p7zip/CPP/7zip/Archive/Common/ItemNameUtils.h +5 -2
  135. data/ext/p7zip/CPP/7zip/Archive/Common/MultiStream.cpp +25 -24
  136. data/ext/p7zip/CPP/7zip/Archive/Common/MultiStream.h +8 -3
  137. data/ext/p7zip/CPP/7zip/Archive/Common/OutStreamWithCRC.h +1 -0
  138. data/ext/p7zip/CPP/7zip/Archive/Common/OutStreamWithSha1.cpp +2 -2
  139. data/ext/p7zip/CPP/7zip/Archive/Common/OutStreamWithSha1.h +5 -5
  140. data/ext/p7zip/CPP/7zip/Archive/Common/ParseProperties.cpp +0 -174
  141. data/ext/p7zip/CPP/7zip/Archive/Common/ParseProperties.h +2 -14
  142. data/ext/p7zip/CPP/7zip/Archive/CpioHandler.cpp +506 -335
  143. data/ext/p7zip/CPP/7zip/Archive/CramfsHandler.cpp +227 -84
  144. data/ext/p7zip/CPP/7zip/Archive/DeflateProps.cpp +0 -115
  145. data/ext/p7zip/CPP/7zip/Archive/DeflateProps.h +0 -29
  146. data/ext/p7zip/CPP/7zip/Archive/DllExports2.cpp +63 -17
  147. data/ext/p7zip/CPP/7zip/Archive/DmgHandler.cpp +1007 -339
  148. data/ext/p7zip/CPP/7zip/Archive/ElfHandler.cpp +618 -177
  149. data/ext/p7zip/CPP/7zip/Archive/ExtHandler.cpp +2867 -0
  150. data/ext/p7zip/CPP/7zip/Archive/FatHandler.cpp +136 -76
  151. data/ext/p7zip/CPP/7zip/Archive/FlvHandler.cpp +132 -150
  152. data/ext/p7zip/CPP/7zip/Archive/GptHandler.cpp +405 -0
  153. data/ext/p7zip/CPP/7zip/Archive/GzHandler.cpp +560 -214
  154. data/ext/p7zip/CPP/7zip/Archive/HandlerCont.cpp +288 -0
  155. data/ext/p7zip/CPP/7zip/Archive/HandlerCont.h +116 -0
  156. data/ext/p7zip/CPP/7zip/Archive/HfsHandler.cpp +1880 -0
  157. data/ext/p7zip/CPP/7zip/Archive/IArchive.h +415 -51
  158. data/ext/p7zip/CPP/7zip/Archive/IhexHandler.cpp +497 -0
  159. data/ext/p7zip/CPP/7zip/Archive/Iso/IsoHandler.cpp +158 -71
  160. data/ext/p7zip/CPP/7zip/Archive/Iso/IsoHandler.h +2 -1
  161. data/ext/p7zip/CPP/7zip/Archive/Iso/IsoHeader.cpp +0 -9
  162. data/ext/p7zip/CPP/7zip/Archive/Iso/IsoHeader.h +8 -5
  163. data/ext/p7zip/CPP/7zip/Archive/Iso/IsoIn.cpp +311 -91
  164. data/ext/p7zip/CPP/7zip/Archive/Iso/IsoIn.h +101 -83
  165. data/ext/p7zip/CPP/7zip/Archive/Iso/IsoItem.h +48 -39
  166. data/ext/p7zip/CPP/7zip/Archive/Iso/IsoRegister.cpp +12 -4
  167. data/ext/p7zip/CPP/7zip/Archive/LzhHandler.cpp +127 -114
  168. data/ext/p7zip/CPP/7zip/Archive/LzmaHandler.cpp +264 -121
  169. data/ext/p7zip/CPP/7zip/Archive/MachoHandler.cpp +402 -242
  170. data/ext/p7zip/CPP/7zip/Archive/MbrHandler.cpp +56 -114
  171. data/ext/p7zip/CPP/7zip/Archive/MslzHandler.cpp +230 -90
  172. data/ext/p7zip/CPP/7zip/Archive/MubHandler.cpp +129 -153
  173. data/ext/p7zip/CPP/7zip/Archive/Nsis/NsisDecode.cpp +179 -58
  174. data/ext/p7zip/CPP/7zip/Archive/Nsis/NsisDecode.h +36 -7
  175. data/ext/p7zip/CPP/7zip/Archive/Nsis/NsisHandler.cpp +407 -237
  176. data/ext/p7zip/CPP/7zip/Archive/Nsis/NsisHandler.h +9 -16
  177. data/ext/p7zip/CPP/7zip/Archive/Nsis/NsisIn.cpp +5535 -1098
  178. data/ext/p7zip/CPP/7zip/Archive/Nsis/NsisIn.h +345 -81
  179. data/ext/p7zip/CPP/7zip/Archive/Nsis/NsisRegister.cpp +11 -4
  180. data/ext/p7zip/CPP/7zip/Archive/NtfsHandler.cpp +1424 -434
  181. data/ext/p7zip/CPP/7zip/Archive/PeHandler.cpp +1831 -521
  182. data/ext/p7zip/CPP/7zip/Archive/PpmdHandler.cpp +50 -35
  183. data/ext/p7zip/CPP/7zip/Archive/QcowHandler.cpp +615 -0
  184. data/ext/p7zip/CPP/7zip/Archive/Rar/Rar5Handler.cpp +2746 -0
  185. data/ext/p7zip/CPP/7zip/Archive/Rar/Rar5Handler.h +411 -0
  186. data/ext/p7zip/CPP/7zip/Archive/Rar/RarHandler.cpp +1241 -355
  187. data/ext/p7zip/CPP/7zip/Archive/Rar/RarHandler.h +70 -20
  188. data/ext/p7zip/CPP/7zip/Archive/Rar/RarHeader.h +38 -34
  189. data/ext/p7zip/CPP/7zip/Archive/Rar/RarItem.h +34 -16
  190. data/ext/p7zip/CPP/7zip/Archive/Rar/RarVol.h +129 -0
  191. data/ext/p7zip/CPP/7zip/Archive/RpmHandler.cpp +641 -194
  192. data/ext/p7zip/CPP/7zip/Archive/SplitHandler.cpp +174 -181
  193. data/ext/p7zip/CPP/7zip/Archive/SquashfsHandler.cpp +237 -174
  194. data/ext/p7zip/CPP/7zip/Archive/SwfHandler.cpp +471 -192
  195. data/ext/p7zip/CPP/7zip/Archive/Tar/TarHandler.cpp +350 -59
  196. data/ext/p7zip/CPP/7zip/Archive/Tar/TarHandler.h +24 -7
  197. data/ext/p7zip/CPP/7zip/Archive/Tar/TarHandlerOut.cpp +79 -27
  198. data/ext/p7zip/CPP/7zip/Archive/Tar/TarHeader.cpp +5 -7
  199. data/ext/p7zip/CPP/7zip/Archive/Tar/TarHeader.h +20 -44
  200. data/ext/p7zip/CPP/7zip/Archive/Tar/TarIn.cpp +279 -64
  201. data/ext/p7zip/CPP/7zip/Archive/Tar/TarIn.h +10 -1
  202. data/ext/p7zip/CPP/7zip/Archive/Tar/TarItem.h +34 -8
  203. data/ext/p7zip/CPP/7zip/Archive/Tar/TarOut.cpp +145 -87
  204. data/ext/p7zip/CPP/7zip/Archive/Tar/TarOut.h +13 -5
  205. data/ext/p7zip/CPP/7zip/Archive/Tar/TarRegister.cpp +14 -9
  206. data/ext/p7zip/CPP/7zip/Archive/Tar/TarUpdate.cpp +154 -27
  207. data/ext/p7zip/CPP/7zip/Archive/Tar/TarUpdate.h +10 -6
  208. data/ext/p7zip/CPP/7zip/Archive/Udf/UdfHandler.cpp +53 -128
  209. data/ext/p7zip/CPP/7zip/Archive/Udf/UdfHandler.h +6 -5
  210. data/ext/p7zip/CPP/7zip/Archive/Udf/UdfIn.cpp +384 -119
  211. data/ext/p7zip/CPP/7zip/Archive/Udf/UdfIn.h +40 -21
  212. data/ext/p7zip/CPP/7zip/Archive/UefiHandler.cpp +1618 -0
  213. data/ext/p7zip/CPP/7zip/Archive/VdiHandler.cpp +362 -0
  214. data/ext/p7zip/CPP/7zip/Archive/VhdHandler.cpp +438 -247
  215. data/ext/p7zip/CPP/7zip/Archive/VmdkHandler.cpp +1518 -0
  216. data/ext/p7zip/CPP/7zip/Archive/Wim/WimHandler.cpp +837 -249
  217. data/ext/p7zip/CPP/7zip/Archive/Wim/WimHandler.h +73 -47
  218. data/ext/p7zip/CPP/7zip/Archive/Wim/WimHandlerOut.cpp +1614 -351
  219. data/ext/p7zip/CPP/7zip/Archive/Wim/WimIn.cpp +1519 -513
  220. data/ext/p7zip/CPP/7zip/Archive/Wim/WimIn.h +498 -139
  221. data/ext/p7zip/CPP/7zip/Archive/Wim/WimRegister.cpp +13 -9
  222. data/ext/p7zip/CPP/7zip/Archive/XarHandler.cpp +272 -128
  223. data/ext/p7zip/CPP/7zip/Archive/XzHandler.cpp +502 -253
  224. data/ext/p7zip/CPP/7zip/Archive/XzHandler.h +65 -0
  225. data/ext/p7zip/CPP/7zip/Archive/ZHandler.cpp +114 -39
  226. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipAddCommon.cpp +118 -134
  227. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipAddCommon.h +6 -0
  228. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipCompressionMode.h +40 -20
  229. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipHandler.cpp +541 -274
  230. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipHandler.h +13 -40
  231. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipHandlerOut.cpp +165 -254
  232. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipHeader.h +70 -178
  233. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipIn.cpp +1934 -550
  234. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipIn.h +294 -63
  235. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipItem.cpp +160 -86
  236. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipItem.h +139 -110
  237. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipOut.cpp +177 -154
  238. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipOut.h +50 -18
  239. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipRegister.cpp +18 -9
  240. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipUpdate.cpp +367 -201
  241. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipUpdate.h +11 -10
  242. data/ext/p7zip/CPP/7zip/Bundles/Format7zFree/makefile +2 -319
  243. data/ext/p7zip/CPP/7zip/Bundles/Format7zFree/makefile.depend +0 -4962
  244. data/ext/p7zip/CPP/7zip/Bundles/Format7zFree/makefile.list +1004 -259
  245. data/ext/p7zip/CPP/7zip/Common/CWrappers.cpp +26 -22
  246. data/ext/p7zip/CPP/7zip/Common/CWrappers.h +19 -14
  247. data/ext/p7zip/CPP/7zip/Common/CreateCoder.cpp +298 -130
  248. data/ext/p7zip/CPP/7zip/Common/CreateCoder.h +118 -34
  249. data/ext/p7zip/CPP/7zip/Common/FilePathAutoRename.cpp +24 -28
  250. data/ext/p7zip/CPP/7zip/Common/FilePathAutoRename.h +5 -5
  251. data/ext/p7zip/CPP/7zip/Common/FileStreams.cpp +268 -65
  252. data/ext/p7zip/CPP/7zip/Common/FileStreams.h +70 -33
  253. data/ext/p7zip/CPP/7zip/Common/FilterCoder.cpp +302 -131
  254. data/ext/p7zip/CPP/7zip/Common/FilterCoder.h +141 -43
  255. data/ext/p7zip/CPP/7zip/Common/InBuffer.cpp +87 -35
  256. data/ext/p7zip/CPP/7zip/Common/InBuffer.h +54 -45
  257. data/ext/p7zip/CPP/7zip/Common/InOutTempBuffer.cpp +22 -17
  258. data/ext/p7zip/CPP/7zip/Common/InOutTempBuffer.h +5 -5
  259. data/ext/p7zip/CPP/7zip/Common/LimitedStreams.cpp +256 -43
  260. data/ext/p7zip/CPP/7zip/Common/LimitedStreams.h +135 -8
  261. data/ext/p7zip/CPP/7zip/Common/MemBlocks.cpp +5 -5
  262. data/ext/p7zip/CPP/7zip/Common/MemBlocks.h +3 -3
  263. data/ext/p7zip/CPP/7zip/Common/MethodId.cpp +0 -24
  264. data/ext/p7zip/CPP/7zip/Common/MethodId.h +1 -1
  265. data/ext/p7zip/CPP/7zip/Common/MethodProps.cpp +430 -71
  266. data/ext/p7zip/CPP/7zip/Common/MethodProps.h +170 -17
  267. data/ext/p7zip/CPP/7zip/Common/OffsetStream.cpp +8 -4
  268. data/ext/p7zip/CPP/7zip/Common/OffsetStream.h +4 -3
  269. data/ext/p7zip/CPP/7zip/Common/OutBuffer.cpp +26 -31
  270. data/ext/p7zip/CPP/7zip/Common/OutBuffer.h +17 -18
  271. data/ext/p7zip/CPP/7zip/Common/OutMemStream.cpp +5 -5
  272. data/ext/p7zip/CPP/7zip/Common/OutMemStream.h +5 -4
  273. data/ext/p7zip/CPP/7zip/Common/ProgressUtils.cpp +22 -13
  274. data/ext/p7zip/CPP/7zip/Common/ProgressUtils.h +4 -3
  275. data/ext/p7zip/CPP/7zip/Common/PropId.cpp +108 -0
  276. data/ext/p7zip/CPP/7zip/Common/RegisterArc.h +63 -17
  277. data/ext/p7zip/CPP/7zip/Common/RegisterCodec.h +79 -6
  278. data/ext/p7zip/CPP/7zip/Common/StreamBinder.cpp +95 -90
  279. data/ext/p7zip/CPP/7zip/Common/StreamBinder.h +46 -23
  280. data/ext/p7zip/CPP/7zip/Common/StreamObjects.cpp +88 -24
  281. data/ext/p7zip/CPP/7zip/Common/StreamObjects.h +36 -14
  282. data/ext/p7zip/CPP/7zip/Common/StreamUtils.cpp +4 -4
  283. data/ext/p7zip/CPP/7zip/Common/StreamUtils.h +6 -6
  284. data/ext/p7zip/CPP/7zip/Common/UniqBlocks.cpp +57 -0
  285. data/ext/p7zip/CPP/7zip/Common/UniqBlocks.h +26 -0
  286. data/ext/p7zip/CPP/7zip/Common/VirtThread.cpp +8 -6
  287. data/ext/p7zip/CPP/7zip/Common/VirtThread.h +6 -5
  288. data/ext/p7zip/CPP/7zip/Compress/BZip2Const.h +13 -12
  289. data/ext/p7zip/CPP/7zip/Compress/BZip2Crc.h +1 -1
  290. data/ext/p7zip/CPP/7zip/Compress/BZip2Decoder.cpp +198 -147
  291. data/ext/p7zip/CPP/7zip/Compress/BZip2Decoder.h +60 -27
  292. data/ext/p7zip/CPP/7zip/Compress/BZip2Encoder.cpp +111 -116
  293. data/ext/p7zip/CPP/7zip/Compress/BZip2Encoder.h +53 -59
  294. data/ext/p7zip/CPP/7zip/Compress/BZip2Register.cpp +12 -7
  295. data/ext/p7zip/CPP/7zip/Compress/Bcj2Coder.cpp +554 -282
  296. data/ext/p7zip/CPP/7zip/Compress/Bcj2Coder.h +73 -71
  297. data/ext/p7zip/CPP/7zip/Compress/Bcj2Register.cpp +10 -5
  298. data/ext/p7zip/CPP/7zip/Compress/BcjCoder.cpp +13 -4
  299. data/ext/p7zip/CPP/7zip/Compress/BcjCoder.h +17 -5
  300. data/ext/p7zip/CPP/7zip/Compress/BcjRegister.cpp +7 -9
  301. data/ext/p7zip/CPP/7zip/Compress/BitlDecoder.cpp +2 -2
  302. data/ext/p7zip/CPP/7zip/Compress/BitlDecoder.h +58 -61
  303. data/ext/p7zip/CPP/7zip/Compress/BitlEncoder.h +24 -25
  304. data/ext/p7zip/CPP/7zip/Compress/BitmDecoder.h +46 -17
  305. data/ext/p7zip/CPP/7zip/Compress/BitmEncoder.h +18 -19
  306. data/ext/p7zip/CPP/7zip/Compress/BranchMisc.cpp +14 -28
  307. data/ext/p7zip/CPP/7zip/Compress/BranchMisc.h +27 -6
  308. data/ext/p7zip/CPP/7zip/Compress/BranchRegister.cpp +26 -15
  309. data/ext/p7zip/CPP/7zip/Compress/ByteSwap.cpp +45 -26
  310. data/ext/p7zip/CPP/7zip/Compress/CodecExports.cpp +254 -70
  311. data/ext/p7zip/CPP/7zip/Compress/CopyCoder.cpp +65 -17
  312. data/ext/p7zip/CPP/7zip/Compress/CopyCoder.h +15 -3
  313. data/ext/p7zip/CPP/7zip/Compress/CopyRegister.cpp +5 -4
  314. data/ext/p7zip/CPP/7zip/Compress/Deflate64Register.cpp +12 -6
  315. data/ext/p7zip/CPP/7zip/Compress/DeflateConst.h +43 -46
  316. data/ext/p7zip/CPP/7zip/Compress/DeflateDecoder.cpp +145 -81
  317. data/ext/p7zip/CPP/7zip/Compress/DeflateDecoder.h +31 -33
  318. data/ext/p7zip/CPP/7zip/Compress/DeflateEncoder.cpp +179 -162
  319. data/ext/p7zip/CPP/7zip/Compress/DeflateEncoder.h +35 -30
  320. data/ext/p7zip/CPP/7zip/Compress/DeflateRegister.cpp +11 -7
  321. data/ext/p7zip/CPP/7zip/Compress/DeltaFilter.cpp +55 -39
  322. data/ext/p7zip/CPP/7zip/Compress/{DllExports2.cpp → DllExports2Compress.cpp} +8 -8
  323. data/ext/p7zip/CPP/7zip/Compress/DllExportsCompress.cpp +48 -0
  324. data/ext/p7zip/CPP/7zip/Compress/HuffmanDecoder.h +220 -49
  325. data/ext/p7zip/CPP/7zip/Compress/ImplodeDecoder.cpp +14 -9
  326. data/ext/p7zip/CPP/7zip/Compress/ImplodeDecoder.h +2 -3
  327. data/ext/p7zip/CPP/7zip/Compress/ImplodeHuffmanDecoder.cpp +7 -7
  328. data/ext/p7zip/CPP/7zip/Compress/ImplodeHuffmanDecoder.h +1 -1
  329. data/ext/p7zip/CPP/7zip/Compress/LzOutWindow.cpp +1 -1
  330. data/ext/p7zip/CPP/7zip/Compress/LzOutWindow.h +21 -18
  331. data/ext/p7zip/CPP/7zip/Compress/LzhDecoder.cpp +171 -141
  332. data/ext/p7zip/CPP/7zip/Compress/LzhDecoder.h +32 -64
  333. data/ext/p7zip/CPP/7zip/Compress/Lzham/LICENSE +22 -0
  334. data/ext/p7zip/CPP/7zip/Compress/Lzham/LzhamRegister.cpp +783 -0
  335. data/ext/p7zip/CPP/7zip/Compress/Lzham/README.md +211 -0
  336. data/ext/p7zip/CPP/7zip/Compress/Lzham/include/lzham.h +803 -0
  337. data/ext/p7zip/CPP/7zip/Compress/Lzham/include/lzham_dynamic_lib.h +156 -0
  338. data/ext/p7zip/CPP/7zip/Compress/Lzham/include/lzham_exports.inc +31 -0
  339. data/ext/p7zip/CPP/7zip/Compress/Lzham/include/lzham_static_lib.h +59 -0
  340. data/ext/p7zip/CPP/7zip/Compress/Lzham/include/zlib.h +2 -0
  341. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/CMakeLists.txt +69 -0
  342. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_comp.h +38 -0
  343. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_lzbase.cpp +244 -0
  344. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_lzbase.h +46 -0
  345. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_lzcomp.cpp +750 -0
  346. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_lzcomp_internal.cpp +2240 -0
  347. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_lzcomp_internal.h +503 -0
  348. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_lzcomp_state.cpp +1684 -0
  349. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_match_accel.cpp +947 -0
  350. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_match_accel.h +164 -0
  351. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_null_threading.h +98 -0
  352. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_pthreads_threading.cpp +214 -0
  353. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_pthreads_threading.h +535 -0
  354. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_threading.h +12 -0
  355. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_win32_threading.cpp +232 -0
  356. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzham_win32_threading.h +387 -0
  357. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamcomp/lzhamcomp.vcxproj +208 -0
  358. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/CMakeLists.txt +86 -0
  359. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_assert.cpp +80 -0
  360. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_assert.h +58 -0
  361. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_checksum.cpp +73 -0
  362. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_checksum.h +13 -0
  363. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_config.h +25 -0
  364. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_core.h +303 -0
  365. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_decomp.h +37 -0
  366. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_helpers.h +54 -0
  367. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_huffman_codes.cpp +286 -0
  368. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_huffman_codes.h +32 -0
  369. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_lzdecomp.cpp +1586 -0
  370. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_lzdecompbase.cpp +131 -0
  371. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_lzdecompbase.h +89 -0
  372. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_math.h +142 -0
  373. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_mem.cpp +463 -0
  374. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_mem.h +115 -0
  375. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_platform.cpp +159 -0
  376. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_platform.h +284 -0
  377. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_prefix_coding.cpp +431 -0
  378. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_prefix_coding.h +157 -0
  379. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_symbol_codec.cpp +1527 -0
  380. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_symbol_codec.h +494 -0
  381. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_timer.cpp +147 -0
  382. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_timer.h +99 -0
  383. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_traits.h +141 -0
  384. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_types.h +72 -0
  385. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_utils.h +58 -0
  386. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_vector.cpp +83 -0
  387. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzham_vector.h +628 -0
  388. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamdecomp/lzhamdecomp.vcxproj +224 -0
  389. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamlib/lzham_lib.cpp +179 -0
  390. data/ext/p7zip/CPP/7zip/Compress/Lzham/lzhamlib/lzhamlib.vcxproj +187 -0
  391. data/ext/p7zip/CPP/7zip/Compress/Lzham/makefile +10 -0
  392. data/ext/p7zip/CPP/7zip/Compress/Lzham/makefile.depend +0 -0
  393. data/ext/p7zip/CPP/7zip/Compress/Lzham/makefile.list +129 -0
  394. data/ext/p7zip/CPP/7zip/Compress/Lzma2Decoder.cpp +123 -46
  395. data/ext/p7zip/CPP/7zip/Compress/Lzma2Decoder.h +29 -14
  396. data/ext/p7zip/CPP/7zip/Compress/Lzma2Encoder.cpp +14 -9
  397. data/ext/p7zip/CPP/7zip/Compress/Lzma2Encoder.h +1 -1
  398. data/ext/p7zip/CPP/7zip/Compress/Lzma2Register.cpp +9 -7
  399. data/ext/p7zip/CPP/7zip/Compress/LzmaDecoder.cpp +24 -8
  400. data/ext/p7zip/CPP/7zip/Compress/LzmaDecoder.h +8 -1
  401. data/ext/p7zip/CPP/7zip/Compress/LzmaEncoder.cpp +30 -27
  402. data/ext/p7zip/CPP/7zip/Compress/LzmaEncoder.h +3 -1
  403. data/ext/p7zip/CPP/7zip/Compress/LzmaRegister.cpp +9 -7
  404. data/ext/p7zip/CPP/7zip/Compress/LzmsDecoder.cpp +576 -0
  405. data/ext/p7zip/CPP/7zip/Compress/LzmsDecoder.h +271 -0
  406. data/ext/p7zip/CPP/7zip/Compress/Lzx.h +32 -36
  407. data/ext/p7zip/CPP/7zip/Compress/LzxDecoder.cpp +380 -238
  408. data/ext/p7zip/CPP/7zip/Compress/LzxDecoder.h +170 -83
  409. data/ext/p7zip/CPP/7zip/Compress/Mtf8.h +7 -9
  410. data/ext/p7zip/CPP/7zip/Compress/PpmdDecoder.cpp +1 -5
  411. data/ext/p7zip/CPP/7zip/Compress/PpmdEncoder.cpp +51 -18
  412. data/ext/p7zip/CPP/7zip/Compress/PpmdEncoder.h +18 -8
  413. data/ext/p7zip/CPP/7zip/Compress/PpmdRegister.cpp +9 -8
  414. data/ext/p7zip/CPP/7zip/Compress/PpmdZip.cpp +61 -25
  415. data/ext/p7zip/CPP/7zip/Compress/PpmdZip.h +21 -6
  416. data/ext/p7zip/CPP/7zip/Compress/QuantumDecoder.cpp +122 -102
  417. data/ext/p7zip/CPP/7zip/Compress/QuantumDecoder.h +68 -157
  418. data/ext/p7zip/CPP/7zip/Compress/Rar/makefile +33 -18
  419. data/ext/p7zip/CPP/7zip/Compress/Rar/makefile.depend +0 -158
  420. data/ext/p7zip/CPP/7zip/Compress/Rar/makefile.list +105 -56
  421. data/ext/p7zip/CPP/7zip/Compress/Rar1Decoder.cpp +34 -21
  422. data/ext/p7zip/CPP/7zip/Compress/Rar1Decoder.h +2 -0
  423. data/ext/p7zip/CPP/7zip/Compress/Rar2Decoder.cpp +77 -67
  424. data/ext/p7zip/CPP/7zip/Compress/Rar2Decoder.h +12 -10
  425. data/ext/p7zip/CPP/7zip/Compress/Rar3Decoder.cpp +139 -118
  426. data/ext/p7zip/CPP/7zip/Compress/Rar3Decoder.h +48 -33
  427. data/ext/p7zip/CPP/7zip/Compress/Rar3Vm.cpp +148 -113
  428. data/ext/p7zip/CPP/7zip/Compress/Rar3Vm.h +35 -19
  429. data/ext/p7zip/CPP/7zip/Compress/Rar5Decoder.cpp +961 -0
  430. data/ext/p7zip/CPP/7zip/Compress/Rar5Decoder.h +335 -0
  431. data/ext/p7zip/CPP/7zip/Compress/RarCodecsRegister.cpp +13 -6
  432. data/ext/p7zip/CPP/7zip/Compress/ShrinkDecoder.cpp +91 -71
  433. data/ext/p7zip/CPP/7zip/Compress/ShrinkDecoder.h +2 -4
  434. data/ext/p7zip/CPP/7zip/Compress/XpressDecoder.cpp +129 -0
  435. data/ext/p7zip/CPP/7zip/Compress/XpressDecoder.h +13 -0
  436. data/ext/p7zip/CPP/7zip/Compress/ZDecoder.cpp +98 -20
  437. data/ext/p7zip/CPP/7zip/Compress/ZDecoder.h +19 -7
  438. data/ext/p7zip/CPP/7zip/Compress/ZlibDecoder.cpp +14 -11
  439. data/ext/p7zip/CPP/7zip/Compress/ZlibDecoder.h +32 -1
  440. data/ext/p7zip/CPP/7zip/Crypto/7zAes.cpp +137 -101
  441. data/ext/p7zip/CPP/7zip/Crypto/7zAes.h +31 -30
  442. data/ext/p7zip/CPP/7zip/Crypto/7zAesRegister.cpp +8 -9
  443. data/ext/p7zip/CPP/7zip/Crypto/HmacSha1.cpp +39 -28
  444. data/ext/p7zip/CPP/7zip/Crypto/HmacSha1.h +3 -3
  445. data/ext/p7zip/CPP/7zip/Crypto/HmacSha256.cpp +62 -0
  446. data/ext/p7zip/CPP/7zip/Crypto/HmacSha256.h +27 -0
  447. data/ext/p7zip/CPP/7zip/Crypto/MyAes.cpp +73 -7
  448. data/ext/p7zip/CPP/7zip/Crypto/MyAes.h +25 -8
  449. data/ext/p7zip/CPP/7zip/Crypto/MyAesReg.cpp +16 -0
  450. data/ext/p7zip/CPP/7zip/Crypto/Pbkdf2HmacSha1.cpp +29 -15
  451. data/ext/p7zip/CPP/7zip/Crypto/Pbkdf2HmacSha1.h +2 -1
  452. data/ext/p7zip/CPP/7zip/Crypto/RandGen.cpp +49 -34
  453. data/ext/p7zip/CPP/7zip/Crypto/RandGen.h +2 -2
  454. data/ext/p7zip/CPP/7zip/Crypto/Rar20Crypto.cpp +36 -39
  455. data/ext/p7zip/CPP/7zip/Crypto/Rar20Crypto.h +15 -17
  456. data/ext/p7zip/CPP/7zip/Crypto/Rar5Aes.cpp +257 -0
  457. data/ext/p7zip/CPP/7zip/Crypto/Rar5Aes.h +84 -0
  458. data/ext/p7zip/CPP/7zip/Crypto/RarAes.cpp +70 -71
  459. data/ext/p7zip/CPP/7zip/Crypto/RarAes.h +24 -19
  460. data/ext/p7zip/CPP/7zip/Crypto/Sha1Cls.h +51 -0
  461. data/ext/p7zip/CPP/7zip/Crypto/WzAes.cpp +68 -54
  462. data/ext/p7zip/CPP/7zip/Crypto/WzAes.h +37 -27
  463. data/ext/p7zip/CPP/7zip/Crypto/ZipCrypto.cpp +60 -34
  464. data/ext/p7zip/CPP/7zip/Crypto/ZipCrypto.h +28 -11
  465. data/ext/p7zip/CPP/7zip/Crypto/ZipStrong.cpp +90 -28
  466. data/ext/p7zip/CPP/7zip/Crypto/ZipStrong.h +13 -2
  467. data/ext/p7zip/CPP/7zip/Guid.txt +57 -11
  468. data/ext/p7zip/CPP/7zip/ICoder.h +202 -17
  469. data/ext/p7zip/CPP/7zip/IDecl.h +16 -3
  470. data/ext/p7zip/CPP/7zip/IPassword.h +1 -2
  471. data/ext/p7zip/CPP/7zip/IProgress.h +2 -16
  472. data/ext/p7zip/CPP/7zip/IStream.h +82 -13
  473. data/ext/p7zip/CPP/7zip/MyVersion.h +2 -11
  474. data/ext/p7zip/CPP/7zip/PropID.h +60 -9
  475. data/ext/p7zip/CPP/Common/C_FileIO.cpp +5 -1
  476. data/ext/p7zip/CPP/Common/C_FileIO.h +7 -1
  477. data/ext/p7zip/CPP/Common/CommandLineParser.cpp +122 -148
  478. data/ext/p7zip/CPP/Common/CommandLineParser.h +20 -29
  479. data/ext/p7zip/CPP/Common/Common.h +13 -0
  480. data/ext/p7zip/CPP/Common/CrcReg.cpp +98 -0
  481. data/ext/p7zip/CPP/Common/Defs.h +5 -10
  482. data/ext/p7zip/CPP/Common/DynLimBuf.cpp +93 -0
  483. data/ext/p7zip/CPP/Common/DynLimBuf.h +40 -0
  484. data/ext/p7zip/CPP/Common/DynamicBuffer.h +45 -31
  485. data/ext/p7zip/CPP/Common/IntToString.cpp +109 -40
  486. data/ext/p7zip/CPP/Common/IntToString.h +14 -9
  487. data/ext/p7zip/CPP/Common/Lang.cpp +120 -87
  488. data/ext/p7zip/CPP/Common/Lang.h +10 -15
  489. data/ext/p7zip/CPP/Common/ListFileUtils.cpp +82 -40
  490. data/ext/p7zip/CPP/Common/ListFileUtils.h +7 -4
  491. data/ext/p7zip/CPP/Common/MyBuffer.h +244 -0
  492. data/ext/p7zip/CPP/Common/MyCom.h +65 -28
  493. data/ext/p7zip/CPP/Common/MyGuidDef.h +1 -1
  494. data/ext/p7zip/CPP/Common/MyInitGuid.h +23 -0
  495. data/ext/p7zip/CPP/Common/MyLinux.h +42 -0
  496. data/ext/p7zip/CPP/Common/MyMap.cpp +8 -8
  497. data/ext/p7zip/CPP/Common/MyMap.h +2 -2
  498. data/ext/p7zip/CPP/Common/MyString.cpp +1643 -117
  499. data/ext/p7zip/CPP/Common/MyString.h +677 -486
  500. data/ext/p7zip/CPP/Common/MyTypes.h +38 -0
  501. data/ext/p7zip/CPP/Common/MyUnknown.h +4 -0
  502. data/ext/p7zip/CPP/Common/MyVector.cpp +0 -84
  503. data/ext/p7zip/CPP/Common/MyVector.h +472 -112
  504. data/ext/p7zip/CPP/Common/MyWindows.cpp +18 -1
  505. data/ext/p7zip/CPP/Common/MyWindows.h +8 -0
  506. data/ext/p7zip/CPP/Common/MyXml.cpp +169 -118
  507. data/ext/p7zip/CPP/Common/MyXml.h +14 -11
  508. data/ext/p7zip/CPP/Common/NewHandler.cpp +39 -0
  509. data/ext/p7zip/CPP/Common/NewHandler.h +55 -2
  510. data/ext/p7zip/CPP/Common/Random.h +14 -0
  511. data/ext/p7zip/CPP/Common/Sha1Reg.cpp +40 -0
  512. data/ext/p7zip/CPP/Common/Sha256Reg.cpp +40 -0
  513. data/ext/p7zip/CPP/Common/StdInStream.cpp +46 -27
  514. data/ext/p7zip/CPP/Common/StdInStream.h +11 -10
  515. data/ext/p7zip/CPP/Common/StdOutStream.cpp +48 -35
  516. data/ext/p7zip/CPP/Common/StdOutStream.h +44 -17
  517. data/ext/p7zip/CPP/Common/StringConvert.cpp +56 -17
  518. data/ext/p7zip/CPP/Common/StringConvert.h +7 -3
  519. data/ext/p7zip/CPP/Common/StringToInt.cpp +102 -48
  520. data/ext/p7zip/CPP/Common/StringToInt.h +13 -10
  521. data/ext/p7zip/CPP/Common/TextConfig.cpp +33 -47
  522. data/ext/p7zip/CPP/Common/TextConfig.h +3 -6
  523. data/ext/p7zip/CPP/Common/UTFConvert.cpp +218 -75
  524. data/ext/p7zip/CPP/Common/UTFConvert.h +4 -3
  525. data/ext/p7zip/CPP/Common/Wildcard.cpp +345 -125
  526. data/ext/p7zip/CPP/Common/Wildcard.h +82 -13
  527. data/ext/p7zip/CPP/Common/XzCrc64Reg.cpp +42 -0
  528. data/ext/p7zip/CPP/Windows/FileDir.cpp +427 -475
  529. data/ext/p7zip/CPP/Windows/FileDir.h +94 -72
  530. data/ext/p7zip/CPP/Windows/FileFind.cpp +235 -244
  531. data/ext/p7zip/CPP/Windows/FileFind.h +63 -59
  532. data/ext/p7zip/CPP/Windows/FileIO.cpp +29 -46
  533. data/ext/p7zip/CPP/Windows/FileIO.h +40 -42
  534. data/ext/p7zip/CPP/Windows/FileName.cpp +696 -17
  535. data/ext/p7zip/CPP/Windows/FileName.h +11 -3
  536. data/ext/p7zip/CPP/Windows/NtCheck.h +2 -0
  537. data/ext/p7zip/CPP/Windows/PropVariant.cpp +134 -30
  538. data/ext/p7zip/CPP/Windows/PropVariant.h +80 -24
  539. data/ext/p7zip/CPP/Windows/PropVariantUtils.cpp +89 -18
  540. data/ext/p7zip/CPP/Windows/PropVariantUtils.h +12 -7
  541. data/ext/p7zip/CPP/Windows/System.cpp +20 -15
  542. data/ext/p7zip/CPP/Windows/System.h +3 -2
  543. data/ext/p7zip/CPP/Windows/TimeUtils.cpp +203 -0
  544. data/ext/p7zip/CPP/Windows/TimeUtils.h +24 -0
  545. data/ext/p7zip/CPP/include_windows/basetyps.h +4 -4
  546. data/ext/p7zip/CPP/include_windows/windows.h +17 -11
  547. data/ext/p7zip/CPP/myWindows/StdAfx.h +97 -5
  548. data/ext/p7zip/CPP/myWindows/config.h +20 -5
  549. data/ext/p7zip/CPP/myWindows/myPrivate.h +8 -0
  550. data/ext/p7zip/CPP/myWindows/wine_date_and_time.cpp +34 -0
  551. data/ext/p7zip/ChangeLog +283 -35
  552. data/ext/p7zip/{DOCS → DOC}/7zC.txt +6 -13
  553. data/ext/p7zip/{DOCS → DOC}/License.txt +3 -2
  554. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/commands/add.htm +93 -87
  555. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/commands/bench.htm +88 -79
  556. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/commands/delete.htm +62 -59
  557. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/commands/extract.htm +96 -91
  558. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/commands/extract_full.htm +73 -68
  559. data/ext/p7zip/DOC/MANUAL/cmdline/commands/hash.htm +65 -0
  560. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/commands/index.htm +36 -33
  561. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/commands/list.htm +78 -77
  562. data/ext/p7zip/DOC/MANUAL/cmdline/commands/rename.htm +51 -0
  563. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/commands/style.css +232 -232
  564. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/commands/test.htm +47 -46
  565. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/commands/update.htm +71 -66
  566. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/exit_codes.htm +27 -27
  567. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/index.htm +29 -29
  568. data/ext/p7zip/{DOCS/MANUAL/switches → DOC/MANUAL/cmdline}/style.css +232 -232
  569. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/ar_exclude.htm +56 -56
  570. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/ar_include.htm +80 -83
  571. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/ar_no.htm +52 -52
  572. data/ext/p7zip/DOC/MANUAL/cmdline/switches/bb.htm +61 -0
  573. data/ext/p7zip/DOC/MANUAL/cmdline/switches/bs.htm +67 -0
  574. data/ext/p7zip/DOC/MANUAL/cmdline/switches/charset.htm +61 -0
  575. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/exclude.htm +71 -60
  576. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/include.htm +89 -87
  577. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/index.htm +95 -64
  578. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/large_pages.htm +59 -50
  579. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/list_tech.htm +36 -36
  580. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/method.htm +738 -625
  581. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/output_dir.htm +53 -53
  582. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/overwrite.htm +56 -56
  583. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/password.htm +55 -54
  584. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/recurse.htm +85 -83
  585. data/ext/p7zip/DOC/MANUAL/cmdline/switches/sa.htm +58 -0
  586. data/ext/p7zip/DOC/MANUAL/cmdline/switches/scc.htm +42 -0
  587. data/ext/p7zip/DOC/MANUAL/cmdline/switches/scrc.htm +53 -0
  588. data/ext/p7zip/DOC/MANUAL/cmdline/switches/sdel.htm +39 -0
  589. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/sfx.htm +153 -156
  590. data/ext/p7zip/DOC/MANUAL/cmdline/switches/shared.htm +40 -0
  591. data/ext/p7zip/DOC/MANUAL/cmdline/switches/sni.htm +56 -0
  592. data/ext/p7zip/DOC/MANUAL/cmdline/switches/sns.htm +77 -0
  593. data/ext/p7zip/DOC/MANUAL/cmdline/switches/spf.htm +80 -0
  594. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/ssc.htm +50 -50
  595. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/stdin.htm +56 -55
  596. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/stdout.htm +54 -50
  597. data/ext/p7zip/DOC/MANUAL/cmdline/switches/stl.htm +39 -0
  598. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/stop_switch.htm +31 -31
  599. data/ext/p7zip/DOC/MANUAL/cmdline/switches/stx.htm +50 -0
  600. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline/switches}/style.css +232 -232
  601. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/type.htm +121 -83
  602. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/update.htm +177 -176
  603. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/volume.htm +49 -49
  604. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/working_dir.htm +56 -55
  605. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/switches/yes.htm +48 -48
  606. data/ext/p7zip/{DOCS/MANUAL → DOC/MANUAL/cmdline}/syntax.htm +120 -120
  607. data/ext/p7zip/DOC/MANUAL/fm/about.htm +21 -0
  608. data/ext/p7zip/DOC/MANUAL/fm/benchmark.htm +56 -0
  609. data/ext/p7zip/DOC/MANUAL/fm/index.htm +54 -0
  610. data/ext/p7zip/DOC/MANUAL/fm/menu.htm +154 -0
  611. data/ext/p7zip/DOC/MANUAL/fm/options.htm +152 -0
  612. data/ext/p7zip/DOC/MANUAL/fm/plugins/7-zip/add.htm +311 -0
  613. data/ext/p7zip/DOC/MANUAL/fm/plugins/7-zip/extract.htm +78 -0
  614. data/ext/p7zip/DOC/MANUAL/fm/plugins/7-zip/index.htm +63 -0
  615. data/ext/p7zip/DOC/MANUAL/fm/plugins/7-zip/style.css +232 -0
  616. data/ext/p7zip/DOC/MANUAL/fm/plugins/index.htm +22 -0
  617. data/ext/p7zip/DOC/MANUAL/fm/plugins/style.css +232 -0
  618. data/ext/p7zip/DOC/MANUAL/fm/style.css +232 -0
  619. data/ext/p7zip/DOC/MANUAL/general/7z.htm +117 -0
  620. data/ext/p7zip/DOC/MANUAL/general/faq.htm +125 -0
  621. data/ext/p7zip/DOC/MANUAL/general/formats.htm +100 -0
  622. data/ext/p7zip/DOC/MANUAL/general/index.htm +27 -0
  623. data/ext/p7zip/DOC/MANUAL/general/license.htm +30 -0
  624. data/ext/p7zip/DOC/MANUAL/general/performance.htm +98 -0
  625. data/ext/p7zip/DOC/MANUAL/general/style.css +232 -0
  626. data/ext/p7zip/DOC/MANUAL/general/thanks.htm +43 -0
  627. data/ext/p7zip/DOC/MANUAL/start.htm +37 -0
  628. data/ext/p7zip/DOC/MANUAL/style.css +232 -0
  629. data/ext/p7zip/DOC/Methods.txt +158 -0
  630. data/ext/p7zip/{DOCS → DOC}/copying.txt +9 -11
  631. data/ext/p7zip/DOC/lzma.txt +328 -0
  632. data/ext/p7zip/{DOCS → DOC}/readme.txt +42 -65
  633. data/ext/p7zip/{DOCS/history.txt → DOC/src-history.txt} +88 -2
  634. data/ext/p7zip/README +117 -91
  635. data/ext/p7zip/TODO +0 -2
  636. data/ext/p7zip/install.sh +31 -29
  637. data/ext/p7zip/last_error +1 -0
  638. data/ext/p7zip/makefile +29 -125
  639. data/ext/p7zip/makefile.afl +23 -0
  640. data/ext/p7zip/makefile.aix_gcc +5 -4
  641. data/ext/p7zip/makefile.android_arm +49 -0
  642. data/ext/p7zip/makefile.beos +5 -4
  643. data/ext/p7zip/makefile.common +150 -0
  644. data/ext/p7zip/makefile.crc32 +3 -3
  645. data/ext/p7zip/makefile.cygwin +5 -4
  646. data/ext/p7zip/makefile.cygwin64 +21 -0
  647. data/ext/p7zip/makefile.cygwin64_asm +22 -0
  648. data/ext/p7zip/makefile.cygwin_asm +6 -4
  649. data/ext/p7zip/makefile.cygwin_clang +21 -0
  650. data/ext/p7zip/makefile.cygwin_clang_asm +23 -0
  651. data/ext/p7zip/{makefile.djgpp_old → makefile.djgpp} +5 -4
  652. data/ext/p7zip/makefile.djgpp_watt +7 -5
  653. data/ext/p7zip/makefile.freebsd5 +5 -4
  654. data/ext/p7zip/{makefile.freebsd6 → makefile.freebsd6+} +6 -5
  655. data/ext/p7zip/makefile.glb +27 -18
  656. data/ext/p7zip/makefile.gprof +3 -2
  657. data/ext/p7zip/makefile.haiku +19 -0
  658. data/ext/p7zip/makefile.hpux-acc +3 -2
  659. data/ext/p7zip/makefile.hpux-acc_64 +3 -2
  660. data/ext/p7zip/makefile.hpux-gcc +5 -4
  661. data/ext/p7zip/makefile.linux_amd64 +5 -4
  662. data/ext/p7zip/makefile.linux_amd64_asm +12 -5
  663. data/ext/p7zip/makefile.linux_amd64_asm_icc +5 -3
  664. data/ext/p7zip/makefile.linux_amd64_sanitizer +26 -0
  665. data/ext/p7zip/makefile.linux_any_cpu +5 -4
  666. data/ext/p7zip/makefile.linux_any_cpu_gcc_4.X +7 -4
  667. data/ext/p7zip/makefile.linux_clang_amd64_asm +25 -0
  668. data/ext/p7zip/makefile.linux_clang_amd64_asm_sanitize +27 -0
  669. data/ext/p7zip/makefile.linux_cross_aarch64 +25 -0
  670. data/ext/p7zip/makefile.linux_cross_arm +7 -4
  671. data/ext/p7zip/makefile.linux_cross_djgpp +27 -0
  672. data/ext/p7zip/makefile.linux_cross_m68k +26 -0
  673. data/ext/p7zip/makefile.linux_cross_mipsel +27 -0
  674. data/ext/p7zip/makefile.linux_cross_ppc +25 -0
  675. data/ext/p7zip/makefile.linux_cross_ppc64 +25 -0
  676. data/ext/p7zip/makefile.linux_cross_ppc64le +25 -0
  677. data/ext/p7zip/makefile.linux_cross_s390x +25 -0
  678. data/ext/p7zip/makefile.linux_cross_sparc64 +25 -0
  679. data/ext/p7zip/makefile.linux_gcc6_sanitize +23 -0
  680. data/ext/p7zip/makefile.linux_gcc_2.95_no_need_for_libstdc +6 -4
  681. data/ext/p7zip/makefile.linux_other +6 -5
  682. data/ext/p7zip/makefile.linux_s390x +5 -4
  683. data/ext/p7zip/{makefile.machine_base → makefile.linux_scan-build} +5 -4
  684. data/ext/p7zip/makefile.linux_valgrind +25 -0
  685. data/ext/p7zip/{makefile.linux_clang_amd64 → makefile.linux_x32} +6 -5
  686. data/ext/p7zip/makefile.linux_x86_asm_gcc_4.X +10 -5
  687. data/ext/p7zip/makefile.linux_x86_asm_gcc_4.X_fltk +8 -4
  688. data/ext/p7zip/makefile.linux_x86_asm_gcc_mudflap_4.X +4 -2
  689. data/ext/p7zip/makefile.linux_x86_asm_icc +4 -2
  690. data/ext/p7zip/makefile.linux_x86_icc +3 -2
  691. data/ext/p7zip/makefile.macosx_arm64 +17 -0
  692. data/ext/p7zip/{makefile.macosx_32bits → makefile.macosx_gcc_32bits} +3 -2
  693. data/ext/p7zip/{makefile.macosx_32bits_asm → makefile.macosx_gcc_32bits_asm} +5 -3
  694. data/ext/p7zip/{makefile.macosx_32bits_ppc → makefile.macosx_gcc_32bits_ppc} +3 -2
  695. data/ext/p7zip/{makefile.macosx_64bits → makefile.macosx_gcc_64bits} +3 -2
  696. data/ext/p7zip/makefile.macosx_llvm_64bits +9 -3
  697. data/ext/p7zip/makefile.netbsd +5 -4
  698. data/ext/p7zip/makefile.netware_asm_gcc_3.X +6 -4
  699. data/ext/p7zip/makefile.oldmake +41 -130
  700. data/ext/p7zip/makefile.openbsd +7 -3
  701. data/ext/p7zip/makefile.openbsd_no_port +9 -5
  702. data/ext/p7zip/makefile.qnx_shared.bin +5 -4
  703. data/ext/p7zip/makefile.qnx_static +5 -4
  704. data/ext/p7zip/makefile.solaris_sparc_CC_32 +5 -4
  705. data/ext/p7zip/makefile.solaris_sparc_CC_64 +6 -4
  706. data/ext/p7zip/makefile.solaris_sparc_gcc +7 -6
  707. data/ext/p7zip/makefile.solaris_x86 +5 -4
  708. data/ext/p7zip/makefile.tru64 +5 -4
  709. data/ext/seven_zip_ruby/extconf.rb +92 -6
  710. data/ext/seven_zip_ruby/seven_zip_archive.cpp +40 -17
  711. data/ext/seven_zip_ruby/seven_zip_archive.h +1 -1
  712. data/ext/seven_zip_ruby/utils.cpp +267 -124
  713. data/ext/seven_zip_ruby/utils.h +2 -0
  714. data/lib/seven_zip_ruby/7z.dll +0 -0
  715. data/lib/seven_zip_ruby/7z.sfx +0 -0
  716. data/lib/seven_zip_ruby/7z64.dll +0 -0
  717. data/lib/seven_zip_ruby/7zCon.sfx +0 -0
  718. data/lib/seven_zip_ruby/seven_zip_reader.rb +16 -1
  719. data/lib/seven_zip_ruby/version.rb +1 -1
  720. data/p7zip/.gitignore +7 -0
  721. data/p7zip/README.txt +29 -0
  722. data/p7zip/extract.sh +134 -0
  723. data/spec/seven_zip_ruby_spec.rb +22 -13
  724. data/test/res/The Flying Spaghetti Monster.txt +3 -0
  725. data/test/res/The Three Little Pigs.txt +5 -0
  726. data/test/res/UTF_content.txt +3 -0
  727. data/test/res/test_reader_data.7z +0 -0
  728. data/test/res/test_reader_filename_cp932.7z +0 -0
  729. data/test/res/test_reader_files.7z +0 -0
  730. data/test/test_seven_zip_reader.rb +187 -0
  731. data/test/test_seven_zip_writer.rb +184 -0
  732. metadata +267 -219
  733. data/.github/workflows/test-and-release.yml +0 -43
  734. data/ext/C/Types.h +0 -254
  735. data/ext/CPP/7zip/Archive/IArchive.h +0 -234
  736. data/ext/CPP/7zip/IDecl.h +0 -15
  737. data/ext/CPP/7zip/IPassword.h +0 -24
  738. data/ext/CPP/7zip/IProgress.h +0 -33
  739. data/ext/CPP/7zip/IStream.h +0 -58
  740. data/ext/CPP/7zip/PropID.h +0 -76
  741. data/ext/CPP/Common/MyCom.h +0 -225
  742. data/ext/CPP/Common/MyGuidDef.h +0 -54
  743. data/ext/CPP/Common/MyInitGuid.h +0 -22
  744. data/ext/CPP/Common/MyUnknown.h +0 -13
  745. data/ext/CPP/Common/MyWindows.h +0 -204
  746. data/ext/CPP/Common/Types.h +0 -11
  747. data/ext/CPP/Windows/PropVariant.h +0 -56
  748. data/ext/CPP/include_windows/basetyps.h +0 -19
  749. data/ext/CPP/include_windows/tchar.h +0 -89
  750. data/ext/CPP/include_windows/windows.h +0 -194
  751. data/ext/p7zip/Asm/x64/7zCrcT8U.asm +0 -103
  752. data/ext/p7zip/Asm/x86/7zCrcT8U.asm +0 -101
  753. data/ext/p7zip/C/7zCrcT8.c +0 -43
  754. data/ext/p7zip/C/Alloc.back3 +0 -238
  755. data/ext/p7zip/C/Alloc.c.back +0 -243
  756. data/ext/p7zip/C/Alloc.c.back2 +0 -222
  757. data/ext/p7zip/C/LzmaUtil/Lzma86Dec.h +0 -51
  758. data/ext/p7zip/CPP/7zip/Archive/7z/7zFolderOutStream.cpp +0 -149
  759. data/ext/p7zip/CPP/7zip/Archive/7z/7zFolderOutStream.h +0 -58
  760. data/ext/p7zip/CPP/7zip/Archive/Chm/ChmHeader.cpp +0 -24
  761. data/ext/p7zip/CPP/7zip/Archive/Chm/ChmHeader.h +0 -28
  762. data/ext/p7zip/CPP/7zip/Archive/Chm/ChmRegister.cpp +0 -13
  763. data/ext/p7zip/CPP/7zip/Archive/Com/ComHandler.cpp +0 -239
  764. data/ext/p7zip/CPP/7zip/Archive/Com/ComHandler.h +0 -28
  765. data/ext/p7zip/CPP/7zip/Archive/Com/ComIn.cpp +0 -389
  766. data/ext/p7zip/CPP/7zip/Archive/Com/ComIn.h +0 -119
  767. data/ext/p7zip/CPP/7zip/Archive/Com/ComRegister.cpp +0 -13
  768. data/ext/p7zip/CPP/7zip/Archive/Common/CoderMixer2MT.cpp +0 -240
  769. data/ext/p7zip/CPP/7zip/Archive/Common/CoderMixer2MT.h +0 -80
  770. data/ext/p7zip/CPP/7zip/Archive/Common/CoderMixer2ST.cpp +0 -239
  771. data/ext/p7zip/CPP/7zip/Archive/Common/CoderMixer2ST.h +0 -88
  772. data/ext/p7zip/CPP/7zip/Archive/Common/CrossThreadProgress.cpp +0 -15
  773. data/ext/p7zip/CPP/7zip/Archive/Common/CrossThreadProgress.h +0 -37
  774. data/ext/p7zip/CPP/7zip/Archive/DebHandler.cpp +0 -413
  775. data/ext/p7zip/CPP/7zip/Archive/Hfs/HfsHandler.cpp +0 -243
  776. data/ext/p7zip/CPP/7zip/Archive/Hfs/HfsHandler.h +0 -26
  777. data/ext/p7zip/CPP/7zip/Archive/Hfs/HfsIn.cpp +0 -480
  778. data/ext/p7zip/CPP/7zip/Archive/Hfs/HfsIn.h +0 -154
  779. data/ext/p7zip/CPP/7zip/Archive/Hfs/HfsRegister.cpp +0 -13
  780. data/ext/p7zip/CPP/7zip/Archive/Rar/RarHeader.cpp +0 -21
  781. data/ext/p7zip/CPP/7zip/Archive/Rar/RarIn.cpp +0 -478
  782. data/ext/p7zip/CPP/7zip/Archive/Rar/RarIn.h +0 -123
  783. data/ext/p7zip/CPP/7zip/Archive/Rar/RarItem.cpp +0 -55
  784. data/ext/p7zip/CPP/7zip/Archive/Rar/RarRegister.cpp +0 -13
  785. data/ext/p7zip/CPP/7zip/Archive/Rar/RarVolumeInStream.cpp +0 -78
  786. data/ext/p7zip/CPP/7zip/Archive/Rar/RarVolumeInStream.h +0 -49
  787. data/ext/p7zip/CPP/7zip/Archive/Udf/UdfRegister.cpp +0 -13
  788. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipHeader.cpp +0 -36
  789. data/ext/p7zip/CPP/7zip/Archive/Zip/ZipItemEx.h +0 -34
  790. data/ext/p7zip/CPP/7zip/CMAKE/CMakeLists_7zFM.txt +0 -163
  791. data/ext/p7zip/CPP/7zip/CMAKE/CMakeLists_7zG.txt +0 -131
  792. data/ext/p7zip/CPP/7zip/CMAKE/CMakeLists_7za.txt +0 -253
  793. data/ext/p7zip/CPP/7zip/CMAKE/CMakeLists_ALL.txt +0 -32
  794. data/ext/p7zip/CPP/7zip/CMAKE/CMakeLists_Format7zFree.txt +0 -290
  795. data/ext/p7zip/CPP/7zip/CMAKE/generate.sh +0 -37
  796. data/ext/p7zip/CPP/7zip/CMAKE/generate_xcode.sh +0 -32
  797. data/ext/p7zip/CPP/7zip/Common/LockedStream.cpp +0 -23
  798. data/ext/p7zip/CPP/7zip/Common/LockedStream.h +0 -38
  799. data/ext/p7zip/CPP/7zip/Compress/ArjDecoder1.cpp +0 -309
  800. data/ext/p7zip/CPP/7zip/Compress/ArjDecoder1.h +0 -98
  801. data/ext/p7zip/CPP/7zip/Compress/ArjDecoder2.cpp +0 -90
  802. data/ext/p7zip/CPP/7zip/Compress/ArjDecoder2.h +0 -59
  803. data/ext/p7zip/CPP/7zip/Compress/BranchCoder.cpp +0 -19
  804. data/ext/p7zip/CPP/7zip/Compress/BranchCoder.h +0 -44
  805. data/ext/p7zip/CPP/7zip/Compress/DllExports.cpp +0 -39
  806. data/ext/p7zip/CPP/7zip/Compress/LZMA_Alone/LzmaAlone.cpp +0 -531
  807. data/ext/p7zip/CPP/7zip/Compress/LZMA_Alone/LzmaBench.cpp +0 -1018
  808. data/ext/p7zip/CPP/7zip/Compress/LZMA_Alone/LzmaBench.h +0 -48
  809. data/ext/p7zip/CPP/7zip/Compress/LZMA_Alone/LzmaBenchCon.cpp +0 -311
  810. data/ext/p7zip/CPP/7zip/Compress/LZMA_Alone/LzmaBenchCon.h +0 -20
  811. data/ext/p7zip/CPP/7zip/Compress/LZMA_Alone/makefile +0 -173
  812. data/ext/p7zip/CPP/7zip/Compress/Lzx86Converter.cpp +0 -90
  813. data/ext/p7zip/CPP/7zip/Compress/Lzx86Converter.h +0 -46
  814. data/ext/p7zip/CPP/7zip/Compress/RangeCoder.h +0 -205
  815. data/ext/p7zip/CPP/7zip/Compress/RangeCoderBit.h +0 -114
  816. data/ext/p7zip/CPP/7zip/Crypto/Sha1.cpp +0 -229
  817. data/ext/p7zip/CPP/7zip/Crypto/Sha1.h +0 -68
  818. data/ext/p7zip/CPP/7zip/PREMAKE/generate.sh +0 -18
  819. data/ext/p7zip/CPP/7zip/PREMAKE/premake4.lua +0 -263
  820. data/ext/p7zip/CPP/7zip/QMAKE/7ZA/7ZA.pro +0 -228
  821. data/ext/p7zip/CPP/7zip/QMAKE/7ZA/7ZA_osx.pro +0 -228
  822. data/ext/p7zip/CPP/7zip/QMAKE/test_emul/test_emul.pro +0 -26
  823. data/ext/p7zip/CPP/7zip/TEST/TestUI/TestUI.cpp +0 -560
  824. data/ext/p7zip/CPP/7zip/TEST/TestUI/makefile +0 -33
  825. data/ext/p7zip/CPP/7zip/TEST/TestUI/makefile.depend +0 -577
  826. data/ext/p7zip/CPP/7zip/TEST/TestUI/makefile.list +0 -16
  827. data/ext/p7zip/CPP/Common/Buffer.h +0 -77
  828. data/ext/p7zip/CPP/Common/Types.h +0 -11
  829. data/ext/p7zip/CPP/Windows/COM.cpp +0 -37
  830. data/ext/p7zip/CPP/Windows/COM.h +0 -69
  831. data/ext/p7zip/CPP/Windows/Clipboard.cpp +0 -160
  832. data/ext/p7zip/CPP/Windows/Clipboard.h +0 -28
  833. data/ext/p7zip/CPP/Windows/CommonDialog.h +0 -19
  834. data/ext/p7zip/CPP/Windows/Control/ComboBox.h +0 -82
  835. data/ext/p7zip/CPP/Windows/Control/Controls.cpp +0 -515
  836. data/ext/p7zip/CPP/Windows/Control/Dialog.cpp +0 -560
  837. data/ext/p7zip/CPP/Windows/Control/Dialog.h +0 -179
  838. data/ext/p7zip/CPP/Windows/Control/DialogImpl.h +0 -73
  839. data/ext/p7zip/CPP/Windows/Control/Edit.h +0 -24
  840. data/ext/p7zip/CPP/Windows/Control/ListView.h +0 -164
  841. data/ext/p7zip/CPP/Windows/Control/ProgressBar.h +0 -34
  842. data/ext/p7zip/CPP/Windows/Control/Static.h +0 -23
  843. data/ext/p7zip/CPP/Windows/Control/StatusBar.h +0 -56
  844. data/ext/p7zip/CPP/Windows/Control/Window2.cpp +0 -211
  845. data/ext/p7zip/CPP/Windows/Control/Window2.h +0 -111
  846. data/ext/p7zip/CPP/Windows/DLL.cpp +0 -193
  847. data/ext/p7zip/CPP/Windows/DLL.h +0 -48
  848. data/ext/p7zip/CPP/Windows/Error.cpp +0 -58
  849. data/ext/p7zip/CPP/Windows/Error.h +0 -33
  850. data/ext/p7zip/CPP/Windows/Menu.h +0 -4
  851. data/ext/p7zip/CPP/Windows/PropVariantConversions.cpp +0 -142
  852. data/ext/p7zip/CPP/Windows/PropVariantConversions.h +0 -14
  853. data/ext/p7zip/CPP/Windows/Registry.cpp +0 -313
  854. data/ext/p7zip/CPP/Windows/Registry.h +0 -113
  855. data/ext/p7zip/CPP/Windows/ResourceString.h +0 -22
  856. data/ext/p7zip/CPP/Windows/Shell.h +0 -21
  857. data/ext/p7zip/CPP/Windows/Time.cpp +0 -88
  858. data/ext/p7zip/CPP/Windows/Time.h +0 -21
  859. data/ext/p7zip/CPP/Windows/Window.cpp +0 -101
  860. data/ext/p7zip/CPP/Windows/Window.h +0 -43
  861. data/ext/p7zip/CPP/myWindows/initguid.h +0 -4
  862. data/ext/p7zip/CPP/myWindows/makefile +0 -21
  863. data/ext/p7zip/CPP/myWindows/makefile.depend +0 -32
  864. data/ext/p7zip/CPP/myWindows/makefile.list +0 -28
  865. data/ext/p7zip/CPP/myWindows/myAddExeFlag.cpp +0 -20
  866. data/ext/p7zip/CPP/myWindows/myGetTickCount.cpp +0 -8
  867. data/ext/p7zip/CPP/myWindows/mySplitCommandLine.cpp +0 -82
  868. data/ext/p7zip/CPP/myWindows/test_emul.cpp +0 -745
  869. data/ext/p7zip/CPP/myWindows/wine_GetXXXDefaultLangID.cpp +0 -741
  870. data/ext/p7zip/DOCS/MANUAL/switches/charset.htm +0 -49
  871. data/ext/p7zip/DOCS/Methods.txt +0 -152
  872. data/ext/p7zip/DOCS/lzma.txt +0 -598
  873. data/ext/p7zip/contrib/VirtualFileSystemForMidnightCommander/ChangeLog +0 -41
  874. data/ext/p7zip/contrib/VirtualFileSystemForMidnightCommander/readme +0 -21
  875. data/ext/p7zip/contrib/VirtualFileSystemForMidnightCommander/readme.u7z +0 -30
  876. data/ext/p7zip/contrib/VirtualFileSystemForMidnightCommander/u7z +0 -133
  877. data/ext/p7zip/contrib/gzip-like_CLI_wrapper_for_7z/README +0 -21
  878. data/ext/p7zip/contrib/gzip-like_CLI_wrapper_for_7z/check/check.sh +0 -117
  879. data/ext/p7zip/contrib/gzip-like_CLI_wrapper_for_7z/check/files.tar +0 -0
  880. data/ext/p7zip/contrib/gzip-like_CLI_wrapper_for_7z/man1/p7zip.1 +0 -33
  881. data/ext/p7zip/contrib/gzip-like_CLI_wrapper_for_7z/p7zip +0 -144
  882. data/ext/p7zip/contrib/qnx630sp3/qnx630sp3-shared +0 -14
  883. data/ext/p7zip/contrib/qnx630sp3/qnx630sp3-static +0 -10
  884. data/ext/p7zip/integration_context_menu.txt +0 -51
  885. data/ext/p7zip/makefile.rules +0 -661
  886. /data/ext/p7zip/{DOCS → DOC}/7zFormat.txt +0 -0
  887. /data/ext/p7zip/{DOCS → DOC}/unRarLicense.txt +0 -0
@@ -2,20 +2,22 @@
2
2
 
3
3
  #include "StdAfx.h"
4
4
 
5
- #include "../../../../C/CpuArch.h"
5
+ #include "../../../Common/ComTry.h"
6
+ #include "../../../Common/IntToString.h"
7
+ #include "../../../Common/StringToInt.h"
8
+ #include "../../../Common/UTFConvert.h"
9
+ #include "../../../Common/Wildcard.h"
6
10
 
7
- #include "Common/ComTry.h"
8
- #include "Common/IntToString.h"
9
-
10
- #include "Windows/PropVariant.h"
11
- #include "Windows/Time.h"
11
+ #include "../../../Windows/PropVariant.h"
12
+ #include "../../../Windows/TimeUtils.h"
12
13
 
13
14
  #include "../../Common/LimitedStreams.h"
14
15
  #include "../../Common/ProgressUtils.h"
15
16
  #include "../../Common/StreamUtils.h"
17
+ #include "../../Common/UniqBlocks.h"
16
18
 
17
19
  #include "../../Crypto/RandGen.h"
18
- #include "../../Crypto/Sha1.h"
20
+ #include "../../Crypto/Sha1Cls.h"
19
21
 
20
22
  #include "WimHandler.h"
21
23
 
@@ -24,125 +26,213 @@ using namespace NWindows;
24
26
  namespace NArchive {
25
27
  namespace NWim {
26
28
 
27
- struct CSha1Hash
28
- {
29
- Byte Hash[kHashSize];
30
- };
31
-
32
- struct CHashList
33
- {
34
- CRecordVector<CSha1Hash> Digests;
35
- CIntVector Sorted;
36
-
37
- int AddUnique(const CSha1Hash &h);
38
- };
39
-
40
- int CHashList::AddUnique(const CSha1Hash &h)
29
+ static int AddUniqHash(const CStreamInfo *streams, CUIntVector &sorted, const Byte *h, int streamIndexForInsert)
41
30
  {
42
- int left = 0, right = Sorted.Size();
31
+ unsigned left = 0, right = sorted.Size();
43
32
  while (left != right)
44
33
  {
45
- int mid = (left + right) / 2;
46
- int index = Sorted[mid];
47
- UInt32 i;
48
- const Byte *hash2 = Digests[index].Hash;
34
+ unsigned mid = (left + right) / 2;
35
+ unsigned index = sorted[mid];
36
+ const Byte *hash2 = streams[index].Hash;
37
+
38
+ unsigned i;
49
39
  for (i = 0; i < kHashSize; i++)
50
- if (h.Hash[i] != hash2[i])
40
+ if (h[i] != hash2[i])
51
41
  break;
42
+
52
43
  if (i == kHashSize)
53
44
  return index;
54
- if (h.Hash[i] < hash2[i])
45
+
46
+ if (h[i] < hash2[i])
55
47
  right = mid;
56
48
  else
57
49
  left = mid + 1;
58
50
  }
59
- Sorted.Insert(left, Digests.Add(h));
51
+
52
+ if (streamIndexForInsert >= 0)
53
+ sorted.Insert(left, streamIndexForInsert);
54
+
60
55
  return -1;
61
56
  }
62
57
 
63
- struct CUpdateItem
58
+
59
+ struct CAltStream
64
60
  {
61
+ int UpdateIndex;
62
+ int HashIndex;
63
+ UInt64 Size;
65
64
  UString Name;
65
+ bool Skip;
66
+
67
+ CAltStream(): UpdateIndex(-1), HashIndex(-1), Skip(false) {}
68
+ };
69
+
70
+
71
+ struct CMetaItem
72
+ {
73
+ int UpdateIndex;
74
+ int HashIndex;
75
+
66
76
  UInt64 Size;
67
77
  FILETIME CTime;
68
78
  FILETIME ATime;
69
79
  FILETIME MTime;
70
80
  UInt32 Attrib;
81
+ UInt64 FileID;
82
+ UInt64 VolID;
83
+
84
+ UString Name;
85
+ UString ShortName;
86
+
87
+ int SecurityId; // -1: means no secutity ID
71
88
  bool IsDir;
72
- int HashIndex;
89
+ bool Skip;
90
+ unsigned NumSkipAltStreams;
91
+ CObjectVector<CAltStream> AltStreams;
92
+
93
+ CByteBuffer Reparse;
94
+
95
+ unsigned GetNumAltStreams() const { return AltStreams.Size() - NumSkipAltStreams; }
96
+ CMetaItem(): UpdateIndex(-1), HashIndex(-1), SecurityId(-1),
97
+ FileID(0), VolID(0),
98
+ Skip(false), NumSkipAltStreams(0) {}
99
+ };
100
+
101
+
102
+ static int Compare_HardLink_MetaItems(const CMetaItem &a1, const CMetaItem &a2)
103
+ {
104
+ if (a1.VolID < a2.VolID) return -1;
105
+ if (a1.VolID > a2.VolID) return 1;
106
+ if (a1.FileID < a2.FileID) return -1;
107
+ if (a1.FileID > a2.FileID) return 1;
108
+ if (a1.Size < a2.Size) return -1;
109
+ if (a1.Size > a2.Size) return 1;
110
+ return ::CompareFileTime(&a1.MTime, &a2.MTime);
111
+ }
112
+
113
+
114
+ static int AddToHardLinkList(const CObjectVector<CMetaItem> &metaItems, unsigned indexOfItem, CUIntVector &indexes)
115
+ {
116
+ const CMetaItem &mi = metaItems[indexOfItem];
117
+ unsigned left = 0, right = indexes.Size();
118
+ while (left != right)
119
+ {
120
+ unsigned mid = (left + right) / 2;
121
+ unsigned index = indexes[mid];
122
+ int comp = Compare_HardLink_MetaItems(mi, metaItems[index]);
123
+ if (comp == 0)
124
+ return index;
125
+ if (comp < 0)
126
+ right = mid;
127
+ else
128
+ left = mid + 1;
129
+ }
130
+ indexes.Insert(left, indexOfItem);
131
+ return -1;
132
+ }
73
133
 
74
- CUpdateItem(): HashIndex(-1) {}
134
+
135
+ struct CUpdateItem
136
+ {
137
+ unsigned CallbackIndex; // index in callback
138
+
139
+ int MetaIndex; // index in in MetaItems[]
140
+
141
+ int AltStreamIndex; // index in CMetaItem::AltStreams vector
142
+ // -1: if not alt stream?
143
+
144
+ int InArcIndex; // >= 0, if we use OLD Data
145
+ // -1, if we use NEW Data
146
+
147
+ CUpdateItem(): MetaIndex(-1), AltStreamIndex(-1), InArcIndex(-1) {}
75
148
  };
76
149
 
150
+
77
151
  struct CDir
78
152
  {
79
- int Index;
80
- UString Name;
153
+ int MetaIndex;
81
154
  CObjectVector<CDir> Dirs;
82
- CIntVector Files;
83
-
84
- CDir(): Index(-1) {}
85
- bool IsLeaf() const { return Index >= 0; }
86
- UInt64 GetNumDirs() const;
87
- UInt64 GetNumFiles() const;
88
- CDir* AddDir(CObjectVector<CUpdateItem> &items, const UString &name, int index);
155
+ CUIntVector Files; // indexes in MetaItems[]
156
+
157
+ CDir(): MetaIndex(-1) {}
158
+ unsigned GetNumDirs() const;
159
+ unsigned GetNumFiles() const;
160
+ UInt64 GetTotalSize(const CObjectVector<CMetaItem> &metaItems) const;
161
+ bool FindDir(const CObjectVector<CMetaItem> &items, const UString &name, unsigned &index);
89
162
  };
90
163
 
91
- UInt64 CDir::GetNumDirs() const
164
+ /* imagex counts Junctions as files (not as dirs).
165
+ We suppose that it's not correct */
166
+
167
+ unsigned CDir::GetNumDirs() const
92
168
  {
93
- UInt64 num = Dirs.Size();
94
- for (int i = 0; i < Dirs.Size(); i++)
169
+ unsigned num = Dirs.Size();
170
+ FOR_VECTOR (i, Dirs)
95
171
  num += Dirs[i].GetNumDirs();
96
172
  return num;
97
173
  }
98
174
 
99
- UInt64 CDir::GetNumFiles() const
175
+ unsigned CDir::GetNumFiles() const
100
176
  {
101
- UInt64 num = Files.Size();
102
- for (int i = 0; i < Dirs.Size(); i++)
177
+ unsigned num = Files.Size();
178
+ FOR_VECTOR (i, Dirs)
103
179
  num += Dirs[i].GetNumFiles();
104
180
  return num;
105
181
  }
106
182
 
107
- CDir* CDir::AddDir(CObjectVector<CUpdateItem> &items, const UString &name, int index)
183
+ UInt64 CDir::GetTotalSize(const CObjectVector<CMetaItem> &metaItems) const
184
+ {
185
+ UInt64 sum = 0;
186
+ unsigned i;
187
+ for (i = 0; i < Files.Size(); i++)
188
+ sum += metaItems[Files[i]].Size;
189
+ for (i = 0; i < Dirs.Size(); i++)
190
+ sum += Dirs[i].GetTotalSize(metaItems);
191
+ return sum;
192
+ }
193
+
194
+ bool CDir::FindDir(const CObjectVector<CMetaItem> &items, const UString &name, unsigned &index)
108
195
  {
109
- int left = 0, right = Dirs.Size();
196
+ unsigned left = 0, right = Dirs.Size();
110
197
  while (left != right)
111
198
  {
112
- int mid = (left + right) / 2;
113
- CDir &d = Dirs[mid];
114
- int compare = name.CompareNoCase(d.IsLeaf() ? items[Dirs[mid].Index].Name : d.Name);
115
- if (compare == 0)
199
+ unsigned mid = (left + right) / 2;
200
+ int comp = CompareFileNames(name, items[Dirs[mid].MetaIndex].Name);
201
+ if (comp == 0)
116
202
  {
117
- if (index >= 0)
118
- d.Index = index;
119
- return &d;
203
+ index = mid;
204
+ return true;
120
205
  }
121
- if (compare < 0)
206
+ if (comp < 0)
122
207
  right = mid;
123
208
  else
124
209
  left = mid + 1;
125
210
  }
126
- Dirs.Insert(left, CDir());
127
- CDir &d = Dirs[left];
128
- d.Index = index;
129
- if (index < 0)
130
- d.Name = name;
131
- return &d;
211
+ index = left;
212
+ return false;
132
213
  }
133
214
 
134
215
 
135
- STDMETHODIMP COutHandler::GetFileTimeType(UInt32 *type)
216
+ STDMETHODIMP CHandler::GetFileTimeType(UInt32 *type)
136
217
  {
137
218
  *type = NFileTimeType::kWindows;
138
219
  return S_OK;
139
220
  }
140
221
 
141
- static HRESULT GetTime(IArchiveUpdateCallback *callback, int index, PROPID propID, FILETIME &ft)
222
+
223
+ HRESULT CHandler::GetOutProperty(IArchiveUpdateCallback *callback, UInt32 callbackIndex, Int32 arcIndex, PROPID propID, PROPVARIANT *value)
224
+ {
225
+ if (arcIndex >= 0)
226
+ return GetProperty(arcIndex, propID, value);
227
+ return callback->GetProperty(callbackIndex, propID, value);
228
+ }
229
+
230
+
231
+ HRESULT CHandler::GetTime(IArchiveUpdateCallback *callback, UInt32 callbackIndex, Int32 arcIndex, PROPID propID, FILETIME &ft)
142
232
  {
143
233
  ft.dwLowDateTime = ft.dwHighDateTime = 0;
144
234
  NCOM::CPropVariant prop;
145
- RINOK(callback->GetProperty(index, propID, &prop));
235
+ RINOK(GetOutProperty(callback, callbackIndex, arcIndex, propID, &prop));
146
236
  if (prop.vt == VT_FILETIME)
147
237
  ft = prop.filetime;
148
238
  else if (prop.vt != VT_EMPTY)
@@ -150,6 +240,38 @@ static HRESULT GetTime(IArchiveUpdateCallback *callback, int index, PROPID propI
150
240
  return S_OK;
151
241
  }
152
242
 
243
+
244
+ static HRESULT GetRootTime(
245
+ IArchiveGetRootProps *callback,
246
+ IArchiveGetRootProps *arcRoot,
247
+ PROPID propID, FILETIME &ft)
248
+ {
249
+ NCOM::CPropVariant prop;
250
+ if (callback)
251
+ {
252
+ RINOK(callback->GetRootProp(propID, &prop));
253
+ if (prop.vt == VT_FILETIME)
254
+ {
255
+ ft = prop.filetime;
256
+ return S_OK;
257
+ }
258
+ if (prop.vt != VT_EMPTY)
259
+ return E_INVALIDARG;
260
+ }
261
+ if (arcRoot)
262
+ {
263
+ RINOK(arcRoot->GetRootProp(propID, &prop));
264
+ if (prop.vt == VT_FILETIME)
265
+ {
266
+ ft = prop.filetime;
267
+ return S_OK;
268
+ }
269
+ if (prop.vt != VT_EMPTY)
270
+ return E_INVALIDARG;
271
+ }
272
+ return S_OK;
273
+ }
274
+
153
275
  #define Set16(p, d) SetUi16(p, d)
154
276
  #define Set32(p, d) SetUi32(p, d)
155
277
  #define Set64(p, d) SetUi64(p, d)
@@ -162,6 +284,7 @@ void CResource::WriteTo(Byte *p) const
162
284
  Set64(p + 16, UnpackSize);
163
285
  }
164
286
 
287
+
165
288
  void CHeader::WriteTo(Byte *p) const
166
289
  {
167
290
  memcpy(p, kSignature, kSignatureSize);
@@ -181,6 +304,7 @@ void CHeader::WriteTo(Byte *p) const
181
304
  memset(p + 0x94, 0, 60);
182
305
  }
183
306
 
307
+
184
308
  void CStreamInfo::WriteTo(Byte *p) const
185
309
  {
186
310
  Resource.WriteTo(p);
@@ -189,6 +313,7 @@ void CStreamInfo::WriteTo(Byte *p) const
189
313
  memcpy(p + 0x1E, Hash, kHashSize);
190
314
  }
191
315
 
316
+
192
317
  class CInStreamWithSha1:
193
318
  public ISequentialInStream,
194
319
  public CMyUnknownImp
@@ -217,132 +342,334 @@ STDMETHODIMP CInStreamWithSha1::Read(void *data, UInt32 size, UInt32 *processedS
217
342
  HRESULT result = _stream->Read(data, size, &realProcessedSize);
218
343
  _size += realProcessedSize;
219
344
  _sha.Update((const Byte *)data, realProcessedSize);
220
- if (processedSize != NULL)
345
+ if (processedSize)
221
346
  *processedSize = realProcessedSize;
222
347
  return result;
223
348
  }
224
349
 
350
+
225
351
  static void SetFileTimeToMem(Byte *p, const FILETIME &ft)
226
352
  {
227
353
  Set32(p, ft.dwLowDateTime);
228
354
  Set32(p + 4, ft.dwHighDateTime);
229
355
  }
230
356
 
231
- static size_t WriteItem(const CUpdateItem &item, Byte *p, const Byte *hash)
357
+ static size_t WriteItem_Dummy(const CMetaItem &item)
232
358
  {
233
- int fileNameLen = item.Name.Length() * 2;
234
- int fileNameLen2 = (fileNameLen == 0 ? fileNameLen : fileNameLen + 2);
359
+ if (item.Skip)
360
+ return 0;
361
+ unsigned fileNameLen = item.Name.Len() * 2;
362
+ // we write fileNameLen + 2 + 2 to be same as original WIM.
363
+ unsigned fileNameLen2 = (fileNameLen == 0 ? 0 : fileNameLen + 2);
235
364
 
236
- size_t totalLen = ((kDirRecordSize + fileNameLen2 + 6) & ~7);
237
- if (p)
365
+ unsigned shortNameLen = item.ShortName.Len() * 2;
366
+ unsigned shortNameLen2 = (shortNameLen == 0 ? 2 : shortNameLen + 4);
367
+
368
+ size_t totalLen = ((kDirRecordSize + fileNameLen2 + shortNameLen2 + 6) & ~7);
369
+ if (item.GetNumAltStreams() != 0)
238
370
  {
239
- memset(p, 0, totalLen);
240
- Set64(p, totalLen);
241
- Set64(p + 8, item.Attrib);
242
- Set32(p + 0xC, (UInt32)(Int32)-1); // item.SecurityId
243
- // Set64(p + 0x10, 0); // subdirOffset
244
- SetFileTimeToMem(p + 0x28, item.CTime);
245
- SetFileTimeToMem(p + 0x30, item.ATime);
246
- SetFileTimeToMem(p + 0x38, item.MTime);
247
- if (hash)
248
- memcpy(p + 0x40, hash, kHashSize);
249
- /*
250
- else
251
- memset(p + 0x40, 0, kHashSize);
252
- */
253
- // Set16(p + 98, 0); // shortNameLen
254
- Set16(p + 100, (UInt16)fileNameLen);
255
- for (int i = 0; i * 2 < fileNameLen; i++)
256
- Set16(p + kDirRecordSize + i * 2, item.Name[i]);
371
+ if (!item.IsDir)
372
+ {
373
+ UInt32 curLen = (((0x26 + 0) + 6) & ~7);
374
+ totalLen += curLen;
375
+ }
376
+ FOR_VECTOR (i, item.AltStreams)
377
+ {
378
+ const CAltStream &ss = item.AltStreams[i];
379
+ if (ss.Skip)
380
+ continue;
381
+ fileNameLen = ss.Name.Len() * 2;
382
+ fileNameLen2 = (fileNameLen == 0 ? 0 : fileNameLen + 2 + 2);
383
+ UInt32 curLen = (((0x26 + fileNameLen2) + 6) & ~7);
384
+ totalLen += curLen;
385
+ }
257
386
  }
258
387
  return totalLen;
259
388
  }
260
389
 
261
- static void WriteTree(const CDir &tree, CRecordVector<CSha1Hash> &digests,
262
- CUpdateItem &defaultDirItem,
263
- CObjectVector<CUpdateItem> &updateItems, Byte *dest, size_t &pos)
390
+
391
+ static size_t WriteItem(const CStreamInfo *streams, const CMetaItem &item, Byte *p)
264
392
  {
265
- int i;
266
- for (i = 0; i < tree.Files.Size(); i++)
393
+ if (item.Skip)
394
+ return 0;
395
+ unsigned fileNameLen = item.Name.Len() * 2;
396
+ unsigned fileNameLen2 = (fileNameLen == 0 ? 0 : fileNameLen + 2);
397
+ unsigned shortNameLen = item.ShortName.Len() * 2;
398
+ unsigned shortNameLen2 = (shortNameLen == 0 ? 2 : shortNameLen + 4);
399
+
400
+ size_t totalLen = ((kDirRecordSize + fileNameLen2 + shortNameLen2 + 6) & ~7);
401
+
402
+ memset(p, 0, totalLen);
403
+ Set64(p, totalLen);
404
+ Set64(p + 8, item.Attrib);
405
+ Set32(p + 0xC, (Int32)item.SecurityId);
406
+ SetFileTimeToMem(p + 0x28, item.CTime);
407
+ SetFileTimeToMem(p + 0x30, item.ATime);
408
+ SetFileTimeToMem(p + 0x38, item.MTime);
409
+
410
+ /* WIM format probably doesn't support hard links to symbolic links.
411
+ In these cases it just stores symbolic links (REPARSE TAGS).
412
+ Check it in new versions of WIM software form MS !!!
413
+ We also follow that scheme */
414
+
415
+ if (item.Reparse.Size() != 0)
416
+ {
417
+ UInt32 tag = GetUi32(item.Reparse);
418
+ Set32(p + 0x58, tag);
419
+ // Set32(p + 0x5C, 0); // probably it's always ZERO
420
+ }
421
+ else if (item.FileID != 0)
422
+ {
423
+ Set64(p + 0x58, item.FileID);
424
+ }
425
+
426
+ Set16(p + 0x62, (UInt16)shortNameLen);
427
+ Set16(p + 0x64, (UInt16)fileNameLen);
428
+ unsigned i;
429
+ for (i = 0; i * 2 < fileNameLen; i++)
430
+ Set16(p + kDirRecordSize + i * 2, item.Name[i]);
431
+ for (i = 0; i * 2 < shortNameLen; i++)
432
+ Set16(p + kDirRecordSize + fileNameLen2 + i * 2, item.ShortName[i]);
433
+
434
+ if (item.GetNumAltStreams() == 0)
435
+ {
436
+ if (item.HashIndex >= 0)
437
+ memcpy(p + 0x40, streams[item.HashIndex].Hash, kHashSize);
438
+ }
439
+ else
267
440
  {
268
- const CUpdateItem &ui = updateItems[tree.Files[i]];
269
- pos += WriteItem(ui, dest ? dest + pos : NULL,
270
- ui.HashIndex >= 0 ? digests[ui.HashIndex].Hash : NULL);
441
+ Set16(p + 0x60, (UInt16)(item.GetNumAltStreams() + (item.IsDir ? 0 : 1)));
442
+ p += totalLen;
443
+
444
+ if (!item.IsDir)
445
+ {
446
+ UInt32 curLen = (((0x26 + 0) + 6) & ~7);
447
+ memset(p, 0, curLen);
448
+ Set64(p, curLen);
449
+ if (item.HashIndex >= 0)
450
+ memcpy(p + 0x10, streams[item.HashIndex].Hash, kHashSize);
451
+ totalLen += curLen;
452
+ p += curLen;
453
+ }
454
+
455
+ FOR_VECTOR (si, item.AltStreams)
456
+ {
457
+ const CAltStream &ss = item.AltStreams[si];
458
+ if (ss.Skip)
459
+ continue;
460
+
461
+ fileNameLen = ss.Name.Len() * 2;
462
+ fileNameLen2 = (fileNameLen == 0 ? 0 : fileNameLen + 2 + 2);
463
+ UInt32 curLen = (((0x26 + fileNameLen2) + 6) & ~7);
464
+ memset(p, 0, curLen);
465
+
466
+ Set64(p, curLen);
467
+ if (ss.HashIndex >= 0)
468
+ memcpy(p + 0x10, streams[ss.HashIndex].Hash, kHashSize);
469
+ Set16(p + 0x24, (UInt16)fileNameLen);
470
+ for (i = 0; i * 2 < fileNameLen; i++)
471
+ Set16(p + 0x26 + i * 2, ss.Name[i]);
472
+ totalLen += curLen;
473
+ p += curLen;
474
+ }
271
475
  }
476
+
477
+ return totalLen;
478
+ }
272
479
 
273
- size_t posStart = pos;
480
+
481
+ struct CDb
482
+ {
483
+ CMetaItem DefaultDirItem;
484
+ const CStreamInfo *Hashes;
485
+ CObjectVector<CMetaItem> MetaItems;
486
+ CRecordVector<CUpdateItem> UpdateItems;
487
+ CUIntVector UpdateIndexes; /* indexes in UpdateItems in order of writing data streams
488
+ to disk (the order of tree items). */
489
+
490
+ size_t WriteTree_Dummy(const CDir &tree) const;
491
+ void WriteTree(const CDir &tree, Byte *dest, size_t &pos) const;
492
+ void WriteOrderList(const CDir &tree);
493
+ };
494
+
495
+
496
+ size_t CDb::WriteTree_Dummy(const CDir &tree) const
497
+ {
498
+ unsigned i;
499
+ size_t pos = 0;
500
+ for (i = 0; i < tree.Files.Size(); i++)
501
+ pos += WriteItem_Dummy(MetaItems[tree.Files[i]]);
274
502
  for (i = 0; i < tree.Dirs.Size(); i++)
275
503
  {
276
- const CDir &subfolder = tree.Dirs[i];
277
- CUpdateItem *item = &defaultDirItem;
278
- if (subfolder.IsLeaf())
279
- item = &updateItems[subfolder.Index];
280
- else
281
- defaultDirItem.Name = subfolder.Name;
282
- pos += WriteItem(*item, NULL, NULL);
504
+ const CDir &subDir = tree.Dirs[i];
505
+ pos += WriteItem_Dummy(MetaItems[subDir.MetaIndex]);
506
+ pos += WriteTree_Dummy(subDir);
283
507
  }
508
+ return pos + 8;
509
+ }
510
+
511
+
512
+ void CDb::WriteTree(const CDir &tree, Byte *dest, size_t &pos) const
513
+ {
514
+ unsigned i;
515
+ for (i = 0; i < tree.Files.Size(); i++)
516
+ pos += WriteItem(Hashes, MetaItems[tree.Files[i]], dest + pos);
284
517
 
285
- if (dest)
286
- Set64(dest + pos, 0);
518
+ size_t posStart = pos;
519
+ for (i = 0; i < tree.Dirs.Size(); i++)
520
+ pos += WriteItem_Dummy(MetaItems[tree.Dirs[i].MetaIndex]);
521
+
522
+ Set64(dest + pos, 0);
287
523
 
288
524
  pos += 8;
289
525
 
290
526
  for (i = 0; i < tree.Dirs.Size(); i++)
291
527
  {
292
- const CDir &subfolder = tree.Dirs[i];
293
- if (dest)
528
+ const CDir &subDir = tree.Dirs[i];
529
+ const CMetaItem &metaItem = MetaItems[subDir.MetaIndex];
530
+ bool needCreateTree = (metaItem.Reparse.Size() == 0)
531
+ || !subDir.Files.IsEmpty()
532
+ || !subDir.Dirs.IsEmpty();
533
+ size_t len = WriteItem(Hashes, metaItem, dest + posStart);
534
+ posStart += len;
535
+ if (needCreateTree)
294
536
  {
295
- CUpdateItem *item = &defaultDirItem;
296
- if (subfolder.IsLeaf())
297
- item = &updateItems[subfolder.Index];
298
- else
299
- defaultDirItem.Name = subfolder.Name;
300
- size_t len = WriteItem(*item, dest + posStart, NULL);
301
- Set64(dest + posStart + 0x10, pos);
302
- posStart += len;
537
+ Set64(dest + posStart - len + 0x10, pos); // subdirOffset
538
+ WriteTree(subDir, dest, pos);
303
539
  }
304
- WriteTree(subfolder, digests, defaultDirItem, updateItems, dest, pos);
305
540
  }
306
541
  }
307
542
 
308
- static void AddTag(AString &s, const char *name, const AString &value)
543
+
544
+ void CDb::WriteOrderList(const CDir &tree)
545
+ {
546
+ if (tree.MetaIndex >= 0)
547
+ {
548
+ const CMetaItem &mi = MetaItems[tree.MetaIndex];
549
+ if (mi.UpdateIndex >= 0)
550
+ UpdateIndexes.Add(mi.UpdateIndex);
551
+ FOR_VECTOR (si, mi.AltStreams)
552
+ UpdateIndexes.Add(mi.AltStreams[si].UpdateIndex);
553
+ }
554
+
555
+ unsigned i;
556
+ for (i = 0; i < tree.Files.Size(); i++)
557
+ {
558
+ const CMetaItem &mi = MetaItems[tree.Files[i]];
559
+ UpdateIndexes.Add(mi.UpdateIndex);
560
+ FOR_VECTOR (si, mi.AltStreams)
561
+ UpdateIndexes.Add(mi.AltStreams[si].UpdateIndex);
562
+ }
563
+
564
+ for (i = 0; i < tree.Dirs.Size(); i++)
565
+ WriteOrderList(tree.Dirs[i]);
566
+ }
567
+
568
+
569
+ static void AddTag_ToString(AString &s, const char *name, const char *value)
309
570
  {
310
- s += "<";
571
+ s += '<';
311
572
  s += name;
312
- s += ">";
573
+ s += '>';
313
574
  s += value;
314
- s += "</";
575
+ s += '<';
576
+ s += '/';
315
577
  s += name;
316
- s += ">";
578
+ s += '>';
579
+ }
580
+
581
+
582
+ static void AddTagUInt64_ToString(AString &s, const char *name, UInt64 value)
583
+ {
584
+ char temp[32];
585
+ ConvertUInt64ToString(value, temp);
586
+ AddTag_ToString(s, name, temp);
587
+ }
588
+
589
+
590
+ static CXmlItem &AddUniqueTag(CXmlItem &parentItem, const char *name)
591
+ {
592
+ int index = parentItem.FindSubTag(name);
593
+ if (index < 0)
594
+ {
595
+ CXmlItem &subItem = parentItem.SubItems.AddNew();
596
+ subItem.IsTag = true;
597
+ subItem.Name = name;
598
+ return subItem;
599
+ }
600
+ CXmlItem &subItem = parentItem.SubItems[index];
601
+ subItem.SubItems.Clear();
602
+ return subItem;
317
603
  }
318
604
 
319
- static void AddTagUInt64(AString &s, const char *name, UInt64 value)
605
+
606
+ static void AddTag_UInt64_2(CXmlItem &item, UInt64 value)
320
607
  {
608
+ CXmlItem &subItem = item.SubItems.AddNew();
609
+ subItem.IsTag = false;
321
610
  char temp[32];
322
611
  ConvertUInt64ToString(value, temp);
323
- AddTag(s, name, temp);
612
+ subItem.Name = temp;
613
+ }
614
+
615
+
616
+ static void AddTag_UInt64(CXmlItem &parentItem, const char *name, UInt64 value)
617
+ {
618
+ AddTag_UInt64_2(AddUniqueTag(parentItem, name), value);
619
+ }
620
+
621
+
622
+ static void AddTag_Hex(CXmlItem &item, const char *name, UInt32 value)
623
+ {
624
+ item.IsTag = true;
625
+ item.Name = name;
626
+ char temp[16];
627
+ temp[0] = '0';
628
+ temp[1] = 'x';
629
+ ConvertUInt32ToHex8Digits(value, temp + 2);
630
+ CXmlItem &subItem = item.SubItems.AddNew();
631
+ subItem.IsTag = false;
632
+ subItem.Name = temp;
633
+ }
634
+
635
+
636
+ static void AddTag_Time_2(CXmlItem &item, const FILETIME &ft)
637
+ {
638
+ AddTag_Hex(item.SubItems.AddNew(), "HIGHPART", ft.dwHighDateTime);
639
+ AddTag_Hex(item.SubItems.AddNew(), "LOWPART", ft.dwLowDateTime);
640
+ }
641
+
642
+
643
+ static void AddTag_Time(CXmlItem &parentItem, const char *name, const FILETIME &ft)
644
+ {
645
+ AddTag_Time_2(AddUniqueTag(parentItem, name), ft);
324
646
  }
325
647
 
326
- static AString TimeToXml(FILETIME &ft)
648
+
649
+ static void AddTag_String_IfEmpty(CXmlItem &parentItem, const char *name, const char *value)
327
650
  {
328
- AString res;
329
- char temp[16] = { '0', 'x' };
330
- ConvertUInt32ToHexWithZeros(ft.dwHighDateTime, temp + 2);
331
- AddTag(res, "HIGHPART", temp);
332
- ConvertUInt32ToHexWithZeros(ft.dwLowDateTime, temp + 2);
333
- AddTag(res, "LOWPART", temp);
334
- return res;
651
+ int index = parentItem.FindSubTag(name);
652
+ if (index >= 0)
653
+ return;
654
+ CXmlItem &tag = parentItem.SubItems.AddNew();
655
+ tag.IsTag = true;
656
+ tag.Name = name;
657
+ CXmlItem &subItem = tag.SubItems.AddNew();
658
+ subItem.IsTag = false;
659
+ subItem.Name = value;
335
660
  }
336
661
 
662
+
337
663
  void CHeader::SetDefaultFields(bool useLZX)
338
664
  {
339
- Version = kWimVersion;
340
- Flags = NHeaderFlags::kRpFix;
665
+ Version = k_Version_NonSolid;
666
+ Flags = NHeaderFlags::kReparsePointFixup;
341
667
  ChunkSize = 0;
342
668
  if (useLZX)
343
669
  {
344
670
  Flags |= NHeaderFlags::kCompression | NHeaderFlags::kLZX;
345
671
  ChunkSize = kChunkSize;
672
+ ChunkSizeBits = kChunkSizeBits;
346
673
  }
347
674
  g_RandomGenerator.Generate(Guid, 16);
348
675
  PartNumber = 1;
@@ -355,284 +682,1220 @@ void CHeader::SetDefaultFields(bool useLZX)
355
682
  IntegrityResource.Clear();
356
683
  }
357
684
 
358
- static HRESULT UpdateArchive(ISequentialOutStream *seqOutStream,
359
- CDir &rootFolder,
360
- CObjectVector<CUpdateItem> &updateItems,
361
- IArchiveUpdateCallback *callback)
685
+
686
+ static void AddTrees(CObjectVector<CDir> &trees, CObjectVector<CMetaItem> &metaItems, const CMetaItem &ri, int curTreeIndex)
362
687
  {
363
- CMyComPtr<IOutStream> outStream;
364
- RINOK(seqOutStream->QueryInterface(IID_IOutStream, (void **)&outStream));
365
- if (!outStream)
366
- return E_NOTIMPL;
688
+ while (curTreeIndex >= (int)trees.Size())
689
+ trees.AddNew().Dirs.AddNew().MetaIndex = metaItems.Add(ri);
690
+ }
367
691
 
368
- UInt64 complexity = 0;
369
692
 
370
- int i;
371
- for (i = 0; i < updateItems.Size(); i++)
372
- complexity += updateItems[i].Size;
693
+ #define IS_LETTER_CHAR(c) ((c) >= 'a' && (c) <= 'z' || (c) >= 'A' && (c) <= 'Z')
373
694
 
374
- RINOK(callback->SetTotal(complexity));
375
695
 
376
- NCompress::CCopyCoder *copyCoderSpec = new NCompress::CCopyCoder;
377
- CMyComPtr<ICompressCoder> copyCoder = copyCoderSpec;
378
696
 
379
- CLocalProgress *lps = new CLocalProgress;
380
- CMyComPtr<ICompressProgressInfo> progress = lps;
381
- lps->Init(callback, true);
697
+ STDMETHODIMP CHandler::UpdateItems(ISequentialOutStream *outSeqStream, UInt32 numItems, IArchiveUpdateCallback *callback)
698
+ {
699
+ COM_TRY_BEGIN
382
700
 
383
- complexity = 0;
701
+ if (!IsUpdateSupported())
702
+ return E_NOTIMPL;
384
703
 
385
- bool useCompression = false;
704
+ bool isUpdate = (_volumes.Size() != 0);
705
+ int defaultImageIndex = _defaultImageNumber - 1;
706
+ bool showImageNumber;
386
707
 
387
- CHeader header;
388
- header.SetDefaultFields(useCompression);
389
- Byte buf[kHeaderSizeMax];
390
- header.WriteTo(buf);
391
- RINOK(WriteStream(outStream, buf, kHeaderSizeMax));
708
+ if (isUpdate)
709
+ {
710
+ showImageNumber = _showImageNumber;
711
+ if (!showImageNumber)
712
+ defaultImageIndex = _db.IndexOfUserImage;
713
+ }
714
+ else
715
+ {
716
+ showImageNumber = (_set_use_ShowImageNumber && _set_showImageNumber);
717
+ if (!showImageNumber)
718
+ defaultImageIndex = 0;
719
+ }
392
720
 
393
- CHashList hashes;
394
- CObjectVector<CStreamInfo> streams;
721
+ if (defaultImageIndex >= kNumImagesMaxUpdate)
722
+ return E_NOTIMPL;
395
723
 
396
- UInt64 curPos = kHeaderSizeMax;
397
- UInt64 unpackTotalSize = 0;
398
- for (i = 0; i < updateItems.Size(); i++)
399
- {
400
- lps->InSize = lps->OutSize = complexity;
401
- RINOK(lps->SetCur());
724
+ CMyComPtr<IOutStream> outStream;
725
+ RINOK(outSeqStream->QueryInterface(IID_IOutStream, (void **)&outStream));
726
+ if (!outStream)
727
+ return E_NOTIMPL;
728
+ if (!callback)
729
+ return E_FAIL;
402
730
 
403
- CUpdateItem &ui = updateItems[i];
404
- if (ui.IsDir || ui.Size == 0)
405
- continue;
731
+ CDb db;
732
+ CObjectVector<CDir> trees;
406
733
 
407
- CInStreamWithSha1 *inShaStreamSpec = new CInStreamWithSha1;
408
- CMyComPtr<ISequentialInStream> inShaStream = inShaStreamSpec;
734
+ CMetaItem ri; // default DIR item
735
+ FILETIME ftCur;
736
+ NTime::GetCurUtcFileTime(ftCur);
737
+ ri.MTime = ri.ATime = ri.CTime = ftCur;
738
+ ri.Attrib = FILE_ATTRIBUTE_DIRECTORY;
739
+ ri.IsDir = true;
409
740
 
410
- {
411
- CMyComPtr<ISequentialInStream> fileInStream;
412
- HRESULT res = callback->GetStream(i, &fileInStream);
413
- if (res != S_FALSE)
414
- {
415
- RINOK(res);
416
- inShaStreamSpec->SetStream(fileInStream);
417
- fileInStream.Release();
418
- inShaStreamSpec->Init();
419
- UInt64 offsetBlockSize = 0;
420
- if (useCompression)
421
- {
422
- for (UInt64 t = kChunkSize; t < ui.Size; t += kChunkSize)
423
- {
424
- Byte buf[8];
425
- SetUi32(buf, (UInt32)t);
426
- RINOK(WriteStream(outStream, buf, 4));
427
- offsetBlockSize += 4;
428
- }
429
- }
430
741
 
431
- RINOK(copyCoder->Code(inShaStream, outStream, NULL, NULL, progress));
432
- ui.Size = copyCoderSpec->TotalSize;
742
+ // ---------- Detect changed images ----------
433
743
 
434
- CSha1Hash hash;
435
- unpackTotalSize += ui.Size;
436
- UInt64 packSize = offsetBlockSize + ui.Size;
437
- inShaStreamSpec->Final(hash.Hash);
438
- int index = hashes.AddUnique(hash);
439
- if (index >= 0)
744
+ unsigned i;
745
+ CBoolVector isChangedImage;
746
+ {
747
+ CUIntVector numUnchangedItemsInImage;
748
+ for (i = 0; i < _db.Images.Size(); i++)
749
+ {
750
+ numUnchangedItemsInImage.Add(0);
751
+ isChangedImage.Add(false);
752
+ }
753
+
754
+ for (i = 0; i < numItems; i++)
755
+ {
756
+ UInt32 indexInArchive;
757
+ Int32 newData, newProps;
758
+ RINOK(callback->GetUpdateItemInfo(i, &newData, &newProps, &indexInArchive));
759
+ if (newProps == 0)
760
+ {
761
+ if (indexInArchive >= _db.SortedItems.Size())
762
+ continue;
763
+ const CItem &item = _db.Items[_db.SortedItems[indexInArchive]];
764
+ if (newData == 0)
440
765
  {
441
- ui.HashIndex = index;
442
- streams[index].RefCount++;
443
- outStream->Seek(-(Int64)packSize, STREAM_SEEK_CUR, &curPos);
444
- outStream->SetSize(curPos);
766
+ if (item.ImageIndex >= 0)
767
+ numUnchangedItemsInImage[item.ImageIndex]++;
445
768
  }
446
769
  else
447
770
  {
448
- ui.HashIndex = hashes.Digests.Size() - 1;
449
- CStreamInfo s;
450
- s.Resource.PackSize = packSize;
451
- s.Resource.Offset = curPos;
452
- s.Resource.UnpackSize = ui.Size;
453
- s.Resource.Flags = 0;
454
- if (useCompression)
455
- s.Resource.Flags = NResourceFlags::Compressed;
456
- s.PartNumber = 1;
457
- s.RefCount = 1;
458
- memcpy(s.Hash, hash.Hash, kHashSize);
459
- streams.Add(s);
460
- curPos += packSize;
771
+ // oldProps & newData. Current version of 7-Zip doesn't use it
772
+ if (item.ImageIndex >= 0)
773
+ isChangedImage[item.ImageIndex] = true;
461
774
  }
462
775
  }
463
- fileInStream.Release();
464
- complexity += ui.Size;
465
- RINOK(callback->SetOperationResult(NArchive::NUpdate::NOperationResult::kOK));
776
+ else if (!showImageNumber)
777
+ {
778
+ if (defaultImageIndex >= 0 && defaultImageIndex < (int)isChangedImage.Size())
779
+ isChangedImage[defaultImageIndex] = true;
780
+ }
781
+ else
782
+ {
783
+ NCOM::CPropVariant prop;
784
+ RINOK(callback->GetProperty(i, kpidPath, &prop));
785
+
786
+ if (prop.vt != VT_BSTR)
787
+ return E_INVALIDARG;
788
+ const wchar_t *path = prop.bstrVal;
789
+ if (!path)
790
+ return E_INVALIDARG;
791
+
792
+ const wchar_t *end;
793
+ UInt64 val = ConvertStringToUInt64(path, &end);
794
+ if (end == path)
795
+ return E_INVALIDARG;
796
+ if (val == 0 || val > kNumImagesMaxUpdate)
797
+ return E_INVALIDARG;
798
+ wchar_t c = *end;
799
+ if (c != 0 && c != ':' && c != L'/' && c != WCHAR_PATH_SEPARATOR)
800
+ return E_INVALIDARG;
801
+ unsigned imageIndex = (unsigned)val - 1;
802
+ if (imageIndex < _db.Images.Size())
803
+ isChangedImage[imageIndex] = true;
804
+ if (_defaultImageNumber > 0 && val != (unsigned)_defaultImageNumber)
805
+ return E_INVALIDARG;
806
+ }
466
807
  }
808
+
809
+ for (i = 0; i < _db.Images.Size(); i++)
810
+ if (!isChangedImage[i])
811
+ isChangedImage[i] = _db.GetNumUserItemsInImage(i) != numUnchangedItemsInImage[i];
467
812
  }
468
813
 
469
-
470
- CUpdateItem ri;
471
- FILETIME ft;
472
- NTime::GetCurUtcFileTime(ft);
473
- ri.MTime = ri.ATime = ri.CTime = ft;
474
- ri.Attrib = FILE_ATTRIBUTE_DIRECTORY;
475
-
476
- const UInt32 kSecuritySize = 8;
477
- size_t pos = kSecuritySize;
478
- WriteTree(rootFolder, hashes.Digests, ri, updateItems, NULL, pos);
479
-
480
- CByteBuffer meta;
481
- meta.SetCapacity(pos);
482
-
483
- // we can write 0 here only if there is no security data, imageX does it,
484
- // but some programs expect size = 8
485
- Set32((Byte *)meta, 8); // size of security data
486
- Set32((Byte *)meta + 4, 0); // num security entries
487
-
488
- pos = kSecuritySize;
489
- WriteTree(rootFolder, hashes.Digests, ri, updateItems, (Byte *)meta, pos);
490
-
814
+ if (defaultImageIndex >= 0)
491
815
  {
492
- NCrypto::NSha1::CContext sha;
493
- sha.Init();
494
- sha.Update((const Byte *)meta, pos);
495
- CSha1Hash digest;
496
- sha.Final(digest.Hash);
497
-
498
- CStreamInfo s;
499
- s.Resource.PackSize = pos;
500
- s.Resource.Offset = curPos;
501
- s.Resource.UnpackSize = pos;
502
- s.Resource.Flags = NResourceFlags::kMetadata;
503
- s.PartNumber = 1;
504
- s.RefCount = 1;
505
- memcpy(s.Hash, digest.Hash, kHashSize);
506
- streams.Add(s);
507
- RINOK(WriteStream(outStream, (const Byte *)meta, pos));
508
- meta.Free();
509
- curPos += pos;
816
+ for (i = 0; i < _db.Images.Size(); i++)
817
+ if ((int)i != defaultImageIndex)
818
+ isChangedImage[i] = false;
510
819
  }
511
820
 
821
+ CMyComPtr<IArchiveGetRawProps> getRawProps;
822
+ callback->QueryInterface(IID_IArchiveGetRawProps, (void **)&getRawProps);
512
823
 
513
- header.OffsetResource.UnpackSize = header.OffsetResource.PackSize = (UInt64)streams.Size() * kStreamInfoSize;
514
- header.OffsetResource.Offset = curPos;
515
- header.OffsetResource.Flags = NResourceFlags::kMetadata;
824
+ CMyComPtr<IArchiveGetRootProps> getRootProps;
825
+ callback->QueryInterface(IID_IArchiveGetRootProps, (void **)&getRootProps);
516
826
 
517
- for (i = 0; i < streams.Size(); i++)
827
+ CObjectVector<CUniqBlocks> secureBlocks;
828
+
829
+ if (!showImageNumber && (getRootProps || isUpdate) &&
830
+ (
831
+ defaultImageIndex >= (int)isChangedImage.Size()
832
+ || defaultImageIndex < 0 // test it
833
+ || isChangedImage[defaultImageIndex]
834
+ ))
518
835
  {
519
- Byte buf[kStreamInfoSize];
520
- streams[i].WriteTo(buf);
521
- RINOK(WriteStream(outStream, buf, kStreamInfoSize));
522
- curPos += kStreamInfoSize;
836
+ // Fill Root Item: Metadata and security
837
+ CMetaItem rootItem = ri;
838
+ {
839
+ const void *data = NULL;
840
+ UInt32 dataSize = 0;
841
+ UInt32 propType = 0;
842
+ if (getRootProps)
843
+ {
844
+ RINOK(getRootProps->GetRootRawProp(kpidNtSecure, &data, &dataSize, &propType));
845
+ }
846
+ if (dataSize == 0 && isUpdate)
847
+ {
848
+ RINOK(GetRootRawProp(kpidNtSecure, &data, &dataSize, &propType));
849
+ }
850
+ if (dataSize != 0)
851
+ {
852
+ if (propType != NPropDataType::kRaw)
853
+ return E_FAIL;
854
+ while (defaultImageIndex >= (int)secureBlocks.Size())
855
+ secureBlocks.AddNew();
856
+ CUniqBlocks &secUniqBlocks = secureBlocks[defaultImageIndex];
857
+ rootItem.SecurityId = secUniqBlocks.AddUniq((const Byte *)data, dataSize);
858
+ }
859
+ }
860
+
861
+ IArchiveGetRootProps *thisGetRoot = isUpdate ? this : NULL;
862
+
863
+ RINOK(GetRootTime(getRootProps, thisGetRoot, kpidCTime, rootItem.CTime));
864
+ RINOK(GetRootTime(getRootProps, thisGetRoot, kpidATime, rootItem.ATime));
865
+ RINOK(GetRootTime(getRootProps, thisGetRoot, kpidMTime, rootItem.MTime));
866
+
867
+ {
868
+ NCOM::CPropVariant prop;
869
+ if (getRootProps)
870
+ {
871
+ RINOK(getRootProps->GetRootProp(kpidAttrib, &prop));
872
+ if (prop.vt == VT_UI4)
873
+ rootItem.Attrib = prop.ulVal;
874
+ else if (prop.vt != VT_EMPTY)
875
+ return E_INVALIDARG;
876
+ }
877
+ if (prop.vt == VT_EMPTY && thisGetRoot)
878
+ {
879
+ RINOK(GetRootProp(kpidAttrib, &prop));
880
+ if (prop.vt == VT_UI4)
881
+ rootItem.Attrib = prop.ulVal;
882
+ else if (prop.vt != VT_EMPTY)
883
+ return E_INVALIDARG;
884
+ }
885
+ rootItem.Attrib |= FILE_ATTRIBUTE_DIRECTORY;
886
+ }
887
+
888
+ AddTrees(trees, db.MetaItems, ri, defaultImageIndex);
889
+ db.MetaItems[trees[defaultImageIndex].Dirs[0].MetaIndex] = rootItem;
523
890
  }
524
891
 
525
- AString xml = "<WIM>";
526
- AddTagUInt64(xml, "TOTALBYTES", curPos);
527
- xml += "<IMAGE INDEX=\"1\"><NAME>1</NAME>";
528
- AddTagUInt64(xml, "DIRCOUNT", rootFolder.GetNumDirs());
529
- AddTagUInt64(xml, "FILECOUNT", rootFolder.GetNumFiles());
530
- AddTagUInt64(xml, "TOTALBYTES", unpackTotalSize);
531
- NTime::GetCurUtcFileTime(ft);
532
- AddTag(xml, "CREATIONTIME", TimeToXml(ft));
533
- AddTag(xml, "LASTMODIFICATIONTIME", TimeToXml(ft));
534
- xml += "</IMAGE></WIM>";
535
-
536
- size_t xmlSize = (xml.Length() + 1) * 2;
537
- meta.SetCapacity(xmlSize);
538
- Set16((Byte *)meta, 0xFEFF);
539
- for (i = 0; i < xml.Length(); i++)
540
- Set16((Byte *)meta + 2 + i * 2, xml[i]);
541
- RINOK(WriteStream(outStream, (const Byte *)meta, xmlSize));
542
- meta.Free();
543
-
544
- header.XmlResource.UnpackSize = header.XmlResource.PackSize = xmlSize;
545
- header.XmlResource.Offset = curPos;
546
- header.XmlResource.Flags = NResourceFlags::kMetadata;
547
-
548
- outStream->Seek(0, STREAM_SEEK_SET, NULL);
549
- header.WriteTo(buf);
550
- return WriteStream(outStream, buf, kHeaderSizeMax);
551
- }
552
-
553
- STDMETHODIMP COutHandler::UpdateItems(ISequentialOutStream *outStream, UInt32 numItems,
554
- IArchiveUpdateCallback *callback)
555
- {
556
- COM_TRY_BEGIN
557
- CObjectVector<CUpdateItem> updateItems;
558
- CDir tree;
559
- tree.Dirs.Add(CDir());
560
- CDir &rootFolder = tree.Dirs.Back();
892
+ // ---------- Request Metadata for changed items ----------
561
893
 
562
- for (UInt32 i = 0; i < numItems; i++)
894
+ UString fileName;
895
+
896
+ for (i = 0; i < numItems; i++)
563
897
  {
564
898
  CUpdateItem ui;
565
- Int32 newData, newProps;
566
899
  UInt32 indexInArchive;
567
- if (!callback)
568
- return E_FAIL;
900
+ Int32 newData, newProps;
569
901
  RINOK(callback->GetUpdateItemInfo(i, &newData, &newProps, &indexInArchive));
570
902
 
903
+ if (newData == 0 || newProps == 0)
904
+ {
905
+ if (indexInArchive >= _db.SortedItems.Size())
906
+ continue;
907
+
908
+ const CItem &item = _db.Items[_db.SortedItems[indexInArchive]];
909
+
910
+ if (item.ImageIndex >= 0)
911
+ {
912
+ if (!isChangedImage[item.ImageIndex])
913
+ {
914
+ if (newData == 0 && newProps == 0)
915
+ continue;
916
+ return E_FAIL;
917
+ }
918
+ }
919
+ else
920
+ {
921
+ // if deleted item was not renamed, we just skip it
922
+ if (newProps == 0)
923
+ continue;
924
+ if (item.StreamIndex >= 0)
925
+ {
926
+ // we don't support property change for SolidBig streams
927
+ if (_db.DataStreams[item.StreamIndex].Resource.IsSolidBig())
928
+ return E_NOTIMPL;
929
+ }
930
+ }
931
+
932
+ if (newData == 0)
933
+ ui.InArcIndex = indexInArchive;
934
+ }
935
+
936
+ // we set arcIndex only if we must use old props
937
+ Int32 arcIndex = (newProps ? -1 : indexInArchive);
938
+
939
+ bool isDir = false;
571
940
  {
572
941
  NCOM::CPropVariant prop;
573
- RINOK(callback->GetProperty(i, kpidIsDir, &prop));
574
- if (prop.vt == VT_EMPTY)
575
- ui.IsDir = false;
576
- else if (prop.vt != VT_BOOL)
942
+ RINOK(GetOutProperty(callback, i, arcIndex, kpidIsDir, &prop));
943
+ if (prop.vt == VT_BOOL)
944
+ isDir = (prop.boolVal != VARIANT_FALSE);
945
+ else if (prop.vt != VT_EMPTY)
577
946
  return E_INVALIDARG;
578
- else
579
- ui.IsDir = (prop.boolVal != VARIANT_FALSE);
580
947
  }
581
-
948
+
949
+ bool isAltStream = false;
582
950
  {
583
951
  NCOM::CPropVariant prop;
584
- RINOK(callback->GetProperty(i, kpidAttrib, &prop));
585
- if (prop.vt == VT_EMPTY)
586
- ui.Attrib = (ui.IsDir ? FILE_ATTRIBUTE_DIRECTORY : 0);
587
- else if (prop.vt != VT_UI4)
952
+ RINOK(GetOutProperty(callback, i, arcIndex, kpidIsAltStream, &prop));
953
+ if (prop.vt == VT_BOOL)
954
+ isAltStream = (prop.boolVal != VARIANT_FALSE);
955
+ else if (prop.vt != VT_EMPTY)
588
956
  return E_INVALIDARG;
589
- else
590
- ui.Attrib = prop.ulVal;
591
957
  }
592
-
593
- RINOK(GetTime(callback, i, kpidCTime, ui.CTime));
594
- RINOK(GetTime(callback, i, kpidATime, ui.ATime));
595
- RINOK(GetTime(callback, i, kpidMTime, ui.MTime));
596
958
 
959
+ if (isDir && isAltStream)
960
+ return E_INVALIDARG;
961
+
962
+ UInt64 size = 0;
963
+ UInt64 iNode = 0;
964
+
965
+ if (!isDir)
597
966
  {
967
+ if (!newData)
968
+ {
969
+ NCOM::CPropVariant prop;
970
+ GetProperty(indexInArchive, kpidINode, &prop);
971
+ if (prop.vt == VT_UI8)
972
+ iNode = prop.uhVal.QuadPart;
973
+ }
974
+
598
975
  NCOM::CPropVariant prop;
599
- RINOK(callback->GetProperty(i, kpidSize, &prop));
600
- if (prop.vt != VT_UI8)
976
+
977
+ if (newData)
978
+ {
979
+ RINOK(callback->GetProperty(i, kpidSize, &prop));
980
+ }
981
+ else
982
+ {
983
+ RINOK(GetProperty(indexInArchive, kpidSize, &prop));
984
+ }
985
+
986
+ if (prop.vt == VT_UI8)
987
+ size = prop.uhVal.QuadPart;
988
+ else if (prop.vt != VT_EMPTY)
601
989
  return E_INVALIDARG;
602
- ui.Size = prop.uhVal.QuadPart;
603
990
  }
604
991
 
605
- UString path;
606
- NCOM::CPropVariant prop;
607
- RINOK(callback->GetProperty(i, kpidPath, &prop));
608
- if (prop.vt == VT_BSTR)
609
- path = prop.bstrVal;
610
- else if (prop.vt != VT_EMPTY)
992
+ {
993
+ NCOM::CPropVariant propPath;
994
+ const wchar_t *path = NULL;
995
+ RINOK(GetOutProperty(callback, i, arcIndex, kpidPath, &propPath));
996
+ if (propPath.vt == VT_BSTR)
997
+ path = propPath.bstrVal;
998
+ else if (propPath.vt != VT_EMPTY)
999
+ return E_INVALIDARG;
1000
+
1001
+ if (!path)
611
1002
  return E_INVALIDARG;
612
1003
 
613
- CDir *curItem = &rootFolder;
614
- int len = path.Length();
615
- UString fileName;
616
- for (int j = 0; j < len; j++)
1004
+ CDir *curItem = NULL;
1005
+ bool isRootImageDir = false;
1006
+ fileName.Empty();
1007
+
1008
+ int imageIndex;
1009
+
1010
+ if (!showImageNumber)
617
1011
  {
618
- wchar_t c = path[j];
619
- if (c == WCHAR_PATH_SEPARATOR || c == L'/')
1012
+ imageIndex = defaultImageIndex;
1013
+ AddTrees(trees, db.MetaItems, ri, imageIndex);
1014
+ curItem = &trees[imageIndex].Dirs[0];
1015
+ }
1016
+ else
1017
+ {
1018
+ const wchar_t *end;
1019
+ UInt64 val = ConvertStringToUInt64(path, &end);
1020
+ if (end == path)
1021
+ return E_INVALIDARG;
1022
+ if (val == 0 || val > kNumImagesMaxUpdate)
1023
+ return E_INVALIDARG;
1024
+
1025
+ imageIndex = (int)val - 1;
1026
+ if (imageIndex < (int)isChangedImage.Size())
1027
+ if (!isChangedImage[imageIndex])
1028
+ return E_FAIL;
1029
+
1030
+ AddTrees(trees, db.MetaItems, ri, imageIndex);
1031
+ curItem = &trees[imageIndex].Dirs[0];
1032
+ wchar_t c = *end;
1033
+
1034
+ if (c == 0)
620
1035
  {
621
- curItem = curItem->AddDir(updateItems, fileName, -1);
622
- fileName.Empty();
1036
+ if (!isDir || isAltStream)
1037
+ return E_INVALIDARG;
1038
+ ui.MetaIndex = curItem->MetaIndex;
1039
+ isRootImageDir = true;
1040
+ }
1041
+ else if (c == ':')
1042
+ {
1043
+ if (isDir || !isAltStream)
1044
+ return E_INVALIDARG;
1045
+ ui.MetaIndex = curItem->MetaIndex;
1046
+ CAltStream ss;
1047
+ ss.Size = size;
1048
+ ss.Name = end + 1;
1049
+ ss.UpdateIndex = db.UpdateItems.Size();
1050
+ ui.AltStreamIndex = db.MetaItems[ui.MetaIndex].AltStreams.Add(ss);
1051
+ }
1052
+ else if (c == WCHAR_PATH_SEPARATOR || c == L'/')
1053
+ {
1054
+ path = end + 1;
1055
+ if (*path == 0)
1056
+ return E_INVALIDARG;
623
1057
  }
624
1058
  else
625
- fileName += c;
1059
+ return E_INVALIDARG;
1060
+ }
1061
+
1062
+ if (ui.MetaIndex < 0)
1063
+ {
1064
+ for (;;)
1065
+ {
1066
+ wchar_t c = *path++;
1067
+ if (c == 0)
1068
+ break;
1069
+ if (c == WCHAR_PATH_SEPARATOR || c == L'/')
1070
+ {
1071
+ unsigned indexOfDir;
1072
+ if (!curItem->FindDir(db.MetaItems, fileName, indexOfDir))
1073
+ {
1074
+ CDir &dir = curItem->Dirs.InsertNew(indexOfDir);
1075
+ dir.MetaIndex = db.MetaItems.Add(ri);
1076
+ db.MetaItems.Back().Name = fileName;
1077
+ }
1078
+ curItem = &curItem->Dirs[indexOfDir];
1079
+ fileName.Empty();
1080
+ }
1081
+ else
1082
+ fileName += c;
1083
+ }
1084
+
1085
+ if (isAltStream)
1086
+ {
1087
+ int colonPos = fileName.Find(L':');
1088
+ if (colonPos < 0)
1089
+ return E_INVALIDARG;
1090
+
1091
+ // we want to support cases of c::substream, where c: is drive name
1092
+ if (colonPos == 1 && fileName[2] == L':' && IS_LETTER_CHAR(fileName[0]))
1093
+ colonPos = 2;
1094
+ const UString mainName = fileName.Left(colonPos);
1095
+ unsigned indexOfDir;
1096
+
1097
+ if (mainName.IsEmpty())
1098
+ ui.MetaIndex = curItem->MetaIndex;
1099
+ else if (curItem->FindDir(db.MetaItems, mainName, indexOfDir))
1100
+ ui.MetaIndex = curItem->Dirs[indexOfDir].MetaIndex;
1101
+ else
1102
+ {
1103
+ for (int j = (int)curItem->Files.Size() - 1; j >= 0; j--)
1104
+ {
1105
+ int metaIndex = curItem->Files[j];
1106
+ const CMetaItem &mi = db.MetaItems[metaIndex];
1107
+ if (CompareFileNames(mainName, mi.Name) == 0)
1108
+ {
1109
+ ui.MetaIndex = metaIndex;
1110
+ break;
1111
+ }
1112
+ }
1113
+ }
1114
+
1115
+ if (ui.MetaIndex >= 0)
1116
+ {
1117
+ CAltStream ss;
1118
+ ss.Size = size;
1119
+ ss.Name = fileName.Ptr(colonPos + 1);
1120
+ ss.UpdateIndex = db.UpdateItems.Size();
1121
+ ui.AltStreamIndex = db.MetaItems[ui.MetaIndex].AltStreams.Add(ss);
1122
+ }
1123
+ }
1124
+ }
1125
+
1126
+
1127
+ if (ui.MetaIndex < 0 || isRootImageDir)
1128
+ {
1129
+ if (!isRootImageDir)
1130
+ {
1131
+ ui.MetaIndex = db.MetaItems.Size();
1132
+ db.MetaItems.AddNew();
1133
+ }
1134
+
1135
+ CMetaItem &mi = db.MetaItems[ui.MetaIndex];
1136
+ mi.Size = size;
1137
+ mi.IsDir = isDir;
1138
+ mi.Name = fileName;
1139
+ mi.UpdateIndex = db.UpdateItems.Size();
1140
+ {
1141
+ NCOM::CPropVariant prop;
1142
+ RINOK(GetOutProperty(callback, i, arcIndex, kpidAttrib, &prop));
1143
+ if (prop.vt == VT_EMPTY)
1144
+ mi.Attrib = 0;
1145
+ else if (prop.vt == VT_UI4)
1146
+ mi.Attrib = prop.ulVal;
1147
+ else
1148
+ return E_INVALIDARG;
1149
+ if (isDir)
1150
+ mi.Attrib |= FILE_ATTRIBUTE_DIRECTORY;
1151
+ }
1152
+ RINOK(GetTime(callback, i, arcIndex, kpidCTime, mi.CTime));
1153
+ RINOK(GetTime(callback, i, arcIndex, kpidATime, mi.ATime));
1154
+ RINOK(GetTime(callback, i, arcIndex, kpidMTime, mi.MTime));
1155
+
1156
+ {
1157
+ NCOM::CPropVariant prop;
1158
+ RINOK(GetOutProperty(callback, i, arcIndex, kpidShortName, &prop));
1159
+ if (prop.vt == VT_BSTR)
1160
+ mi.ShortName.SetFromBstr(prop.bstrVal);
1161
+ else if (prop.vt != VT_EMPTY)
1162
+ return E_INVALIDARG;
1163
+ }
1164
+
1165
+ while (imageIndex >= (int)secureBlocks.Size())
1166
+ secureBlocks.AddNew();
1167
+
1168
+ if (!isAltStream && (getRawProps || arcIndex >= 0))
1169
+ {
1170
+ CUniqBlocks &secUniqBlocks = secureBlocks[imageIndex];
1171
+ const void *data;
1172
+ UInt32 dataSize;
1173
+ UInt32 propType;
1174
+
1175
+ data = NULL;
1176
+ dataSize = 0;
1177
+ propType = 0;
1178
+
1179
+ if (arcIndex >= 0)
1180
+ {
1181
+ GetRawProp(arcIndex, kpidNtSecure, &data, &dataSize, &propType);
1182
+ }
1183
+ else
1184
+ {
1185
+ getRawProps->GetRawProp(i, kpidNtSecure, &data, &dataSize, &propType);
1186
+ }
1187
+
1188
+ if (dataSize != 0)
1189
+ {
1190
+ if (propType != NPropDataType::kRaw)
1191
+ return E_FAIL;
1192
+ mi.SecurityId = secUniqBlocks.AddUniq((const Byte *)data, dataSize);
1193
+ }
1194
+
1195
+ data = NULL;
1196
+ dataSize = 0;
1197
+ propType = 0;
1198
+
1199
+ if (arcIndex >= 0)
1200
+ {
1201
+ GetRawProp(arcIndex, kpidNtReparse, &data, &dataSize, &propType);
1202
+ }
1203
+ else
1204
+ {
1205
+ getRawProps->GetRawProp(i, kpidNtReparse, &data, &dataSize, &propType);
1206
+ }
1207
+
1208
+ if (dataSize != 0)
1209
+ {
1210
+ if (propType != NPropDataType::kRaw)
1211
+ return E_FAIL;
1212
+ mi.Reparse.CopyFrom((const Byte *)data, dataSize);
1213
+ }
1214
+ }
1215
+
1216
+ if (!isRootImageDir)
1217
+ {
1218
+ if (isDir)
1219
+ {
1220
+ unsigned indexOfDir;
1221
+ if (curItem->FindDir(db.MetaItems, fileName, indexOfDir))
1222
+ curItem->Dirs[indexOfDir].MetaIndex = ui.MetaIndex;
1223
+ else
1224
+ curItem->Dirs.InsertNew(indexOfDir).MetaIndex = ui.MetaIndex;
1225
+ }
1226
+ else
1227
+ curItem->Files.Add(ui.MetaIndex);
1228
+ }
1229
+ }
1230
+
626
1231
  }
1232
+
1233
+ if (iNode != 0 && ui.MetaIndex >= 0 && ui.AltStreamIndex < 0)
1234
+ db.MetaItems[ui.MetaIndex].FileID = iNode;
1235
+
1236
+ ui.CallbackIndex = i;
1237
+ db.UpdateItems.Add(ui);
1238
+ }
1239
+
1240
+ unsigned numNewImages = trees.Size();
1241
+ for (i = numNewImages; i < isChangedImage.Size(); i++)
1242
+ if (!isChangedImage[i])
1243
+ numNewImages = i + 1;
1244
+
1245
+ AddTrees(trees, db.MetaItems, ri, numNewImages - 1);
1246
+
1247
+ for (i = 0; i < trees.Size(); i++)
1248
+ if (i >= isChangedImage.Size() || isChangedImage[i])
1249
+ db.WriteOrderList(trees[i]);
1250
+
1251
+
1252
+ UInt64 complexity = 0;
1253
+
1254
+ unsigned numDataStreams = _db.DataStreams.Size();
1255
+ CUIntArr streamsRefs(numDataStreams);
1256
+ for (i = 0; i < numDataStreams; i++)
1257
+ streamsRefs[i] = 0;
627
1258
 
628
- ui.Name = fileName;
629
- updateItems.Add(ui);
630
- if (ui.IsDir)
631
- curItem->AddDir(updateItems, fileName, (int)i);
1259
+ // ---------- Calculate Streams Refs Counts in unchanged images
1260
+
1261
+ for (i = 0; i < _db.Images.Size(); i++)
1262
+ {
1263
+ if (isChangedImage[i])
1264
+ continue;
1265
+ complexity += _db.MetaStreams[i].Resource.PackSize;
1266
+ const CImage &image = _db.Images[i];
1267
+ unsigned endItem = image.StartItem + image.NumItems;
1268
+ for (unsigned k = image.StartItem; k < endItem; k++)
1269
+ {
1270
+ const CItem &item = _db.Items[k];
1271
+ if (item.StreamIndex >= 0)
1272
+ streamsRefs[(unsigned)item.StreamIndex]++;
1273
+ }
1274
+ }
1275
+
1276
+
1277
+ // ---------- Update Streams Refs Counts in changed images
1278
+
1279
+ for (i = 0; i < db.UpdateIndexes.Size(); i++)
1280
+ {
1281
+ const CUpdateItem &ui = db.UpdateItems[db.UpdateIndexes[i]];
1282
+
1283
+ if (ui.InArcIndex >= 0)
1284
+ {
1285
+ if ((unsigned)ui.InArcIndex >= _db.SortedItems.Size())
1286
+ continue;
1287
+ const CItem &item = _db.Items[_db.SortedItems[ui.InArcIndex]];
1288
+ if (item.StreamIndex >= 0)
1289
+ streamsRefs[(unsigned)item.StreamIndex]++;
1290
+ }
632
1291
  else
633
- curItem->Files.Add(i);
1292
+ {
1293
+ const CMetaItem &mi = db.MetaItems[ui.MetaIndex];
1294
+ UInt64 size;
1295
+ if (ui.AltStreamIndex < 0)
1296
+ size = mi.Size;
1297
+ else
1298
+ size = mi.AltStreams[ui.AltStreamIndex].Size;
1299
+ complexity += size;
1300
+ }
634
1301
  }
635
- return UpdateArchive(outStream, tree, updateItems, callback);
1302
+
1303
+ // Clear ref counts for SolidBig streams
1304
+
1305
+ for (i = 0; i < _db.DataStreams.Size(); i++)
1306
+ if (_db.DataStreams[i].Resource.IsSolidBig())
1307
+ streamsRefs[i] = 0;
1308
+
1309
+ // Set ref counts for SolidBig streams
1310
+
1311
+ for (i = 0; i < _db.DataStreams.Size(); i++)
1312
+ if (streamsRefs[i] != 0)
1313
+ {
1314
+ const CResource &rs = _db.DataStreams[i].Resource;
1315
+ if (rs.IsSolidSmall())
1316
+ streamsRefs[_db.Solids[rs.SolidIndex].StreamIndex] = 1;
1317
+ }
1318
+
1319
+ for (i = 0; i < _db.DataStreams.Size(); i++)
1320
+ if (streamsRefs[i] != 0)
1321
+ {
1322
+ const CResource &rs = _db.DataStreams[i].Resource;
1323
+ if (!rs.IsSolidSmall())
1324
+ complexity += rs.PackSize;
1325
+ }
1326
+
1327
+ RINOK(callback->SetTotal(complexity));
1328
+ UInt64 totalComplexity = complexity;
1329
+
1330
+ NCompress::CCopyCoder *copyCoderSpec = new NCompress::CCopyCoder;
1331
+ CMyComPtr<ICompressCoder> copyCoder = copyCoderSpec;
1332
+
1333
+ CLocalProgress *lps = new CLocalProgress;
1334
+ CMyComPtr<ICompressProgressInfo> progress = lps;
1335
+ lps->Init(callback, true);
1336
+
1337
+ complexity = 0;
1338
+
1339
+ // bool useResourceCompression = false;
1340
+ // use useResourceCompression only if CHeader::Flags compression is also set
1341
+
1342
+ CHeader header;
1343
+ header.SetDefaultFields(false);
1344
+
1345
+ if (isUpdate)
1346
+ {
1347
+ const CHeader &srcHeader = _volumes[1].Header;
1348
+ header.Flags = srcHeader.Flags;
1349
+ header.Version = srcHeader.Version;
1350
+ header.ChunkSize = srcHeader.ChunkSize;
1351
+ header.ChunkSizeBits = srcHeader.ChunkSizeBits;
1352
+ }
1353
+
1354
+ {
1355
+ Byte buf[kHeaderSizeMax];
1356
+ header.WriteTo(buf);
1357
+ RINOK(WriteStream(outStream, buf, kHeaderSizeMax));
1358
+ }
1359
+
1360
+ UInt64 curPos = kHeaderSizeMax;
1361
+
1362
+ CInStreamWithSha1 *inShaStreamSpec = new CInStreamWithSha1;
1363
+ CMyComPtr<ISequentialInStream> inShaStream = inShaStreamSpec;
1364
+
1365
+ CLimitedSequentialInStream *inStreamLimitedSpec = NULL;
1366
+ CMyComPtr<CLimitedSequentialInStream> inStreamLimited;
1367
+ if (_volumes.Size() == 2)
1368
+ {
1369
+ inStreamLimitedSpec = new CLimitedSequentialInStream;
1370
+ inStreamLimited = inStreamLimitedSpec;
1371
+ inStreamLimitedSpec->SetStream(_volumes[1].Stream);
1372
+ }
1373
+
1374
+
1375
+ CRecordVector<CStreamInfo> streams;
1376
+ CUIntVector sortedHashes; // indexes to streams, sorted by SHA1
1377
+
1378
+ // ---------- Copy unchanged data streams ----------
1379
+
1380
+ UInt64 solidRunOffset = 0;
1381
+ UInt64 curSolidSize = 0;
1382
+
1383
+ for (i = 0; i < _db.DataStreams.Size(); i++)
1384
+ {
1385
+ const CStreamInfo &siOld = _db.DataStreams[i];
1386
+ const CResource &rs = siOld.Resource;
1387
+
1388
+ unsigned numRefs = streamsRefs[i];
1389
+
1390
+ if (numRefs == 0)
1391
+ {
1392
+ if (!rs.IsSolidSmall())
1393
+ continue;
1394
+ if (streamsRefs[_db.Solids[rs.SolidIndex].StreamIndex] == 0)
1395
+ continue;
1396
+ }
1397
+
1398
+ lps->InSize = lps->OutSize = complexity;
1399
+ RINOK(lps->SetCur());
1400
+
1401
+ int streamIndex = streams.Size();
1402
+ CStreamInfo s;
1403
+ s.Resource = rs;
1404
+ s.PartNumber = 1;
1405
+ s.RefCount = numRefs;
1406
+
1407
+ memcpy(s.Hash, siOld.Hash, kHashSize);
1408
+
1409
+ if (rs.IsSolid())
1410
+ {
1411
+ CSolid &ss = _db.Solids[rs.SolidIndex];
1412
+ if (rs.IsSolidSmall())
1413
+ {
1414
+ UInt64 oldOffset = ss.SolidOffset;
1415
+ if (rs.Offset < oldOffset)
1416
+ return E_FAIL;
1417
+ UInt64 relatOffset = rs.Offset - oldOffset;
1418
+ s.Resource.Offset = solidRunOffset + relatOffset;
1419
+ }
1420
+ else
1421
+ {
1422
+ // IsSolidBig
1423
+ solidRunOffset += curSolidSize;
1424
+ curSolidSize = ss.UnpackSize;
1425
+ }
1426
+ }
1427
+ else
1428
+ {
1429
+ solidRunOffset = 0;
1430
+ curSolidSize = 0;
1431
+ }
1432
+
1433
+ if (!rs.IsSolid() || rs.IsSolidSmall())
1434
+ {
1435
+ int find = AddUniqHash(&streams.Front(), sortedHashes, siOld.Hash, streamIndex);
1436
+ if (find >= 0)
1437
+ return E_FAIL; // two streams with same SHA-1
1438
+ }
1439
+
1440
+ if (!rs.IsSolid() || rs.IsSolidBig())
1441
+ {
1442
+ RINOK(_volumes[siOld.PartNumber].Stream->Seek(rs.Offset, STREAM_SEEK_SET, NULL));
1443
+ inStreamLimitedSpec->Init(rs.PackSize);
1444
+ RINOK(copyCoder->Code(inStreamLimited, outStream, NULL, NULL, progress));
1445
+ if (copyCoderSpec->TotalSize != rs.PackSize)
1446
+ return E_FAIL;
1447
+ s.Resource.Offset = curPos;
1448
+ curPos += rs.PackSize;
1449
+ lps->ProgressOffset += rs.PackSize;
1450
+ }
1451
+
1452
+ streams.Add(s);
1453
+ }
1454
+
1455
+
1456
+ // ---------- Write new items ----------
1457
+
1458
+ CUIntVector hlIndexes; // sorted indexes for hard link items
1459
+
1460
+ for (i = 0; i < db.UpdateIndexes.Size(); i++)
1461
+ {
1462
+ lps->InSize = lps->OutSize = complexity;
1463
+ RINOK(lps->SetCur());
1464
+ const CUpdateItem &ui = db.UpdateItems[db.UpdateIndexes[i]];
1465
+ CMetaItem &mi = db.MetaItems[ui.MetaIndex];
1466
+ UInt64 size = 0;
1467
+
1468
+ if (ui.AltStreamIndex >= 0)
1469
+ {
1470
+ if (mi.Skip)
1471
+ continue;
1472
+ size = mi.AltStreams[ui.AltStreamIndex].Size;
1473
+ }
1474
+ else
1475
+ {
1476
+ size = mi.Size;
1477
+ if (mi.IsDir)
1478
+ {
1479
+ // we support LINK files here
1480
+ if (mi.Reparse.Size() == 0)
1481
+ continue;
1482
+ }
1483
+ }
1484
+
1485
+ if (ui.InArcIndex >= 0)
1486
+ {
1487
+ // data streams with OLD Data were written already
1488
+ // we just need to find HashIndex in hashes.
1489
+
1490
+ if ((unsigned)ui.InArcIndex >= _db.SortedItems.Size())
1491
+ return E_FAIL;
1492
+
1493
+ const CItem &item = _db.Items[_db.SortedItems[ui.InArcIndex]];
1494
+
1495
+ if (item.StreamIndex < 0)
1496
+ {
1497
+ if (size == 0)
1498
+ continue;
1499
+ // if (_db.ItemHasStream(item))
1500
+ return E_FAIL;
1501
+ }
1502
+
1503
+ // We support empty file (size = 0, but with stream and SHA-1) from old archive
1504
+
1505
+ const CStreamInfo &siOld = _db.DataStreams[item.StreamIndex];
1506
+
1507
+ int index = AddUniqHash(&streams.Front(), sortedHashes, siOld.Hash, -1);
1508
+ // we must have written that stream already
1509
+ if (index < 0)
1510
+ return E_FAIL;
1511
+
1512
+ if (ui.AltStreamIndex < 0)
1513
+ mi.HashIndex = index;
1514
+ else
1515
+ mi.AltStreams[ui.AltStreamIndex].HashIndex = index;
1516
+
1517
+ continue;
1518
+ }
1519
+
1520
+ CMyComPtr<ISequentialInStream> fileInStream;
1521
+ HRESULT res = callback->GetStream(ui.CallbackIndex, &fileInStream);
1522
+
1523
+ if (res == S_FALSE)
1524
+ {
1525
+ if (ui.AltStreamIndex >= 0)
1526
+ {
1527
+ mi.NumSkipAltStreams++;
1528
+ mi.AltStreams[ui.AltStreamIndex].Skip = true;
1529
+ }
1530
+ else
1531
+ mi.Skip = true;
1532
+ }
1533
+ else
1534
+ {
1535
+ RINOK(res);
1536
+
1537
+ int miIndex = -1;
1538
+
1539
+ if (!fileInStream)
1540
+ {
1541
+ if (!mi.IsDir)
1542
+ return E_INVALIDARG;
1543
+ }
1544
+ else if (ui.AltStreamIndex < 0)
1545
+ {
1546
+ CMyComPtr<IStreamGetProps2> getProps2;
1547
+ fileInStream->QueryInterface(IID_IStreamGetProps2, (void **)&getProps2);
1548
+ if (getProps2)
1549
+ {
1550
+ CStreamFileProps props;
1551
+ if (getProps2->GetProps2(&props) == S_OK)
1552
+ {
1553
+ mi.Attrib = props.Attrib;
1554
+ mi.CTime = props.CTime;
1555
+ mi.ATime = props.ATime;
1556
+ mi.MTime = props.MTime;
1557
+ mi.FileID = props.FileID_Low;
1558
+ if (props.NumLinks <= 1)
1559
+ mi.FileID = 0;
1560
+ mi.VolID = props.VolID;
1561
+ if (mi.FileID != 0)
1562
+ miIndex = AddToHardLinkList(db.MetaItems, ui.MetaIndex, hlIndexes);
1563
+
1564
+ if (props.Size != size && props.Size != (UInt64)(Int64)-1)
1565
+ {
1566
+ Int64 delta = (Int64)props.Size - (Int64)size;
1567
+ Int64 newComplexity = totalComplexity + delta;
1568
+ if (newComplexity > 0)
1569
+ {
1570
+ totalComplexity = newComplexity;
1571
+ callback->SetTotal(totalComplexity);
1572
+ }
1573
+ mi.Size = props.Size;
1574
+ size = props.Size;
1575
+ }
1576
+ }
1577
+ }
1578
+ }
1579
+
1580
+ if (miIndex >= 0)
1581
+ {
1582
+ mi.HashIndex = db.MetaItems[miIndex].HashIndex;
1583
+ if (mi.HashIndex >= 0)
1584
+ streams[mi.HashIndex].RefCount++;
1585
+ // fix for future: maybe we need to check also that real size is equal to size from IStreamGetProps2
1586
+ }
1587
+ else if (ui.AltStreamIndex < 0 && mi.Reparse.Size() != 0)
1588
+ {
1589
+ if (mi.Reparse.Size() < 8)
1590
+ return E_FAIL;
1591
+ NCrypto::NSha1::CContext sha1;
1592
+ sha1.Init();
1593
+ size_t packSize = mi.Reparse.Size() - 8;
1594
+ sha1.Update((const Byte *)mi.Reparse + 8, packSize);
1595
+ Byte hash[kHashSize];
1596
+ sha1.Final(hash);
1597
+
1598
+ int index = AddUniqHash(&streams.Front(), sortedHashes, hash, streams.Size());
1599
+
1600
+ if (index >= 0)
1601
+ streams[index].RefCount++;
1602
+ else
1603
+ {
1604
+ index = streams.Size();
1605
+ RINOK(WriteStream(outStream, (const Byte *)mi.Reparse + 8, packSize));
1606
+ CStreamInfo s;
1607
+ s.Resource.PackSize = packSize;
1608
+ s.Resource.Offset = curPos;
1609
+ s.Resource.UnpackSize = packSize;
1610
+ s.Resource.Flags = 0; // check it
1611
+ /*
1612
+ if (useResourceCompression)
1613
+ s.Resource.Flags = NResourceFlags::Compressed;
1614
+ */
1615
+ s.PartNumber = 1;
1616
+ s.RefCount = 1;
1617
+ memcpy(s.Hash, hash, kHashSize);
1618
+ curPos += packSize;
1619
+
1620
+ streams.Add(s);
1621
+ }
1622
+
1623
+ mi.HashIndex = index;
1624
+ }
1625
+ else
1626
+ {
1627
+ inShaStreamSpec->SetStream(fileInStream);
1628
+ fileInStream.Release();
1629
+ inShaStreamSpec->Init();
1630
+ UInt64 offsetBlockSize = 0;
1631
+ /*
1632
+ if (useResourceCompression)
1633
+ {
1634
+ for (UInt64 t = kChunkSize; t < size; t += kChunkSize)
1635
+ {
1636
+ Byte buf[8];
1637
+ SetUi32(buf, (UInt32)t);
1638
+ RINOK(WriteStream(outStream, buf, 4));
1639
+ offsetBlockSize += 4;
1640
+ }
1641
+ }
1642
+ */
1643
+
1644
+ RINOK(copyCoder->Code(inShaStream, outStream, NULL, NULL, progress));
1645
+ size = copyCoderSpec->TotalSize;
1646
+
1647
+ if (size != 0)
1648
+ {
1649
+ Byte hash[kHashSize];
1650
+ UInt64 packSize = offsetBlockSize + size;
1651
+ inShaStreamSpec->Final(hash);
1652
+
1653
+ int index = AddUniqHash(&streams.Front(), sortedHashes, hash, streams.Size());
1654
+
1655
+ if (index >= 0)
1656
+ {
1657
+ streams[index].RefCount++;
1658
+ outStream->Seek(-(Int64)packSize, STREAM_SEEK_CUR, &curPos);
1659
+ outStream->SetSize(curPos);
1660
+ }
1661
+ else
1662
+ {
1663
+ index = streams.Size();
1664
+ CStreamInfo s;
1665
+ s.Resource.PackSize = packSize;
1666
+ s.Resource.Offset = curPos;
1667
+ s.Resource.UnpackSize = size;
1668
+ s.Resource.Flags = 0;
1669
+ /*
1670
+ if (useResourceCompression)
1671
+ s.Resource.Flags = NResourceFlags::Compressed;
1672
+ */
1673
+ s.PartNumber = 1;
1674
+ s.RefCount = 1;
1675
+ memcpy(s.Hash, hash, kHashSize);
1676
+ curPos += packSize;
1677
+
1678
+ streams.Add(s);
1679
+ }
1680
+
1681
+ if (ui.AltStreamIndex < 0)
1682
+ mi.HashIndex = index;
1683
+ else
1684
+ mi.AltStreams[ui.AltStreamIndex].HashIndex = index;
1685
+ }
1686
+ }
1687
+ }
1688
+ fileInStream.Release();
1689
+ complexity += size;
1690
+ RINOK(callback->SetOperationResult(NArchive::NUpdate::NOperationResult::kOK));
1691
+ }
1692
+
1693
+ while (secureBlocks.Size() < numNewImages)
1694
+ secureBlocks.AddNew();
1695
+
1696
+
1697
+
1698
+ // ---------- Write Images ----------
1699
+
1700
+ for (i = 0; i < numNewImages; i++)
1701
+ {
1702
+ lps->InSize = lps->OutSize = complexity;
1703
+ RINOK(lps->SetCur());
1704
+ if (i < isChangedImage.Size() && !isChangedImage[i])
1705
+ {
1706
+ CStreamInfo s = _db.MetaStreams[i];
1707
+
1708
+ RINOK(_volumes[1].Stream->Seek(s.Resource.Offset, STREAM_SEEK_SET, NULL));
1709
+ inStreamLimitedSpec->Init(s.Resource.PackSize);
1710
+ RINOK(copyCoder->Code(inStreamLimited, outStream, NULL, NULL, progress));
1711
+ if (copyCoderSpec->TotalSize != s.Resource.PackSize)
1712
+ return E_FAIL;
1713
+
1714
+ s.Resource.Offset = curPos;
1715
+ s.PartNumber = 1;
1716
+ s.RefCount = 1;
1717
+ streams.Add(s);
1718
+
1719
+ if (_bootIndex != 0 && _bootIndex == (UInt32)i + 1)
1720
+ {
1721
+ header.MetadataResource = s.Resource;
1722
+ header.BootIndex = _bootIndex;
1723
+ }
1724
+
1725
+ lps->ProgressOffset += s.Resource.PackSize;
1726
+ curPos += s.Resource.PackSize;
1727
+ // printf("\nWrite old image %x\n", i + 1);
1728
+ continue;
1729
+ }
1730
+
1731
+ const CDir &tree = trees[i];
1732
+ const UInt32 kSecuritySize = 8;
1733
+
1734
+ size_t pos = kSecuritySize;
1735
+
1736
+ const CUniqBlocks &secUniqBlocks = secureBlocks[i];
1737
+ const CObjectVector<CByteBuffer> &secBufs = secUniqBlocks.Bufs;
1738
+ pos += (size_t)secUniqBlocks.GetTotalSizeInBytes();
1739
+ pos += secBufs.Size() * 8;
1740
+ pos = (pos + 7) & ~(size_t)7;
1741
+
1742
+ db.DefaultDirItem = ri;
1743
+ pos += db.WriteTree_Dummy(tree);
1744
+
1745
+ CByteArr meta(pos);
1746
+
1747
+ Set32((Byte *)meta + 4, secBufs.Size()); // num security entries
1748
+ pos = kSecuritySize;
1749
+
1750
+ if (secBufs.Size() == 0)
1751
+ {
1752
+ // we can write 0 here only if there is no security data, imageX does it,
1753
+ // but some programs expect size = 8
1754
+ Set32((Byte *)meta, 8); // size of security data
1755
+ // Set32((Byte *)meta, 0);
1756
+ }
1757
+ else
1758
+ {
1759
+ unsigned k;
1760
+ for (k = 0; k < secBufs.Size(); k++, pos += 8)
1761
+ {
1762
+ Set64(meta + pos, secBufs[k].Size());
1763
+ }
1764
+ for (k = 0; k < secBufs.Size(); k++)
1765
+ {
1766
+ const CByteBuffer &buf = secBufs[k];
1767
+ size_t size = buf.Size();
1768
+ if (size != 0)
1769
+ {
1770
+ memcpy(meta + pos, buf, size);
1771
+ pos += size;
1772
+ }
1773
+ }
1774
+ while ((pos & 7) != 0)
1775
+ meta[pos++] = 0;
1776
+ Set32((Byte *)meta, (UInt32)pos); // size of security data
1777
+ }
1778
+
1779
+ db.Hashes = &streams.Front();
1780
+ db.WriteTree(tree, (Byte *)meta, pos);
1781
+
1782
+ {
1783
+ NCrypto::NSha1::CContext sha;
1784
+ sha.Init();
1785
+ sha.Update((const Byte *)meta, pos);
1786
+
1787
+ Byte digest[kHashSize];
1788
+ sha.Final(digest);
1789
+
1790
+ CStreamInfo s;
1791
+ s.Resource.PackSize = pos;
1792
+ s.Resource.Offset = curPos;
1793
+ s.Resource.UnpackSize = pos;
1794
+ s.Resource.Flags = NResourceFlags::kMetadata;
1795
+ s.PartNumber = 1;
1796
+ s.RefCount = 1;
1797
+ memcpy(s.Hash, digest, kHashSize);
1798
+ streams.Add(s);
1799
+
1800
+ if (_bootIndex != 0 && _bootIndex == (UInt32)i + 1)
1801
+ {
1802
+ header.MetadataResource = s.Resource;
1803
+ header.BootIndex = _bootIndex;
1804
+ }
1805
+
1806
+ RINOK(WriteStream(outStream, (const Byte *)meta, pos));
1807
+ meta.Free();
1808
+ curPos += pos;
1809
+ }
1810
+ }
1811
+
1812
+ lps->InSize = lps->OutSize = complexity;
1813
+ RINOK(lps->SetCur());
1814
+
1815
+ header.OffsetResource.UnpackSize = header.OffsetResource.PackSize = (UInt64)streams.Size() * kStreamInfoSize;
1816
+ header.OffsetResource.Offset = curPos;
1817
+ header.OffsetResource.Flags = NResourceFlags::kMetadata;
1818
+
1819
+
1820
+
1821
+ // ---------- Write Streams Info Tables ----------
1822
+
1823
+ for (i = 0; i < streams.Size(); i++)
1824
+ {
1825
+ Byte buf[kStreamInfoSize];
1826
+ streams[i].WriteTo(buf);
1827
+ RINOK(WriteStream(outStream, buf, kStreamInfoSize));
1828
+ curPos += kStreamInfoSize;
1829
+ }
1830
+
1831
+ AString xml = "<WIM>";
1832
+ AddTagUInt64_ToString(xml, "TOTALBYTES", curPos);
1833
+ for (i = 0; i < trees.Size(); i++)
1834
+ {
1835
+ CDir &tree = trees[i];
1836
+
1837
+ CXmlItem item;
1838
+ if (_xmls.Size() == 1)
1839
+ {
1840
+ const CWimXml &_oldXml = _xmls[0];
1841
+ if ((int)i < _oldXml.Images.Size())
1842
+ {
1843
+ // int ttt = _oldXml.Images[i].ItemIndexInXml;
1844
+ item = _oldXml.Xml.Root.SubItems[_oldXml.Images[i].ItemIndexInXml];
1845
+ }
1846
+ }
1847
+ if (i >= isChangedImage.Size() || isChangedImage[i])
1848
+ {
1849
+ char temp[16];
1850
+ if (item.Name.IsEmpty())
1851
+ {
1852
+ ConvertUInt32ToString(i + 1, temp);
1853
+ item.Name = "IMAGE";
1854
+ item.IsTag = true;
1855
+ CXmlProp &prop = item.Props.AddNew();
1856
+ prop.Name = "INDEX";
1857
+ prop.Value = temp;
1858
+ }
1859
+
1860
+ AddTag_String_IfEmpty(item, "NAME", temp);
1861
+ AddTag_UInt64(item, "DIRCOUNT", tree.GetNumDirs() - 1);
1862
+ AddTag_UInt64(item, "FILECOUNT", tree.GetNumFiles());
1863
+ AddTag_UInt64(item, "TOTALBYTES", tree.GetTotalSize(db.MetaItems));
1864
+
1865
+ AddTag_Time(item, "CREATIONTIME", ftCur);
1866
+ AddTag_Time(item, "LASTMODIFICATIONTIME", ftCur);
1867
+ }
1868
+
1869
+ item.AppendTo(xml);
1870
+ }
1871
+ xml += "</WIM>";
1872
+
1873
+ size_t xmlSize;
1874
+ {
1875
+ UString utf16;
1876
+ if (!ConvertUTF8ToUnicode(xml, utf16))
1877
+ return S_FALSE;
1878
+ xmlSize = (utf16.Len() + 1) * 2;
1879
+
1880
+ CByteArr xmlBuf(xmlSize);
1881
+ Set16((Byte *)xmlBuf, 0xFEFF);
1882
+ for (i = 0; i < (unsigned)utf16.Len(); i++)
1883
+ Set16((Byte *)xmlBuf + 2 + i * 2, utf16[i]);
1884
+ RINOK(WriteStream(outStream, (const Byte *)xmlBuf, xmlSize));
1885
+ }
1886
+
1887
+ header.XmlResource.UnpackSize = header.XmlResource.PackSize = xmlSize;
1888
+ header.XmlResource.Offset = curPos;
1889
+ header.XmlResource.Flags = NResourceFlags::kMetadata;
1890
+
1891
+ outStream->Seek(0, STREAM_SEEK_SET, NULL);
1892
+ header.NumImages = trees.Size();
1893
+ {
1894
+ Byte buf[kHeaderSizeMax];
1895
+ header.WriteTo(buf);
1896
+ return WriteStream(outStream, buf, kHeaderSizeMax);
1897
+ }
1898
+
636
1899
  COM_TRY_END
637
1900
  }
638
1901