@appzung/react-native-code-push 9.0.2 → 10.0.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.
- package/CodePush.js +22 -19
- package/LICENSE.md +1 -1
- package/README.md +159 -298
- package/android/app/.gradle/config.properties +2 -0
- package/android/app/build.gradle +1 -1
- package/android/app/local.properties +8 -0
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePush.java +27 -21
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushBuilder.java +5 -5
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushConstants.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushDialog.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushInstallMode.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushInvalidPublicKeyException.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushInvalidUpdateException.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushMalformedDataException.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushNativeModule.java +5 -5
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushNotInitializedException.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushTelemetryManager.java +14 -14
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUnknownException.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUpdateManager.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUpdateState.java +2 -2
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUpdateUtils.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/CodePushUtils.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/DownloadProgress.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/DownloadProgressCallback.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/FileUtils.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/ReactInstanceHolder.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/SettingsManager.java +1 -1
- package/android/app/src/main/java/com/microsoft/codepush/react/TLSSocketFactory.java +1 -1
- package/android/build.gradle +1 -1
- package/android/codepush.gradle +3 -3
- package/docs/advanced-usage.md +56 -0
- package/docs/api-android.md +12 -75
- package/docs/api-ios.md +5 -17
- package/docs/api-js.md +18 -55
- package/docs/setup-android.md +15 -397
- package/docs/setup-ios.md +24 -198
- package/docs/setup-windows.md +7 -74
- package/ios/CodePush/CodePush.h +4 -4
- package/ios/CodePush/CodePush.m +8 -8
- package/ios/CodePush/CodePushConfig.m +14 -11
- package/ios/CodePush/CodePushPackage.m +60 -60
- package/ios/CodePush/CodePushTelemetryManager.m +13 -13
- package/ios/CodePush.xcodeproj/project.pbxproj +1 -562
- package/package.json +27 -24
- package/react-native.config.js +1 -1
- package/scripts/generateBundledResourcesHash.js +1 -1
- package/scripts/getFilesInFolder.js +1 -1
- package/scripts/recordFilesBeforeBundleCommand.js +1 -1
- package/typings/react-native-code-push.d.ts +22 -22
- package/windows/CodePush/CodePushConfig.cpp +3 -3
- package/windows/CodePush/CodePushConfig.h +3 -3
- package/windows/CodePush/CodePushNativeModule.cpp +27 -27
- package/windows/CodePush/CodePushNativeModule.h +4 -4
- package/windows/CodePush/CodePushTelemetryManager.cpp +12 -12
- package/windows/CodePush/CodePushTelemetryManager.h +1 -1
- package/.azurepipelines/build-rn-code-push-1es.yml +0 -104
- package/.azurepipelines/test-rn-code-push.yml +0 -94
- package/.config/CredScanSuppressions.json +0 -14
- package/SECURITY.md +0 -41
- package/docs/multi-deployment-testing-android.md +0 -148
- package/docs/multi-deployment-testing-ios.md +0 -59
- package/ios/CodePush/Base64/Base64/MF_Base64Additions.h +0 -34
- package/ios/CodePush/Base64/Base64/MF_Base64Additions.m +0 -252
- package/ios/CodePush/Base64/README.md +0 -47
- package/ios/CodePush/JWT/Core/Algorithms/Base/JWTAlgorithm.h +0 -69
- package/ios/CodePush/JWT/Core/Algorithms/Base/JWTAlgorithmFactory.h +0 -16
- package/ios/CodePush/JWT/Core/Algorithms/Base/JWTAlgorithmFactory.m +0 -51
- package/ios/CodePush/JWT/Core/Algorithms/Base/JWTAlgorithmNone.h +0 -15
- package/ios/CodePush/JWT/Core/Algorithms/Base/JWTAlgorithmNone.m +0 -55
- package/ios/CodePush/JWT/Core/Algorithms/ESFamily/JWTAlgorithmESBase.h +0 -24
- package/ios/CodePush/JWT/Core/Algorithms/ESFamily/JWTAlgorithmESBase.m +0 -41
- package/ios/CodePush/JWT/Core/Algorithms/HSFamily/JWTAlgorithmHSBase.h +0 -28
- package/ios/CodePush/JWT/Core/Algorithms/HSFamily/JWTAlgorithmHSBase.m +0 -205
- package/ios/CodePush/JWT/Core/Algorithms/Holders/JWTAlgorithmDataHolder.h +0 -103
- package/ios/CodePush/JWT/Core/Algorithms/Holders/JWTAlgorithmDataHolder.m +0 -322
- package/ios/CodePush/JWT/Core/Algorithms/Holders/JWTAlgorithmDataHolderChain.h +0 -37
- package/ios/CodePush/JWT/Core/Algorithms/Holders/JWTAlgorithmDataHolderChain.m +0 -145
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/JWTAlgorithmRSBase.h +0 -35
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/JWTAlgorithmRSBase.m +0 -551
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/JWTRSAlgorithm.h +0 -23
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoKey.h +0 -43
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoKey.m +0 -230
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoKeyExtractor.h +0 -31
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoKeyExtractor.m +0 -113
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoSecurity.h +0 -38
- package/ios/CodePush/JWT/Core/Algorithms/RSFamily/RSKeys/JWTCryptoSecurity.m +0 -500
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaim.h +0 -18
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaim.m +0 -214
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSet.h +0 -23
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSet.m +0 -29
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSetSerializer.h +0 -19
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSetSerializer.m +0 -68
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSetVerifier.h +0 -18
- package/ios/CodePush/JWT/Core/ClaimSet/JWTClaimsSetVerifier.m +0 -72
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+ResultTypes.h +0 -67
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+ResultTypes.m +0 -111
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionOne.h +0 -119
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionOne.m +0 -307
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionThree.h +0 -94
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionThree.m +0 -619
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionTwo.h +0 -164
- package/ios/CodePush/JWT/Core/Coding/JWTCoding+VersionTwo.m +0 -514
- package/ios/CodePush/JWT/Core/Coding/JWTCoding.h +0 -24
- package/ios/CodePush/JWT/Core/Coding/JWTCoding.m +0 -11
- package/ios/CodePush/JWT/Core/FrameworkSupplement/JWT.h +0 -52
- package/ios/CodePush/JWT/Core/FrameworkSupplement/Map.modulemap +0 -5
- package/ios/CodePush/JWT/Core/Supplement/JWTBase64Coder.h +0 -28
- package/ios/CodePush/JWT/Core/Supplement/JWTBase64Coder.m +0 -70
- package/ios/CodePush/JWT/Core/Supplement/JWTDeprecations.h +0 -22
- package/ios/CodePush/JWT/Core/Supplement/JWTErrorDescription.h +0 -34
- package/ios/CodePush/JWT/Core/Supplement/JWTErrorDescription.m +0 -73
- package/ios/CodePush/JWT/LICENSE +0 -19
- package/ios/CodePush/JWT/README.md +0 -489
- package/ios/CodePush/SSZipArchive/Info.plist +0 -26
- package/ios/CodePush/SSZipArchive/README.md +0 -1
- package/ios/CodePush/SSZipArchive/SSZipArchive.h +0 -178
- package/ios/CodePush/SSZipArchive/SSZipArchive.m +0 -1496
- package/ios/CodePush/SSZipArchive/SSZipCommon.h +0 -71
- package/ios/CodePush/SSZipArchive/Supporting Files/PrivacyInfo.xcprivacy +0 -23
- package/ios/CodePush/SSZipArchive/include/ZipArchive.h +0 -25
- package/ios/CodePush/SSZipArchive/minizip/LICENSE +0 -17
- package/ios/CodePush/SSZipArchive/minizip/mz.h +0 -273
- package/ios/CodePush/SSZipArchive/minizip/mz_compat.c +0 -1306
- package/ios/CodePush/SSZipArchive/minizip/mz_compat.h +0 -346
- package/ios/CodePush/SSZipArchive/minizip/mz_crypt.c +0 -187
- package/ios/CodePush/SSZipArchive/minizip/mz_crypt.h +0 -65
- package/ios/CodePush/SSZipArchive/minizip/mz_crypt_apple.c +0 -526
- package/ios/CodePush/SSZipArchive/minizip/mz_os.c +0 -348
- package/ios/CodePush/SSZipArchive/minizip/mz_os.h +0 -176
- package/ios/CodePush/SSZipArchive/minizip/mz_os_posix.c +0 -350
- package/ios/CodePush/SSZipArchive/minizip/mz_strm.c +0 -556
- package/ios/CodePush/SSZipArchive/minizip/mz_strm.h +0 -132
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_buf.c +0 -383
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_buf.h +0 -42
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_mem.c +0 -269
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_mem.h +0 -48
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_os.h +0 -40
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_os_posix.c +0 -203
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_pkcrypt.c +0 -334
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_pkcrypt.h +0 -46
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_split.c +0 -429
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_split.h +0 -43
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_wzaes.c +0 -360
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_wzaes.h +0 -46
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_zlib.c +0 -389
- package/ios/CodePush/SSZipArchive/minizip/mz_strm_zlib.h +0 -43
- package/ios/CodePush/SSZipArchive/minizip/mz_zip.c +0 -2782
- package/ios/CodePush/SSZipArchive/minizip/mz_zip.h +0 -262
- package/ios/CodePush/SSZipArchive/minizip/mz_zip_rw.c +0 -1942
- package/ios/CodePush/SSZipArchive/minizip/mz_zip_rw.h +0 -285
- package/scripts/postlink/android/postlink.js +0 -87
- package/scripts/postlink/ios/postlink.js +0 -116
- package/scripts/postlink/run.js +0 -11
- package/scripts/postunlink/android/postunlink.js +0 -74
- package/scripts/postunlink/ios/postunlink.js +0 -87
- package/scripts/postunlink/run.js +0 -11
- package/scripts/tools/linkToolsAndroid.js +0 -57
- package/scripts/tools/linkToolsIos.js +0 -130
- package/windows-legacy/CodePush/CodePush.csproj +0 -128
- package/windows-legacy/CodePush/CodePushUtils.cs +0 -47
- package/windows-legacy/CodePush/FileUtils.cs +0 -40
- package/windows-legacy/CodePush/Properties/AssemblyInfo.cs +0 -29
- package/windows-legacy/CodePush/Properties/CodePush.rd.xml +0 -33
- package/windows-legacy/CodePush/UpdateManager.cs +0 -305
- package/windows-legacy/CodePush/UpdateUtils.cs +0 -46
- package/windows-legacy/CodePush.Net46/Adapters/Http/HttpProgress.cs +0 -28
- package/windows-legacy/CodePush.Net46/Adapters/Storage/ApplicationDataContainer.cs +0 -106
- package/windows-legacy/CodePush.Net46/CodePush.Net46.csproj +0 -103
- package/windows-legacy/CodePush.Net46/CodePushUtils.cs +0 -158
- package/windows-legacy/CodePush.Net46/FileUtils.cs +0 -55
- package/windows-legacy/CodePush.Net46/Properties/AssemblyInfo.cs +0 -36
- package/windows-legacy/CodePush.Net46/UpdateManager.cs +0 -330
- package/windows-legacy/CodePush.Net46/UpdateUtils.cs +0 -70
- package/windows-legacy/CodePush.Net46/packages.config +0 -5
- package/windows-legacy/CodePush.Net46.Test/ApplicationDataContainerTest.cs +0 -105
- package/windows-legacy/CodePush.Net46.Test/CodePush.Net46.Test.csproj +0 -137
- package/windows-legacy/CodePush.Net46.Test/Properties/AssemblyInfo.cs +0 -36
- package/windows-legacy/CodePush.Net46.Test/TelemetryManagerTest.cs +0 -117
- package/windows-legacy/CodePush.Net46.Test/app.config +0 -11
- package/windows-legacy/CodePush.Net46.Test/packages.config +0 -4
- package/windows-legacy/CodePush.Shared/CodePush.Shared.projitems +0 -22
- package/windows-legacy/CodePush.Shared/CodePush.Shared.shproj +0 -13
- package/windows-legacy/CodePush.Shared/CodePushConstants.cs +0 -35
- package/windows-legacy/CodePush.Shared/CodePushNativeModule.cs +0 -329
- package/windows-legacy/CodePush.Shared/CodePushReactPackage.cs +0 -235
- package/windows-legacy/CodePush.Shared/CodePushUtils.cs +0 -70
- package/windows-legacy/CodePush.Shared/InstallMode.cs +0 -9
- package/windows-legacy/CodePush.Shared/MinimumBackgroundListener.cs +0 -44
- package/windows-legacy/CodePush.Shared/SettingsManager.cs +0 -148
- package/windows-legacy/CodePush.Shared/TelemetryManager.cs +0 -250
- package/windows-legacy/CodePush.Shared/UpdateState.cs +0 -9
|
@@ -1,383 +0,0 @@
|
|
|
1
|
-
/* mz_strm_buf.c -- Stream for buffering reads/writes
|
|
2
|
-
part of the minizip-ng project
|
|
3
|
-
|
|
4
|
-
This version of ioapi is designed to buffer IO.
|
|
5
|
-
|
|
6
|
-
Copyright (C) Nathan Moinvaziri
|
|
7
|
-
https://github.com/zlib-ng/minizip-ng
|
|
8
|
-
|
|
9
|
-
This program is distributed under the terms of the same license as zlib.
|
|
10
|
-
See the accompanying LICENSE file for the full text of the license.
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
#include "mz.h"
|
|
14
|
-
#include "mz_strm.h"
|
|
15
|
-
#include "mz_strm_buf.h"
|
|
16
|
-
|
|
17
|
-
/***************************************************************************/
|
|
18
|
-
|
|
19
|
-
static mz_stream_vtbl mz_stream_buffered_vtbl = {
|
|
20
|
-
mz_stream_buffered_open,
|
|
21
|
-
mz_stream_buffered_is_open,
|
|
22
|
-
mz_stream_buffered_read,
|
|
23
|
-
mz_stream_buffered_write,
|
|
24
|
-
mz_stream_buffered_tell,
|
|
25
|
-
mz_stream_buffered_seek,
|
|
26
|
-
mz_stream_buffered_close,
|
|
27
|
-
mz_stream_buffered_error,
|
|
28
|
-
mz_stream_buffered_create,
|
|
29
|
-
mz_stream_buffered_delete,
|
|
30
|
-
NULL,
|
|
31
|
-
NULL
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
/***************************************************************************/
|
|
35
|
-
|
|
36
|
-
typedef struct mz_stream_buffered_s {
|
|
37
|
-
mz_stream stream;
|
|
38
|
-
int32_t error;
|
|
39
|
-
char readbuf[INT16_MAX];
|
|
40
|
-
int32_t readbuf_len;
|
|
41
|
-
int32_t readbuf_pos;
|
|
42
|
-
int32_t readbuf_hits;
|
|
43
|
-
int32_t readbuf_misses;
|
|
44
|
-
char writebuf[INT16_MAX];
|
|
45
|
-
int32_t writebuf_len;
|
|
46
|
-
int32_t writebuf_pos;
|
|
47
|
-
int32_t writebuf_hits;
|
|
48
|
-
int32_t writebuf_misses;
|
|
49
|
-
int64_t position;
|
|
50
|
-
} mz_stream_buffered;
|
|
51
|
-
|
|
52
|
-
/***************************************************************************/
|
|
53
|
-
|
|
54
|
-
#if 0
|
|
55
|
-
# define mz_stream_buffered_print printf
|
|
56
|
-
#else
|
|
57
|
-
# define mz_stream_buffered_print(fmt,...)
|
|
58
|
-
#endif
|
|
59
|
-
|
|
60
|
-
/***************************************************************************/
|
|
61
|
-
|
|
62
|
-
static int32_t mz_stream_buffered_reset(void *stream) {
|
|
63
|
-
mz_stream_buffered *buffered = (mz_stream_buffered *)stream;
|
|
64
|
-
|
|
65
|
-
buffered->readbuf_len = 0;
|
|
66
|
-
buffered->readbuf_pos = 0;
|
|
67
|
-
buffered->writebuf_len = 0;
|
|
68
|
-
buffered->writebuf_pos = 0;
|
|
69
|
-
buffered->position = 0;
|
|
70
|
-
|
|
71
|
-
return MZ_OK;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
int32_t mz_stream_buffered_open(void *stream, const char *path, int32_t mode) {
|
|
75
|
-
mz_stream_buffered *buffered = (mz_stream_buffered *)stream;
|
|
76
|
-
mz_stream_buffered_print("Buffered - Open (mode %" PRId32 ")\n", mode);
|
|
77
|
-
mz_stream_buffered_reset(buffered);
|
|
78
|
-
return mz_stream_open(buffered->stream.base, path, mode);
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
int32_t mz_stream_buffered_is_open(void *stream) {
|
|
82
|
-
mz_stream_buffered *buffered = (mz_stream_buffered *)stream;
|
|
83
|
-
return mz_stream_is_open(buffered->stream.base);
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
static int32_t mz_stream_buffered_flush(void *stream, int32_t *written) {
|
|
87
|
-
mz_stream_buffered *buffered = (mz_stream_buffered *)stream;
|
|
88
|
-
int32_t total_bytes_written = 0;
|
|
89
|
-
int32_t bytes_to_write = buffered->writebuf_len;
|
|
90
|
-
int32_t bytes_left_to_write = buffered->writebuf_len;
|
|
91
|
-
int32_t bytes_written = 0;
|
|
92
|
-
|
|
93
|
-
*written = 0;
|
|
94
|
-
|
|
95
|
-
while (bytes_left_to_write > 0) {
|
|
96
|
-
bytes_written = mz_stream_write(buffered->stream.base,
|
|
97
|
-
buffered->writebuf + (bytes_to_write - bytes_left_to_write), bytes_left_to_write);
|
|
98
|
-
|
|
99
|
-
if (bytes_written != bytes_left_to_write)
|
|
100
|
-
return MZ_WRITE_ERROR;
|
|
101
|
-
|
|
102
|
-
buffered->writebuf_misses += 1;
|
|
103
|
-
|
|
104
|
-
mz_stream_buffered_print("Buffered - Write flush (%" PRId32 ":%" PRId32 " len %" PRId32 ")\n",
|
|
105
|
-
bytes_to_write, bytes_left_to_write, buffered->writebuf_len);
|
|
106
|
-
|
|
107
|
-
total_bytes_written += bytes_written;
|
|
108
|
-
bytes_left_to_write -= bytes_written;
|
|
109
|
-
buffered->position += bytes_written;
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
buffered->writebuf_len = 0;
|
|
113
|
-
buffered->writebuf_pos = 0;
|
|
114
|
-
|
|
115
|
-
*written = total_bytes_written;
|
|
116
|
-
return MZ_OK;
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
int32_t mz_stream_buffered_read(void *stream, void *buf, int32_t size) {
|
|
120
|
-
mz_stream_buffered *buffered = (mz_stream_buffered *)stream;
|
|
121
|
-
int32_t buf_len = 0;
|
|
122
|
-
int32_t bytes_to_read = 0;
|
|
123
|
-
int32_t bytes_to_copy = 0;
|
|
124
|
-
int32_t bytes_left_to_read = size;
|
|
125
|
-
int32_t bytes_read = 0;
|
|
126
|
-
int32_t bytes_flushed = 0;
|
|
127
|
-
|
|
128
|
-
mz_stream_buffered_print("Buffered - Read (size %" PRId32 " pos %" PRId64 ")\n", size, buffered->position);
|
|
129
|
-
|
|
130
|
-
if (buffered->writebuf_len > 0) {
|
|
131
|
-
int64_t position = buffered->position + buffered->writebuf_pos
|
|
132
|
-
|
|
133
|
-
mz_stream_buffered_print("Buffered - Switch from write to read, flushing (pos %" PRId64 ")\n", position);
|
|
134
|
-
|
|
135
|
-
mz_stream_buffered_flush(stream, &bytes_flushed);
|
|
136
|
-
mz_stream_buffered_seek(stream, position, MZ_SEEK_SET);
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
while (bytes_left_to_read > 0) {
|
|
140
|
-
if ((buffered->readbuf_len == 0) || (buffered->readbuf_pos == buffered->readbuf_len)) {
|
|
141
|
-
if (buffered->readbuf_len == sizeof(buffered->readbuf)) {
|
|
142
|
-
buffered->readbuf_pos = 0;
|
|
143
|
-
buffered->readbuf_len = 0;
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
bytes_to_read = (int32_t)sizeof(buffered->readbuf) - (buffered->readbuf_len - buffered->readbuf_pos);
|
|
147
|
-
bytes_read = mz_stream_read(buffered->stream.base, buffered->readbuf + buffered->readbuf_pos, bytes_to_read);
|
|
148
|
-
if (bytes_read < 0)
|
|
149
|
-
return bytes_read;
|
|
150
|
-
|
|
151
|
-
buffered->readbuf_misses += 1;
|
|
152
|
-
buffered->readbuf_len += bytes_read;
|
|
153
|
-
buffered->position += bytes_read;
|
|
154
|
-
|
|
155
|
-
mz_stream_buffered_print("Buffered - Filled (read %" PRId32 "/%" PRId32 " buf %" PRId32 ":%" PRId32 " pos %" PRId64 ")\n",
|
|
156
|
-
bytes_read, bytes_to_read, buffered->readbuf_pos, buffered->readbuf_len, buffered->position);
|
|
157
|
-
|
|
158
|
-
if (bytes_read == 0)
|
|
159
|
-
break;
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
if ((buffered->readbuf_len - buffered->readbuf_pos) > 0) {
|
|
163
|
-
bytes_to_copy = buffered->readbuf_len - buffered->readbuf_pos;
|
|
164
|
-
if (bytes_to_copy > bytes_left_to_read)
|
|
165
|
-
bytes_to_copy = bytes_left_to_read;
|
|
166
|
-
|
|
167
|
-
memcpy((char *)buf + buf_len, buffered->readbuf + buffered->readbuf_pos, bytes_to_copy);
|
|
168
|
-
|
|
169
|
-
buf_len += bytes_to_copy;
|
|
170
|
-
bytes_left_to_read -= bytes_to_copy;
|
|
171
|
-
|
|
172
|
-
buffered->readbuf_hits += 1;
|
|
173
|
-
buffered->readbuf_pos += bytes_to_copy;
|
|
174
|
-
|
|
175
|
-
mz_stream_buffered_print("Buffered - Emptied (copied %" PRId32 " remaining %" PRId32 " buf %" PRId32 ":%" PRId32 " pos %" PRId64 ")\n",
|
|
176
|
-
bytes_to_copy, bytes_left_to_read, buffered->readbuf_pos, buffered->readbuf_len, buffered->position);
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
return size - bytes_left_to_read;
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
int32_t mz_stream_buffered_write(void *stream, const void *buf, int32_t size) {
|
|
184
|
-
mz_stream_buffered *buffered = (mz_stream_buffered *)stream;
|
|
185
|
-
int32_t bytes_to_write = size;
|
|
186
|
-
int32_t bytes_left_to_write = size;
|
|
187
|
-
int32_t bytes_to_copy = 0;
|
|
188
|
-
int32_t bytes_used = 0;
|
|
189
|
-
int32_t bytes_flushed = 0;
|
|
190
|
-
int32_t err = MZ_OK;
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
mz_stream_buffered_print("Buffered - Write (size %" PRId32 " len %" PRId32 " pos %" PRId64 ")\n",
|
|
194
|
-
size, buffered->writebuf_len, buffered->position);
|
|
195
|
-
|
|
196
|
-
if (buffered->readbuf_len > 0) {
|
|
197
|
-
buffered->position -= buffered->readbuf_len;
|
|
198
|
-
buffered->position += buffered->readbuf_pos;
|
|
199
|
-
|
|
200
|
-
buffered->readbuf_len = 0;
|
|
201
|
-
buffered->readbuf_pos = 0;
|
|
202
|
-
|
|
203
|
-
mz_stream_buffered_print("Buffered - Switch from read to write (pos %" PRId64 ")\n", buffered->position);
|
|
204
|
-
|
|
205
|
-
err = mz_stream_seek(buffered->stream.base, buffered->position, MZ_SEEK_SET);
|
|
206
|
-
if (err != MZ_OK)
|
|
207
|
-
return err;
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
while (bytes_left_to_write > 0) {
|
|
211
|
-
bytes_used = buffered->writebuf_len;
|
|
212
|
-
if (bytes_used > buffered->writebuf_pos)
|
|
213
|
-
bytes_used = buffered->writebuf_pos;
|
|
214
|
-
bytes_to_copy = (int32_t)sizeof(buffered->writebuf) - bytes_used;
|
|
215
|
-
if (bytes_to_copy > bytes_left_to_write)
|
|
216
|
-
bytes_to_copy = bytes_left_to_write;
|
|
217
|
-
|
|
218
|
-
if (bytes_to_copy == 0) {
|
|
219
|
-
err = mz_stream_buffered_flush(stream, &bytes_flushed);
|
|
220
|
-
if (err != MZ_OK)
|
|
221
|
-
return err;
|
|
222
|
-
if (bytes_flushed == 0)
|
|
223
|
-
return 0;
|
|
224
|
-
|
|
225
|
-
continue;
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
memcpy(buffered->writebuf + buffered->writebuf_pos,
|
|
229
|
-
(const char *)buf + (bytes_to_write - bytes_left_to_write), bytes_to_copy);
|
|
230
|
-
|
|
231
|
-
mz_stream_buffered_print("Buffered - Write copy (remaining %" PRId32 " write %" PRId32 ":%" PRId32 " len %" PRId32 ")\n",
|
|
232
|
-
bytes_to_copy, bytes_to_write, bytes_left_to_write, buffered->writebuf_len);
|
|
233
|
-
|
|
234
|
-
bytes_left_to_write -= bytes_to_copy;
|
|
235
|
-
|
|
236
|
-
buffered->writebuf_pos += bytes_to_copy;
|
|
237
|
-
buffered->writebuf_hits += 1;
|
|
238
|
-
if (buffered->writebuf_pos > buffered->writebuf_len)
|
|
239
|
-
buffered->writebuf_len += buffered->writebuf_pos - buffered->writebuf_len;
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
return size - bytes_left_to_write;
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
int64_t mz_stream_buffered_tell(void *stream) {
|
|
246
|
-
mz_stream_buffered *buffered = (mz_stream_buffered *)stream;
|
|
247
|
-
int64_t position = mz_stream_tell(buffered->stream.base);
|
|
248
|
-
|
|
249
|
-
buffered->position = position;
|
|
250
|
-
|
|
251
|
-
mz_stream_buffered_print("Buffered - Tell (pos %" PRId64 " readpos %" PRId32 " writepos %" PRId32 ")\n",
|
|
252
|
-
buffered->position, buffered->readbuf_pos, buffered->writebuf_pos);
|
|
253
|
-
|
|
254
|
-
if (buffered->readbuf_len > 0)
|
|
255
|
-
position -= ((int64_t)buffered->readbuf_len - buffered->readbuf_pos);
|
|
256
|
-
if (buffered->writebuf_len > 0)
|
|
257
|
-
position += buffered->writebuf_pos;
|
|
258
|
-
return position;
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
int32_t mz_stream_buffered_seek(void *stream, int64_t offset, int32_t origin) {
|
|
262
|
-
mz_stream_buffered *buffered = (mz_stream_buffered *)stream;
|
|
263
|
-
int32_t bytes_flushed = 0;
|
|
264
|
-
int32_t err = MZ_OK;
|
|
265
|
-
|
|
266
|
-
mz_stream_buffered_print("Buffered - Seek (origin %" PRId32 " offset %" PRId64 " pos %" PRId64 ")\n",
|
|
267
|
-
origin, offset, buffered->position);
|
|
268
|
-
|
|
269
|
-
switch (origin) {
|
|
270
|
-
case MZ_SEEK_SET:
|
|
271
|
-
|
|
272
|
-
if ((buffered->readbuf_len > 0) && (offset < buffered->position) &&
|
|
273
|
-
(offset >= buffered->position - buffered->readbuf_len)) {
|
|
274
|
-
buffered->readbuf_pos = (int32_t)(offset - (buffered->position - buffered->readbuf_len));
|
|
275
|
-
return MZ_OK;
|
|
276
|
-
}
|
|
277
|
-
if (buffered->writebuf_len > 0) {
|
|
278
|
-
if ((offset >= buffered->position) && (offset <= buffered->position + buffered->writebuf_len)) {
|
|
279
|
-
buffered->writebuf_pos = (int32_t)(offset - buffered->position);
|
|
280
|
-
return MZ_OK;
|
|
281
|
-
}
|
|
282
|
-
}
|
|
283
|
-
|
|
284
|
-
err = mz_stream_buffered_flush(stream, &bytes_flushed);
|
|
285
|
-
if (err != MZ_OK)
|
|
286
|
-
return err;
|
|
287
|
-
|
|
288
|
-
buffered->position = offset;
|
|
289
|
-
break;
|
|
290
|
-
|
|
291
|
-
case MZ_SEEK_CUR:
|
|
292
|
-
|
|
293
|
-
if (buffered->readbuf_len > 0) {
|
|
294
|
-
if (offset <= ((int64_t)buffered->readbuf_len - buffered->readbuf_pos)) {
|
|
295
|
-
buffered->readbuf_pos += (uint32_t)offset;
|
|
296
|
-
return MZ_OK;
|
|
297
|
-
}
|
|
298
|
-
offset -= ((int64_t)buffered->readbuf_len - buffered->readbuf_pos);
|
|
299
|
-
buffered->position += offset;
|
|
300
|
-
}
|
|
301
|
-
if (buffered->writebuf_len > 0) {
|
|
302
|
-
if (offset <= ((int64_t)buffered->writebuf_len - buffered->writebuf_pos)) {
|
|
303
|
-
buffered->writebuf_pos += (uint32_t)offset;
|
|
304
|
-
return MZ_OK;
|
|
305
|
-
}
|
|
306
|
-
/* offset -= (buffered->writebuf_len - buffered->writebuf_pos); */
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
err = mz_stream_buffered_flush(stream, &bytes_flushed);
|
|
310
|
-
if (err != MZ_OK)
|
|
311
|
-
return err;
|
|
312
|
-
|
|
313
|
-
break;
|
|
314
|
-
|
|
315
|
-
case MZ_SEEK_END:
|
|
316
|
-
|
|
317
|
-
if (buffered->writebuf_len > 0) {
|
|
318
|
-
buffered->writebuf_pos = buffered->writebuf_len;
|
|
319
|
-
return MZ_OK;
|
|
320
|
-
}
|
|
321
|
-
break;
|
|
322
|
-
}
|
|
323
|
-
|
|
324
|
-
buffered->readbuf_len = 0;
|
|
325
|
-
buffered->readbuf_pos = 0;
|
|
326
|
-
buffered->writebuf_len = 0;
|
|
327
|
-
buffered->writebuf_pos = 0;
|
|
328
|
-
|
|
329
|
-
return mz_stream_seek(buffered->stream.base, offset, origin);
|
|
330
|
-
}
|
|
331
|
-
|
|
332
|
-
int32_t mz_stream_buffered_close(void *stream) {
|
|
333
|
-
mz_stream_buffered *buffered = (mz_stream_buffered *)stream;
|
|
334
|
-
int32_t bytes_flushed = 0;
|
|
335
|
-
|
|
336
|
-
mz_stream_buffered_flush(stream, &bytes_flushed);
|
|
337
|
-
mz_stream_buffered_print("Buffered - Close (flushed %" PRId32 ")\n", bytes_flushed);
|
|
338
|
-
|
|
339
|
-
if (buffered->readbuf_hits + buffered->readbuf_misses > 0) {
|
|
340
|
-
mz_stream_buffered_print("Buffered - Read efficiency %.02f%%\n",
|
|
341
|
-
(buffered->readbuf_hits / ((float)buffered->readbuf_hits + buffered->readbuf_misses)) * 100);
|
|
342
|
-
}
|
|
343
|
-
|
|
344
|
-
if (buffered->writebuf_hits + buffered->writebuf_misses > 0) {
|
|
345
|
-
mz_stream_buffered_print("Buffered - Write efficiency %.02f%%\n",
|
|
346
|
-
(buffered->writebuf_hits / ((float)buffered->writebuf_hits + buffered->writebuf_misses)) * 100);
|
|
347
|
-
}
|
|
348
|
-
|
|
349
|
-
mz_stream_buffered_reset(buffered);
|
|
350
|
-
|
|
351
|
-
return mz_stream_close(buffered->stream.base);
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
int32_t mz_stream_buffered_error(void *stream) {
|
|
355
|
-
mz_stream_buffered *buffered = (mz_stream_buffered *)stream;
|
|
356
|
-
return mz_stream_error(buffered->stream.base);
|
|
357
|
-
}
|
|
358
|
-
|
|
359
|
-
void *mz_stream_buffered_create(void **stream) {
|
|
360
|
-
mz_stream_buffered *buffered = NULL;
|
|
361
|
-
|
|
362
|
-
buffered = (mz_stream_buffered *)calloc(1, sizeof(mz_stream_buffered));
|
|
363
|
-
if (buffered)
|
|
364
|
-
buffered->stream.vtbl = &mz_stream_buffered_vtbl;
|
|
365
|
-
if (stream)
|
|
366
|
-
*stream = buffered;
|
|
367
|
-
|
|
368
|
-
return buffered;
|
|
369
|
-
}
|
|
370
|
-
|
|
371
|
-
void mz_stream_buffered_delete(void **stream) {
|
|
372
|
-
mz_stream_buffered *buffered = NULL;
|
|
373
|
-
if (!stream)
|
|
374
|
-
return;
|
|
375
|
-
buffered = (mz_stream_buffered *)*stream;
|
|
376
|
-
if (buffered)
|
|
377
|
-
free(buffered);
|
|
378
|
-
*stream = NULL;
|
|
379
|
-
}
|
|
380
|
-
|
|
381
|
-
void *mz_stream_buffered_get_interface(void) {
|
|
382
|
-
return (void *)&mz_stream_buffered_vtbl;
|
|
383
|
-
}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
/* mz_strm_buf.h -- Stream for buffering reads/writes
|
|
2
|
-
part of the minizip-ng project
|
|
3
|
-
|
|
4
|
-
This version of ioapi is designed to buffer IO.
|
|
5
|
-
|
|
6
|
-
Copyright (C) Nathan Moinvaziri
|
|
7
|
-
https://github.com/zlib-ng/minizip-ng
|
|
8
|
-
|
|
9
|
-
This program is distributed under the terms of the same license as zlib.
|
|
10
|
-
See the accompanying LICENSE file for the full text of the license.
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
#ifndef MZ_STREAM_BUFFERED_H
|
|
14
|
-
#define MZ_STREAM_BUFFERED_H
|
|
15
|
-
|
|
16
|
-
#ifdef __cplusplus
|
|
17
|
-
extern "C" {
|
|
18
|
-
#endif
|
|
19
|
-
|
|
20
|
-
/***************************************************************************/
|
|
21
|
-
|
|
22
|
-
int32_t mz_stream_buffered_open(void *stream, const char *path, int32_t mode);
|
|
23
|
-
int32_t mz_stream_buffered_is_open(void *stream);
|
|
24
|
-
int32_t mz_stream_buffered_read(void *stream, void *buf, int32_t size);
|
|
25
|
-
int32_t mz_stream_buffered_write(void *stream, const void *buf, int32_t size);
|
|
26
|
-
int64_t mz_stream_buffered_tell(void *stream);
|
|
27
|
-
int32_t mz_stream_buffered_seek(void *stream, int64_t offset, int32_t origin);
|
|
28
|
-
int32_t mz_stream_buffered_close(void *stream);
|
|
29
|
-
int32_t mz_stream_buffered_error(void *stream);
|
|
30
|
-
|
|
31
|
-
void* mz_stream_buffered_create(void **stream);
|
|
32
|
-
void mz_stream_buffered_delete(void **stream);
|
|
33
|
-
|
|
34
|
-
void* mz_stream_buffered_get_interface(void);
|
|
35
|
-
|
|
36
|
-
/***************************************************************************/
|
|
37
|
-
|
|
38
|
-
#ifdef __cplusplus
|
|
39
|
-
}
|
|
40
|
-
#endif
|
|
41
|
-
|
|
42
|
-
#endif
|
|
@@ -1,269 +0,0 @@
|
|
|
1
|
-
/* mz_strm_mem.c -- Stream for memory access
|
|
2
|
-
part of the minizip-ng project
|
|
3
|
-
|
|
4
|
-
This interface is designed to access memory rather than files.
|
|
5
|
-
We do use a region of memory to put data in to and take it out of.
|
|
6
|
-
|
|
7
|
-
Based on Unzip ioapi.c version 0.22, May 19th, 2003
|
|
8
|
-
|
|
9
|
-
Copyright (C) Nathan Moinvaziri
|
|
10
|
-
https://github.com/zlib-ng/minizip-ng
|
|
11
|
-
Copyright (C) 2003 Justin Fletcher
|
|
12
|
-
Copyright (C) 1998-2003 Gilles Vollant
|
|
13
|
-
https://www.winimage.com/zLibDll/minizip.html
|
|
14
|
-
|
|
15
|
-
This program is distributed under the terms of the same license as zlib.
|
|
16
|
-
See the accompanying LICENSE file for the full text of the license.
|
|
17
|
-
*/
|
|
18
|
-
|
|
19
|
-
#include "mz.h"
|
|
20
|
-
#include "mz_strm.h"
|
|
21
|
-
#include "mz_strm_mem.h"
|
|
22
|
-
|
|
23
|
-
/***************************************************************************/
|
|
24
|
-
|
|
25
|
-
static mz_stream_vtbl mz_stream_mem_vtbl = {
|
|
26
|
-
mz_stream_mem_open,
|
|
27
|
-
mz_stream_mem_is_open,
|
|
28
|
-
mz_stream_mem_read,
|
|
29
|
-
mz_stream_mem_write,
|
|
30
|
-
mz_stream_mem_tell,
|
|
31
|
-
mz_stream_mem_seek,
|
|
32
|
-
mz_stream_mem_close,
|
|
33
|
-
mz_stream_mem_error,
|
|
34
|
-
mz_stream_mem_create,
|
|
35
|
-
mz_stream_mem_delete,
|
|
36
|
-
NULL,
|
|
37
|
-
NULL
|
|
38
|
-
};
|
|
39
|
-
|
|
40
|
-
/***************************************************************************/
|
|
41
|
-
|
|
42
|
-
typedef struct mz_stream_mem_s {
|
|
43
|
-
mz_stream stream;
|
|
44
|
-
int32_t mode;
|
|
45
|
-
uint8_t *buffer; /* Memory buffer pointer */
|
|
46
|
-
int32_t size; /* Size of the memory buffer */
|
|
47
|
-
int32_t limit; /* Furthest we've written */
|
|
48
|
-
int32_t position; /* Current position in the memory */
|
|
49
|
-
int32_t grow_size; /* Size to grow when full */
|
|
50
|
-
} mz_stream_mem;
|
|
51
|
-
|
|
52
|
-
/***************************************************************************/
|
|
53
|
-
|
|
54
|
-
static int32_t mz_stream_mem_set_size(void *stream, int32_t size) {
|
|
55
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
56
|
-
int32_t new_size = size;
|
|
57
|
-
uint8_t *new_buf = NULL;
|
|
58
|
-
|
|
59
|
-
new_buf = (uint8_t *)malloc((uint32_t)new_size);
|
|
60
|
-
if (!new_buf)
|
|
61
|
-
return MZ_BUF_ERROR;
|
|
62
|
-
|
|
63
|
-
if (mem->buffer) {
|
|
64
|
-
memcpy(new_buf, mem->buffer, mem->size);
|
|
65
|
-
free(mem->buffer);
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
mem->buffer = new_buf;
|
|
69
|
-
mem->size = new_size;
|
|
70
|
-
return MZ_OK;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
int32_t mz_stream_mem_open(void *stream, const char *path, int32_t mode) {
|
|
74
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
75
|
-
int32_t err = MZ_OK;
|
|
76
|
-
|
|
77
|
-
MZ_UNUSED(path);
|
|
78
|
-
|
|
79
|
-
mem->mode = mode;
|
|
80
|
-
mem->limit = 0;
|
|
81
|
-
mem->position = 0;
|
|
82
|
-
|
|
83
|
-
if (mem->mode & MZ_OPEN_MODE_CREATE)
|
|
84
|
-
err = mz_stream_mem_set_size(stream, mem->grow_size);
|
|
85
|
-
else
|
|
86
|
-
mem->limit = mem->size;
|
|
87
|
-
|
|
88
|
-
return err;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
int32_t mz_stream_mem_is_open(void *stream) {
|
|
92
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
93
|
-
if (!mem->buffer)
|
|
94
|
-
return MZ_OPEN_ERROR;
|
|
95
|
-
return MZ_OK;
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
int32_t mz_stream_mem_read(void *stream, void *buf, int32_t size) {
|
|
99
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
100
|
-
|
|
101
|
-
if (size > mem->size - mem->position)
|
|
102
|
-
size = mem->size - mem->position;
|
|
103
|
-
if (mem->position + size > mem->limit)
|
|
104
|
-
size = mem->limit - mem->position;
|
|
105
|
-
|
|
106
|
-
if (size <= 0)
|
|
107
|
-
return 0;
|
|
108
|
-
|
|
109
|
-
memcpy(buf, mem->buffer + mem->position, size);
|
|
110
|
-
mem->position += size;
|
|
111
|
-
|
|
112
|
-
return size;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
int32_t mz_stream_mem_write(void *stream, const void *buf, int32_t size) {
|
|
116
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
117
|
-
int32_t new_size = 0;
|
|
118
|
-
int32_t err = MZ_OK;
|
|
119
|
-
|
|
120
|
-
if (!size)
|
|
121
|
-
return size;
|
|
122
|
-
|
|
123
|
-
if (size > mem->size - mem->position) {
|
|
124
|
-
if (mem->mode & MZ_OPEN_MODE_CREATE) {
|
|
125
|
-
new_size = mem->size;
|
|
126
|
-
if (size < mem->grow_size)
|
|
127
|
-
new_size += mem->grow_size;
|
|
128
|
-
else
|
|
129
|
-
new_size += size;
|
|
130
|
-
|
|
131
|
-
err = mz_stream_mem_set_size(stream, new_size);
|
|
132
|
-
if (err != MZ_OK)
|
|
133
|
-
return err;
|
|
134
|
-
} else {
|
|
135
|
-
size = mem->size - mem->position;
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
memcpy(mem->buffer + mem->position, buf, size);
|
|
140
|
-
|
|
141
|
-
mem->position += size;
|
|
142
|
-
if (mem->position > mem->limit)
|
|
143
|
-
mem->limit = mem->position;
|
|
144
|
-
|
|
145
|
-
return size;
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
int64_t mz_stream_mem_tell(void *stream) {
|
|
149
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
150
|
-
return mem->position;
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
int32_t mz_stream_mem_seek(void *stream, int64_t offset, int32_t origin) {
|
|
154
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
155
|
-
int64_t new_pos = 0;
|
|
156
|
-
int32_t err = MZ_OK;
|
|
157
|
-
|
|
158
|
-
switch (origin) {
|
|
159
|
-
case MZ_SEEK_CUR:
|
|
160
|
-
new_pos = mem->position + offset;
|
|
161
|
-
break;
|
|
162
|
-
case MZ_SEEK_END:
|
|
163
|
-
new_pos = mem->limit + offset;
|
|
164
|
-
break;
|
|
165
|
-
case MZ_SEEK_SET:
|
|
166
|
-
new_pos = offset;
|
|
167
|
-
break;
|
|
168
|
-
default:
|
|
169
|
-
return MZ_SEEK_ERROR;
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
if (new_pos > mem->size) {
|
|
173
|
-
if ((mem->mode & MZ_OPEN_MODE_CREATE) == 0)
|
|
174
|
-
return MZ_SEEK_ERROR;
|
|
175
|
-
|
|
176
|
-
err = mz_stream_mem_set_size(stream, (int32_t)new_pos);
|
|
177
|
-
if (err != MZ_OK)
|
|
178
|
-
return err;
|
|
179
|
-
} else if (new_pos < 0) {
|
|
180
|
-
return MZ_SEEK_ERROR;
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
mem->position = (int32_t)new_pos;
|
|
184
|
-
return MZ_OK;
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
int32_t mz_stream_mem_close(void *stream) {
|
|
188
|
-
MZ_UNUSED(stream);
|
|
189
|
-
|
|
190
|
-
/* We never return errors */
|
|
191
|
-
return MZ_OK;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
int32_t mz_stream_mem_error(void *stream) {
|
|
195
|
-
MZ_UNUSED(stream);
|
|
196
|
-
|
|
197
|
-
/* We never return errors */
|
|
198
|
-
return MZ_OK;
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
void mz_stream_mem_set_buffer(void *stream, void *buf, int32_t size) {
|
|
202
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
203
|
-
mem->buffer = (uint8_t *)buf;
|
|
204
|
-
mem->size = size;
|
|
205
|
-
mem->limit = size;
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
int32_t mz_stream_mem_get_buffer(void *stream, const void **buf) {
|
|
209
|
-
return mz_stream_mem_get_buffer_at(stream, 0, buf);
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
int32_t mz_stream_mem_get_buffer_at(void *stream, int64_t position, const void **buf) {
|
|
213
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
214
|
-
if (!buf || position < 0 || !mem->buffer|| mem->size < position)
|
|
215
|
-
return MZ_SEEK_ERROR;
|
|
216
|
-
*buf = mem->buffer + position;
|
|
217
|
-
return MZ_OK;
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
int32_t mz_stream_mem_get_buffer_at_current(void *stream, const void **buf) {
|
|
221
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
222
|
-
return mz_stream_mem_get_buffer_at(stream, mem->position, buf);
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
void mz_stream_mem_get_buffer_length(void *stream, int32_t *length) {
|
|
226
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
227
|
-
*length = mem->limit;
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
void mz_stream_mem_set_buffer_limit(void *stream, int32_t limit) {
|
|
231
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
232
|
-
mem->limit = limit;
|
|
233
|
-
}
|
|
234
|
-
|
|
235
|
-
void mz_stream_mem_set_grow_size(void *stream, int32_t grow_size) {
|
|
236
|
-
mz_stream_mem *mem = (mz_stream_mem *)stream;
|
|
237
|
-
mem->grow_size = grow_size;
|
|
238
|
-
}
|
|
239
|
-
|
|
240
|
-
void *mz_stream_mem_create(void **stream) {
|
|
241
|
-
mz_stream_mem *mem = NULL;
|
|
242
|
-
|
|
243
|
-
mem = (mz_stream_mem *)calloc(1, sizeof(mz_stream_mem));
|
|
244
|
-
if (mem) {
|
|
245
|
-
mem->stream.vtbl = &mz_stream_mem_vtbl;
|
|
246
|
-
mem->grow_size = 4096;
|
|
247
|
-
}
|
|
248
|
-
if (stream)
|
|
249
|
-
*stream = mem;
|
|
250
|
-
|
|
251
|
-
return mem;
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
void mz_stream_mem_delete(void **stream) {
|
|
255
|
-
mz_stream_mem *mem = NULL;
|
|
256
|
-
if (!stream)
|
|
257
|
-
return;
|
|
258
|
-
mem = (mz_stream_mem *)*stream;
|
|
259
|
-
if (mem) {
|
|
260
|
-
if ((mem->mode & MZ_OPEN_MODE_CREATE) && (mem->buffer))
|
|
261
|
-
free(mem->buffer);
|
|
262
|
-
free(mem);
|
|
263
|
-
}
|
|
264
|
-
*stream = NULL;
|
|
265
|
-
}
|
|
266
|
-
|
|
267
|
-
void *mz_stream_mem_get_interface(void) {
|
|
268
|
-
return (void *)&mz_stream_mem_vtbl;
|
|
269
|
-
}
|