mirror of
https://github.com/bblanchon/ArduinoJson.git
synced 2025-10-04 10:40:54 +02:00
74 lines
2.0 KiB
C++
74 lines
2.0 KiB
C++
// Copyright Benoit Blanchon 2014-2015
|
|
// MIT License
|
|
//
|
|
// Arduino JSON library
|
|
// https://github.com/bblanchon/ArduinoJson
|
|
|
|
#pragma once
|
|
|
|
#include "../JsonBuffer.hpp"
|
|
#include "ListConstIterator.hpp"
|
|
#include "ListIterator.hpp"
|
|
|
|
namespace ArduinoJson {
|
|
namespace Internals {
|
|
|
|
// A singly linked list of T.
|
|
// The linked list is composed of ListNode<T>.
|
|
// It is derived by JsonArray and JsonObject
|
|
template <typename T>
|
|
class List {
|
|
public:
|
|
typedef T value_type;
|
|
typedef ListNode<T> node_type;
|
|
typedef ListIterator<T> iterator;
|
|
typedef ListConstIterator<T> const_iterator;
|
|
|
|
// Creates an empty List<T> attached to a JsonBuffer.
|
|
// The JsonBuffer allows to allocate new nodes.
|
|
// When buffer is NULL, the List is not able to grow and success() returns
|
|
// false. This is used to identify bad memory allocations and parsing
|
|
// failures.
|
|
explicit List(JsonBuffer *buffer) : _buffer(buffer), _firstNode(NULL) {}
|
|
|
|
// Returns true if the object is valid
|
|
// Would return false in the following situation:
|
|
// - the memory allocation failed (StaticJsonBuffer was too small)
|
|
// - the JSON parsing failed
|
|
bool success() const { return _buffer != NULL; }
|
|
|
|
// Returns the numbers of elements in the list.
|
|
// For a JsonObject, it would return the number of key-value pairs
|
|
size_t size() const;
|
|
|
|
iterator begin() { return iterator(_firstNode); }
|
|
iterator end() { return iterator(NULL); }
|
|
|
|
const_iterator begin() const { return const_iterator(_firstNode); }
|
|
const_iterator end() const { return const_iterator(NULL); }
|
|
|
|
protected:
|
|
node_type *addNewNode() {
|
|
if (!_buffer) return NULL;
|
|
|
|
node_type *newNode = new (_buffer) node_type();
|
|
|
|
if (_firstNode) {
|
|
node_type *lastNode = _firstNode;
|
|
while (lastNode->next) lastNode = lastNode->next;
|
|
lastNode->next = newNode;
|
|
} else {
|
|
_firstNode = newNode;
|
|
}
|
|
|
|
return newNode;
|
|
}
|
|
|
|
void removeNode(node_type *nodeToRemove);
|
|
|
|
JsonBuffer *_buffer;
|
|
node_type *_firstNode;
|
|
};
|
|
}
|
|
}
|