summaryrefslogtreecommitdiffstats
path: root/thirdparty
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-08-28 13:14:27 +0200
committerRémi Verschelde <rverschelde@gmail.com>2024-08-28 13:14:27 +0200
commit5a11abc899655d980d2e0aacaa743c88bcbdade8 (patch)
tree12fadcd49bf7822b8a1c7eaeed830cbcb4110469 /thirdparty
parent60765bebe4ce6a1f645f6c934aa4ea4058cf3b90 (diff)
parente67cc7346387c0bf27bd9606ebfca2f550d59bcd (diff)
downloadredot-engine-5a11abc899655d980d2e0aacaa743c88bcbdade8.tar.gz
Merge pull request #96198 from DeeJayLSP/qoa-leak
ResourceImporterWAV: Fix memory leak on QOA import
Diffstat (limited to 'thirdparty')
-rw-r--r--thirdparty/README.md4
-rw-r--r--thirdparty/misc/patches/qoa-min-fix.patch14
-rw-r--r--thirdparty/misc/qoa.h6
3 files changed, 10 insertions, 14 deletions
diff --git a/thirdparty/README.md b/thirdparty/README.md
index 799eb97cd2..d87c1c3c33 100644
--- a/thirdparty/README.md
+++ b/thirdparty/README.md
@@ -692,8 +692,8 @@ Collection of single-file libraries used in Godot components.
* License: MIT
- `qoa.h`
* Upstream: https://github.com/phoboslab/qoa
- * Version: git (5c2a86d615661f34636cf179abf4fa278d3257e0, 2024)
- * Modifications: Inlined functions, patched uninitialized variables and untyped mallocs.
+ * Version: git (e0c69447d4d3945c3c92ac1751e4cdc9803a8303, 2024)
+ * Modifications: Added a few modifiers to comply with C++ nature.
* License: MIT
- `r128.{c,h}`
* Upstream: https://github.com/fahickman/r128
diff --git a/thirdparty/misc/patches/qoa-min-fix.patch b/thirdparty/misc/patches/qoa-min-fix.patch
index 38303a1521..6008b5f8bc 100644
--- a/thirdparty/misc/patches/qoa-min-fix.patch
+++ b/thirdparty/misc/patches/qoa-min-fix.patch
@@ -1,5 +1,5 @@
diff --git a/qoa.h b/qoa.h
-index 592082933a..c890b88bd6 100644
+index cfed266bef..23612bb0bf 100644
--- a/qoa.h
+++ b/qoa.h
@@ -140,14 +140,14 @@ typedef struct {
@@ -24,19 +24,15 @@ index 592082933a..c890b88bd6 100644
#ifndef QOA_NO_STDIO
-@@ -394,9 +394,9 @@ unsigned int qoa_encode_frame(const short *sample_data, qoa_desc *qoa, unsigned
- #ifdef QOA_RECORD_TOTAL_ERROR
+@@ -395,7 +395,7 @@ unsigned int qoa_encode_frame(const short *sample_data, qoa_desc *qoa, unsigned
qoa_uint64_t best_error = -1;
#endif
-- qoa_uint64_t best_slice;
+ qoa_uint64_t best_slice = 0;
- qoa_lms_t best_lms;
-- int best_scalefactor;
-+ qoa_uint64_t best_slice = -1;
-+ qoa_lms_t best_lms = {{-1, -1, -1, -1}, {-1, -1, -1, -1}};
-+ int best_scalefactor = -1;
++ qoa_lms_t best_lms = {};
+ int best_scalefactor = 0;
for (int sfi = 0; sfi < 16; sfi++) {
- /* There is a strong correlation between the scalefactors of
@@ -500,7 +500,7 @@ void *qoa_encode(const short *sample_data, qoa_desc *qoa, unsigned int *out_len)
num_frames * QOA_LMS_LEN * 4 * qoa->channels + /* 4 * 4 bytes lms state per channel */
num_slices * 8 * qoa->channels; /* 8 byte slices */
diff --git a/thirdparty/misc/qoa.h b/thirdparty/misc/qoa.h
index c890b88bd6..23612bb0bf 100644
--- a/thirdparty/misc/qoa.h
+++ b/thirdparty/misc/qoa.h
@@ -394,9 +394,9 @@ unsigned int qoa_encode_frame(const short *sample_data, qoa_desc *qoa, unsigned
#ifdef QOA_RECORD_TOTAL_ERROR
qoa_uint64_t best_error = -1;
#endif
- qoa_uint64_t best_slice = -1;
- qoa_lms_t best_lms = {{-1, -1, -1, -1}, {-1, -1, -1, -1}};
- int best_scalefactor = -1;
+ qoa_uint64_t best_slice = 0;
+ qoa_lms_t best_lms = {};
+ int best_scalefactor = 0;
for (int sfi = 0; sfi < 16; sfi++) {
/* There is a strong correlation between the scalefactors of