Merge pull request #32744 from qarmin/bytearray_compress_fix

Don't use in some functions empty PoolByteArrays
This commit is contained in:
Rémi Verschelde 2019-10-11 15:16:35 +02:00 committed by GitHub
commit ebbbcd4e16
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -553,7 +553,7 @@ struct _VariantCall {
PoolByteArray *ba = reinterpret_cast<PoolByteArray *>(p_self._data._mem); PoolByteArray *ba = reinterpret_cast<PoolByteArray *>(p_self._data._mem);
String s; String s;
if (ba->size() >= 0) { if (ba->size() > 0) {
PoolByteArray::Read r = ba->read(); PoolByteArray::Read r = ba->read();
CharString cs; CharString cs;
cs.resize(ba->size() + 1); cs.resize(ba->size() + 1);
@ -569,7 +569,7 @@ struct _VariantCall {
PoolByteArray *ba = reinterpret_cast<PoolByteArray *>(p_self._data._mem); PoolByteArray *ba = reinterpret_cast<PoolByteArray *>(p_self._data._mem);
String s; String s;
if (ba->size() >= 0) { if (ba->size() > 0) {
PoolByteArray::Read r = ba->read(); PoolByteArray::Read r = ba->read();
s.parse_utf8((const char *)r.ptr(), ba->size()); s.parse_utf8((const char *)r.ptr(), ba->size());
} }
@ -580,6 +580,7 @@ struct _VariantCall {
PoolByteArray *ba = reinterpret_cast<PoolByteArray *>(p_self._data._mem); PoolByteArray *ba = reinterpret_cast<PoolByteArray *>(p_self._data._mem);
PoolByteArray compressed; PoolByteArray compressed;
if (ba->size() > 0) {
Compression::Mode mode = (Compression::Mode)(int)(*p_args[0]); Compression::Mode mode = (Compression::Mode)(int)(*p_args[0]);
compressed.resize(Compression::get_max_compressed_buffer_size(ba->size(), mode)); compressed.resize(Compression::get_max_compressed_buffer_size(ba->size(), mode));
@ -587,7 +588,7 @@ struct _VariantCall {
result = result >= 0 ? result : 0; result = result >= 0 ? result : 0;
compressed.resize(result); compressed.resize(result);
}
r_ret = compressed; r_ret = compressed;
} }
@ -615,6 +616,10 @@ struct _VariantCall {
static void _call_PoolByteArray_hex_encode(Variant &r_ret, Variant &p_self, const Variant **p_args) { static void _call_PoolByteArray_hex_encode(Variant &r_ret, Variant &p_self, const Variant **p_args) {
PoolByteArray *ba = reinterpret_cast<PoolByteArray *>(p_self._data._mem); PoolByteArray *ba = reinterpret_cast<PoolByteArray *>(p_self._data._mem);
if (ba->size() == 0) {
r_ret = String();
return;
}
PoolByteArray::Read r = ba->read(); PoolByteArray::Read r = ba->read();
String s = String::hex_encode_buffer(&r[0], ba->size()); String s = String::hex_encode_buffer(&r[0], ba->size());
r_ret = s; r_ret = s;