mirror of
https://github.com/SerenityOS/serenity
synced 2024-11-05 17:46:52 +00:00
eda2a2f5da
Due to 582c55a
, both `must_set()` and `set()` should be providing the
same behavior. Not only is that a reason to remove `must_set()`, but
it also performs erroneous behavior since it inserts an element at
a specified index instead of modifying an element at that index.
121 lines
3.1 KiB
C++
121 lines
3.1 KiB
C++
/*
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/Concepts.h>
|
|
#include <AK/Error.h>
|
|
#include <AK/JsonArraySerializer.h>
|
|
#include <AK/JsonValue.h>
|
|
#include <AK/Vector.h>
|
|
|
|
namespace AK {
|
|
|
|
class JsonArray {
|
|
template<typename Callback>
|
|
using CallbackErrorType = decltype(declval<Callback>()(declval<JsonValue const&>()).release_error());
|
|
|
|
public:
|
|
JsonArray() = default;
|
|
~JsonArray() = default;
|
|
|
|
JsonArray(JsonArray const& other)
|
|
: m_values(other.m_values)
|
|
{
|
|
}
|
|
|
|
JsonArray(JsonArray&& other)
|
|
: m_values(move(other.m_values))
|
|
{
|
|
}
|
|
|
|
template<IterableContainer ContainerT>
|
|
JsonArray(ContainerT const& source)
|
|
{
|
|
for (auto& value : source)
|
|
m_values.append(move(value));
|
|
}
|
|
|
|
JsonArray& operator=(JsonArray const& other)
|
|
{
|
|
if (this != &other)
|
|
m_values = other.m_values;
|
|
return *this;
|
|
}
|
|
|
|
JsonArray& operator=(JsonArray&& other)
|
|
{
|
|
if (this != &other)
|
|
m_values = move(other.m_values);
|
|
return *this;
|
|
}
|
|
|
|
[[nodiscard]] size_t size() const { return m_values.size(); }
|
|
[[nodiscard]] bool is_empty() const { return m_values.is_empty(); }
|
|
|
|
[[nodiscard]] JsonValue const& at(size_t index) const { return m_values.at(index); }
|
|
[[nodiscard]] JsonValue const& operator[](size_t index) const { return at(index); }
|
|
|
|
[[nodiscard]] JsonValue take(size_t index) { return m_values.take(index); }
|
|
|
|
void must_append(JsonValue value) { m_values.append(move(value)); }
|
|
|
|
void clear() { m_values.clear(); }
|
|
ErrorOr<void> append(JsonValue value) { return m_values.try_append(move(value)); }
|
|
void set(size_t index, JsonValue value) { m_values.at(index) = move(value); }
|
|
|
|
template<typename Builder>
|
|
typename Builder::OutputType serialized() const;
|
|
|
|
template<typename Builder>
|
|
void serialize(Builder&) const;
|
|
|
|
[[nodiscard]] DeprecatedString to_deprecated_string() const { return serialized<StringBuilder>(); }
|
|
|
|
template<typename Callback>
|
|
void for_each(Callback callback) const
|
|
{
|
|
for (auto const& value : m_values)
|
|
callback(value);
|
|
}
|
|
|
|
template<FallibleFunction<JsonValue const&> Callback>
|
|
ErrorOr<void, CallbackErrorType<Callback>> try_for_each(Callback&& callback) const
|
|
{
|
|
for (auto const& value : m_values)
|
|
TRY(callback(value));
|
|
return {};
|
|
}
|
|
|
|
[[nodiscard]] Vector<JsonValue> const& values() const { return m_values; }
|
|
|
|
void ensure_capacity(size_t capacity) { m_values.ensure_capacity(capacity); }
|
|
|
|
private:
|
|
Vector<JsonValue> m_values;
|
|
};
|
|
|
|
template<typename Builder>
|
|
inline void JsonArray::serialize(Builder& builder) const
|
|
{
|
|
auto serializer = MUST(JsonArraySerializer<>::try_create(builder));
|
|
for_each([&](auto& value) { MUST(serializer.add(value)); });
|
|
MUST(serializer.finish());
|
|
}
|
|
|
|
template<typename Builder>
|
|
inline typename Builder::OutputType JsonArray::serialized() const
|
|
{
|
|
Builder builder;
|
|
serialize(builder);
|
|
return builder.to_deprecated_string();
|
|
}
|
|
|
|
}
|
|
|
|
#if USING_AK_GLOBALLY
|
|
using AK::JsonArray;
|
|
#endif
|