Mercurial > minori
view dep/toml11/toml/types.hpp @ 337:a7d4e5107531
dep/animone: REFACTOR ALL THE THINGS
1: animone now has its own syntax divergent from anisthesia,
making different platforms actually have their own sections
2: process names in animone are now called `comm' (this will
probably break things). this is what its called in bsd/linux
so I'm just going to use it everywhere
3: the X11 code now checks for the existence of a UTF-8 window title
and passes it if available
4: ANYTHING THATS NOT LINUX IS 100% UNTESTED AND CAN AND WILL BREAK!
I still actually need to test the bsd code. to be honest I'm probably
going to move all of the bsds into separate files because they're
all essentially different operating systems at this point
author | Paper <paper@paper.us.eu.org> |
---|---|
date | Wed, 19 Jun 2024 12:51:15 -0400 |
parents | 3b355fa948c7 |
children |
line wrap: on
line source
// Copyright Toru Niina 2017. // Distributed under the MIT License. #ifndef TOML11_TYPES_HPP #define TOML11_TYPES_HPP #include <unordered_map> #include <vector> #include "comments.hpp" #include "datetime.hpp" #include "string.hpp" #include "traits.hpp" namespace toml { template<typename Comment, // discard/preserve_comment template<typename ...> class Table, // map-like class template<typename ...> class Array> // vector-like class class basic_value; using character = char; using key = std::string; #if !defined(__clang__) && defined(__GNUC__) && __GNUC__ <= 4 # pragma GCC diagnostic push # pragma GCC diagnostic ignored "-Wshadow" #endif using boolean = bool; using integer = std::int64_t; using floating = double; // "float" is a keyword, cannot use it here. // the following stuffs are structs defined here, so aliases are not needed. // - string // - offset_datetime // - offset_datetime // - local_datetime // - local_date // - local_time #if defined(__GNUC__) && !defined(__clang__) # pragma GCC diagnostic pop #endif // default toml::value and default array/table. these are defined after defining // basic_value itself. // using value = basic_value<discard_comments, std::unordered_map, std::vector>; // using array = typename value::array_type; // using table = typename value::table_type; // to avoid warnings about `value_t::integer` is "shadowing" toml::integer in // GCC -Wshadow=global. #if defined(__GNUC__) && !defined(__clang__) # pragma GCC diagnostic push # if 7 <= __GNUC__ # pragma GCC diagnostic ignored "-Wshadow=global" # else // gcc-6 or older # pragma GCC diagnostic ignored "-Wshadow" # endif #endif enum class value_t : std::uint8_t { empty = 0, boolean = 1, integer = 2, floating = 3, string = 4, offset_datetime = 5, local_datetime = 6, local_date = 7, local_time = 8, array = 9, table = 10, }; #if defined(__GNUC__) && !defined(__clang__) # pragma GCC diagnostic pop #endif template<typename charT, typename traits> inline std::basic_ostream<charT, traits>& operator<<(std::basic_ostream<charT, traits>& os, value_t t) { switch(t) { case value_t::boolean : os << "boolean"; return os; case value_t::integer : os << "integer"; return os; case value_t::floating : os << "floating"; return os; case value_t::string : os << "string"; return os; case value_t::offset_datetime : os << "offset_datetime"; return os; case value_t::local_datetime : os << "local_datetime"; return os; case value_t::local_date : os << "local_date"; return os; case value_t::local_time : os << "local_time"; return os; case value_t::array : os << "array"; return os; case value_t::table : os << "table"; return os; case value_t::empty : os << "empty"; return os; default : os << "unknown"; return os; } } template<typename charT = char, typename traits = std::char_traits<charT>, typename alloc = std::allocator<charT>> inline std::basic_string<charT, traits, alloc> stringize(value_t t) { std::basic_ostringstream<charT, traits, alloc> oss; oss << t; return oss.str(); } namespace detail { // helper to define a type that represents a value_t value. template<value_t V> using value_t_constant = std::integral_constant<value_t, V>; // meta-function that convertes from value_t to the exact toml type that corresponds to. // It takes toml::basic_value type because array and table types depend on it. template<value_t t, typename Value> struct enum_to_type {using type = void ;}; template<typename Value> struct enum_to_type<value_t::empty , Value>{using type = void ;}; template<typename Value> struct enum_to_type<value_t::boolean , Value>{using type = boolean ;}; template<typename Value> struct enum_to_type<value_t::integer , Value>{using type = integer ;}; template<typename Value> struct enum_to_type<value_t::floating , Value>{using type = floating ;}; template<typename Value> struct enum_to_type<value_t::string , Value>{using type = string ;}; template<typename Value> struct enum_to_type<value_t::offset_datetime, Value>{using type = offset_datetime ;}; template<typename Value> struct enum_to_type<value_t::local_datetime , Value>{using type = local_datetime ;}; template<typename Value> struct enum_to_type<value_t::local_date , Value>{using type = local_date ;}; template<typename Value> struct enum_to_type<value_t::local_time , Value>{using type = local_time ;}; template<typename Value> struct enum_to_type<value_t::array , Value>{using type = typename Value::array_type;}; template<typename Value> struct enum_to_type<value_t::table , Value>{using type = typename Value::table_type;}; // meta-function that converts from an exact toml type to the enum that corresponds to. template<typename T, typename Value> struct type_to_enum : std::conditional< std::is_same<T, typename Value::array_type>::value, // if T == array_type, value_t_constant<value_t::array>, // then value_t::array typename std::conditional< // else... std::is_same<T, typename Value::table_type>::value, // if T == table_type value_t_constant<value_t::table>, // then value_t::table value_t_constant<value_t::empty> // else value_t::empty >::type >::type {}; template<typename Value> struct type_to_enum<boolean , Value>: value_t_constant<value_t::boolean > {}; template<typename Value> struct type_to_enum<integer , Value>: value_t_constant<value_t::integer > {}; template<typename Value> struct type_to_enum<floating , Value>: value_t_constant<value_t::floating > {}; template<typename Value> struct type_to_enum<string , Value>: value_t_constant<value_t::string > {}; template<typename Value> struct type_to_enum<offset_datetime, Value>: value_t_constant<value_t::offset_datetime> {}; template<typename Value> struct type_to_enum<local_datetime , Value>: value_t_constant<value_t::local_datetime > {}; template<typename Value> struct type_to_enum<local_date , Value>: value_t_constant<value_t::local_date > {}; template<typename Value> struct type_to_enum<local_time , Value>: value_t_constant<value_t::local_time > {}; // meta-function that checks the type T is the same as one of the toml::* types. template<typename T, typename Value> struct is_exact_toml_type : disjunction< std::is_same<T, boolean >, std::is_same<T, integer >, std::is_same<T, floating >, std::is_same<T, string >, std::is_same<T, offset_datetime>, std::is_same<T, local_datetime >, std::is_same<T, local_date >, std::is_same<T, local_time >, std::is_same<T, typename Value::array_type>, std::is_same<T, typename Value::table_type> >{}; template<typename T, typename V> struct is_exact_toml_type<T&, V> : is_exact_toml_type<T, V>{}; template<typename T, typename V> struct is_exact_toml_type<T const&, V> : is_exact_toml_type<T, V>{}; template<typename T, typename V> struct is_exact_toml_type<T volatile&, V> : is_exact_toml_type<T, V>{}; template<typename T, typename V> struct is_exact_toml_type<T const volatile&, V>: is_exact_toml_type<T, V>{}; } // detail } // toml #endif// TOML11_TYPES_H