// The MIT License (MIT) // Copyright (c) 2013 Danny Y., Rapptz // Permission is hereby granted, free of charge, to any person obtaining a copy of // this software and associated documentation files (the "Software"), to deal in // the Software without restriction, including without limitation the rights to // use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of // the Software, and to permit persons to whom the Software is furnished to do so, // subject to the following conditions: // The above copyright notice and this permission notice shall be included in all // copies or substantial portions of the Software. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS // FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR // COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER // IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN // CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. #ifndef SOL_TYPES_HPP #define SOL_TYPES_HPP #include #include #include "traits.hpp" namespace sol { struct nil_t {}; const nil_t nil {}; struct void_type {}; const void_type Void {}; template struct function_sig_t {}; using function_t = function_sig_t<>; struct upvalue_t { void* value; upvalue_t(void* data) : value(data) {} operator void*() const { return value; } }; struct lightuserdata_t { void* value; lightuserdata_t(void* data) : value(data) {} operator void*() const { return value; } }; struct userdata_t { void* value; userdata_t(void* data) : value(data) {} operator void*() const { return value; } }; enum class call_syntax { dot = 0, colon = 1 }; enum class type : int { none = LUA_TNONE, nil = LUA_TNIL, string = LUA_TSTRING, number = LUA_TNUMBER, thread = LUA_TTHREAD, boolean = LUA_TBOOLEAN, function = LUA_TFUNCTION, userdata = LUA_TUSERDATA, lightuserdata = LUA_TLIGHTUSERDATA, table = LUA_TTABLE, poly = none | nil | string | number | thread | table | boolean | function | userdata | lightuserdata }; inline void type_error(lua_State* L, int expected, int actual) { luaL_error(L, "expected %s, received %s", lua_typename(L, expected), lua_typename(L, actual)); } inline void type_assert(lua_State* L, int index, type expected) { int actual = lua_type(L, index); if(expected != type::poly && static_cast(expected) != actual) { type_error(L, static_cast(expected), actual); } } inline std::string type_name(lua_State*L, type t) { return lua_typename(L, static_cast(t)); } template class usertype; class table; class function; class object; namespace detail { template inline type arithmetic(std::true_type) { return type::number; } template inline type arithmetic(std::false_type) { return type::userdata; } } // detail template inline type type_of() { return detail::arithmetic(std::is_arithmetic{}); } template<> inline type type_of() { return type::table; } template<> inline type type_of() { return type::function; } template<> inline type type_of() { return type::poly; } template<> inline type type_of() { return type::string; } template<> inline type type_of() { return type::string; } template<> inline type type_of() { return type::nil; } template<> inline type type_of() { return type::boolean; } template<> inline type type_of() { return type::lightuserdata; } template<> inline type type_of() { return type::userdata; } inline bool operator==(nil_t, nil_t) { return true; } inline bool operator!=(nil_t, nil_t) { return false; } } // sol #endif // SOL_TYPES_HPP