forked from bblanchon/ArduinoJson
Remove JsonDocument::data()
and JsonDocument::memoryPool()
This commit is contained in:
@ -11,6 +11,7 @@ HEAD
|
|||||||
* Remove undocumented `accept()` functions
|
* Remove undocumented `accept()` functions
|
||||||
* Rename `addElement()` to `add()`
|
* Rename `addElement()` to `add()`
|
||||||
* Remove `getElement()`, `getOrAddElement()`, `getMember()`, and `getOrAddMember()`
|
* Remove `getElement()`, `getOrAddElement()`, `getMember()`, and `getOrAddMember()`
|
||||||
|
* Remove `JsonDocument::data()` and `JsonDocument::memoryPool()`
|
||||||
|
|
||||||
> ### BREAKING CHANGES
|
> ### BREAKING CHANGES
|
||||||
>
|
>
|
||||||
|
@ -12,7 +12,7 @@ TEST_CASE("StringCopier") {
|
|||||||
|
|
||||||
SECTION("Works when buffer is big enough") {
|
SECTION("Works when buffer is big enough") {
|
||||||
MemoryPool pool(buffer, addPadding(JSON_STRING_SIZE(5)));
|
MemoryPool pool(buffer, addPadding(JSON_STRING_SIZE(5)));
|
||||||
StringCopier str(pool);
|
StringCopier str(&pool);
|
||||||
|
|
||||||
str.startString();
|
str.startString();
|
||||||
str.append("hello");
|
str.append("hello");
|
||||||
@ -24,7 +24,7 @@ TEST_CASE("StringCopier") {
|
|||||||
|
|
||||||
SECTION("Returns null when too small") {
|
SECTION("Returns null when too small") {
|
||||||
MemoryPool pool(buffer, sizeof(void*));
|
MemoryPool pool(buffer, sizeof(void*));
|
||||||
StringCopier str(pool);
|
StringCopier str(&pool);
|
||||||
|
|
||||||
str.startString();
|
str.startString();
|
||||||
str.append("hello world!");
|
str.append("hello world!");
|
||||||
@ -35,7 +35,7 @@ TEST_CASE("StringCopier") {
|
|||||||
|
|
||||||
SECTION("Increases size of memory pool") {
|
SECTION("Increases size of memory pool") {
|
||||||
MemoryPool pool(buffer, addPadding(JSON_STRING_SIZE(6)));
|
MemoryPool pool(buffer, addPadding(JSON_STRING_SIZE(6)));
|
||||||
StringCopier str(pool);
|
StringCopier str(&pool);
|
||||||
|
|
||||||
str.startString();
|
str.startString();
|
||||||
str.save();
|
str.save();
|
||||||
@ -46,7 +46,7 @@ TEST_CASE("StringCopier") {
|
|||||||
|
|
||||||
SECTION("Works when memory pool is 0 bytes") {
|
SECTION("Works when memory pool is 0 bytes") {
|
||||||
MemoryPool pool(buffer, 0);
|
MemoryPool pool(buffer, 0);
|
||||||
StringCopier str(pool);
|
StringCopier str(&pool);
|
||||||
|
|
||||||
str.startString();
|
str.startString();
|
||||||
REQUIRE(str.isValid() == false);
|
REQUIRE(str.isValid() == false);
|
||||||
@ -55,7 +55,7 @@ TEST_CASE("StringCopier") {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static const char* addStringToPool(MemoryPool& pool, const char* s) {
|
static const char* addStringToPool(MemoryPool& pool, const char* s) {
|
||||||
StringCopier str(pool);
|
StringCopier str(&pool);
|
||||||
str.startString();
|
str.startString();
|
||||||
str.append(s);
|
str.append(s);
|
||||||
return str.save().c_str();
|
return str.save().c_str();
|
||||||
|
@ -12,7 +12,7 @@ using namespace ARDUINOJSON_NAMESPACE;
|
|||||||
static void testCodepoint(uint32_t codepoint, std::string expected) {
|
static void testCodepoint(uint32_t codepoint, std::string expected) {
|
||||||
char buffer[4096];
|
char buffer[4096];
|
||||||
MemoryPool pool(buffer, 4096);
|
MemoryPool pool(buffer, 4096);
|
||||||
StringCopier str(pool);
|
StringCopier str(&pool);
|
||||||
str.startString();
|
str.startString();
|
||||||
|
|
||||||
CAPTURE(codepoint);
|
CAPTURE(codepoint);
|
||||||
|
@ -14,9 +14,10 @@ namespace ARDUINOJSON_NAMESPACE {
|
|||||||
|
|
||||||
template <template <typename, typename> class TDeserializer, typename TReader,
|
template <template <typename, typename> class TDeserializer, typename TReader,
|
||||||
typename TWriter>
|
typename TWriter>
|
||||||
TDeserializer<TReader, TWriter> makeDeserializer(MemoryPool &pool,
|
TDeserializer<TReader, TWriter> makeDeserializer(MemoryPool *pool,
|
||||||
TReader reader,
|
TReader reader,
|
||||||
TWriter writer) {
|
TWriter writer) {
|
||||||
|
ARDUINOJSON_ASSERT(pool != 0);
|
||||||
return TDeserializer<TReader, TWriter>(pool, reader, writer);
|
return TDeserializer<TReader, TWriter>(pool, reader, writer);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -31,11 +32,12 @@ typename enable_if<!is_array<TString>::value, DeserializationError>::type
|
|||||||
deserialize(JsonDocument &doc, const TString &input, NestingLimit nestingLimit,
|
deserialize(JsonDocument &doc, const TString &input, NestingLimit nestingLimit,
|
||||||
TFilter filter) {
|
TFilter filter) {
|
||||||
Reader<TString> reader(input);
|
Reader<TString> reader(input);
|
||||||
|
VariantData *data = VariantAttorney::getData(doc);
|
||||||
|
MemoryPool *pool = VariantAttorney::getPool(doc);
|
||||||
doc.clear();
|
doc.clear();
|
||||||
return makeDeserializer<TDeserializer>(
|
return makeDeserializer<TDeserializer>(pool, reader,
|
||||||
doc.memoryPool(), reader,
|
makeStringStorage(input, pool))
|
||||||
makeStringStorage(input, doc.memoryPool()))
|
.parse(*data, filter, nestingLimit);
|
||||||
.parse(doc.data(), filter, nestingLimit);
|
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
// deserialize(JsonDocument&, char*, size_t, NestingLimit, Filter);
|
// deserialize(JsonDocument&, char*, size_t, NestingLimit, Filter);
|
||||||
@ -47,11 +49,12 @@ DeserializationError deserialize(JsonDocument &doc, TChar *input,
|
|||||||
size_t inputSize, NestingLimit nestingLimit,
|
size_t inputSize, NestingLimit nestingLimit,
|
||||||
TFilter filter) {
|
TFilter filter) {
|
||||||
BoundedReader<TChar *> reader(input, inputSize);
|
BoundedReader<TChar *> reader(input, inputSize);
|
||||||
|
VariantData *data = VariantAttorney::getData(doc);
|
||||||
|
MemoryPool *pool = VariantAttorney::getPool(doc);
|
||||||
doc.clear();
|
doc.clear();
|
||||||
return makeDeserializer<TDeserializer>(
|
return makeDeserializer<TDeserializer>(pool, reader,
|
||||||
doc.memoryPool(), reader,
|
makeStringStorage(input, pool))
|
||||||
makeStringStorage(input, doc.memoryPool()))
|
.parse(*data, filter, nestingLimit);
|
||||||
.parse(doc.data(), filter, nestingLimit);
|
|
||||||
}
|
}
|
||||||
//
|
//
|
||||||
// deserialize(JsonDocument&, std::istream&, NestingLimit, Filter);
|
// deserialize(JsonDocument&, std::istream&, NestingLimit, Filter);
|
||||||
@ -61,11 +64,12 @@ template <template <typename, typename> class TDeserializer, typename TStream,
|
|||||||
DeserializationError deserialize(JsonDocument &doc, TStream &input,
|
DeserializationError deserialize(JsonDocument &doc, TStream &input,
|
||||||
NestingLimit nestingLimit, TFilter filter) {
|
NestingLimit nestingLimit, TFilter filter) {
|
||||||
Reader<TStream> reader(input);
|
Reader<TStream> reader(input);
|
||||||
|
VariantData *data = VariantAttorney::getData(doc);
|
||||||
|
MemoryPool *pool = VariantAttorney::getPool(doc);
|
||||||
doc.clear();
|
doc.clear();
|
||||||
return makeDeserializer<TDeserializer>(
|
return makeDeserializer<TDeserializer>(pool, reader,
|
||||||
doc.memoryPool(), reader,
|
makeStringStorage(input, pool))
|
||||||
makeStringStorage(input, doc.memoryPool()))
|
.parse(*data, filter, nestingLimit);
|
||||||
.parse(doc.data(), filter, nestingLimit);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace ARDUINOJSON_NAMESPACE
|
} // namespace ARDUINOJSON_NAMESPACE
|
||||||
|
@ -146,7 +146,7 @@ class BasicJsonDocument : AllocatorOwner<TAllocator>, public JsonDocument {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void freePool() {
|
void freePool() {
|
||||||
this->deallocate(memoryPool().buffer());
|
this->deallocate(getPool()->buffer());
|
||||||
}
|
}
|
||||||
|
|
||||||
void copyAssignFrom(const JsonDocument& src) {
|
void copyAssignFrom(const JsonDocument& src) {
|
||||||
|
@ -83,16 +83,6 @@ class JsonDocument : public VariantOperators<const JsonDocument&> {
|
|||||||
return getVariant().template to<T>();
|
return getVariant().template to<T>();
|
||||||
}
|
}
|
||||||
|
|
||||||
// for internal use only
|
|
||||||
MemoryPool& memoryPool() {
|
|
||||||
return _pool;
|
|
||||||
}
|
|
||||||
|
|
||||||
// for internal use only
|
|
||||||
VariantData& data() {
|
|
||||||
return _data;
|
|
||||||
}
|
|
||||||
|
|
||||||
ArrayRef createNestedArray() {
|
ArrayRef createNestedArray() {
|
||||||
return add().to<ArrayRef>();
|
return add().to<ArrayRef>();
|
||||||
}
|
}
|
||||||
|
@ -20,12 +20,12 @@ namespace ARDUINOJSON_NAMESPACE {
|
|||||||
template <typename TReader, typename TStringStorage>
|
template <typename TReader, typename TStringStorage>
|
||||||
class JsonDeserializer {
|
class JsonDeserializer {
|
||||||
public:
|
public:
|
||||||
JsonDeserializer(MemoryPool &pool, TReader reader,
|
JsonDeserializer(MemoryPool *pool, TReader reader,
|
||||||
TStringStorage stringStorage)
|
TStringStorage stringStorage)
|
||||||
: _stringStorage(stringStorage),
|
: _stringStorage(stringStorage),
|
||||||
_foundSomething(false),
|
_foundSomething(false),
|
||||||
_latch(reader),
|
_latch(reader),
|
||||||
_pool(&pool) {}
|
_pool(pool) {}
|
||||||
|
|
||||||
template <typename TFilter>
|
template <typename TFilter>
|
||||||
DeserializationError parse(VariantData &variant, TFilter filter,
|
DeserializationError parse(VariantData &variant, TFilter filter,
|
||||||
|
@ -16,9 +16,9 @@ namespace ARDUINOJSON_NAMESPACE {
|
|||||||
template <typename TReader, typename TStringStorage>
|
template <typename TReader, typename TStringStorage>
|
||||||
class MsgPackDeserializer {
|
class MsgPackDeserializer {
|
||||||
public:
|
public:
|
||||||
MsgPackDeserializer(MemoryPool &pool, TReader reader,
|
MsgPackDeserializer(MemoryPool *pool, TReader reader,
|
||||||
TStringStorage stringStorage)
|
TStringStorage stringStorage)
|
||||||
: _pool(&pool),
|
: _pool(pool),
|
||||||
_reader(reader),
|
_reader(reader),
|
||||||
_stringStorage(stringStorage),
|
_stringStorage(stringStorage),
|
||||||
_foundSomething(false) {}
|
_foundSomething(false) {}
|
||||||
|
@ -10,7 +10,7 @@ namespace ARDUINOJSON_NAMESPACE {
|
|||||||
|
|
||||||
class StringCopier {
|
class StringCopier {
|
||||||
public:
|
public:
|
||||||
StringCopier(MemoryPool& pool) : _pool(&pool) {}
|
StringCopier(MemoryPool* pool) : _pool(pool) {}
|
||||||
|
|
||||||
void startString() {
|
void startString() {
|
||||||
_pool->getFreeZone(&_ptr, &_capacity);
|
_pool->getFreeZone(&_ptr, &_capacity);
|
||||||
|
@ -10,13 +10,14 @@
|
|||||||
namespace ARDUINOJSON_NAMESPACE {
|
namespace ARDUINOJSON_NAMESPACE {
|
||||||
|
|
||||||
template <typename TInput>
|
template <typename TInput>
|
||||||
StringCopier makeStringStorage(TInput&, MemoryPool& pool) {
|
StringCopier makeStringStorage(TInput&, MemoryPool* pool) {
|
||||||
|
ARDUINOJSON_ASSERT(pool != 0);
|
||||||
return StringCopier(pool);
|
return StringCopier(pool);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename TChar>
|
template <typename TChar>
|
||||||
StringMover makeStringStorage(
|
StringMover makeStringStorage(
|
||||||
TChar* input, MemoryPool&,
|
TChar* input, MemoryPool*,
|
||||||
typename enable_if<!is_const<TChar>::value>::type* = 0) {
|
typename enable_if<!is_const<TChar>::value>::type* = 0) {
|
||||||
return StringMover(reinterpret_cast<char*>(input));
|
return StringMover(reinterpret_cast<char*>(input));
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user