@appzung/react-native-code-push 7.1.1 → 9.0.2

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 (97) hide show
  1. package/.azurepipelines/build-rn-code-push-1es.yml +104 -0
  2. package/.azurepipelines/test-rn-code-push.yml +94 -0
  3. package/.config/CredScanSuppressions.json +14 -0
  4. package/CONTRIBUTING.md +3 -3
  5. package/CodePush.js +20 -21
  6. package/CodePush.podspec +3 -3
  7. package/README.md +7 -5
  8. package/android/app/build.gradle +3 -1
  9. package/android/app/src/main/AndroidManifest.xml +2 -7
  10. package/android/app/src/main/java/com/microsoft/codepush/react/CodePush.java +14 -5
  11. package/android/app/src/main/java/com/microsoft/codepush/react/CodePushConstants.java +1 -0
  12. package/android/app/src/main/java/com/microsoft/codepush/react/CodePushNativeModule.java +9 -1
  13. package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUpdateUtils.java +18 -10
  14. package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUtils.java +3 -1
  15. package/android/build.gradle +6 -2
  16. package/android/codepush.gradle +72 -26
  17. package/docs/api-js.md +1 -1
  18. package/docs/setup-android.md +27 -3
  19. package/docs/setup-ios.md +1 -1
  20. package/docs/setup-windows.md +23 -0
  21. package/ios/CodePush/CodePush.m +2 -1
  22. package/ios/CodePush/CodePushPackage.m +4 -0
  23. package/ios/CodePush/SSZipArchive/Info.plist +26 -0
  24. package/ios/CodePush/SSZipArchive/README.md +1 -1
  25. package/ios/CodePush/SSZipArchive/SSZipArchive.h +129 -27
  26. package/ios/CodePush/SSZipArchive/SSZipArchive.m +1119 -314
  27. package/ios/CodePush/SSZipArchive/SSZipCommon.h +71 -0
  28. package/ios/CodePush/SSZipArchive/Supporting Files/PrivacyInfo.xcprivacy +23 -0
  29. package/ios/CodePush/SSZipArchive/include/ZipArchive.h +25 -0
  30. package/ios/CodePush/SSZipArchive/minizip/LICENSE +17 -0
  31. package/ios/CodePush/SSZipArchive/minizip/mz.h +273 -0
  32. package/ios/CodePush/SSZipArchive/minizip/mz_compat.c +1306 -0
  33. package/ios/CodePush/SSZipArchive/minizip/mz_compat.h +346 -0
  34. package/ios/CodePush/SSZipArchive/minizip/mz_crypt.c +187 -0
  35. package/ios/CodePush/SSZipArchive/minizip/mz_crypt.h +65 -0
  36. package/ios/CodePush/SSZipArchive/minizip/mz_crypt_apple.c +526 -0
  37. package/ios/CodePush/SSZipArchive/minizip/mz_os.c +348 -0
  38. package/ios/CodePush/SSZipArchive/minizip/mz_os.h +176 -0
  39. package/ios/CodePush/SSZipArchive/minizip/mz_os_posix.c +350 -0
  40. package/ios/CodePush/SSZipArchive/minizip/mz_strm.c +556 -0
  41. package/ios/CodePush/SSZipArchive/minizip/mz_strm.h +132 -0
  42. package/ios/CodePush/SSZipArchive/minizip/mz_strm_buf.c +383 -0
  43. package/ios/CodePush/SSZipArchive/minizip/mz_strm_buf.h +42 -0
  44. package/ios/CodePush/SSZipArchive/minizip/mz_strm_mem.c +269 -0
  45. package/ios/CodePush/SSZipArchive/minizip/mz_strm_mem.h +48 -0
  46. package/ios/CodePush/SSZipArchive/minizip/mz_strm_os.h +40 -0
  47. package/ios/CodePush/SSZipArchive/minizip/mz_strm_os_posix.c +203 -0
  48. package/ios/CodePush/SSZipArchive/minizip/mz_strm_pkcrypt.c +334 -0
  49. package/ios/CodePush/SSZipArchive/minizip/mz_strm_pkcrypt.h +46 -0
  50. package/ios/CodePush/SSZipArchive/minizip/mz_strm_split.c +429 -0
  51. package/ios/CodePush/SSZipArchive/minizip/mz_strm_split.h +43 -0
  52. package/ios/CodePush/SSZipArchive/minizip/mz_strm_wzaes.c +360 -0
  53. package/ios/CodePush/SSZipArchive/minizip/mz_strm_wzaes.h +46 -0
  54. package/ios/CodePush/SSZipArchive/minizip/mz_strm_zlib.c +389 -0
  55. package/ios/CodePush/SSZipArchive/minizip/mz_strm_zlib.h +43 -0
  56. package/ios/CodePush/SSZipArchive/minizip/mz_zip.c +2782 -0
  57. package/ios/CodePush/SSZipArchive/minizip/mz_zip.h +262 -0
  58. package/ios/CodePush/SSZipArchive/minizip/mz_zip_rw.c +1942 -0
  59. package/ios/CodePush/SSZipArchive/minizip/mz_zip_rw.h +285 -0
  60. package/ios/CodePush.xcodeproj/project.pbxproj +245 -130
  61. package/ios/PrivacyInfo.xcprivacy +31 -0
  62. package/package.json +2 -2
  63. package/typings/react-native-code-push.d.ts +1 -1
  64. package/windows/CodePush/CodePush.vcxproj +2 -3
  65. package/windows-legacy/CodePush.Net46/CodePush.Net46.csproj +2 -2
  66. package/windows-legacy/CodePush.Net46.Test/CodePush.Net46.Test.csproj +2 -2
  67. package/ios/CodePush/SSZipArchive/Common.h +0 -81
  68. package/ios/CodePush/SSZipArchive/aes/aes.h +0 -198
  69. package/ios/CodePush/SSZipArchive/aes/aes_via_ace.h +0 -541
  70. package/ios/CodePush/SSZipArchive/aes/aescrypt.c +0 -294
  71. package/ios/CodePush/SSZipArchive/aes/aeskey.c +0 -548
  72. package/ios/CodePush/SSZipArchive/aes/aesopt.h +0 -739
  73. package/ios/CodePush/SSZipArchive/aes/aestab.c +0 -391
  74. package/ios/CodePush/SSZipArchive/aes/aestab.h +0 -173
  75. package/ios/CodePush/SSZipArchive/aes/brg_endian.h +0 -126
  76. package/ios/CodePush/SSZipArchive/aes/brg_types.h +0 -219
  77. package/ios/CodePush/SSZipArchive/aes/entropy.c +0 -54
  78. package/ios/CodePush/SSZipArchive/aes/entropy.h +0 -16
  79. package/ios/CodePush/SSZipArchive/aes/fileenc.c +0 -144
  80. package/ios/CodePush/SSZipArchive/aes/fileenc.h +0 -121
  81. package/ios/CodePush/SSZipArchive/aes/hmac.c +0 -145
  82. package/ios/CodePush/SSZipArchive/aes/hmac.h +0 -103
  83. package/ios/CodePush/SSZipArchive/aes/prng.c +0 -155
  84. package/ios/CodePush/SSZipArchive/aes/prng.h +0 -82
  85. package/ios/CodePush/SSZipArchive/aes/pwd2key.c +0 -103
  86. package/ios/CodePush/SSZipArchive/aes/pwd2key.h +0 -57
  87. package/ios/CodePush/SSZipArchive/aes/sha1.c +0 -258
  88. package/ios/CodePush/SSZipArchive/aes/sha1.h +0 -73
  89. package/ios/CodePush/SSZipArchive/minizip/crypt.h +0 -130
  90. package/ios/CodePush/SSZipArchive/minizip/ioapi.c +0 -369
  91. package/ios/CodePush/SSZipArchive/minizip/ioapi.h +0 -175
  92. package/ios/CodePush/SSZipArchive/minizip/mztools.c +0 -284
  93. package/ios/CodePush/SSZipArchive/minizip/mztools.h +0 -31
  94. package/ios/CodePush/SSZipArchive/minizip/unzip.c +0 -1839
  95. package/ios/CodePush/SSZipArchive/minizip/unzip.h +0 -248
  96. package/ios/CodePush/SSZipArchive/minizip/zip.c +0 -1910
  97. package/ios/CodePush/SSZipArchive/minizip/zip.h +0 -202
