Merge commit 'c61a434561b863bab870873992c4ab23f963ca6c' into sol3

# Conflicts:
#	include/sol/types.hpp
This commit is contained in:
ThePhD 2018-11-21 15:45:17 -05:00
commit 8f73b92109
No known key found for this signature in database
GPG Key ID: 1509DB1C0F702BFA

View File

@ -51,6 +51,21 @@
#endif // Using Boost #endif // Using Boost
namespace sol { namespace sol {
namespace usertype_detail {
#if defined(SOL_USE_BOOST)
#if defined(SOL_CXX17_FEATURES)
template <typename K, typename V, typename H = std::hash<K>, typename E = std::equal_to<>>
using map_t = boost::unordered_map<K, V, H, E>;
#else
template <typename K, typename V, typename H = boost::hash<K>, typename E = std::equal_to<>>
using map_t = boost::unordered_map<K, V, H, E>;
#endif // C++17 or not, WITH boost
#else
template <typename K, typename V, typename H = std::hash<K>, typename E = std::equal_to<>>
using map_t = std::unordered_map<K, V, H, E>;
#endif // Boost map target
} // namespace usertype_detail
namespace detail { namespace detail {
#ifdef SOL_NOEXCEPT_FUNCTION_TYPE #ifdef SOL_NOEXCEPT_FUNCTION_TYPE
typedef int (*lua_CFunction_noexcept)(lua_State* L) noexcept; typedef int (*lua_CFunction_noexcept)(lua_State* L) noexcept;
@ -79,14 +94,14 @@ namespace sol {
}; };
struct unchecked_t {}; struct unchecked_t {};
const unchecked_t unchecked = unchecked_t {}; const unchecked_t unchecked = unchecked_t{};
struct yield_tag_t {}; struct yield_tag_t {};
const yield_tag_t yield_tag = yield_tag_t {}; const yield_tag_t yield_tag = yield_tag_t{};
} // namespace detail } // namespace detail
struct lua_nil_t {}; struct lua_nil_t {};
const lua_nil_t lua_nil {}; const lua_nil_t lua_nil{};
inline bool operator==(lua_nil_t, lua_nil_t) { inline bool operator==(lua_nil_t, lua_nil_t) {
return true; return true;
} }
@ -95,7 +110,7 @@ namespace sol {
} }
typedef lua_nil_t nil_t; typedef lua_nil_t nil_t;
#if !defined(SOL_NO_NIL) || (SOL_NO_NIL == 0) #if !defined(SOL_NO_NIL) || (SOL_NO_NIL == 0)
const nil_t nil {}; const nil_t nil{};
#endif #endif
namespace detail { namespace detail {
@ -596,7 +611,7 @@ namespace sol {
}; };
inline const std::string& to_string(call_status c) { inline const std::string& to_string(call_status c) {
static const std::array<std::string, 10> names { { "ok", static const std::array<std::string, 10> names{ { "ok",
"yielded", "yielded",
"runtime", "runtime",
"memory", "memory",
@ -647,7 +662,7 @@ namespace sol {
} }
inline const std::string& to_string(load_status c) { inline const std::string& to_string(load_status c) {
static const std::array<std::string, 7> names { { "ok", static const std::array<std::string, 7> names{ { "ok",
"memory", "memory",
"gc", "gc",
"syntax", "syntax",
@ -674,7 +689,7 @@ namespace sol {
} }
inline const std::string& to_string(load_mode c) { inline const std::string& to_string(load_mode c) {
static const std::array<std::string, 3> names { { static const std::array<std::string, 3> names{ {
"bt", "bt",
"t", "t",
"b", "b",
@ -982,8 +997,10 @@ namespace sol {
template <typename T> template <typename T>
struct lua_type_of<optional<T>> : std::integral_constant<type, type::poly> {}; struct lua_type_of<optional<T>> : std::integral_constant<type, type::poly> {};
#if defined(SOL_CXX17_FEATURES) && SOL_CXX17_FEATURES
template <typename T> template <typename T>
struct lua_type_of<std::optional<T>> : std::integral_constant<type, type::poly> {}; struct lua_type_of<std::optional<T>> : std::integral_constant<type, type::poly> {};
#endif // std::optional
template <> template <>
struct lua_type_of<variadic_args> : std::integral_constant<type, type::poly> {}; struct lua_type_of<variadic_args> : std::integral_constant<type, type::poly> {};
@ -1124,6 +1141,10 @@ namespace sol {
struct is_lua_primitive<light<T>> : is_lua_primitive<T*> {}; struct is_lua_primitive<light<T>> : is_lua_primitive<T*> {};
template <typename T> template <typename T>
struct is_lua_primitive<optional<T>> : std::true_type {}; struct is_lua_primitive<optional<T>> : std::true_type {};
#if defined(SOL_CXX17_FEATURES) && SOL_CXX17_FEATURES
template <typename T>
struct is_lua_primitive<std::optional<T>> : std::true_type {};
#endif
template <typename T> template <typename T>
struct is_lua_primitive<as_table_t<T>> : std::true_type {}; struct is_lua_primitive<as_table_t<T>> : std::true_type {};
template <typename T> template <typename T>
@ -1241,7 +1262,7 @@ namespace sol {
struct add_destructor_tag {}; struct add_destructor_tag {};
struct check_destructor_tag {}; struct check_destructor_tag {};
struct verified_tag { struct verified_tag {
} const verified {}; } const verified{};
} // namespace detail } // namespace detail
struct automagic_enrollments { struct automagic_enrollments {