mirror of
https://github.com/bblanchon/ArduinoJson.git
synced 2025-08-01 11:44:45 +02:00
Reduce the size of deserializeMsgPack()
This commit is contained in:
@@ -52,6 +52,82 @@ class MsgPackDeserializer {
|
|||||||
ARDUINOJSON_ASSERT(variant != 0);
|
ARDUINOJSON_ASSERT(variant != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
size_t size = 0;
|
||||||
|
|
||||||
|
switch (code) {
|
||||||
|
case 0xc4: // bin 8
|
||||||
|
case 0xc7: // ext 8
|
||||||
|
case 0xd9: // str 8
|
||||||
|
uint8_t size8;
|
||||||
|
err = readInteger(size8);
|
||||||
|
size = size8;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 0xc5: // bin 16
|
||||||
|
case 0xc8: // ext 16
|
||||||
|
case 0xda: // str 16
|
||||||
|
case 0xdc: // array 16
|
||||||
|
case 0xde: // map 16
|
||||||
|
uint16_t size16;
|
||||||
|
err = readInteger(size16);
|
||||||
|
size = size16;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 0xc6: // bin 32
|
||||||
|
case 0xc9: // ext 32
|
||||||
|
case 0xdb: // str 32
|
||||||
|
case 0xdd: // array 32
|
||||||
|
case 0xdf: // map 32
|
||||||
|
uint32_t size32;
|
||||||
|
err = readInteger(size32);
|
||||||
|
size = size32;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (err)
|
||||||
|
return err;
|
||||||
|
|
||||||
|
switch (code & 0xf0) {
|
||||||
|
case 0x90: // fixarray
|
||||||
|
case 0x80: // fixmap
|
||||||
|
size = code & 0x0F;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (code & 0xe0) {
|
||||||
|
case 0xa0: // fixstr
|
||||||
|
size = code & 0x1f;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
// array 16, 32 and fixarray
|
||||||
|
if (code == 0xdc || code == 0xdd || (code & 0xf0) == 0x90)
|
||||||
|
return readArray(variant, size, filter, nestingLimit);
|
||||||
|
|
||||||
|
// map 16, 32 and fixmap
|
||||||
|
if (code == 0xde || code == 0xdf || (code & 0xf0) == 0x80)
|
||||||
|
return readObject(variant, size, filter, nestingLimit);
|
||||||
|
|
||||||
|
// str 8, 16, 32 and fixstr
|
||||||
|
if (code == 0xd9 || code == 0xda || code == 0xdb || (code & 0xe0) == 0xa0) {
|
||||||
|
if (allowValue)
|
||||||
|
return readString(variant, size);
|
||||||
|
else
|
||||||
|
return skipBytes(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
// bin 8, 16, 32
|
||||||
|
if (code == 0xc4 || code == 0xc5 || code == 0xc6) {
|
||||||
|
if (allowValue)
|
||||||
|
return readBinary(variant, size);
|
||||||
|
else
|
||||||
|
return skipBytes(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
// ext 8, 16, 32
|
||||||
|
if (code == 0xc7 || code == 0xc8 || code == 0xc9)
|
||||||
|
return skipBytes(size + 1);
|
||||||
|
|
||||||
switch (code) {
|
switch (code) {
|
||||||
case 0xc0:
|
case 0xc0:
|
||||||
// already null
|
// already null
|
||||||
@@ -70,33 +146,6 @@ class MsgPackDeserializer {
|
|||||||
variant->setBoolean(true);
|
variant->setBoolean(true);
|
||||||
return DeserializationError::Ok;
|
return DeserializationError::Ok;
|
||||||
|
|
||||||
case 0xc4:
|
|
||||||
if (allowValue)
|
|
||||||
return readBinary<uint8_t>(variant);
|
|
||||||
else
|
|
||||||
return skipString<uint8_t>();
|
|
||||||
|
|
||||||
case 0xc5:
|
|
||||||
if (allowValue)
|
|
||||||
return readBinary<uint16_t>(variant);
|
|
||||||
else
|
|
||||||
return skipString<uint16_t>();
|
|
||||||
|
|
||||||
case 0xc6:
|
|
||||||
if (allowValue)
|
|
||||||
return readBinary<uint32_t>(variant);
|
|
||||||
else
|
|
||||||
return skipString<uint32_t>();
|
|
||||||
|
|
||||||
case 0xc7: // ext 8 (not supported)
|
|
||||||
return skipExt<uint8_t>();
|
|
||||||
|
|
||||||
case 0xc8: // ext 16 (not supported)
|
|
||||||
return skipExt<uint16_t>();
|
|
||||||
|
|
||||||
case 0xc9: // ext 32 (not supported)
|
|
||||||
return skipExt<uint32_t>();
|
|
||||||
|
|
||||||
case 0xca:
|
case 0xca:
|
||||||
if (allowValue)
|
if (allowValue)
|
||||||
return readFloat<float>(variant);
|
return readFloat<float>(variant);
|
||||||
@@ -180,56 +229,11 @@ class MsgPackDeserializer {
|
|||||||
case 0xd8: // fixext 16 (not supported)
|
case 0xd8: // fixext 16 (not supported)
|
||||||
return skipBytes(17);
|
return skipBytes(17);
|
||||||
|
|
||||||
case 0xd9:
|
default: // fixint
|
||||||
if (allowValue)
|
if (allowValue)
|
||||||
return readString<uint8_t>(variant);
|
variant->setInteger(static_cast<int8_t>(code));
|
||||||
else
|
return DeserializationError::Ok;
|
||||||
return skipString<uint8_t>();
|
|
||||||
|
|
||||||
case 0xda:
|
|
||||||
if (allowValue)
|
|
||||||
return readString<uint16_t>(variant);
|
|
||||||
else
|
|
||||||
return skipString<uint16_t>();
|
|
||||||
|
|
||||||
case 0xdb:
|
|
||||||
if (allowValue)
|
|
||||||
return readString<uint32_t>(variant);
|
|
||||||
else
|
|
||||||
return skipString<uint32_t>();
|
|
||||||
|
|
||||||
case 0xdc:
|
|
||||||
return readArray<uint16_t>(variant, filter, nestingLimit);
|
|
||||||
|
|
||||||
case 0xdd:
|
|
||||||
return readArray<uint32_t>(variant, filter, nestingLimit);
|
|
||||||
|
|
||||||
case 0xde:
|
|
||||||
return readObject<uint16_t>(variant, filter, nestingLimit);
|
|
||||||
|
|
||||||
case 0xdf:
|
|
||||||
return readObject<uint32_t>(variant, filter, nestingLimit);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (code & 0xf0) {
|
|
||||||
case 0x80:
|
|
||||||
return readObject(variant, code & 0x0F, filter, nestingLimit);
|
|
||||||
|
|
||||||
case 0x90:
|
|
||||||
return readArray(variant, code & 0x0F, filter, nestingLimit);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((code & 0xe0) == 0xa0) {
|
|
||||||
if (allowValue)
|
|
||||||
return readString(variant, code & 0x1f);
|
|
||||||
else
|
|
||||||
return skipBytes(code & 0x1f);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (allowValue)
|
|
||||||
variant->setInteger(static_cast<int8_t>(code));
|
|
||||||
|
|
||||||
return DeserializationError::Ok;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
DeserializationError::Code readByte(uint8_t& value) {
|
DeserializationError::Code readByte(uint8_t& value) {
|
||||||
@@ -337,18 +341,6 @@ class MsgPackDeserializer {
|
|||||||
return DeserializationError::Ok;
|
return DeserializationError::Ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
DeserializationError::Code readString(VariantData* variant) {
|
|
||||||
DeserializationError::Code err;
|
|
||||||
T size;
|
|
||||||
|
|
||||||
err = readInteger(size);
|
|
||||||
if (err)
|
|
||||||
return err;
|
|
||||||
|
|
||||||
return readString(variant, size);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
DeserializationError::Code readString() {
|
DeserializationError::Code readString() {
|
||||||
DeserializationError::Code err;
|
DeserializationError::Code err;
|
||||||
@@ -361,18 +353,6 @@ class MsgPackDeserializer {
|
|||||||
return readString(size);
|
return readString(size);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
DeserializationError::Code skipString() {
|
|
||||||
DeserializationError::Code err;
|
|
||||||
T size;
|
|
||||||
|
|
||||||
err = readInteger(size);
|
|
||||||
if (err)
|
|
||||||
return err;
|
|
||||||
|
|
||||||
return skipBytes(size);
|
|
||||||
}
|
|
||||||
|
|
||||||
DeserializationError::Code readString(VariantData* variant, size_t n) {
|
DeserializationError::Code readString(VariantData* variant, size_t n) {
|
||||||
DeserializationError::Code err;
|
DeserializationError::Code err;
|
||||||
|
|
||||||
@@ -392,18 +372,6 @@ class MsgPackDeserializer {
|
|||||||
return readBytes(p, n);
|
return readBytes(p, n);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
DeserializationError::Code readBinary(VariantData* variant) {
|
|
||||||
DeserializationError::Code err;
|
|
||||||
T size;
|
|
||||||
|
|
||||||
err = readInteger(size);
|
|
||||||
if (err)
|
|
||||||
return err;
|
|
||||||
|
|
||||||
return readBinary(variant, size);
|
|
||||||
}
|
|
||||||
|
|
||||||
DeserializationError::Code readBinary(VariantData* variant, size_t n) {
|
DeserializationError::Code readBinary(VariantData* variant, size_t n) {
|
||||||
DeserializationError::Code err;
|
DeserializationError::Code err;
|
||||||
|
|
||||||
@@ -415,20 +383,6 @@ class MsgPackDeserializer {
|
|||||||
return DeserializationError::Ok;
|
return DeserializationError::Ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename TSize, typename TFilter>
|
|
||||||
DeserializationError::Code readArray(
|
|
||||||
VariantData* variant, TFilter filter,
|
|
||||||
DeserializationOption::NestingLimit nestingLimit) {
|
|
||||||
DeserializationError::Code err;
|
|
||||||
TSize size;
|
|
||||||
|
|
||||||
err = readInteger(size);
|
|
||||||
if (err)
|
|
||||||
return err;
|
|
||||||
|
|
||||||
return readArray(variant, size, filter, nestingLimit);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename TFilter>
|
template <typename TFilter>
|
||||||
DeserializationError::Code readArray(
|
DeserializationError::Code readArray(
|
||||||
VariantData* variant, size_t n, TFilter filter,
|
VariantData* variant, size_t n, TFilter filter,
|
||||||
@@ -470,20 +424,6 @@ class MsgPackDeserializer {
|
|||||||
return DeserializationError::Ok;
|
return DeserializationError::Ok;
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename TSize, typename TFilter>
|
|
||||||
DeserializationError::Code readObject(
|
|
||||||
VariantData* variant, TFilter filter,
|
|
||||||
DeserializationOption::NestingLimit nestingLimit) {
|
|
||||||
DeserializationError::Code err;
|
|
||||||
TSize size;
|
|
||||||
|
|
||||||
err = readInteger(size);
|
|
||||||
if (err)
|
|
||||||
return err;
|
|
||||||
|
|
||||||
return readObject(variant, size, filter, nestingLimit);
|
|
||||||
}
|
|
||||||
|
|
||||||
template <typename TFilter>
|
template <typename TFilter>
|
||||||
DeserializationError::Code readObject(
|
DeserializationError::Code readObject(
|
||||||
VariantData* variant, size_t n, TFilter filter,
|
VariantData* variant, size_t n, TFilter filter,
|
||||||
@@ -557,18 +497,6 @@ class MsgPackDeserializer {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
DeserializationError::Code skipExt() {
|
|
||||||
DeserializationError::Code err;
|
|
||||||
T size;
|
|
||||||
|
|
||||||
err = readInteger(size);
|
|
||||||
if (err)
|
|
||||||
return err;
|
|
||||||
|
|
||||||
return skipBytes(size + 1U);
|
|
||||||
}
|
|
||||||
|
|
||||||
ResourceManager* resources_;
|
ResourceManager* resources_;
|
||||||
TReader reader_;
|
TReader reader_;
|
||||||
StringBuffer stringBuffer_;
|
StringBuffer stringBuffer_;
|
||||||
|
Reference in New Issue
Block a user