0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2024-10-31 19:08:59 +01:00
construct/include/ircd/json/strung.h
Jason Volk b0217fd371 ircd::json: Eliminate double-references; optimize ABI.
ircd::json: Inline trivial functions; value optimize.
2023-02-12 19:19:56 -08:00

81 lines
1.8 KiB
C++

// Matrix Construct
//
// Copyright (C) Matrix Construct Developers, Authors & Contributors
// Copyright (C) 2016-2018 Jason Volk <jason@zemos.net>
//
// Permission to use, copy, modify, and/or distribute this software for any
// purpose with or without fee is hereby granted, provided that the above
// copyright notice and this permission notice is present in all copies. The
// full license for this software is available in the LICENSE file.
#pragma once
#define HAVE_IRCD_JSON_STRUNG_H
namespace ircd::json
{
struct strung;
}
/// Interface around an allocated std::string of JSON. This is not a
/// json::string type; it is a full JSON which will stringify the
/// constructor arguments into the std::string's buffer as a convenience
/// to reduce boilerplate when the user has no interest in buffering the
/// stringify() calls another way.
///
struct ircd::json::strung
:std::string
{
explicit operator json::object() const;
explicit operator json::array() const;
strung() = default;
template<class... T> strung(T&&... t);
strung(strung &&s) noexcept;
strung(const strung &s);
strung &operator=(strung &&) = default;
strung &operator=(const strung &) = default;
};
inline
ircd::json::strung::strung(strung &&s)
noexcept
:std::string{std::move(s)}
{}
inline
ircd::json::strung::strung(const strung &s)
:std::string{s}
{}
template<class... T>
inline
ircd::json::strung::strung(T&&... t)
:std::string
{
util::string(serialized(std::forward<T>(t)...), [&t...]
(const mutable_buffer &out)
{
const auto sv
{
stringify(mutable_buffer{out}, std::forward<T>(t)...)
};
debug_valid_output(sv, ircd::size(out));
return sv;
})
}
{}
inline ircd::json::strung::operator
json::array()
const
{
return string_view{*this};
}
inline ircd::json::strung::operator
json::object()
const
{
return string_view{*this};
}