Try to get rid of std::variant in json_container.hpp
This commit is contained in:
parent
4f1c62a768
commit
dbc52728c3
@ -90,33 +90,146 @@ struct Null
|
|||||||
{
|
{
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* Typed Value sum-type implemented as a variant able to represent tree-like JSON structures.
|
|
||||||
*
|
|
||||||
* Dispatch on its type by either by using apply_visitor or its get function.
|
|
||||||
*/
|
|
||||||
using Value = std::variant<String, Number, Object, Array, True, False, Null>;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Typed Object.
|
* Typed Object.
|
||||||
*
|
*
|
||||||
* Unwrap the key-value pairs holding type via its values member attribute.
|
* Unwrap the key-value pairs holding type via its values member attribute.
|
||||||
*/
|
*/
|
||||||
struct Object
|
struct Object;
|
||||||
{
|
|
||||||
std::unordered_map<std::string, Value> values;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Typed Array.
|
* Typed Array.
|
||||||
*
|
*
|
||||||
* Unwrap the Value holding type via its values member attribute.
|
* Unwrap the Value holding type via its values member attribute.
|
||||||
*/
|
*/
|
||||||
|
struct Array;
|
||||||
|
|
||||||
|
struct Value;
|
||||||
|
|
||||||
|
// Definitions of Object and Array (must come after Value is defined)
|
||||||
|
struct Object
|
||||||
|
{
|
||||||
|
std::unordered_map<std::string, Value> values;
|
||||||
|
};
|
||||||
|
|
||||||
struct Array
|
struct Array
|
||||||
{
|
{
|
||||||
std::vector<Value> values;
|
std::vector<Value> values;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
struct Value {
|
||||||
|
enum class Type {
|
||||||
|
Invalid,
|
||||||
|
String,
|
||||||
|
Number,
|
||||||
|
Object,
|
||||||
|
Array,
|
||||||
|
True,
|
||||||
|
False,
|
||||||
|
Null
|
||||||
|
};
|
||||||
|
String string;
|
||||||
|
Number number;
|
||||||
|
Object object;
|
||||||
|
Array array;
|
||||||
|
Type type;
|
||||||
|
|
||||||
|
Value() noexcept : type(Type::Invalid) {}
|
||||||
|
Value(const Null&) noexcept : type(Type::Null) {}
|
||||||
|
Value(const True&) noexcept : type(Type::True) {}
|
||||||
|
Value(const False&) noexcept : type(Type::False) {}
|
||||||
|
Value(String &&string_) noexcept : string(std::move(string_)), type(Type::String) {}
|
||||||
|
Value(const Number &number_) noexcept : number(number_), type(Type::Number) {}
|
||||||
|
Value(const Object &object_) noexcept : object(object_), type(Type::Object) {}
|
||||||
|
Value(const Array &array_) noexcept : array(array_), type(Type::Array) {}
|
||||||
|
|
||||||
|
Value(double number) noexcept : number(number), type(Type::Number) {}
|
||||||
|
Value(std::string string) noexcept : string(std::move(string)), type(Type::String) {}
|
||||||
|
Value(const char* string) noexcept : string(string), type(Type::String) {}
|
||||||
|
};
|
||||||
|
|
||||||
} // namespace osrm::util::json
|
} // namespace osrm::util::json
|
||||||
|
|
||||||
|
namespace std {
|
||||||
|
template <typename T>
|
||||||
|
inline T& get(osrm::util::json::Value& value) noexcept;
|
||||||
|
|
||||||
|
template<>
|
||||||
|
inline osrm::util::json::String& get<osrm::util::json::String>(osrm::util::json::Value& value) noexcept
|
||||||
|
{
|
||||||
|
return value.string;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<>
|
||||||
|
inline osrm::util::json::Number& get<osrm::util::json::Number>(osrm::util::json::Value& value) noexcept
|
||||||
|
{
|
||||||
|
return value.number;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<>
|
||||||
|
inline osrm::util::json::Object& get<osrm::util::json::Object>(osrm::util::json::Value& value) noexcept
|
||||||
|
{
|
||||||
|
return value.object;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<>
|
||||||
|
inline osrm::util::json::Array& get<osrm::util::json::Array>(osrm::util::json::Value& value) noexcept
|
||||||
|
{
|
||||||
|
return value.array;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
inline const T& get(const osrm::util::json::Value& value) noexcept;
|
||||||
|
|
||||||
|
template<>
|
||||||
|
inline const osrm::util::json::String& get<osrm::util::json::String>(const osrm::util::json::Value& value) noexcept
|
||||||
|
{
|
||||||
|
return value.string;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<>
|
||||||
|
inline const osrm::util::json::Number& get<osrm::util::json::Number>(const osrm::util::json::Value& value) noexcept
|
||||||
|
{
|
||||||
|
return value.number;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<>
|
||||||
|
inline const osrm::util::json::Object& get<osrm::util::json::Object>(const osrm::util::json::Value& value) noexcept
|
||||||
|
{
|
||||||
|
return value.object;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<typename Visitor>
|
||||||
|
inline void visit(Visitor&& visitor, const osrm::util::json::Value& value)
|
||||||
|
{
|
||||||
|
switch (value.type)
|
||||||
|
{
|
||||||
|
case osrm::util::json::Value::Type::String:
|
||||||
|
visitor(value.string);
|
||||||
|
break;
|
||||||
|
case osrm::util::json::Value::Type::Number:
|
||||||
|
visitor(value.number);
|
||||||
|
break;
|
||||||
|
case osrm::util::json::Value::Type::Object:
|
||||||
|
visitor(value.object);
|
||||||
|
break;
|
||||||
|
case osrm::util::json::Value::Type::Array:
|
||||||
|
visitor(value.array);
|
||||||
|
break;
|
||||||
|
case osrm::util::json::Value::Type::True:
|
||||||
|
visitor(osrm::util::json::True{});
|
||||||
|
break;
|
||||||
|
case osrm::util::json::Value::Type::False:
|
||||||
|
visitor(osrm::util::json::False{});
|
||||||
|
break;
|
||||||
|
case osrm::util::json::Value::Type::Null:
|
||||||
|
visitor(osrm::util::json::Null{});
|
||||||
|
break;
|
||||||
|
case osrm::util::json::Value::Type::Invalid:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}// namespace std
|
||||||
#endif // JSON_CONTAINER_HPP
|
#endif // JSON_CONTAINER_HPP
|
||||||
|
Loading…
Reference in New Issue
Block a user