Extracting a common base class for JsonArray and JsonObject...

This commit is contained in:
Benoit Blanchon
2014-11-05 11:53:08 +01:00
parent 0fb4fa8f86
commit a9f4f611d4
7 changed files with 26 additions and 36 deletions

View File

@ -34,6 +34,8 @@ class List {
protected: protected:
node_type *createNode(); node_type *createNode();
void addNode(node_type *node);
void removeNode(node_type *nodeToRemove);
JsonBuffer *_buffer; JsonBuffer *_buffer;
node_type *_firstNode; node_type *_firstNode;

View File

@ -15,8 +15,8 @@ template <typename T>
struct Node { struct Node {
Node() : next(NULL) {} Node() : next(NULL) {}
T content;
Node<T>* next; Node<T>* next;
T content;
}; };
} }
} }

View File

@ -50,8 +50,6 @@ class JsonArray : public Internals::JsonPrintable<JsonArray>,
// constructor is private: instance must be created via a JsonBuffer // constructor is private: instance must be created via a JsonBuffer
JsonArray(JsonBuffer *buffer) : List(buffer) {} JsonArray(JsonBuffer *buffer) : List(buffer) {}
inline void addNode(node_type *node);
static JsonArray _invalid; static JsonArray _invalid;
}; };
} }

View File

@ -55,8 +55,6 @@ class JsonObject : public Internals::JsonPrintable<JsonObject>,
JsonObject(JsonBuffer *buffer) : List(buffer) {} JsonObject(JsonBuffer *buffer) : List(buffer) {}
JsonVariant &add(key_type key) { return (*this)[key]; } JsonVariant &add(key_type key) { return (*this)[key]; }
void addNode(node_type *nodeToAdd);
void removeNode(node_type *nodeToRemove);
node_type *getNodeAt(key_type key) const; node_type *getNodeAt(key_type key) const;
node_type *getOrCreateNodeAt(key_type key); node_type *getOrCreateNodeAt(key_type key);

View File

@ -21,11 +21,33 @@ int List<T>::size() const {
} }
template <typename T> template <typename T>
Node<T> *List<T>::createNode() { typename List<T>::node_type *List<T>::createNode() {
if (!_buffer) return NULL; if (!_buffer) return NULL;
void *ptr = _buffer->alloc(sizeof(node_type)); void *ptr = _buffer->alloc(sizeof(node_type));
return ptr ? new (ptr) node_type() : NULL; return ptr ? new (ptr) node_type() : NULL;
} }
template <typename T>
void List<T>::addNode(node_type *nodeToAdd) {
if (_firstNode) {
node_type *lastNode = _firstNode;
while (lastNode->next) lastNode = lastNode->next;
lastNode->next = nodeToAdd;
} else {
_firstNode = nodeToAdd;
}
}
template <typename T>
void List<T>::removeNode(node_type *nodeToRemove) {
if (!nodeToRemove) return;
if (nodeToRemove == _firstNode) {
_firstNode = nodeToRemove->next;
} else {
for (node_type *node = _firstNode; node; node = node->next)
if (node->next == nodeToRemove) node->next = nodeToRemove->next;
}
}
template class List<JsonPair>; template class List<JsonPair>;
template class List<JsonVariant>; template class List<JsonVariant>;

View File

@ -30,16 +30,6 @@ JsonVariant &JsonArray::add() {
return node->content; return node->content;
} }
void JsonArray::addNode(node_type *newNode) {
if (_firstNode) {
node_type *lastNode = _firstNode;
while (lastNode->next) lastNode = lastNode->next;
lastNode->next = newNode;
} else {
_firstNode = newNode;
}
}
JsonArray &JsonArray::createNestedArray() { JsonArray &JsonArray::createNestedArray() {
if (!_buffer) return JsonArray::invalid(); if (!_buffer) return JsonArray::invalid();
JsonArray &array = _buffer->createArray(); JsonArray &array = _buffer->createArray();

View File

@ -69,26 +69,6 @@ JsonObject::node_type *JsonObject::getOrCreateNodeAt(const char *key) {
return newNode; return newNode;
} }
void JsonObject::addNode(node_type *nodeToAdd) {
if (!_firstNode) {
_firstNode = nodeToAdd;
} else {
node_type *lastNode = _firstNode;
while (lastNode->next) lastNode = lastNode->next;
lastNode->next = nodeToAdd;
}
}
void JsonObject::removeNode(node_type *nodeToRemove) {
if (!nodeToRemove) return;
if (nodeToRemove == _firstNode) {
_firstNode = nodeToRemove->next;
} else {
for (node_type *node = _firstNode; node; node = node->next)
if (node->next == nodeToRemove) node->next = nodeToRemove->next;
}
}
template <typename T> template <typename T>
void JsonObject::writeTo(T &writer) const { void JsonObject::writeTo(T &writer) const {
node_type *node = _firstNode; node_type *node = _firstNode;