2017-11-07 20:42:50 +01:00
|
|
|
// ArduinoJson - arduinojson.org
|
2019-02-15 13:31:46 +01:00
|
|
|
// Copyright Benoit Blanchon 2014-2019
|
2014-10-23 23:39:22 +02:00
|
|
|
// MIT License
|
|
|
|
|
2014-10-16 00:11:23 +02:00
|
|
|
#pragma once
|
|
|
|
|
2018-11-30 17:53:54 +01:00
|
|
|
#include "../Variant/VariantData.hpp"
|
|
|
|
#include "ArrayFunctions.hpp"
|
|
|
|
#include "ArrayIterator.hpp"
|
2014-10-16 00:11:23 +02:00
|
|
|
|
2018-09-11 16:05:56 +02:00
|
|
|
// Returns the size (in bytes) of an array with n elements.
|
|
|
|
// Can be very handy to determine the size of a StaticMemoryPool.
|
|
|
|
#define JSON_ARRAY_SIZE(NUMBER_OF_ELEMENTS) \
|
2018-11-09 17:27:32 +01:00
|
|
|
((NUMBER_OF_ELEMENTS) * sizeof(ARDUINOJSON_NAMESPACE::VariantSlot))
|
2018-09-11 16:05:56 +02:00
|
|
|
|
2018-10-02 16:54:05 +02:00
|
|
|
namespace ARDUINOJSON_NAMESPACE {
|
2014-10-30 14:03:33 +01:00
|
|
|
|
2018-11-30 17:53:54 +01:00
|
|
|
class ObjectRef;
|
2019-01-29 14:09:09 +01:00
|
|
|
template <typename>
|
|
|
|
class ElementProxy;
|
2014-10-31 12:27:33 +01:00
|
|
|
|
2018-10-12 12:00:27 +02:00
|
|
|
template <typename TData>
|
2018-11-30 17:53:54 +01:00
|
|
|
class ArrayRefBase {
|
2018-10-12 12:00:27 +02:00
|
|
|
public:
|
2019-01-29 14:09:09 +01:00
|
|
|
operator VariantConstRef() const {
|
|
|
|
return VariantConstRef(reinterpret_cast<const VariantData*>(_data));
|
|
|
|
}
|
|
|
|
|
2018-12-07 09:16:58 +01:00
|
|
|
template <typename Visitor>
|
|
|
|
FORCE_INLINE void accept(Visitor& visitor) const {
|
|
|
|
arrayAccept(_data, visitor);
|
|
|
|
}
|
|
|
|
|
2018-10-12 12:00:27 +02:00
|
|
|
FORCE_INLINE bool isNull() const {
|
|
|
|
return _data == 0;
|
|
|
|
}
|
|
|
|
|
2019-01-16 09:50:57 +01:00
|
|
|
FORCE_INLINE size_t memoryUsage() const {
|
|
|
|
return _data ? _data->memoryUsage() : 0;
|
|
|
|
}
|
|
|
|
|
2019-01-17 09:55:51 +01:00
|
|
|
FORCE_INLINE size_t nesting() const {
|
|
|
|
return _data ? _data->nesting() : 0;
|
|
|
|
}
|
|
|
|
|
2018-10-12 12:00:27 +02:00
|
|
|
FORCE_INLINE size_t size() const {
|
2018-12-07 09:16:58 +01:00
|
|
|
return _data ? _data->size() : 0;
|
2018-10-12 12:00:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
protected:
|
2018-11-30 17:53:54 +01:00
|
|
|
ArrayRefBase(TData* data) : _data(data) {}
|
2018-10-12 12:00:27 +02:00
|
|
|
TData* _data;
|
|
|
|
};
|
|
|
|
|
2018-12-07 09:16:58 +01:00
|
|
|
class ArrayConstRef : public ArrayRefBase<const CollectionData>,
|
|
|
|
public Visitable {
|
2018-11-30 17:53:54 +01:00
|
|
|
friend class ArrayRef;
|
2018-12-07 09:16:58 +01:00
|
|
|
typedef ArrayRefBase<const CollectionData> base_type;
|
2018-10-12 12:00:27 +02:00
|
|
|
|
|
|
|
public:
|
2018-11-30 17:53:54 +01:00
|
|
|
typedef ArrayConstRefIterator iterator;
|
2018-10-12 12:00:27 +02:00
|
|
|
|
|
|
|
FORCE_INLINE iterator begin() const {
|
|
|
|
if (!_data) return iterator();
|
2018-12-07 09:16:58 +01:00
|
|
|
return iterator(_data->head());
|
2018-10-12 12:00:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
FORCE_INLINE iterator end() const {
|
|
|
|
return iterator();
|
|
|
|
}
|
|
|
|
|
2018-11-30 17:53:54 +01:00
|
|
|
FORCE_INLINE ArrayConstRef() : base_type(0) {}
|
2018-12-07 09:16:58 +01:00
|
|
|
FORCE_INLINE ArrayConstRef(const CollectionData* data) : base_type(data) {}
|
2018-10-12 12:00:27 +02:00
|
|
|
|
2018-11-30 17:53:54 +01:00
|
|
|
FORCE_INLINE bool operator==(ArrayConstRef rhs) const {
|
2018-10-12 12:00:27 +02:00
|
|
|
return arrayEquals(_data, rhs._data);
|
|
|
|
}
|
2019-01-29 14:09:09 +01:00
|
|
|
|
|
|
|
FORCE_INLINE VariantConstRef operator[](size_t index) const {
|
|
|
|
return VariantConstRef(_data ? _data->get(index) : 0);
|
|
|
|
}
|
2018-10-12 12:00:27 +02:00
|
|
|
};
|
|
|
|
|
2019-01-29 14:09:09 +01:00
|
|
|
class ArrayRef : public ArrayRefBase<CollectionData>,
|
|
|
|
public ArrayShortcuts<ArrayRef>,
|
|
|
|
public Visitable {
|
2018-12-07 09:16:58 +01:00
|
|
|
typedef ArrayRefBase<CollectionData> base_type;
|
2014-11-06 16:29:29 +01:00
|
|
|
|
2018-07-02 09:35:21 +02:00
|
|
|
public:
|
2018-11-30 17:53:54 +01:00
|
|
|
typedef ArrayIterator iterator;
|
2014-10-23 19:54:00 +02:00
|
|
|
|
2018-12-07 09:16:58 +01:00
|
|
|
FORCE_INLINE ArrayRef() : base_type(0), _pool(0) {}
|
|
|
|
FORCE_INLINE ArrayRef(MemoryPool* pool, CollectionData* data)
|
|
|
|
: base_type(data), _pool(pool) {}
|
2018-10-01 12:55:40 +02:00
|
|
|
|
2018-11-30 17:53:54 +01:00
|
|
|
operator VariantRef() {
|
2018-12-07 09:16:58 +01:00
|
|
|
return VariantRef(_pool, reinterpret_cast<VariantData*>(_data));
|
2018-10-01 12:55:40 +02:00
|
|
|
}
|
2014-11-06 14:48:14 +01:00
|
|
|
|
2018-11-30 17:53:54 +01:00
|
|
|
operator ArrayConstRef() const {
|
|
|
|
return ArrayConstRef(_data);
|
2018-10-12 12:00:27 +02:00
|
|
|
}
|
|
|
|
|
2019-02-15 15:53:53 +01:00
|
|
|
VariantRef addElement() const {
|
2018-12-07 09:16:58 +01:00
|
|
|
return VariantRef(_pool, arrayAdd(_data, _pool));
|
2016-02-14 16:18:13 +01:00
|
|
|
}
|
2014-10-25 21:02:13 +02:00
|
|
|
|
2018-08-31 16:29:08 +02:00
|
|
|
FORCE_INLINE iterator begin() const {
|
2018-07-02 09:35:21 +02:00
|
|
|
if (!_data) return iterator();
|
2018-12-07 09:16:58 +01:00
|
|
|
return iterator(_pool, _data->head());
|
2016-06-22 21:41:19 +02:00
|
|
|
}
|
2014-11-06 14:48:14 +01:00
|
|
|
|
2018-08-31 16:29:08 +02:00
|
|
|
FORCE_INLINE iterator end() const {
|
2018-07-02 09:35:21 +02:00
|
|
|
return iterator();
|
2016-06-22 21:41:19 +02:00
|
|
|
}
|
2014-11-06 14:48:14 +01:00
|
|
|
|
2018-11-30 17:53:54 +01:00
|
|
|
// Copy a ArrayRef
|
2019-02-15 15:33:04 +01:00
|
|
|
FORCE_INLINE bool set(ArrayConstRef src) const {
|
2018-12-07 09:16:58 +01:00
|
|
|
if (!_data || !src._data) return false;
|
|
|
|
return _data->copyFrom(*src._data, _pool);
|
2018-09-11 16:05:56 +02:00
|
|
|
}
|
|
|
|
|
2018-11-30 17:53:54 +01:00
|
|
|
FORCE_INLINE bool operator==(ArrayRef rhs) const {
|
2018-10-12 12:00:27 +02:00
|
|
|
return arrayEquals(_data, rhs._data);
|
2018-07-02 09:35:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Gets the value at the specified index.
|
2019-02-15 15:53:53 +01:00
|
|
|
FORCE_INLINE VariantRef getElement(size_t index) const {
|
2018-12-07 09:16:58 +01:00
|
|
|
return VariantRef(_pool, _data ? _data->get(index) : 0);
|
2018-07-02 09:35:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Removes element at specified position.
|
2018-10-12 12:00:27 +02:00
|
|
|
FORCE_INLINE void remove(iterator it) const {
|
2018-12-07 09:16:58 +01:00
|
|
|
if (!_data) return;
|
|
|
|
_data->remove(it.internal());
|
2018-07-02 09:35:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Removes element at specified index.
|
2018-10-12 12:00:27 +02:00
|
|
|
FORCE_INLINE void remove(size_t index) const {
|
2018-12-07 09:16:58 +01:00
|
|
|
if (!_data) return;
|
|
|
|
_data->remove(index);
|
2018-04-17 21:27:45 +02:00
|
|
|
}
|
|
|
|
|
2014-10-26 21:18:09 +01:00
|
|
|
private:
|
2018-12-07 09:16:58 +01:00
|
|
|
MemoryPool* _pool;
|
2016-12-03 22:19:11 +01:00
|
|
|
};
|
2018-10-02 16:54:05 +02:00
|
|
|
} // namespace ARDUINOJSON_NAMESPACE
|