@@ -0,0 +1,429 @@
1
+ /* mz_strm_split.c -- Stream for split files
2
+ part of the minizip-ng project
3
+
4
+ Copyright (C) Nathan Moinvaziri
5
+ https://github.com/zlib-ng/minizip-ng
6
+
7
+ This program is distributed under the terms of the same license as zlib.
8
+ See the accompanying LICENSE file for the full text of the license.
9
+ */
10
+
11
+ #include "mz.h"
12
+ #include "mz_os.h"
13
+ #include "mz_strm.h"
14
+ #include "mz_strm_split.h"
15
+
16
+ #include <stdio.h> /* snprintf */
17
+
18
+ #if defined(_MSC_VER) && (_MSC_VER < 1900)
19
+ # define snprintf _snprintf
20
+ #endif
21
+
22
+ /***************************************************************************/
23
+
24
+ #define MZ_ZIP_MAGIC_DISKHEADER (0x08074b50)
25
+
26
+ /***************************************************************************/
27
+
28
+ static mz_stream_vtbl mz_stream_split_vtbl = {
29
+ mz_stream_split_open,
30
+ mz_stream_split_is_open,
31
+ mz_stream_split_read,
32
+ mz_stream_split_write,
33
+ mz_stream_split_tell,
34
+ mz_stream_split_seek,
35
+ mz_stream_split_close,
36
+ mz_stream_split_error,
37
+ mz_stream_split_create,
38
+ mz_stream_split_delete,
39
+ mz_stream_split_get_prop_int64,
40
+ mz_stream_split_set_prop_int64
41
+ };
42
+
43
+ /***************************************************************************/
44
+
45
+ typedef struct mz_stream_split_s {
46
+ mz_stream stream;
47
+ int32_t is_open;
48
+ int64_t disk_size;
49
+ int64_t total_in;
50
+ int64_t total_in_disk;
51
+ int64_t total_out;
52
+ int64_t total_out_disk;
53
+ int32_t mode;
54
+ char *path_cd;
55
+ char *path_disk;
56
+ uint32_t path_disk_size;
57
+ int32_t number_disk;
58
+ int32_t current_disk;
59
+ int64_t current_disk_size;
60
+ int32_t reached_end;
61
+ } mz_stream_split;
62
+
63
+ /***************************************************************************/
64
+
65
+ #if 0
66
+ # define mz_stream_split_print printf
67
+ #else
68
+ # define mz_stream_split_print(fmt, ...)
69
+ #endif
70
+
71
+ /***************************************************************************/
72
+
73
+ static int32_t mz_stream_split_open_disk(void *stream, int32_t number_disk) {
74
+ mz_stream_split *split = (mz_stream_split *)stream;
75
+ uint32_t magic = 0;
76
+ int64_t position = 0;
77
+ int32_t i = 0;
78
+ int32_t err = MZ_OK;
79
+ int16_t disk_part = 0;
80
+
81
+ /* Check if we are reading or writing a disk part or the cd disk */
82
+ if (number_disk >= 0) {
83
+ if ((split->mode & MZ_OPEN_MODE_WRITE) == 0)
84
+ disk_part = MZ_OPEN_MODE_READ;
85
+ else if (split->disk_size > 0)
86
+ disk_part = MZ_OPEN_MODE_WRITE;
87
+ }
88
+
89
+ /* Construct disk path */
90
+ if (disk_part > 0) {
91
+ for (i = (int32_t)strlen(split->path_disk) - 1; i >= 0; i -= 1) {
92
+ if (split->path_disk[i] != '.')
93
+ continue;
94
+ snprintf(&split->path_disk[i], split->path_disk_size - (uint32_t)i,
95
+ ".z%02" PRId32, number_disk + 1);
96
+ break;
97
+ }
98
+ } else {
99
+ strncpy(split->path_disk, split->path_cd, split->path_disk_size - 1);
100
+ split->path_disk[split->path_disk_size - 1] = 0;
101
+ }
102
+
103
+ mz_stream_split_print("Split - Goto disk - %s (disk %" PRId32 ")\n", split->path_disk, number_disk);
104
+
105
+ /* If disk part doesn't exist during reading then return MZ_EXIST_ERROR */
106
+ if (disk_part == MZ_OPEN_MODE_READ)
107
+ err = mz_os_file_exists(split->path_disk);
108
+
109
+ if (err == MZ_OK)
110
+ err = mz_stream_open(split->stream.base, split->path_disk, split->mode);
111
+
112
+ if (err == MZ_OK) {
113
+ split->total_in_disk = 0;
114
+ split->total_out_disk = 0;
115
+ split->current_disk = number_disk;
116
+
117
+ if (split->mode & MZ_OPEN_MODE_WRITE) {
118
+ if ((split->current_disk == 0) && (split->disk_size > 0)) {
119
+ err = mz_stream_write_uint32(split->stream.base, MZ_ZIP_MAGIC_DISKHEADER);
120
+
121
+ split->total_out_disk += 4;
122
+ split->total_out += split->total_out_disk;
123
+ }
124
+ } else if (split->mode & MZ_OPEN_MODE_READ) {
125
+ if (split->current_disk == 0) {
126
+ err = mz_stream_read_uint32(split->stream.base, &magic);
127
+ if (magic != MZ_ZIP_MAGIC_DISKHEADER)
128
+ err = MZ_FORMAT_ERROR;
129
+ }
130
+ }
131
+ }
132
+
133
+ if (err == MZ_OK) {
134
+ /* Get the size of the current disk we are on */
135
+ position = mz_stream_tell(split->stream.base);
136
+ mz_stream_seek(split->stream.base, 0, MZ_SEEK_END);
137
+ split->current_disk_size = mz_stream_tell(split->stream.base);
138
+ mz_stream_seek(split->stream.base, position, MZ_SEEK_SET);
139
+
140
+ split->is_open = 1;
141
+ }
142
+
143
+ return err;
144
+ }
145
+
146
+ static int32_t mz_stream_split_close_disk(void *stream) {
147
+ mz_stream_split *split = (mz_stream_split *)stream;
148
+
149
+ if (mz_stream_is_open(split->stream.base) != MZ_OK)
150
+ return MZ_OK;
151
+
152
+ mz_stream_split_print("Split - Close disk\n");
153
+ return mz_stream_close(split->stream.base);
154
+ }
155
+
156
+ static int32_t mz_stream_split_goto_disk(void *stream, int32_t number_disk) {
157
+ mz_stream_split *split = (mz_stream_split *)stream;
158
+ int32_t err = MZ_OK;
159
+ int32_t err_is_open = MZ_OK;
160
+
161
+ err_is_open = mz_stream_is_open(split->stream.base);
162
+
163
+ if ((split->disk_size == 0) && (split->mode & MZ_OPEN_MODE_WRITE)) {
164
+ if (err_is_open != MZ_OK)
165
+ err = mz_stream_split_open_disk(stream, number_disk);
166
+ } else if ((number_disk != split->current_disk) || (err_is_open != MZ_OK)) {
167
+ err = mz_stream_split_close_disk(stream);
168
+ if (err == MZ_OK) {
169
+ err = mz_stream_split_open_disk(stream, number_disk);
170
+ if (err == MZ_OK)
171
+ split->number_disk = number_disk;
172
+ }
173
+ }
174
+
175
+ return err;
176
+ }
177
+
178
+ int32_t mz_stream_split_open(void *stream, const char *path, int32_t mode) {
179
+ mz_stream_split *split = (mz_stream_split *)stream;
180
+ int32_t number_disk = 0;
181
+
182
+ split->mode = mode;
183
+ split->path_cd = strdup(path);
184
+
185
+ if (!split->path_cd)
186
+ return MZ_MEM_ERROR;
187
+
188
+ mz_stream_split_print("Split - Open - %s (disk %" PRId32 ")\n", split->path_cd, number_disk);
189
+
190
+ split->path_disk_size = (uint32_t)strlen(path) + 10;
191
+ split->path_disk = (char *)malloc(split->path_disk_size);
192
+
193
+ if (!split->path_disk) {
194
+ free(split->path_cd);
195
+ return MZ_MEM_ERROR;
196
+ }
197
+
198
+ strncpy(split->path_disk, path, split->path_disk_size - 1);
199
+ split->path_disk[split->path_disk_size - 1] = 0;
200
+
201
+ if ((mode & MZ_OPEN_MODE_WRITE) && ((mode & MZ_OPEN_MODE_APPEND) == 0)) {
202
+ number_disk = 0;
203
+ split->current_disk = -1;
204
+ } else {
205
+ number_disk = -1;
206
+ split->current_disk = 0;
207
+ }
208
+
209
+ return mz_stream_split_goto_disk(stream, number_disk);
210
+ }
211
+
212
+ int32_t mz_stream_split_is_open(void *stream) {
213
+ mz_stream_split *split = (mz_stream_split *)stream;
214
+ if (split->is_open != 1)
215
+ return MZ_OPEN_ERROR;
216
+ return MZ_OK;
217
+ }
218
+
219
+ int32_t mz_stream_split_read(void *stream, void *buf, int32_t size) {
220
+ mz_stream_split *split = (mz_stream_split *)stream;
221
+ int32_t bytes_left = size;
222
+ int32_t read = 0;
223
+ int32_t err = MZ_OK;
224
+ uint8_t *buf_ptr = (uint8_t *)buf;
225
+
226
+ err = mz_stream_split_goto_disk(stream, split->number_disk);
227
+ if (err != MZ_OK)
228
+ return err;
229
+
230
+ while (bytes_left > 0) {
231
+ read = mz_stream_read(split->stream.base, buf_ptr, bytes_left);
232
+
233
+ mz_stream_split_print("Split - Read disk - %" PRId32 "\n", read);
234
+
235
+ if (read < 0)
236
+ return read;
237
+ if (read == 0) {
238
+ if (split->current_disk < 0) /* No more disks to goto */
239
+ break;
240
+ err = mz_stream_split_goto_disk(stream, split->current_disk + 1);
241
+ if (err == MZ_EXIST_ERROR) {
242
+ split->current_disk = -1;
243
+ break;
244
+ }
245
+ if (err != MZ_OK)
246
+ return err;
247
+ }
248
+
249
+ bytes_left -= read;
250
+ buf_ptr += read;
251
+ split->total_in += read;
252
+ split->total_in_disk += read;
253
+ }
254
+ return size - bytes_left;
255
+ }
256
+
257
+ int32_t mz_stream_split_write(void *stream, const void *buf, int32_t size) {
258
+ mz_stream_split *split = (mz_stream_split *)stream;
259
+ int64_t position = 0;
260
+ int32_t written = 0;
261
+ int32_t bytes_left = size;
262
+ int32_t bytes_to_write = 0;
263
+ int32_t bytes_avail = 0;
264
+ int32_t number_disk = -1;
265
+ int32_t err = MZ_OK;
266
+ const uint8_t *buf_ptr = (const uint8_t *)buf;
267
+
268
+ position = mz_stream_tell(split->stream.base);
269
+
270
+ while (bytes_left > 0) {
271
+ bytes_to_write = bytes_left;
272
+
273
+ if (split->disk_size > 0) {
274
+ if ((split->total_out_disk == split->disk_size && split->total_out > 0) ||
275
+ (split->number_disk == -1 && split->number_disk != split->current_disk)) {
276
+ if (split->number_disk != -1)
277
+ number_disk = split->current_disk + 1;
278
+
279
+ err = mz_stream_split_goto_disk(stream, number_disk);
280
+ if (err != MZ_OK)
281
+ return err;
282
+
283
+ position = 0;
284
+ }
285
+
286
+ if (split->number_disk != -1) {
287
+ bytes_avail = (int32_t)(split->disk_size - split->total_out_disk);
288
+ if (bytes_to_write > bytes_avail)
289
+ bytes_to_write = bytes_avail;
290
+ }
291
+ }
292
+
293
+ written = mz_stream_write(split->stream.base, buf_ptr, bytes_to_write);
294
+ if (written != bytes_to_write)
295
+ return MZ_WRITE_ERROR;
296
+
297
+ mz_stream_split_print("Split - Write disk - %" PRId32 "\n", written);
298
+
299
+ bytes_left -= written;
300
+ buf_ptr += written;
301
+
302
+ split->total_out += written;
303
+ split->total_out_disk += written;
304
+
305
+ position += written;
306
+ if (position > split->current_disk_size)
307
+ split->current_disk_size = position;
308
+ }
309
+
310
+ return size - bytes_left;
311
+ }
312
+
313
+ int64_t mz_stream_split_tell(void *stream) {
314
+ mz_stream_split *split = (mz_stream_split *)stream;
315
+ int32_t err = MZ_OK;
316
+ err = mz_stream_split_goto_disk(stream, split->number_disk);
317
+ if (err != MZ_OK)
318
+ return err;
319
+ return mz_stream_tell(split->stream.base);
320
+ }
321
+
322
+ int32_t mz_stream_split_seek(void *stream, int64_t offset, int32_t origin) {
323
+ mz_stream_split *split = (mz_stream_split *)stream;
324
+ int64_t disk_left = 0;
325
+ int64_t position = 0;
326
+ int32_t err = MZ_OK;
327
+
328
+ err = mz_stream_split_goto_disk(stream, split->number_disk);
329
+
330
+ if (err != MZ_OK)
331
+ return err;
332
+
333
+ mz_stream_split_print("Split - Seek disk - %" PRId64 " (origin %" PRId32 ")\n", offset, origin);
334
+
335
+ if ((origin == MZ_SEEK_CUR) && (split->number_disk != -1)) {
336
+ position = mz_stream_tell(split->stream.base);
337
+ disk_left = split->current_disk_size - position;
338
+
339
+ while (offset > disk_left) {
340
+ err = mz_stream_split_goto_disk(stream, split->current_disk + 1);
341
+ if (err != MZ_OK)
342
+ return err;
343
+
344
+ offset -= disk_left;
345
+ disk_left = split->current_disk_size;
346
+ }
347
+ }
348
+
349
+ return mz_stream_seek(split->stream.base, offset, origin);
350
+ }
351
+
352
+ int32_t mz_stream_split_close(void *stream) {
353
+ mz_stream_split *split = (mz_stream_split *)stream;
354
+ int32_t err = MZ_OK;
355
+
356
+ err = mz_stream_split_close_disk(stream);
357
+ split->is_open = 0;
358
+ return err;
359
+ }
360
+
361
+ int32_t mz_stream_split_error(void *stream) {
362
+ mz_stream_split *split = (mz_stream_split *)stream;
363
+ return mz_stream_error(split->stream.base);
364
+ }
365
+
366
+ int32_t mz_stream_split_get_prop_int64(void *stream, int32_t prop, int64_t *value) {
367
+ mz_stream_split *split = (mz_stream_split *)stream;
368
+ switch (prop) {
369
+ case MZ_STREAM_PROP_TOTAL_OUT:
370
+ *value = split->total_out;
371
+ break;
372
+ case MZ_STREAM_PROP_DISK_NUMBER:
373
+ *value = split->number_disk;
374
+ break;
375
+ case MZ_STREAM_PROP_DISK_SIZE:
376
+ *value = split->disk_size;
377
+ break;
378
+ default:
379
+ return MZ_EXIST_ERROR;
380
+ }
381
+ return MZ_OK;
382
+ }
383
+
384
+ int32_t mz_stream_split_set_prop_int64(void *stream, int32_t prop, int64_t value) {
385
+ mz_stream_split *split = (mz_stream_split *)stream;
386
+ switch (prop) {
387
+ case MZ_STREAM_PROP_DISK_NUMBER:
388
+ split->number_disk = (int32_t)value;
389
+ break;
390
+ case MZ_STREAM_PROP_DISK_SIZE:
391
+ split->disk_size = value;
392
+ break;
393
+ default:
394
+ return MZ_EXIST_ERROR;
395
+ }
396
+ return MZ_OK;
397
+ }
398
+
399
+ void *mz_stream_split_create(void **stream) {
400
+ mz_stream_split *split = NULL;
401
+
402
+ split = (mz_stream_split *)calloc(1, sizeof(mz_stream_split));
403
+ if (split)
404
+ split->stream.vtbl = &mz_stream_split_vtbl;
405
+ if (stream)
406
+ *stream = split;
407
+
408
+ return split;
409
+ }
410
+
411
+ void mz_stream_split_delete(void **stream) {
412
+ mz_stream_split *split = NULL;
413
+ if (!stream)
414
+ return;
415
+ split = (mz_stream_split *)*stream;
416
+ if (split) {
417
+ if (split->path_cd)
418
+ free(split->path_cd);
419
+ if (split->path_disk)
420
+ free(split->path_disk);
421
+
422
+ free(split);
423
+ }
424
+ *stream = NULL;
425
+ }
426
+
427
+ void *mz_stream_split_get_interface(void) {
428
+ return (void *)&mz_stream_split_vtbl;
429
+ }
@@ -0,0 +1,43 @@
1
+ /* mz_strm_split.h -- Stream for split files
2
+ part of the minizip-ng project
3
+
4
+ Copyright (C) Nathan Moinvaziri
5
+ https://github.com/zlib-ng/minizip-ng
6
+
7
+ This program is distributed under the terms of the same license as zlib.
8
+ See the accompanying LICENSE file for the full text of the license.
9
+ */
10
+
11
+ #ifndef MZ_STREAM_SPLIT_H
12
+ #define MZ_STREAM_SPLIT_H
13
+
14
+ #ifdef __cplusplus
15
+ extern "C" {
16
+ #endif
17
+
18
+ /***************************************************************************/
19
+
20
+ int32_t mz_stream_split_open(void *stream, const char *filename, int32_t mode);
21
+ int32_t mz_stream_split_is_open(void *stream);
22
+ int32_t mz_stream_split_read(void *stream, void *buf, int32_t size);
23
+ int32_t mz_stream_split_write(void *stream, const void *buf, int32_t size);
24
+ int64_t mz_stream_split_tell(void *stream);
25
+ int32_t mz_stream_split_seek(void *stream, int64_t offset, int32_t origin);
26
+ int32_t mz_stream_split_close(void *stream);
27
+ int32_t mz_stream_split_error(void *stream);
28
+
29
+ int32_t mz_stream_split_get_prop_int64(void *stream, int32_t prop, int64_t *value);
30
+ int32_t mz_stream_split_set_prop_int64(void *stream, int32_t prop, int64_t value);
31
+
32
+ void* mz_stream_split_create(void **stream);
33
+ void mz_stream_split_delete(void **stream);
34
+
35
+ void* mz_stream_split_get_interface(void);
36
+
37
+ /***************************************************************************/
38
+
39
+ #ifdef __cplusplus
40
+ }
41
+ #endif
42
+
43
+ #endif