2020-05-15 12:12:32 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <cstdint> // uint8_t
|
|
|
|
#include <utility> // move
|
|
|
|
|
|
|
|
namespace nlohmann
|
|
|
|
{
|
|
|
|
namespace detail
|
|
|
|
{
|
|
|
|
|
|
|
|
/*!
|
|
|
|
@brief an internal type for a backed binary type
|
|
|
|
|
|
|
|
This type is designed to be `binary_t` but with the subtype implementation
|
2020-05-17 11:51:59 +00:00
|
|
|
detail. This type exists so that the user does not have to specify a type
|
|
|
|
themselves with a specific naming scheme in order to override the binary type.
|
2020-05-15 12:12:32 +00:00
|
|
|
*/
|
|
|
|
template<typename BinaryType>
|
2020-05-15 21:21:49 +00:00
|
|
|
class wrapped_binary_t : public BinaryType
|
2020-05-15 12:12:32 +00:00
|
|
|
{
|
2020-05-15 21:21:49 +00:00
|
|
|
public:
|
2020-05-17 20:50:27 +00:00
|
|
|
/// the type of the underlying container
|
|
|
|
using container_type = BinaryType;
|
2020-05-15 12:12:32 +00:00
|
|
|
|
2020-05-17 20:50:27 +00:00
|
|
|
wrapped_binary_t() noexcept(noexcept(container_type()))
|
|
|
|
: container_type()
|
2020-05-15 20:38:18 +00:00
|
|
|
{}
|
2020-05-15 12:12:32 +00:00
|
|
|
|
2020-05-17 20:50:27 +00:00
|
|
|
wrapped_binary_t(const container_type& b) noexcept(noexcept(container_type(b)))
|
|
|
|
: container_type(b)
|
2020-05-15 12:12:32 +00:00
|
|
|
{}
|
|
|
|
|
2020-05-17 20:50:27 +00:00
|
|
|
wrapped_binary_t(container_type&& b) noexcept(noexcept(container_type(std::move(b))))
|
|
|
|
: container_type(std::move(b))
|
2020-05-15 12:12:32 +00:00
|
|
|
{}
|
|
|
|
|
2020-05-17 20:50:27 +00:00
|
|
|
wrapped_binary_t(const container_type& b,
|
|
|
|
std::uint8_t subtype) noexcept(noexcept(container_type(b)))
|
|
|
|
: container_type(b)
|
2020-05-17 11:51:59 +00:00
|
|
|
, m_subtype(subtype)
|
2020-05-15 21:21:49 +00:00
|
|
|
, m_has_subtype(true)
|
2020-05-15 12:12:32 +00:00
|
|
|
{}
|
|
|
|
|
2020-05-17 20:50:27 +00:00
|
|
|
wrapped_binary_t(container_type&& b, std::uint8_t subtype) noexcept(noexcept(container_type(std::move(b))))
|
|
|
|
: container_type(std::move(b))
|
2020-05-17 11:51:59 +00:00
|
|
|
, m_subtype(subtype)
|
2020-05-15 21:21:49 +00:00
|
|
|
, m_has_subtype(true)
|
2020-05-15 12:12:32 +00:00
|
|
|
{}
|
|
|
|
|
2020-05-15 21:21:49 +00:00
|
|
|
/*!
|
2020-05-17 20:50:27 +00:00
|
|
|
@brief sets the binary subtype
|
|
|
|
|
|
|
|
Sets the binary subtype of the value, also flags a binary JSON value as
|
|
|
|
having a subtype, which has implications for serialization.
|
|
|
|
|
|
|
|
@complexity Constant.
|
|
|
|
|
|
|
|
@exceptionsafety No-throw guarantee: this member function never throws
|
|
|
|
exceptions.
|
|
|
|
|
|
|
|
@sa @ref subtype() -- return the binary subtype
|
|
|
|
@sa @ref clear_subtype() -- clears the binary subtype
|
|
|
|
@sa @ref has_subtype() -- returns whether or not the binary value has a
|
|
|
|
subtype
|
|
|
|
|
|
|
|
@since version 3.8.0
|
2020-05-15 21:21:49 +00:00
|
|
|
*/
|
|
|
|
void set_subtype(std::uint8_t subtype) noexcept
|
|
|
|
{
|
|
|
|
m_subtype = subtype;
|
|
|
|
m_has_subtype = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
2020-05-17 20:50:27 +00:00
|
|
|
@brief return the binary subtype
|
|
|
|
|
|
|
|
Returns the numerical subtype of the value if it has a subtype. If it does
|
|
|
|
not have a subtype, this function will return size_t(-1) as a sentinel
|
|
|
|
value.
|
|
|
|
|
|
|
|
@return the numerical subtype of the binary value
|
|
|
|
|
|
|
|
@complexity Constant.
|
|
|
|
|
|
|
|
@exceptionsafety No-throw guarantee: this member function never throws
|
|
|
|
exceptions.
|
|
|
|
|
|
|
|
@sa @ref set_subtype() -- sets the binary subtype
|
|
|
|
@sa @ref clear_subtype() -- clears the binary subtype
|
|
|
|
@sa @ref has_subtype() -- returns whether or not the binary value has a
|
|
|
|
subtype
|
|
|
|
|
|
|
|
@since version 3.8.0
|
2020-05-15 21:21:49 +00:00
|
|
|
*/
|
|
|
|
constexpr std::uint8_t subtype() const noexcept
|
|
|
|
{
|
|
|
|
return m_subtype;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
2020-05-17 20:50:27 +00:00
|
|
|
@brief return whether the value has a subtype
|
|
|
|
|
|
|
|
@return whether the value has a subtype
|
|
|
|
|
|
|
|
@complexity Constant.
|
|
|
|
|
|
|
|
@exceptionsafety No-throw guarantee: this member function never throws
|
|
|
|
exceptions.
|
|
|
|
|
|
|
|
@sa @ref subtype() -- return the binary subtype
|
|
|
|
@sa @ref set_subtype() -- sets the binary subtype
|
|
|
|
@sa @ref clear_subtype() -- clears the binary subtype
|
|
|
|
|
|
|
|
@since version 3.8.0
|
2020-05-15 21:21:49 +00:00
|
|
|
*/
|
|
|
|
constexpr bool has_subtype() const noexcept
|
|
|
|
{
|
|
|
|
return m_has_subtype;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
2020-05-17 20:50:27 +00:00
|
|
|
@brief clears the binary subtype
|
|
|
|
|
|
|
|
Clears the binary subtype and flags the value as not having a subtype, which
|
|
|
|
has implications for serialization; for instance MessagePack will prefer the
|
|
|
|
bin family over the ext family.
|
|
|
|
|
|
|
|
@complexity Constant.
|
|
|
|
|
|
|
|
@exceptionsafety No-throw guarantee: this member function never throws
|
|
|
|
exceptions.
|
|
|
|
|
|
|
|
@sa @ref subtype() -- return the binary subtype
|
|
|
|
@sa @ref set_subtype() -- sets the binary subtype
|
|
|
|
@sa @ref has_subtype() -- returns whether or not the binary value has a
|
|
|
|
subtype
|
|
|
|
|
|
|
|
@since version 3.8.0
|
2020-05-15 21:21:49 +00:00
|
|
|
*/
|
|
|
|
void clear_subtype() noexcept
|
|
|
|
{
|
|
|
|
m_subtype = 0;
|
|
|
|
m_has_subtype = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
std::uint8_t m_subtype = 0;
|
|
|
|
bool m_has_subtype = false;
|
2020-05-15 12:12:32 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace detail
|
|
|
|
} // namespace nlohmann
|