Heavily improve usage of Preprocessor checks

- Weed out bugs in the numeric checking implementation
- Solve the problem with load_result/protected_function_result/unsafe_function_result being copyable and thus amenable to explosions. Fixes #995.
- Resolve the warning in sol::readonly. Fixes #1000.
- Looke into #1014. Not sure I can help there, honestly; looks like a mix up of multiply-loaded libraries and mixing the two.
This commit is contained in:
ThePhD 2020-09-26 06:47:20 -04:00
parent 0e1aafe4df
commit 000fa31809
No known key found for this signature in database
GPG Key ID: 1509DB1C0F702BFA
28 changed files with 836 additions and 654 deletions

View File

@ -31,10 +31,10 @@ two_things sol_lua_get(sol::types<two_things>, lua_State* L, int index, sol::sta
bool b = sol::stack::get<bool>(L, absolute_index + 1); bool b = sol::stack::get<bool>(L, absolute_index + 1);
// we use 2 slots, each of the previous takes 1 // we use 2 slots, each of the previous takes 1
tracking.use(2); tracking.use(2);
return two_things{ a, b }; return two_things { a, b };
} }
int sol_lua_push(sol::types<two_things>, lua_State* L, const two_things& things) { int sol_lua_push(lua_State* L, const two_things& things) {
int amount = sol::stack::push(L, things.a); int amount = sol::stack::push(L, things.a);
// amount will be 1: int pushes 1 item // amount will be 1: int pushes 1 item
amount += sol::stack::push(L, things.b); amount += sol::stack::push(L, things.b);
@ -56,7 +56,7 @@ int main() {
// get the function out of Lua // get the function out of Lua
sol::function f = lua["f"]; sol::function f = lua["f"];
two_things things = f(two_things{ 24, false }); two_things things = f(two_things { 24, false });
c_assert(things.a == 24); c_assert(things.a == 24);
c_assert(things.b == false); c_assert(things.b == false);
// things.a == 24 // things.a == 24

View File

@ -32,7 +32,7 @@
#include <sol/version.hpp> #include <sol/version.hpp>
#include <sol/compatibility/lua_version.hpp> #include <sol/compatibility/lua_version.hpp>
#if !defined(SOL_NO_COMPAT) || !(SOL_NO_COMPAT) #if SOL_IS_ON(SOL_USE_COMPATIBILITY_LAYER_I_)
#if SOL_IS_ON(SOL_USE_CXX_LUA_I_) || SOL_IS_ON(SOL_USE_CXX_LUAJIT_I_) #if SOL_IS_ON(SOL_USE_CXX_LUA_I_) || SOL_IS_ON(SOL_USE_CXX_LUAJIT_I_)
#ifndef COMPAT53_LUA_CPP #ifndef COMPAT53_LUA_CPP
@ -46,6 +46,6 @@
#include <sol/compatibility/compat-5.3.h> #include <sol/compatibility/compat-5.3.h>
#include <sol/compatibility/compat-5.4.h> #include <sol/compatibility/compat-5.4.h>
#endif // SOL_NO_COMPAT #endif
#endif // SOL_COMPATIBILITY_HPP #endif // SOL_COMPATIBILITY_HPP

View File

@ -51,7 +51,7 @@
#elif defined(LUAJIT_VERSION) #elif defined(LUAJIT_VERSION)
#define SOL_USE_LUAJIT_I_ SOL_OFF #define SOL_USE_LUAJIT_I_ SOL_OFF
#else #else
#define SOL_USE_LUAJIT_I_ SOL_OFF #define SOL_USE_LUAJIT_I_ SOL_DEFAULT_OFF
#endif // luajit #endif // luajit
#if SOL_IS_ON(SOL_USE_CXX_LUAJIT_I_) #if SOL_IS_ON(SOL_USE_CXX_LUAJIT_I_)
@ -71,9 +71,9 @@
#endif #endif
#if defined(MOONJIT_VERSION) #if defined(MOONJIT_VERSION)
#define SOL_MOONJIT_I_ SOL_ON #define SOL_USE_MOONJIT_I_ SOL_ON
#else #else
#define SOL_MOONJIT_I_ SOL_OFF #define SOL_USE_MOONJIT_I_ SOL_OFF
#endif #endif
#if !defined(SOL_LUA_VERSION) #if !defined(SOL_LUA_VERSION)
@ -98,10 +98,18 @@
// Exception safety / propagation, according to Lua information // Exception safety / propagation, according to Lua information
// and user defines. Note this can sometimes change based on version information... // and user defines. Note this can sometimes change based on version information...
#if defined(SOL_EXCEPTIONS_ALWAYS_UNSAFE) && (SOL_EXCEPTIONS_ALWAYS_UNSAFE != 0) #if defined(SOL_EXCEPTIONS_ALWAYS_UNSAFE)
#define SOL_PROPAGATE_EXCEPTIONS_I_ SOL_OFF #if (SOL_EXCEPTIONS_ALWAYS_UNSAFE != 0)
#elif defined(SOL_EXCEPTIONS_SAFE_PROPAGATION) && (SOL_EXCEPTIONS_SAFE_PROPAGATION != 0) #define SOL_PROPAGATE_EXCEPTIONS_I_ SOL_OFF
#define SOL_PROPAGATE_EXCEPTIONS_I_ SOL_ON #else
#define SOL_PROPAGATE_EXCEPTIONS_I_ SOL_ON
#endif
#elif defined(SOL_EXCEPTIONS_SAFE_PROPAGATION)
#if (SOL_EXCEPTIONS_SAFE_PROPAGATION != 0)
#define SOL_PROPAGATE_EXCEPTIONS_I_ SOL_ON
#else
#define SOL_PROPAGATE_EXCEPTIONS_I_ SOL_OFF
#endif
#elif SOL_LUAJIT_VERSION_I_ >= 20100 #elif SOL_LUAJIT_VERSION_I_ >= 20100
// LuaJIT 2.1.0-beta3 and better have exception support locked in for all platforms (mostly) // LuaJIT 2.1.0-beta3 and better have exception support locked in for all platforms (mostly)
#define SOL_PROPAGATE_EXCEPTIONS_I_ SOL_DEFAULT_ON #define SOL_PROPAGATE_EXCEPTIONS_I_ SOL_DEFAULT_ON
@ -116,9 +124,37 @@
// otherwise, there is no exception safety for // otherwise, there is no exception safety for
// shoving exceptions through Lua and errors should // shoving exceptions through Lua and errors should
// always be serialized // always be serialized
#define SOL_PROPAGATE_EXCEPTIONS_I_ SOL_OFF #define SOL_PROPAGATE_EXCEPTIONS_I_ SOL_DEFAULT_OFF
#endif // LuaJIT beta 02.01.00 have better exception handling on all platforms since beta3 #endif // LuaJIT beta 02.01.00 have better exception handling on all platforms since beta3
#if defined(SOL_LUAJIT_USE_EXCEPTION_TRAMPOLINE)
#if (SOL_LUAJIT_USE_EXCEPTION_TRAMPOLINE != 0)
#define SOL_USE_LUAJIT_EXCEPTION_TRAMPOLINE_I_ SOL_ON
#else
#define SOL_USE_LUAJIT_EXCEPTION_TRAMPOLINE_I_ SOL_OFF
#endif
#else
#if SOL_IS_OFF(SOL_PROPAGATE_EXCEPTIONS_I_) && SOL_IS_ON(SOL_USE_LUAJIT_I_)
#define SOL_USE_LUAJIT_EXCEPTION_TRAMPOLINE_I_ SOL_ON
#else
#define SOL_USE_LUAJIT_EXCEPTION_TRAMPOLINE_I_ SOL_DEFAULT_OFF
#endif
#endif
#if defined(SOL_LUAL_STREAM_HAS_CLOSE_FUNCTION)
#if (SOL_LUAL_STREAM_HAS_CLOSE_FUNCTION != 0)
#define SOL_LUAL_STREAM_USE_CLOSE_FUNCTION_I_ SOL_ON
#else
#define SOL_LUAL_STREAM_USE_CLOSE_FUNCTION_I_ SOL_OFF
#endif
#else
#if SOL_IS_OFF(SOL_USE_LUAJIT_I_) && (SOL_LUA_VERSION > 501)
#define SOL_LUAL_STREAM_USE_CLOSE_FUNCTION_I_ SOL_ON
#else
#define SOL_LUAL_STREAM_USE_CLOSE_FUNCTION_I_ SOL_DEFAULT_OFF
#endif
#endif
// clang-format on // clang-format on
#endif // SOL_COMPATIBILITY_VERSION_HPP #endif // SOL_COMPATIBILITY_VERSION_HPP

View File

@ -45,7 +45,7 @@ namespace sol {
call_status stats = call_status::yielded; call_status stats = call_status::yielded;
void luacall(std::ptrdiff_t argcount, std::ptrdiff_t) { void luacall(std::ptrdiff_t argcount, std::ptrdiff_t) {
#if SOL_LUA_VERSION >= 504 #if SOL_LUA_VESION_I_ >= 504
int nresults; int nresults;
stats = static_cast<call_status>(lua_resume(lua_state(), nullptr, static_cast<int>(argcount), &nresults)); stats = static_cast<call_status>(lua_resume(lua_state(), nullptr, static_cast<int>(argcount), &nresults));
#else #else
@ -91,13 +91,16 @@ namespace sol {
using base_t::lua_state; using base_t::lua_state;
basic_coroutine() = default; basic_coroutine() = default;
template <typename T, meta::enable<meta::neg<std::is_same<meta::unqualified_t<T>, basic_coroutine>>, meta::neg<std::is_base_of<proxy_base_tag, meta::unqualified_t<T>>>, meta::neg<std::is_same<base_t, stack_reference>>, meta::neg<std::is_same<lua_nil_t, meta::unqualified_t<T>>>, is_lua_reference<meta::unqualified_t<T>>> = meta::enabler> template <typename T,
meta::enable<meta::neg<std::is_same<meta::unqualified_t<T>, basic_coroutine>>,
meta::neg<std::is_base_of<proxy_base_tag, meta::unqualified_t<T>>>, meta::neg<std::is_same<base_t, stack_reference>>,
meta::neg<std::is_same<lua_nil_t, meta::unqualified_t<T>>>, is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
basic_coroutine(T&& r) noexcept basic_coroutine(T&& r) noexcept
: base_t(std::forward<T>(r)), error_handler(detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) { : base_t(std::forward<T>(r)), error_handler(detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) {
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_) #if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
if (!is_function<meta::unqualified_t<T>>::value) { if (!is_function<meta::unqualified_t<T>>::value) {
auto pp = stack::push_pop(*this); auto pp = stack::push_pop(*this);
constructor_handler handler{}; constructor_handler handler {};
stack::check<basic_coroutine>(lua_state(), -1, handler); stack::check<basic_coroutine>(lua_state(), -1, handler);
} }
#endif // Safety #endif // Safety
@ -112,11 +115,9 @@ namespace sol {
basic_coroutine(basic_function<base_t>&& b) basic_coroutine(basic_function<base_t>&& b)
: basic_coroutine(std::move(b), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(b.lua_state())) { : basic_coroutine(std::move(b), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(b.lua_state())) {
} }
basic_coroutine(const basic_function<base_t>& b, handler_t eh) basic_coroutine(const basic_function<base_t>& b, handler_t eh) : base_t(b), error_handler(std::move(eh)) {
: base_t(b), error_handler(std::move(eh)) {
} }
basic_coroutine(basic_function<base_t>&& b, handler_t eh) basic_coroutine(basic_function<base_t>&& b, handler_t eh) : base_t(std::move(b)), error_handler(std::move(eh)) {
: base_t(std::move(b)), error_handler(std::move(eh)) {
} }
basic_coroutine(const stack_reference& r) basic_coroutine(const stack_reference& r)
: basic_coroutine(r.lua_state(), r.stack_index(), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) { : basic_coroutine(r.lua_state(), r.stack_index(), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) {
@ -124,11 +125,9 @@ namespace sol {
basic_coroutine(stack_reference&& r) basic_coroutine(stack_reference&& r)
: basic_coroutine(r.lua_state(), r.stack_index(), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) { : basic_coroutine(r.lua_state(), r.stack_index(), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(r.lua_state())) {
} }
basic_coroutine(const stack_reference& r, handler_t eh) basic_coroutine(const stack_reference& r, handler_t eh) : basic_coroutine(r.lua_state(), r.stack_index(), std::move(eh)) {
: basic_coroutine(r.lua_state(), r.stack_index(), std::move(eh)) {
} }
basic_coroutine(stack_reference&& r, handler_t eh) basic_coroutine(stack_reference&& r, handler_t eh) : basic_coroutine(r.lua_state(), r.stack_index(), std::move(eh)) {
: basic_coroutine(r.lua_state(), r.stack_index(), std::move(eh)) {
} }
template <typename Super> template <typename Super>
@ -139,9 +138,9 @@ namespace sol {
basic_coroutine(proxy_base<Super>&& p) basic_coroutine(proxy_base<Super>&& p)
: basic_coroutine(std::move(p), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(p.lua_state())) { : basic_coroutine(std::move(p), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(p.lua_state())) {
} }
template <typename Proxy, typename Handler, meta::enable<std::is_base_of<proxy_base_tag, meta::unqualified_t<Proxy>>, meta::neg<is_lua_index<meta::unqualified_t<Handler>>>> = meta::enabler> template <typename Proxy, typename Handler,
basic_coroutine(Proxy&& p, Handler&& eh) meta::enable<std::is_base_of<proxy_base_tag, meta::unqualified_t<Proxy>>, meta::neg<is_lua_index<meta::unqualified_t<Handler>>>> = meta::enabler>
: basic_coroutine(detail::force_cast<base_t>(p), std::forward<Handler>(eh)) { basic_coroutine(Proxy&& p, Handler&& eh) : basic_coroutine(detail::force_cast<base_t>(p), std::forward<Handler>(eh)) {
} }
template <typename T, meta::enable<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler> template <typename T, meta::enable<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
@ -149,57 +148,51 @@ namespace sol {
: basic_coroutine(L, std::forward<T>(r), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) { : basic_coroutine(L, std::forward<T>(r), detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
} }
template <typename T, meta::enable<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler> template <typename T, meta::enable<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
basic_coroutine(lua_State* L, T&& r, handler_t eh) basic_coroutine(lua_State* L, T&& r, handler_t eh) : base_t(L, std::forward<T>(r)), error_handler(std::move(eh)) {
: base_t(L, std::forward<T>(r)), error_handler(std::move(eh)) {
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_) #if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
auto pp = stack::push_pop(*this); auto pp = stack::push_pop(*this);
constructor_handler handler{}; constructor_handler handler {};
stack::check<basic_coroutine>(lua_state(), -1, handler); stack::check<basic_coroutine>(lua_state(), -1, handler);
#endif // Safety #endif // Safety
} }
basic_coroutine(lua_nil_t n) basic_coroutine(lua_nil_t n) : base_t(n), error_handler(n) {
: base_t(n), error_handler(n) {
} }
basic_coroutine(lua_State* L, int index = -1) basic_coroutine(lua_State* L, int index = -1)
: basic_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) { : basic_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
} }
basic_coroutine(lua_State* L, int index, handler_t eh) basic_coroutine(lua_State* L, int index, handler_t eh) : base_t(L, index), error_handler(std::move(eh)) {
: base_t(L, index), error_handler(std::move(eh)) {
#ifdef SOL_SAFE_REFERENCES #ifdef SOL_SAFE_REFERENCES
constructor_handler handler{}; constructor_handler handler {};
stack::check<basic_coroutine>(L, index, handler); stack::check<basic_coroutine>(L, index, handler);
#endif // Safety #endif // Safety
} }
basic_coroutine(lua_State* L, absolute_index index) basic_coroutine(lua_State* L, absolute_index index)
: basic_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) { : basic_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
} }
basic_coroutine(lua_State* L, absolute_index index, handler_t eh) basic_coroutine(lua_State* L, absolute_index index, handler_t eh) : base_t(L, index), error_handler(std::move(eh)) {
: base_t(L, index), error_handler(std::move(eh)) {
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_) #if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
constructor_handler handler{}; constructor_handler handler {};
stack::check<basic_coroutine>(L, index, handler); stack::check<basic_coroutine>(L, index, handler);
#endif // Safety #endif // Safety
} }
basic_coroutine(lua_State* L, raw_index index) basic_coroutine(lua_State* L, raw_index index)
: basic_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) { : basic_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
} }
basic_coroutine(lua_State* L, raw_index index, handler_t eh) basic_coroutine(lua_State* L, raw_index index, handler_t eh) : base_t(L, index), error_handler(std::move(eh)) {
: base_t(L, index), error_handler(std::move(eh)) {
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_) #if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
constructor_handler handler{}; constructor_handler handler {};
stack::check<basic_coroutine>(L, index, handler); stack::check<basic_coroutine>(L, index, handler);
#endif // Safety #endif // Safety
} }
basic_coroutine(lua_State* L, ref_index index) basic_coroutine(lua_State* L, ref_index index)
: basic_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) { : basic_coroutine(L, index, detail::get_default_handler<reference, is_main_threaded<base_t>::value>(L)) {
} }
basic_coroutine(lua_State* L, ref_index index, handler_t eh) basic_coroutine(lua_State* L, ref_index index, handler_t eh) : base_t(L, index), error_handler(std::move(eh)) {
: base_t(L, index), error_handler(std::move(eh)) {
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_) #if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
auto pp = stack::push_pop(*this); auto pp = stack::push_pop(*this);
constructor_handler handler{}; constructor_handler handler {};
stack::check<basic_coroutine>(lua_state(), -1, handler); stack::check<basic_coroutine>(lua_state(), -1, handler);
#endif // Safety #endif // Safety
} }
@ -214,8 +207,7 @@ namespace sol {
} }
bool runnable() const noexcept { bool runnable() const noexcept {
return base_t::valid() return base_t::valid() && (status() == call_status::yielded);
&& (status() == call_status::yielded);
} }
explicit operator bool() const noexcept { explicit operator bool() const noexcept {

View File

@ -28,16 +28,15 @@
#include <string> #include <string>
#include <array> #include <array>
#include <cctype> #include <cctype>
#if defined(__GNUC__) && defined(__MINGW32__) && (__GNUC__ < 6) #if SOL_IS_ON(SOL_MINGW_CCTYPE_IS_POISONED_I_)
extern "C" { extern "C" {
#include <ctype.h> #include <ctype.h>
} }
#endif // MinGW is on some stuff #endif // MinGW is on some stuff
#include <locale> #include <locale>
namespace sol { namespace sol { namespace detail {
namespace detail { inline constexpr std::array<string_view, 9> removals { { "{anonymous}",
inline constexpr std::array<string_view, 9> removals{ { "{anonymous}",
"(anonymous namespace)", "(anonymous namespace)",
"public:", "public:",
"private:", "private:",
@ -48,7 +47,7 @@ namespace detail {
"`anonymous namespace'" } }; "`anonymous namespace'" } };
#if defined(__GNUC__) || defined(__clang__) #if SOL_IS_ON(SOL_COMPILER_GCC_I_) || SOL_IS_ON(SOL_COMPILER_CLANG_I_)
inline std::string ctti_get_type_name_from_sig(std::string name) { inline std::string ctti_get_type_name_from_sig(std::string name) {
// cardinal sins from MINGW // cardinal sins from MINGW
using namespace std; using namespace std;
@ -86,7 +85,7 @@ namespace detail {
inline std::string ctti_get_type_name() { inline std::string ctti_get_type_name() {
return ctti_get_type_name_from_sig(__PRETTY_FUNCTION__); return ctti_get_type_name_from_sig(__PRETTY_FUNCTION__);
} }
#elif defined(_MSC_VER) #elif SOL_IS_ON(SOL_COMPILER_VCXX_I_)
inline std::string ctti_get_type_name_from_sig(std::string name) { inline std::string ctti_get_type_name_from_sig(std::string name) {
std::size_t start = name.find("get_type_name"); std::size_t start = name.find("get_type_name");
if (start == std::string::npos) if (start == std::string::npos)
@ -135,7 +134,9 @@ namespace detail {
inline std::string short_demangle_from_type_name(std::string realname) { inline std::string short_demangle_from_type_name(std::string realname) {
// This isn't the most complete but it'll do for now...? // This isn't the most complete but it'll do for now...?
static const std::array<std::string, 10> ops = {{"operator<", "operator<<", "operator<<=", "operator<=", "operator>", "operator>>", "operator>>=", "operator>=", "operator->", "operator->*"}}; static const std::array<std::string, 10> ops = {
{ "operator<", "operator<<", "operator<<=", "operator<=", "operator>", "operator>>", "operator>>=", "operator>=", "operator->", "operator->*" }
};
int level = 0; int level = 0;
std::ptrdiff_t idx = 0; std::ptrdiff_t idx = 0;
for (idx = static_cast<std::ptrdiff_t>(realname.empty() ? 0 : realname.size() - 1); idx > 0; --idx) { for (idx = static_cast<std::ptrdiff_t>(realname.empty() ? 0 : realname.size() - 1); idx > 0; --idx) {
@ -186,7 +187,6 @@ namespace detail {
static const std::string d = short_demangle_once<T>(); static const std::string d = short_demangle_once<T>();
return d; return d;
} }
} }} // namespace sol::detail
} // namespace sol::detail
#endif // SOL_DEMANGLE_HPP #endif // SOL_DEMANGLE_HPP

View File

@ -41,19 +41,15 @@ namespace sol {
basic_environment(basic_environment&&) = default; basic_environment(basic_environment&&) = default;
basic_environment& operator=(const basic_environment&) = default; basic_environment& operator=(const basic_environment&) = default;
basic_environment& operator=(basic_environment&&) = default; basic_environment& operator=(basic_environment&&) = default;
basic_environment(const stack_reference& r) basic_environment(const stack_reference& r) : basic_environment(r.lua_state(), r.stack_index()) {
: basic_environment(r.lua_state(), r.stack_index()) {
} }
basic_environment(stack_reference&& r) basic_environment(stack_reference&& r) : basic_environment(r.lua_state(), r.stack_index()) {
: basic_environment(r.lua_state(), r.stack_index()) {
} }
basic_environment(lua_State* L, new_table nt) basic_environment(lua_State* L, new_table nt) : base_t(L, std::move(nt)) {
: base_t(L, std::move(nt)) {
} }
template <bool b> template <bool b>
basic_environment(lua_State* L, new_table t, const basic_reference<b>& fallback) basic_environment(lua_State* L, new_table t, const basic_reference<b>& fallback) : basic_environment(L, std::move(t)) {
: basic_environment(L, std::move(t)) {
stack_table mt(L, new_table(0, 1)); stack_table mt(L, new_table(0, 1));
mt.set(meta_function::index, fallback); mt.set(meta_function::index, fallback);
this->set(metatable_key, mt); this->set(metatable_key, mt);
@ -63,7 +59,7 @@ namespace sol {
basic_environment(env_key_t, const stack_reference& extraction_target) basic_environment(env_key_t, const stack_reference& extraction_target)
: base_t(detail::no_safety, extraction_target.lua_state(), (stack::push_environment_of(extraction_target), -1)) { : base_t(detail::no_safety, extraction_target.lua_state(), (stack::push_environment_of(extraction_target), -1)) {
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_) #if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
constructor_handler handler{}; constructor_handler handler {};
stack::check<env_key_t>(this->lua_state(), -1, handler); stack::check<env_key_t>(this->lua_state(), -1, handler);
#endif // Safety #endif // Safety
lua_pop(this->lua_state(), 2); lua_pop(this->lua_state(), 2);
@ -72,48 +68,45 @@ namespace sol {
basic_environment(env_key_t, const basic_reference<b>& extraction_target) basic_environment(env_key_t, const basic_reference<b>& extraction_target)
: base_t(detail::no_safety, extraction_target.lua_state(), (stack::push_environment_of(extraction_target), -1)) { : base_t(detail::no_safety, extraction_target.lua_state(), (stack::push_environment_of(extraction_target), -1)) {
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_) #if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
constructor_handler handler{}; constructor_handler handler {};
stack::check<env_key_t>(this->lua_state(), -1, handler); stack::check<env_key_t>(this->lua_state(), -1, handler);
#endif // Safety #endif // Safety
lua_pop(this->lua_state(), 2); lua_pop(this->lua_state(), 2);
} }
basic_environment(lua_State* L, int index = -1) basic_environment(lua_State* L, int index = -1) : base_t(detail::no_safety, L, index) {
: base_t(detail::no_safety, L, index) {
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_) #if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
constructor_handler handler{}; constructor_handler handler {};
stack::check<basic_environment>(L, index, handler); stack::check<basic_environment>(L, index, handler);
#endif // Safety #endif // Safety
} }
basic_environment(lua_State* L, ref_index index) basic_environment(lua_State* L, ref_index index) : base_t(detail::no_safety, L, index) {
: base_t(detail::no_safety, L, index) {
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_) #if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
auto pp = stack::push_pop(*this); auto pp = stack::push_pop(*this);
constructor_handler handler{}; constructor_handler handler {};
stack::check<basic_environment>(L, -1, handler); stack::check<basic_environment>(L, -1, handler);
#endif // Safety #endif // Safety
} }
template <typename T, meta::enable<meta::neg<meta::any_same<meta::unqualified_t<T>, basic_environment>>, meta::neg<std::is_same<base_type, stack_reference>>, meta::neg<std::is_same<lua_nil_t, meta::unqualified_t<T>>>, is_lua_reference<meta::unqualified_t<T>>> = meta::enabler> template <typename T,
basic_environment(T&& r) noexcept meta::enable<meta::neg<meta::any_same<meta::unqualified_t<T>, basic_environment>>, meta::neg<std::is_same<base_type, stack_reference>>,
: base_t(detail::no_safety, std::forward<T>(r)) { meta::neg<std::is_same<lua_nil_t, meta::unqualified_t<T>>>, is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
basic_environment(T&& r) noexcept : base_t(detail::no_safety, std::forward<T>(r)) {
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_) #if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
if (!is_environment<meta::unqualified_t<T>>::value) { if (!is_environment<meta::unqualified_t<T>>::value) {
auto pp = stack::push_pop(*this); auto pp = stack::push_pop(*this);
constructor_handler handler{}; constructor_handler handler {};
stack::check<basic_environment>(lua_state(), -1, handler); stack::check<basic_environment>(lua_state(), -1, handler);
} }
#endif // Safety #endif // Safety
} }
basic_environment(lua_nil_t r) noexcept basic_environment(lua_nil_t r) noexcept : base_t(detail::no_safety, r) {
: base_t(detail::no_safety, r) {
} }
template <typename T, meta::enable<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler> template <typename T, meta::enable<is_lua_reference<meta::unqualified_t<T>>> = meta::enabler>
basic_environment(lua_State* L, T&& r) noexcept basic_environment(lua_State* L, T&& r) noexcept : base_t(detail::no_safety, L, std::forward<T>(r)) {
: base_t(detail::no_safety, L, std::forward<T>(r)) {
#if SOL_IS_ON(SOL_SAFE_REFERENCES_I_) #if SOL_IS_ON(SOL_SAFE_REFERENCES_I_)
if (!is_environment<meta::unqualified_t<T>>::value) { if (!is_environment<meta::unqualified_t<T>>::value) {
auto pp = stack::push_pop(*this); auto pp = stack::push_pop(*this);
constructor_handler handler{}; constructor_handler handler {};
stack::check<basic_environment>(lua_state(), -1, handler); stack::check<basic_environment>(lua_state(), -1, handler);
} }
#endif // Safety #endif // Safety
@ -123,7 +116,7 @@ namespace sol {
void set_on(const T& target) const { void set_on(const T& target) const {
lua_State* L = target.lua_state(); lua_State* L = target.lua_state();
auto pp = stack::push_pop(target); auto pp = stack::push_pop(target);
#if SOL_LUA_VERSION < 502 #if SOL_LUA_VESION_I_ < 502
// Use lua_setfenv // Use lua_setfenv
this->push(); this->push();
lua_setfenv(L, -2); lua_setfenv(L, -2);
@ -153,11 +146,9 @@ namespace sol {
struct this_environment { struct this_environment {
optional<environment> env; optional<environment> env;
this_environment() this_environment() : env(nullopt) {
: env(nullopt) {
} }
this_environment(environment e) this_environment(environment e) : env(std::move(e)) {
: env(std::move(e)) {
} }
this_environment(const this_environment&) = default; this_environment(const this_environment&) = default;
this_environment(this_environment&&) = default; this_environment(this_environment&&) = default;
@ -168,11 +159,11 @@ namespace sol {
return static_cast<bool>(env); return static_cast<bool>(env);
} }
operator optional<environment>&() { operator optional<environment> &() {
return env; return env;
} }
operator const optional<environment>&() const { operator const optional<environment> &() const {
return env; return env;
} }

View File

@ -39,12 +39,18 @@ namespace sol {
load_status err; load_status err;
public: public:
load_result() = default; load_result() noexcept = default;
load_result(lua_State* Ls, int stackindex = -1, int retnum = 0, int popnum = 0, load_status lerr = load_status::ok) noexcept load_result(lua_State* Ls, int stackindex = -1, int retnum = 0, int popnum = 0, load_status lerr = load_status::ok) noexcept
: L(Ls), index(stackindex), returncount(retnum), popcount(popnum), err(lerr) { : L(Ls), index(stackindex), returncount(retnum), popcount(popnum), err(lerr) {
} }
load_result(const load_result&) = default;
load_result& operator=(const load_result&) = default; // We do not want anyone to copy these around willy-nilly
// Will likely break people, but also will probably get rid of quiet bugs that have
// been lurking. (E.g., Vanilla Lua will just quietly discard over-pops and under-pops:
// LuaJIT and other Lua engines will implode and segfault at random later times.)
load_result(const load_result&) = delete;
load_result& operator=(const load_result&) = delete;
load_result(load_result&& o) noexcept : L(o.L), index(o.index), returncount(o.returncount), popcount(o.popcount), err(o.err) { load_result(load_result&& o) noexcept : L(o.L), index(o.index), returncount(o.returncount), popcount(o.popcount), err(o.err) {
// Must be manual, otherwise destructor will screw us // Must be manual, otherwise destructor will screw us
// return count being 0 is enough to keep things clean // return count being 0 is enough to keep things clean

View File

@ -54,12 +54,18 @@ namespace sol {
typedef std::reverse_iterator<iterator> reverse_iterator; typedef std::reverse_iterator<iterator> reverse_iterator;
typedef std::reverse_iterator<const_iterator> const_reverse_iterator; typedef std::reverse_iterator<const_iterator> const_reverse_iterator;
protected_function_result() = default; protected_function_result() noexcept = default;
protected_function_result(lua_State* Ls, int idx = -1, int retnum = 0, int popped = 0, call_status pferr = call_status::ok) noexcept protected_function_result(lua_State* Ls, int idx = -1, int retnum = 0, int popped = 0, call_status pferr = call_status::ok) noexcept
: L(Ls), index(idx), returncount(retnum), popcount(popped), err(pferr) { : L(Ls), index(idx), returncount(retnum), popcount(popped), err(pferr) {
} }
protected_function_result(const protected_function_result&) = default;
protected_function_result& operator=(const protected_function_result&) = default; // We do not want anyone to copy these around willy-nilly
// Will likely break people, but also will probably get rid of quiet bugs that have
// been lurking. (E.g., Vanilla Lua will just quietly discard over-pops and under-pops:
// LuaJIT and other Lua engines will implode and segfault at random later times.)
protected_function_result(const protected_function_result&) = delete;
protected_function_result& operator=(const protected_function_result&) = delete;
protected_function_result(protected_function_result&& o) noexcept protected_function_result(protected_function_result&& o) noexcept
: L(o.L), index(o.index), returncount(o.returncount), popcount(o.popcount), err(o.err) { : L(o.L), index(o.index), returncount(o.returncount), popcount(o.popcount), err(o.err) {
// Must be manual, otherwise destructor will screw us // Must be manual, otherwise destructor will screw us

View File

@ -68,8 +68,7 @@ namespace sol {
lua_State* L; lua_State* L;
int index; int index;
int count; int count;
push_popper_at(lua_State* luastate, int index = -1, int count = 1) push_popper_at(lua_State* luastate, int index = -1, int count = 1) : L(luastate), index(index), count(count) {
: L(luastate), index(index), count(count) {
} }
~push_popper_at() { ~push_popper_at() {
remove(L, index, count); remove(L, index, count);
@ -80,8 +79,7 @@ namespace sol {
struct push_popper_n { struct push_popper_n {
lua_State* L; lua_State* L;
int t; int t;
push_popper_n(lua_State* luastate, int x) push_popper_n(lua_State* luastate, int x) : L(luastate), t(x) {
: L(luastate), t(x) {
} }
push_popper_n(const push_popper_n&) = delete; push_popper_n(const push_popper_n&) = delete;
push_popper_n(push_popper_n&&) = default; push_popper_n(push_popper_n&&) = default;
@ -104,9 +102,7 @@ namespace sol {
T t; T t;
int idx; int idx;
push_popper(T x) push_popper(T x) : t(x), idx(lua_absindex(t.lua_state(), -t.push())) {
: t(x), idx(lua_absindex(t.lua_state(), -t.push())) {
} }
int index_of(const Tu&) { int index_of(const Tu&) {
@ -167,7 +163,7 @@ namespace sol {
} // namespace stack } // namespace stack
inline lua_State* main_thread(lua_State* L, lua_State* backup_if_unsupported = nullptr) { inline lua_State* main_thread(lua_State* L, lua_State* backup_if_unsupported = nullptr) {
#if SOL_LUA_VERSION < 502 #if SOL_LUA_VESION_I_ < 502
if (L == nullptr) if (L == nullptr)
return backup_if_unsupported; return backup_if_unsupported;
lua_getglobal(L, detail::default_main_thread_name()); lua_getglobal(L, detail::default_main_thread_name());
@ -235,7 +231,7 @@ namespace sol {
} }
protected: protected:
int stack_index () const noexcept { int stack_index() const noexcept {
return -1; return -1;
} }
@ -319,8 +315,7 @@ namespace sol {
stateless_reference(const stateless_reference& o) noexcept = delete; stateless_reference(const stateless_reference& o) noexcept = delete;
stateless_reference& operator=(const stateless_reference& r) noexcept = delete; stateless_reference& operator=(const stateless_reference& r) noexcept = delete;
stateless_reference(stateless_reference&& o) noexcept stateless_reference(stateless_reference&& o) noexcept : ref(o.ref) {
: ref(o.ref) {
o.ref = LUA_NOREF; o.ref = LUA_NOREF;
} }
@ -437,8 +432,7 @@ namespace sol {
: basic_reference(detail::pick_main_thread<main_only>(L, L), detail::global_, detail::global_) { : basic_reference(detail::pick_main_thread<main_only>(L, L), detail::global_, detail::global_) {
} }
basic_reference(lua_State* L, detail::global_tag, detail::global_tag) noexcept basic_reference(lua_State* L, detail::global_tag, detail::global_tag) noexcept : stateless_reference(L, detail::global_), luastate(L) {
: stateless_reference(L, detail::global_), luastate(L) {
} }
basic_reference(lua_State* oL, const basic_reference<!main_only>& o) noexcept : stateless_reference(oL, o), luastate(oL) { basic_reference(lua_State* oL, const basic_reference<!main_only>& o) noexcept : stateless_reference(oL, o), luastate(oL) {
@ -458,18 +452,14 @@ namespace sol {
public: public:
basic_reference() noexcept = default; basic_reference() noexcept = default;
basic_reference(lua_nil_t) noexcept basic_reference(lua_nil_t) noexcept : basic_reference() {
: basic_reference() {
} }
basic_reference(const stack_reference& r) noexcept basic_reference(const stack_reference& r) noexcept : basic_reference(r.lua_state(), r.stack_index()) {
: basic_reference(r.lua_state(), r.stack_index()) {
} }
basic_reference(stack_reference&& r) noexcept basic_reference(stack_reference&& r) noexcept : basic_reference(r.lua_state(), r.stack_index()) {
: basic_reference(r.lua_state(), r.stack_index()) {
} }
template <bool r_main_only> template <bool r_main_only>
basic_reference(lua_State* L, const basic_reference<r_main_only>& r) noexcept basic_reference(lua_State* L, const basic_reference<r_main_only>& r) noexcept : luastate(detail::pick_main_thread<main_only>(L, L)) {
: luastate(detail::pick_main_thread<main_only>(L, L)) {
if (r.ref == LUA_REFNIL) { if (r.ref == LUA_REFNIL) {
ref = LUA_REFNIL; ref = LUA_REFNIL;
return; return;
@ -487,8 +477,7 @@ namespace sol {
} }
template <bool r_main_only> template <bool r_main_only>
basic_reference(lua_State* L, basic_reference<r_main_only>&& r) noexcept basic_reference(lua_State* L, basic_reference<r_main_only>&& r) noexcept : luastate(detail::pick_main_thread<main_only>(L, L)) {
: luastate(detail::pick_main_thread<main_only>(L, L)) {
if (r.ref == LUA_REFNIL) { if (r.ref == LUA_REFNIL) {
ref = LUA_REFNIL; ref = LUA_REFNIL;
return; return;
@ -507,8 +496,7 @@ namespace sol {
r.luastate = nullptr; r.luastate = nullptr;
} }
basic_reference(lua_State* L, const stack_reference& r) noexcept basic_reference(lua_State* L, const stack_reference& r) noexcept : luastate(detail::pick_main_thread<main_only>(L, L)) {
: luastate(detail::pick_main_thread<main_only>(L, L)) {
if (lua_state() == nullptr || r.lua_state() == nullptr || r.get_type() == type::none) { if (lua_state() == nullptr || r.lua_state() == nullptr || r.get_type() == type::none) {
ref = LUA_NOREF; ref = LUA_NOREF;
return; return;
@ -523,8 +511,7 @@ namespace sol {
r.push(lua_state()); r.push(lua_state());
ref = luaL_ref(lua_state(), LUA_REGISTRYINDEX); ref = luaL_ref(lua_state(), LUA_REGISTRYINDEX);
} }
basic_reference(lua_State* L, int index = -1) noexcept basic_reference(lua_State* L, int index = -1) noexcept : luastate(detail::pick_main_thread<main_only>(L, L)) {
: luastate(detail::pick_main_thread<main_only>(L, L)) {
// use L to stick with that state's execution stack // use L to stick with that state's execution stack
#if SOL_IS_ON(SOL_SAFE_STACK_CHECK_I_) #if SOL_IS_ON(SOL_SAFE_STACK_CHECK_I_)
luaL_checkstack(L, 1, "not enough Lua stack space to push this reference value"); luaL_checkstack(L, 1, "not enough Lua stack space to push this reference value");
@ -532,13 +519,11 @@ namespace sol {
lua_pushvalue(L, index); lua_pushvalue(L, index);
ref = luaL_ref(L, LUA_REGISTRYINDEX); ref = luaL_ref(L, LUA_REGISTRYINDEX);
} }
basic_reference(lua_State* L, ref_index index) noexcept basic_reference(lua_State* L, ref_index index) noexcept : luastate(detail::pick_main_thread<main_only>(L, L)) {
: luastate(detail::pick_main_thread<main_only>(L, L)) {
lua_rawgeti(lua_state(), LUA_REGISTRYINDEX, index.index); lua_rawgeti(lua_state(), LUA_REGISTRYINDEX, index.index);
ref = luaL_ref(lua_state(), LUA_REGISTRYINDEX); ref = luaL_ref(lua_state(), LUA_REGISTRYINDEX);
} }
basic_reference(lua_State* L, lua_nil_t) noexcept basic_reference(lua_State* L, lua_nil_t) noexcept : luastate(detail::pick_main_thread<main_only>(L, L)) {
: luastate(detail::pick_main_thread<main_only>(L, L)) {
} }
~basic_reference() noexcept { ~basic_reference() noexcept {
@ -547,12 +532,10 @@ namespace sol {
deref(); deref();
} }
basic_reference(const basic_reference& o) noexcept basic_reference(const basic_reference& o) noexcept : stateless_reference(o.copy()), luastate(o.lua_state()) {
: stateless_reference(o.copy()), luastate(o.lua_state()) {
} }
basic_reference(basic_reference&& o) noexcept basic_reference(basic_reference&& o) noexcept : stateless_reference(std::move(o)), luastate(o.lua_state()) {
: stateless_reference(std::move(o)), luastate(o.lua_state()) {
o.luastate = nullptr; o.luastate = nullptr;
} }

View File

@ -22,27 +22,28 @@
#ifndef SOL_HPP #ifndef SOL_HPP
#define SOL_HPP #define SOL_HPP
#if defined(UE_BUILD_DEBUG) || defined(UE_BUILD_DEVELOPMENT) || defined(UE_BUILD_TEST) || defined(UE_BUILD_SHIPPING) || defined(UE_SERVER) #include <sol/version.hpp>
#define SOL_INSIDE_UNREAL
#if SOL_IS_ON(SOL_INSIDE_UNREAL_ENGINE_I_)
#ifdef check #ifdef check
#pragma push_macro("check") #pragma push_macro("check")
#undef check #undef check
#endif #endif
#endif // Unreal Engine 4 Bullshit #endif // Unreal Engine 4 Bullshit
#if defined(__GNUC__) #if SOL_IS_ON(SOL_COMPILER_GCC_I_)
#pragma GCC diagnostic push #pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wshadow" #pragma GCC diagnostic ignored "-Wshadow"
#pragma GCC diagnostic ignored "-Wconversion" #pragma GCC diagnostic ignored "-Wconversion"
#if __GNUC__ > 6 #if __GNUC__ > 6
#pragma GCC diagnostic ignored "-Wnoexcept-type" #pragma GCC diagnostic ignored "-Wnoexcept-type"
#endif #endif
#elif defined(__clang__) #elif SOL_IS_ON(SOL_COMPILER_CLANG_I_)
// we'll just let this alone for now // we'll just let this alone for now
#elif defined _MSC_VER #elif SOL_IS_ON(SOL_COMPILER_VCXX_I_)
#pragma warning(push) #pragma warning(push)
#pragma warning(disable : 4505) // unreferenced local function has been removed GEE THANKS #pragma warning(disable : 4505) // unreferenced local function has been removed GEE THANKS
#endif // clang++ vs. g++ vs. VC++ #endif // clang++ vs. g++ vs. VC++
#include <sol/forward.hpp> #include <sol/forward.hpp>
#include <sol/forward_detail.hpp> #include <sol/forward_detail.hpp>
@ -63,13 +64,13 @@
#include <sol/variadic_results.hpp> #include <sol/variadic_results.hpp>
#include <sol/lua_value.hpp> #include <sol/lua_value.hpp>
#if defined(__GNUC__) #if SOL_IS_ON(SOL_COMPILER_GCC_I_)
#pragma GCC diagnostic pop #pragma GCC diagnostic pop
#elif defined _MSC_VER #elif SOL_IS_ON(SOL_COMPILER_VCXX_I_)
#pragma warning(pop) #pragma warning(pop)
#endif // g++ #endif // g++
#if defined(SOL_INSIDE_UNREAL) #if SOL_IS_ON(SOL_INSIDE_UNREAL_ENGINE_I_)
#undef check #undef check
#pragma pop_macro("check") #pragma pop_macro("check")
#endif // Unreal Engine 4 Bullshit #endif // Unreal Engine 4 Bullshit

View File

@ -272,7 +272,7 @@ namespace sol {
} }
inline void luajit_exception_handler(lua_State* L, int (*handler)(lua_State*, lua_CFunction) = detail::c_trampoline) { inline void luajit_exception_handler(lua_State* L, int (*handler)(lua_State*, lua_CFunction) = detail::c_trampoline) {
#if defined(SOL_LUAJIT) && (!defined(SOL_EXCEPTIONS_SAFE_PROPAGATION) || !(SOL_EXCEPTIONS_SAFE_PROPAGATION)) #if SOL_IS_ON(SOL_USE_LUAJIT_EXCEPTION_TRAMPOLINE_I_)
if (L == nullptr) { if (L == nullptr) {
return; return;
} }
@ -289,7 +289,7 @@ namespace sol {
} }
inline void luajit_exception_off(lua_State* L) { inline void luajit_exception_off(lua_State* L) {
#if defined(SOL_LUAJIT) #if SOL_IS_ON(SOL_USE_LUAJIT_EXCEPTION_TRAMPOLINE_I_)
if (L == nullptr) { if (L == nullptr) {
return; return;
} }

View File

@ -58,7 +58,7 @@ namespace sol { namespace stack {
return stack_detail::unchecked_get<T>(L, index, tracking); return stack_detail::unchecked_get<T>(L, index, tracking);
} }
else if constexpr ((std::is_integral_v<T> || std::is_same_v<T, lua_Integer>)&&!std::is_same_v<T, bool>) { else if constexpr ((std::is_integral_v<T> || std::is_same_v<T, lua_Integer>)&&!std::is_same_v<T, bool>) {
#if SOL_LUA_VERSION >= 503 #if SOL_LUA_VESION_I_ >= 503
if (lua_isinteger(L, index) != 0) { if (lua_isinteger(L, index) != 0) {
tracking.use(1); tracking.use(1);
return static_cast<T>(lua_tointeger(L, index)); return static_cast<T>(lua_tointeger(L, index));
@ -67,7 +67,7 @@ namespace sol { namespace stack {
int isnum = 0; int isnum = 0;
const lua_Number value = lua_tonumberx(L, index, &isnum); const lua_Number value = lua_tonumberx(L, index, &isnum);
if (isnum != 0) { if (isnum != 0) {
#if (defined(SOL_SAFE_NUMERICS) && SOL_SAFE_NUMERICS) && !(defined(SOL_NO_CHECK_NUMBER_PRECISION) && SOL_NO_CHECK_NUMBER_PRECISION) #if SOL_IS_ON(SOL_NUMBER_PRECISION_CHECKS_I_)
const auto integer_value = llround(value); const auto integer_value = llround(value);
if (static_cast<lua_Number>(integer_value) == value) { if (static_cast<lua_Number>(integer_value) == value) {
tracking.use(1); tracking.use(1);

View File

@ -105,8 +105,10 @@ namespace sol { namespace stack {
} }
else if constexpr (std::is_integral_v<T> || std::is_same_v<T, lua_Integer>) { else if constexpr (std::is_integral_v<T> || std::is_same_v<T, lua_Integer>) {
tracking.use(1); tracking.use(1);
#if SOL_LUA_VERSION >= 503 #if SOL_LUA_VESION_I_ >= 503
// Lua 5.3 and greater checks for numeric precision
#if SOL_IS_ON(SOL_STRINGS_ARE_NUMBERS_I_) #if SOL_IS_ON(SOL_STRINGS_ARE_NUMBERS_I_)
// imprecise, sloppy conversions
int isnum = 0; int isnum = 0;
lua_tointegerx(L, index, &isnum); lua_tointegerx(L, index, &isnum);
const bool success = isnum != 0; const bool success = isnum != 0;
@ -114,8 +116,8 @@ namespace sol { namespace stack {
// expected type, actual type // expected type, actual type
handler(L, index, type::number, type_of(L, index), detail::not_a_number_or_number_string_integral); handler(L, index, type::number, type_of(L, index), detail::not_a_number_or_number_string_integral);
} }
#elif (defined(SOL_SAFE_NUMERICS) && SOL_SAFE_NUMERICS) && !(defined(SOL_NO_CHECK_NUMBER_PRECISION) && SOL_NO_CHECK_NUMBER_PRECISION) #elif SOL_IS_ON(SOL_NUMBER_PRECISION_CHECKS_I_)
// this check is precise, does not convert // this check is precise, do not convert
if (lua_isinteger(L, index) == 1) { if (lua_isinteger(L, index) == 1) {
return true; return true;
} }
@ -125,16 +127,18 @@ namespace sol { namespace stack {
handler(L, index, type::number, type_of(L, index), detail::not_a_number_integral); handler(L, index, type::number, type_of(L, index), detail::not_a_number_integral);
} }
#else #else
// Numerics are neither safe nor string-convertible
type t = type_of(L, index); type t = type_of(L, index);
const bool success = t == type::number; const bool success = t == type::number;
#endif // If numbers are enabled, use the imprecise check #endif
if (!success) { if (!success) {
// expected type, actual type // expected type, actual type
handler(L, index, type::number, type_of(L, index), detail::not_a_number); handler(L, index, type::number, type_of(L, index), detail::not_a_number);
} }
return success; return success;
#else #else
#if !defined(SOL_STRINGS_ARE_NUMBERS) || !SOL_STRINGS_ARE_NUMBERS // Lua 5.2 and below checks
#if SOL_IS_OFF(SOL_STRINGS_ARE_NUMBERS_I_)
// must pre-check, because it will convert // must pre-check, because it will convert
type t = type_of(L, index); type t = type_of(L, index);
if (t != type::number) { if (t != type::number) {
@ -143,7 +147,8 @@ namespace sol { namespace stack {
return false; return false;
} }
#endif // Do not allow strings to be numbers #endif // Do not allow strings to be numbers
#if (defined(SOL_SAFE_NUMERICS) && SOL_SAFE_NUMERICS) && !(defined(SOL_NO_CHECK_NUMBER_PRECISION) && SOL_NO_CHECK_NUMBER_PRECISION)
#if SOL_IS_ON(SOL_NUMBER_PRECISION_CHECKS_I_)
int isnum = 0; int isnum = 0;
const lua_Number v = lua_tonumberx(L, index, &isnum); const lua_Number v = lua_tonumberx(L, index, &isnum);
const bool success = isnum != 0 && static_cast<lua_Number>(llround(v)) == v; const bool success = isnum != 0 && static_cast<lua_Number>(llround(v)) == v;
@ -151,17 +156,17 @@ namespace sol { namespace stack {
const bool success = true; const bool success = true;
#endif // Safe numerics and number precision checking #endif // Safe numerics and number precision checking
if (!success) { if (!success) {
// expected type, actual type // Use defines to provide a better error message!
#if SOL_IS_ON(SOL_STRINGS_ARE_NUMBERS_I_) #if SOL_IS_ON(SOL_STRINGS_ARE_NUMBERS_I_)
handler(L, index, type::number, type_of(L, index), detail::not_a_number_or_number_string); handler(L, index, type::number, type_of(L, index), detail::not_a_number_or_number_string);
#elif (defined(SOL_SAFE_NUMERICS) && SOL_SAFE_NUMERICS) #elif SOL_IS_ON(SOL_NUMBER_PRECISION_CHECKS_I_)
handler(L, index, type::number, t, detail::not_a_number_or_number_string); handler(L, index, type::number, t, detail::not_a_number_or_number_string);
#else #else
handler(L, index, type::number, t, detail::not_a_number); handler(L, index, type::number, t, detail::not_a_number);
#endif #endif
} }
return success; return success;
#endif // Lua Version 5.3 versus others #endif
} }
else if constexpr (std::is_floating_point_v<T> || std::is_same_v<T, lua_Number>) { else if constexpr (std::is_floating_point_v<T> || std::is_same_v<T, lua_Number>) {
tracking.use(1); tracking.use(1);
@ -461,7 +466,7 @@ namespace sol { namespace stack {
}; };
template <typename T> template <typename T>
struct unqualified_checker<non_null<T>, type::userdata> : unqualified_checker<T, lua_type_of_v<T>> {}; struct unqualified_checker<non_null<T>, type::userdata> : unqualified_checker<T, lua_type_of_v<T>> { };
template <typename T> template <typename T>
struct unqualified_checker<detail::as_value_tag<T>, type::userdata> { struct unqualified_checker<detail::as_value_tag<T>, type::userdata> {

View File

@ -33,11 +33,11 @@ namespace sol { namespace stack {
template <typename T, bool global, bool raw, typename> template <typename T, bool global, bool raw, typename>
struct field_getter { struct field_getter {
static constexpr int default_table_index = meta::conditional_t < meta::is_c_str_v<T> static constexpr int default_table_index = meta::conditional_t < meta::is_c_str_v<T>
#if SOL_LUA_VERSION >= 503 #if SOL_LUA_VESION_I_ >= 503
|| (std::is_integral_v<T> && !std::is_same_v<T, bool>) || (std::is_integral_v<T> && !std::is_same_v<T, bool>)
#endif // integer global keys 5.3 or better #endif // integer global keys 5.3 or better
|| (raw && std::is_void_v<std::remove_pointer_t<T>>), || (raw && std::is_void_v<std::remove_pointer_t<T>>),
std::integral_constant<int, -1>, std::integral_constant<int, -2>> ::value; std::integral_constant<int, -1>, std::integral_constant<int, -2> > ::value;
template <typename Key> template <typename Key>
void get(lua_State* L, Key&& key, int tableindex = default_table_index) { void get(lua_State* L, Key&& key, int tableindex = default_table_index) {
@ -48,7 +48,7 @@ namespace sol { namespace stack {
} }
else if constexpr (std::is_same_v<T, env_key_t>) { else if constexpr (std::is_same_v<T, env_key_t>) {
(void)key; (void)key;
#if SOL_LUA_VERSION < 502 #if SOL_LUA_VESION_I_ < 502
// Use lua_setfenv // Use lua_setfenv
lua_getfenv(L, tableindex); lua_getfenv(L, tableindex);
#else #else
@ -67,7 +67,7 @@ namespace sol { namespace stack {
if constexpr (std::is_integral_v<T> && !std::is_same_v<bool, T>) { if constexpr (std::is_integral_v<T> && !std::is_same_v<bool, T>) {
lua_rawgeti(L, tableindex, static_cast<lua_Integer>(key)); lua_rawgeti(L, tableindex, static_cast<lua_Integer>(key));
} }
#if SOL_LUA_VERSION >= 502 #if SOL_LUA_VESION_I_ >= 502
else if constexpr (std::is_void_v<std::remove_pointer_t<T>>) { else if constexpr (std::is_void_v<std::remove_pointer_t<T>>) {
lua_rawgetp(L, tableindex, key); lua_rawgetp(L, tableindex, key);
} }
@ -87,7 +87,7 @@ namespace sol { namespace stack {
lua_getfield(L, tableindex, &key[0]); lua_getfield(L, tableindex, &key[0]);
} }
} }
#if SOL_LUA_VERSION >= 503 #if SOL_LUA_VESION_I_ >= 503
else if constexpr (std::is_integral_v<T> && !std::is_same_v<bool, T>) { else if constexpr (std::is_integral_v<T> && !std::is_same_v<bool, T>) {
lua_geti(L, tableindex, static_cast<lua_Integer>(key)); lua_geti(L, tableindex, static_cast<lua_Integer>(key));
} }
@ -105,7 +105,7 @@ namespace sol { namespace stack {
template <std::size_t... I, typename Keys> template <std::size_t... I, typename Keys>
void apply(std::index_sequence<0, I...>, lua_State* L, Keys&& keys, int tableindex) { void apply(std::index_sequence<0, I...>, lua_State* L, Keys&& keys, int tableindex) {
get_field<b, raw>(L, std::get<0>(std::forward<Keys>(keys)), tableindex); get_field<b, raw>(L, std::get<0>(std::forward<Keys>(keys)), tableindex);
void(detail::swallow{ (get_field<false, raw>(L, std::get<I>(std::forward<Keys>(keys))), 0)... }); void(detail::swallow { (get_field<false, raw>(L, std::get<I>(std::forward<Keys>(keys))), 0)... });
reference saved(L, -1); reference saved(L, -1);
lua_pop(L, static_cast<int>(sizeof...(I))); lua_pop(L, static_cast<int>(sizeof...(I)));
saved.push(); saved.push();
@ -148,7 +148,7 @@ namespace sol { namespace stack {
static constexpr int default_table_index static constexpr int default_table_index
= meta::conditional_t < (meta::is_c_str_v<T> || meta::is_string_of_v<T, char>) || (std::is_integral_v<T> && !std::is_same_v<T, bool>) = meta::conditional_t < (meta::is_c_str_v<T> || meta::is_string_of_v<T, char>) || (std::is_integral_v<T> && !std::is_same_v<T, bool>)
|| (std::is_integral_v<T> && !std::is_same_v<T, bool>) || (raw && std::is_void_v<std::remove_pointer_t<T>>), || (std::is_integral_v<T> && !std::is_same_v<T, bool>) || (raw && std::is_void_v<std::remove_pointer_t<T>>),
std::integral_constant<int, -2>, std::integral_constant<int, -3>> ::value; std::integral_constant<int, -2>, std::integral_constant<int, -3> > ::value;
template <typename Key, typename Value> template <typename Key, typename Value>
void set(lua_State* L, Key&& key, Value&& value, int tableindex = default_table_index) { void set(lua_State* L, Key&& key, Value&& value, int tableindex = default_table_index) {
@ -168,7 +168,7 @@ namespace sol { namespace stack {
push(L, std::forward<Value>(value)); push(L, std::forward<Value>(value));
lua_rawseti(L, tableindex, static_cast<lua_Integer>(key)); lua_rawseti(L, tableindex, static_cast<lua_Integer>(key));
} }
#if SOL_LUA_VERSION >= 502 #if SOL_LUA_VESION_I_ >= 502
else if constexpr (std::is_void_v<std::remove_pointer_t<T>>) { else if constexpr (std::is_void_v<std::remove_pointer_t<T>>) {
push(L, std::forward<Value>(value)); push(L, std::forward<Value>(value));
lua_rawsetp(L, tableindex, std::forward<Key>(key)); lua_rawsetp(L, tableindex, std::forward<Key>(key));
@ -192,7 +192,7 @@ namespace sol { namespace stack {
lua_setfield(L, tableindex, &key[0]); lua_setfield(L, tableindex, &key[0]);
} }
} }
#if SOL_LUA_VERSION >= 503 #if SOL_LUA_VESION_I_ >= 503
else if constexpr (std::is_integral_v<T> && !std::is_same_v<bool, T>) { else if constexpr (std::is_integral_v<T> && !std::is_same_v<bool, T>) {
push(L, std::forward<Value>(value)); push(L, std::forward<Value>(value));
lua_seti(L, tableindex, static_cast<lua_Integer>(key)); lua_seti(L, tableindex, static_cast<lua_Integer>(key));

View File

@ -127,7 +127,7 @@ namespace sol { namespace stack {
} }
else if constexpr (std::is_integral_v<T> || std::is_same_v<T, lua_Integer>) { else if constexpr (std::is_integral_v<T> || std::is_same_v<T, lua_Integer>) {
tracking.use(1); tracking.use(1);
#if SOL_LUA_VERSION >= 503 #if SOL_LUA_VESION_I_ >= 503
if (lua_isinteger(L, index) != 0) { if (lua_isinteger(L, index) != 0) {
return static_cast<T>(lua_tointeger(L, index)); return static_cast<T>(lua_tointeger(L, index));
} }
@ -326,7 +326,7 @@ namespace sol { namespace stack {
int index = lua_absindex(L, relindex); int index = lua_absindex(L, relindex);
T cont; T cont;
std::size_t idx = 0; std::size_t idx = 0;
#if SOL_LUA_VERSION >= 503 #if SOL_LUA_VESION_I_ >= 503
// This method is HIGHLY performant over regular table iteration // This method is HIGHLY performant over regular table iteration
// thanks to the Lua API changes in 5.3 // thanks to the Lua API changes in 5.3
// Questionable in 5.4 // Questionable in 5.4
@ -337,7 +337,7 @@ namespace sol { namespace stack {
} }
bool isnil = false; bool isnil = false;
for (int vi = 0; vi < lua_size<V>::value; ++vi) { for (int vi = 0; vi < lua_size<V>::value; ++vi) {
#if defined(LUA_NILINTABLE) && LUA_NILINTABLE && SOL_LUA_VERSION >= 600 #if defined(LUA_NILINTABLE) && LUA_NILINTABLE && SOL_LUA_VESION_I_ >= 600
#if SOL_IS_ON(SOL_SAFE_STACK_CHECK_I_) #if SOL_IS_ON(SOL_SAFE_STACK_CHECK_I_)
luaL_checkstack(L, 1, detail::not_enough_stack_space_generic); luaL_checkstack(L, 1, detail::not_enough_stack_space_generic);
#endif // make sure stack doesn't overflow #endif // make sure stack doesn't overflow
@ -358,7 +358,7 @@ namespace sol { namespace stack {
if (i == 0) { if (i == 0) {
break; break;
} }
#if defined(LUA_NILINTABLE) && LUA_NILINTABLE && SOL_LUA_VERSION >= 600 #if defined(LUA_NILINTABLE) && LUA_NILINTABLE && SOL_LUA_VESION_I_ >= 600
lua_pop(L, vi); lua_pop(L, vi);
#else #else
lua_pop(L, (vi + 1)); lua_pop(L, (vi + 1));
@ -368,7 +368,7 @@ namespace sol { namespace stack {
} }
} }
if (isnil) { if (isnil) {
#if defined(LUA_NILINTABLE) && LUA_NILINTABLE && SOL_LUA_VERSION >= 600 #if defined(LUA_NILINTABLE) && LUA_NILINTABLE && SOL_LUA_VESION_I_ >= 600
#else #else
lua_pop(L, lua_size<V>::value); lua_pop(L, lua_size<V>::value);
#endif #endif
@ -476,7 +476,7 @@ namespace sol { namespace stack {
C cont; C cont;
auto at = cont.cbefore_begin(); auto at = cont.cbefore_begin();
std::size_t idx = 0; std::size_t idx = 0;
#if SOL_LUA_VERSION >= 503 #if SOL_LUA_VESION_I_ >= 503
// This method is HIGHLY performant over regular table iteration thanks to the Lua API changes in 5.3 // This method is HIGHLY performant over regular table iteration thanks to the Lua API changes in 5.3
for (lua_Integer i = 0;; i += lua_size<V>::value, lua_pop(L, lua_size<V>::value)) { for (lua_Integer i = 0;; i += lua_size<V>::value, lua_pop(L, lua_size<V>::value)) {
if (idx >= cont.max_size()) { if (idx >= cont.max_size()) {

View File

@ -83,7 +83,7 @@ namespace sol { namespace stack {
#if SOL_IS_ON(SOL_SAFE_STACK_CHECK_I_) #if SOL_IS_ON(SOL_SAFE_STACK_CHECK_I_)
luaL_checkstack(L, 1, detail::not_enough_stack_space_environment); luaL_checkstack(L, 1, detail::not_enough_stack_space_environment);
#endif // make sure stack doesn't overflow #endif // make sure stack doesn't overflow
#if SOL_LUA_VERSION < 502 #if SOL_LUA_VESION_I_ < 502
// Use lua_getfenv // Use lua_getfenv
lua_getfenv(L, index); lua_getfenv(L, index);
#else #else
@ -265,13 +265,13 @@ namespace sol { namespace stack {
#if SOL_IS_ON(SOL_SAFE_STACK_CHECK_I_) #if SOL_IS_ON(SOL_SAFE_STACK_CHECK_I_)
luaL_checkstack(L, 1, detail::not_enough_stack_space_integral); luaL_checkstack(L, 1, detail::not_enough_stack_space_integral);
#endif // make sure stack doesn't overflow #endif // make sure stack doesn't overflow
#if SOL_LUA_VERSION >= 503 #if SOL_LUA_VESION_I_ >= 503
if (stack_detail::integer_value_fits<Tu>(value)) { if (stack_detail::integer_value_fits<Tu>(value)) {
lua_pushinteger(L, static_cast<lua_Integer>(value)); lua_pushinteger(L, static_cast<lua_Integer>(value));
return 1; return 1;
} }
#endif // Lua 5.3 and above #endif // Lua 5.3 and above
#if (defined(SOL_SAFE_NUMERICS) && SOL_SAFE_NUMERICS) && !(defined(SOL_NO_CHECK_NUMBER_PRECISION) && SOL_NO_CHECK_NUMBER_PRECISION) #if SOL_IS_ON(SOL_NUMBER_PRECISION_CHECKS_I_)
if (static_cast<T>(llround(static_cast<lua_Number>(value))) != value) { if (static_cast<T>(llround(static_cast<lua_Number>(value))) != value) {
#if SOL_IS_OFF(SOL_EXCEPTIONS_I_) #if SOL_IS_OFF(SOL_EXCEPTIONS_I_)
// Is this really worth it? // Is this really worth it?
@ -297,7 +297,7 @@ namespace sol { namespace stack {
luaL_Stream* source { std::forward<Args>(args)... }; luaL_Stream* source { std::forward<Args>(args)... };
luaL_Stream* stream = static_cast<luaL_Stream*>(lua_newuserdata(L, sizeof(luaL_Stream))); luaL_Stream* stream = static_cast<luaL_Stream*>(lua_newuserdata(L, sizeof(luaL_Stream)));
stream->f = source->f; stream->f = source->f;
#if !defined(SOL_LUAJIT) && (SOL_LUA_VERSION > 501) #if SOL_IS_ON(SOL_LUAL_STREAM_USE_CLOSE_FUNCTION_I_)
stream->closef = source->closef; stream->closef = source->closef;
#endif // LuaJIT and Lua 5.1 and below do not have #endif // LuaJIT and Lua 5.1 and below do not have
return 1; return 1;
@ -306,7 +306,7 @@ namespace sol { namespace stack {
luaL_Stream& source(std::forward<Args>(args)...); luaL_Stream& source(std::forward<Args>(args)...);
luaL_Stream* stream = static_cast<luaL_Stream*>(lua_newuserdata(L, sizeof(luaL_Stream))); luaL_Stream* stream = static_cast<luaL_Stream*>(lua_newuserdata(L, sizeof(luaL_Stream)));
stream->f = source.f; stream->f = source.f;
#if !defined(SOL_LUAJIT) && (SOL_LUA_VERSION > 501) #if SOL_IS_ON(SOL_LUAL_STREAM_USE_CLOSE_FUNCTION_I_)
stream->closef = source.closef; stream->closef = source.closef;
#endif // LuaJIT and Lua 5.1 and below do not have #endif // LuaJIT and Lua 5.1 and below do not have
return 1; return 1;
@ -376,7 +376,7 @@ namespace sol { namespace stack {
int tableindex = lua_gettop(L); int tableindex = lua_gettop(L);
std::size_t index = 1; std::size_t index = 1;
for (const auto& i : cont) { for (const auto& i : cont) {
#if SOL_LUA_VERSION >= 503 #if SOL_LUA_VESION_I_ >= 503
int p = is_nested ? stack::push(L, as_nested_ref(i)) : stack::push(L, i); int p = is_nested ? stack::push(L, as_nested_ref(i)) : stack::push(L, i);
for (int pi = 0; pi < p; ++pi) { for (int pi = 0; pi < p; ++pi) {
lua_seti(L, tableindex, static_cast<lua_Integer>(index++)); lua_seti(L, tableindex, static_cast<lua_Integer>(index++));

View File

@ -37,7 +37,7 @@
namespace sol { namespace sol {
inline void register_main_thread(lua_State* L) { inline void register_main_thread(lua_State* L) {
#if SOL_LUA_VERSION < 502 #if SOL_LUA_VESION_I_ < 502
if (L == nullptr) { if (L == nullptr) {
lua_pushnil(L); lua_pushnil(L);
lua_setglobal(L, detail::default_main_thread_name()); lua_setglobal(L, detail::default_main_thread_name());
@ -120,7 +120,7 @@ namespace sol {
std::string err = "sol: "; std::string err = "sol: ";
err += to_string(result.status()); err += to_string(result.status());
err += " error"; err += " error";
#if !(defined(SOL_NO_EXCEPTIONS) && SOL_NO_EXCEPTIONS) #if SOL_IS_ON(SOL_EXCEPTIONS_I_)
std::exception_ptr eptr = std::current_exception(); std::exception_ptr eptr = std::current_exception();
if (eptr) { if (eptr) {
err += " with a "; err += " with a ";

View File

@ -46,7 +46,7 @@ namespace sol {
bool is53mod = loaded && !(loaded->is<bool>() && !loaded->as<bool>()); bool is53mod = loaded && !(loaded->is<bool>() && !loaded->as<bool>());
if (is53mod) if (is53mod)
return loaded; return loaded;
#if SOL_LUA_VERSION <= 501 #if SOL_LUA_VESION_I_ <= 501
auto loaded51 = global.traverse_get<optional<object>>("package", "loaded", key); auto loaded51 = global.traverse_get<optional<object>>("package", "loaded", key);
bool is51mod = loaded51 && !(loaded51->is<bool>() && !loaded51->as<bool>()); bool is51mod = loaded51 && !(loaded51->is<bool>() && !loaded51->as<bool>());
if (is51mod) if (is51mod)
@ -57,7 +57,7 @@ namespace sol {
template <typename T> template <typename T>
void ensure_package(const std::string& key, T&& sr) { void ensure_package(const std::string& key, T&& sr) {
#if SOL_LUA_VERSION <= 501 #if SOL_LUA_VESION_I_ <= 501
auto pkg = global["package"]; auto pkg = global["package"];
if (!pkg.valid()) { if (!pkg.valid()) {
pkg = create_table_with("loaded", create_table_with(key, sr)); pkg = create_table_with("loaded", create_table_with(key, sr));
@ -120,7 +120,7 @@ namespace sol {
for (auto&& library : libraries) { for (auto&& library : libraries) {
switch (library) { switch (library) {
#if SOL_LUA_VERSION <= 501 && defined(SOL_LUAJIT) #if SOL_LUA_VESION_I_ <= 501 && defined(SOL_LUAJIT)
case lib::coroutine: case lib::coroutine:
#endif // luajit opens coroutine base stuff #endif // luajit opens coroutine base stuff
case lib::base: case lib::base:
@ -133,7 +133,7 @@ namespace sol {
break; break;
#if !defined(SOL_LUAJIT) #if !defined(SOL_LUAJIT)
case lib::coroutine: case lib::coroutine:
#if SOL_LUA_VERSION > 501 #if SOL_LUA_VESION_I_ > 501
luaL_requiref(L, "coroutine", luaopen_coroutine, 1); luaL_requiref(L, "coroutine", luaopen_coroutine, 1);
lua_pop(L, 1); lua_pop(L, 1);
#endif // Lua 5.2+ only #endif // Lua 5.2+ only
@ -155,7 +155,7 @@ namespace sol {
#ifdef SOL_LUAJIT #ifdef SOL_LUAJIT
luaL_requiref(L, "bit32", luaopen_bit, 1); luaL_requiref(L, "bit32", luaopen_bit, 1);
lua_pop(L, 1); lua_pop(L, 1);
#elif (SOL_LUA_VERSION == 502) || defined(LUA_COMPAT_BITLIB) || defined(LUA_COMPAT_5_2) #elif (SOL_LUA_VESION_I_ == 502) || defined(LUA_COMPAT_BITLIB) || defined(LUA_COMPAT_5_2)
luaL_requiref(L, "bit32", luaopen_bit32, 1); luaL_requiref(L, "bit32", luaopen_bit32, 1);
lua_pop(L, 1); lua_pop(L, 1);
#else #else
@ -174,7 +174,7 @@ namespace sol {
lua_pop(L, 1); lua_pop(L, 1);
break; break;
case lib::utf8: case lib::utf8:
#if SOL_LUA_VERSION > 502 && !defined(SOL_LUAJIT) #if SOL_LUA_VESION_I_ > 502 && !defined(SOL_LUAJIT)
luaL_requiref(L, "utf8", luaopen_utf8, 1); luaL_requiref(L, "utf8", luaopen_utf8, 1);
lua_pop(L, 1); lua_pop(L, 1);
#endif // Lua 5.3+ only #endif // Lua 5.3+ only
@ -227,7 +227,7 @@ namespace sol {
// one day Lua 5.1 will die a peaceful death // one day Lua 5.1 will die a peaceful death
// and its old bones will find blissful rest // and its old bones will find blissful rest
auto loaders_proxy = package auto loaders_proxy = package
#if SOL_LUA_VERSION < 502 #if SOL_LUA_VESION_I_ < 502
["loaders"] ["loaders"]
#else #else
["searchers"] ["searchers"]
@ -255,7 +255,7 @@ namespace sol {
// one day Lua 5.1 will die a peaceful death // one day Lua 5.1 will die a peaceful death
// and its old bones will find blissful rest // and its old bones will find blissful rest
auto loaders_proxy = package auto loaders_proxy = package
#if SOL_LUA_VERSION < 502 #if SOL_LUA_VESION_I_ < 502
["loaders"] ["loaders"]
#else #else
["searchers"] ["searchers"]
@ -638,7 +638,7 @@ namespace sol {
} }
bool supports_gc_mode(gc_mode mode) const noexcept { bool supports_gc_mode(gc_mode mode) const noexcept {
#if SOL_LUA_VERSION >= 504 #if SOL_LUA_VESION_I_ >= 504
// supports all modes // supports all modes
(void)mode; (void)mode;
return true; return true;
@ -647,7 +647,12 @@ namespace sol {
} }
bool is_gc_on() const { bool is_gc_on() const {
#if SOL_LUA_VESION_I_ >= 502
return lua_gc(lua_state(), LUA_GCISRUNNING, 0) == 1; return lua_gc(lua_state(), LUA_GCISRUNNING, 0) == 1;
#else
// You cannot turn it off in Lua 5.1
return true;
#endif
} }
void collect_garbage() { void collect_garbage() {
@ -662,7 +667,7 @@ namespace sol {
// THOUGHT: std::chrono-alikes to map "kilobyte size" here...? // THOUGHT: std::chrono-alikes to map "kilobyte size" here...?
// Make it harder to give MB or KB to a B parameter...? // Make it harder to give MB or KB to a B parameter...?
// Probably overkill for now. // Probably overkill for now.
#if SOL_LUA_VERSION >= 504 #if SOL_LUA_VESION_I_ >= 504
// The manual implies that this function is almost always successful... // The manual implies that this function is almost always successful...
// is it?? It could depend on the GC mode... // is it?? It could depend on the GC mode...
return lua_gc(lua_state(), LUA_GCSTEP, step_size_kilobytes) != 0; return lua_gc(lua_state(), LUA_GCSTEP, step_size_kilobytes) != 0;
@ -687,7 +692,7 @@ namespace sol {
// THOUGHT: std::chrono-alikes to map "byte size" here...? // THOUGHT: std::chrono-alikes to map "byte size" here...?
// Make it harder to give MB or KB to a B parameter...? // Make it harder to give MB or KB to a B parameter...?
// Probably overkill for now. // Probably overkill for now.
#if SOL_LUA_VERSION >= 504 #if SOL_LUA_VESION_I_ >= 504
int old_mode = lua_gc(lua_state(), LUA_GCINC, pause, step_multiplier, step_byte_size); int old_mode = lua_gc(lua_state(), LUA_GCINC, pause, step_multiplier, step_byte_size);
if (old_mode == LUA_GCGEN) { if (old_mode == LUA_GCGEN) {
return gc_mode::generational; return gc_mode::generational;
@ -705,7 +710,7 @@ namespace sol {
// Returns the old GC mode. Check support using the supports_gc_mode function. // Returns the old GC mode. Check support using the supports_gc_mode function.
gc_mode change_gc_mode_generational(int minor_multiplier, int major_multiplier) { gc_mode change_gc_mode_generational(int minor_multiplier, int major_multiplier) {
#if SOL_LUA_VERSION >= 504 #if SOL_LUA_VESION_I_ >= 504
// "What does this shit mean?" // "What does this shit mean?"
// http://www.lua.org/manual/5.4/manual.html#2.5.2 // http://www.lua.org/manual/5.4/manual.html#2.5.2
int old_mode = lua_gc(lua_state(), LUA_GCGEN, minor_multiplier, major_multiplier); int old_mode = lua_gc(lua_state(), LUA_GCGEN, minor_multiplier, major_multiplier);

View File

@ -37,10 +37,10 @@ namespace sol {
// must push a single object to be the error object // must push a single object to be the error object
// NOTE: the VAST MAJORITY of all Lua libraries -- C or otherwise -- expect a string for the type of error // NOTE: the VAST MAJORITY of all Lua libraries -- C or otherwise -- expect a string for the type of error
// break this convention at your own risk // break this convention at your own risk
using exception_handler_function = int(*)(lua_State*, optional<const std::exception&>, string_view); using exception_handler_function = int (*)(lua_State*, optional<const std::exception&>, string_view);
namespace detail { namespace detail {
inline const char(&default_exception_handler_name())[11]{ inline const char (&default_exception_handler_name())[11] {
static const char name[11] = "sol.\xE2\x98\xA2\xE2\x98\xA2"; static const char name[11] = "sol.\xE2\x98\xA2\xE2\x98\xA2";
return name; return name;
} }
@ -72,13 +72,13 @@ namespace sol {
return exfunc(L, std::move(maybe_ex), std::move(what)); return exfunc(L, std::move(maybe_ex), std::move(what));
} }
#ifdef SOL_NO_EXCEPTIONS #if SOL_IS_OFF(SOL_EXCEPTIONS_I_)
template <lua_CFunction f> template <lua_CFunction f>
int static_trampoline(lua_State* L) noexcept { int static_trampoline(lua_State* L) noexcept {
return f(L); return f(L);
} }
#ifdef SOL_NOEXCEPT_FUNCTION_TYPE #if SOL_IS_ON(SOL_USE_NOEXCEPT_FUNCTION_TYPE_I_)
template <lua_CFunction_noexcept f> template <lua_CFunction_noexcept f>
int static_trampoline_noexcept(lua_State* L) noexcept { int static_trampoline_noexcept(lua_State* L) noexcept {
return f(L); return f(L);
@ -100,8 +100,8 @@ namespace sol {
} }
#else #else
inline int impl_static_trampoline(lua_State* L, lua_CFunction f) { inline int lua_cfunction_trampoline(lua_State* L, lua_CFunction f) {
#if defined(SOL_EXCEPTIONS_SAFE_PROPAGATION) && !defined(SOL_LUAJIT) #if SOL_IS_ON(SOL_PROPAGATE_EXCEPTIONS_I_)
return f(L); return f(L);
#else #else
@ -117,7 +117,7 @@ namespace sol {
catch (const std::exception& e) { catch (const std::exception& e) {
call_exception_handler(L, optional<const std::exception&>(e), e.what()); call_exception_handler(L, optional<const std::exception&>(e), e.what());
} }
#if !defined(SOL_EXCEPTIONS_SAFE_PROPAGATION) #if SOL_IS_OFF(SOL_USE_LUAJIT_I_)
// LuaJIT cannot have the catchall when the safe propagation is on // LuaJIT cannot have the catchall when the safe propagation is on
// but LuaJIT will swallow all C++ errors // but LuaJIT will swallow all C++ errors
// if we don't at least catch std::exception ones // if we don't at least catch std::exception ones
@ -131,61 +131,53 @@ namespace sol {
template <lua_CFunction f> template <lua_CFunction f>
int static_trampoline(lua_State* L) { int static_trampoline(lua_State* L) {
return impl_static_trampoline(L, f); return lua_cfunction_trampoline(L, f);
} }
#ifdef SOL_NOEXCEPT_FUNCTION_TYPE #if SOL_IS_ON(SOL_USE_NOEXCEPT_FUNCTION_TYPE_I_)
#if 0
// impossible: g++/clang++ choke as they think this function is ambiguous:
// to fix, wait for template <auto X> and then switch on no-exceptness of the function
template <lua_CFunction_noexcept f>
int static_trampoline(lua_State* L) noexcept {
return f(L);
}
#else
template <lua_CFunction_noexcept f> template <lua_CFunction_noexcept f>
int static_trampoline_noexcept(lua_State* L) noexcept { int static_trampoline_noexcept(lua_State* L) noexcept {
return f(L); return f(L);
} }
#endif // impossible
#else #else
template <lua_CFunction f> template <lua_CFunction f>
int static_trampoline_noexcept(lua_State* L) noexcept { int static_trampoline_noexcept(lua_State* L) noexcept {
return f(L); return f(L);
} }
#endif // noexcept lua_CFunction type #endif
template <typename Fx, typename... Args> template <typename Fx, typename... Args>
int trampoline(lua_State* L, Fx&& f, Args&&... args) { int trampoline(lua_State* L, Fx&& f, Args&&... args) {
if (meta::bind_traits<meta::unqualified_t<Fx>>::is_noexcept) { if constexpr (meta::bind_traits<meta::unqualified_t<Fx>>::is_noexcept) {
return f(L, std::forward<Args>(args)...); return f(L, std::forward<Args>(args)...);
} }
#if defined(SOL_EXCEPTIONS_SAFE_PROPAGATION) && !defined(SOL_LUAJIT) else {
return f(L, std::forward<Args>(args)...); #if SOL_IS_ON(SOL_PROPAGATE_EXCEPTIONS_I_)
return f(L, std::forward<Args>(args)...);
#else #else
try { try {
return f(L, std::forward<Args>(args)...); return f(L, std::forward<Args>(args)...);
} }
catch (const char* cs) { catch (const char* cs) {
call_exception_handler(L, optional<const std::exception&>(nullopt), string_view(cs)); call_exception_handler(L, optional<const std::exception&>(nullopt), string_view(cs));
} }
catch (const std::string& s) { catch (const std::string& s) {
call_exception_handler(L, optional<const std::exception&>(nullopt), string_view(s.c_str(), s.size())); call_exception_handler(L, optional<const std::exception&>(nullopt), string_view(s.c_str(), s.size()));
} }
catch (const std::exception& e) { catch (const std::exception& e) {
call_exception_handler(L, optional<const std::exception&>(e), e.what()); call_exception_handler(L, optional<const std::exception&>(e), e.what());
} }
#if !defined(SOL_EXCEPTIONS_SAFE_PROPAGATION) #if SOL_IS_OFF(SOL_USE_LUAJIT_I_)
// LuaJIT cannot have the catchall when the safe propagation is on // LuaJIT cannot have the catchall when the safe propagation is on
// but LuaJIT will swallow all C++ errors // but LuaJIT will swallow all C++ errors
// if we don't at least catch std::exception ones // if we don't at least catch std::exception ones
catch (...) { catch (...) {
call_exception_handler(L, optional<const std::exception&>(nullopt), "caught (...) exception"); call_exception_handler(L, optional<const std::exception&>(nullopt), "caught (...) exception");
} }
#endif #endif
return lua_error(L); return lua_error(L);
#endif #endif
}
} }
inline int c_trampoline(lua_State* L, lua_CFunction f) { inline int c_trampoline(lua_State* L, lua_CFunction f) {
@ -193,29 +185,25 @@ namespace sol {
} }
#endif // Exceptions vs. No Exceptions #endif // Exceptions vs. No Exceptions
template <typename F, F fx>
inline int typed_static_trampoline_raw(std::true_type, lua_State* L) {
return static_trampoline_noexcept<fx>(L);
}
template <typename F, F fx>
inline int typed_static_trampoline_raw(std::false_type, lua_State* L) {
return static_trampoline<fx>(L);
}
template <typename F, F fx> template <typename F, F fx>
inline int typed_static_trampoline(lua_State* L) { inline int typed_static_trampoline(lua_State* L) {
return typed_static_trampoline_raw<F, fx>(std::integral_constant<bool, meta::bind_traits<F>::is_noexcept>(), L); if constexpr (meta::bind_traits<F>::is_noexcept) {
return static_trampoline_noexcept<fx>(L);
}
else {
return static_trampoline<fx>(L);
}
} }
} // namespace detail } // namespace detail
inline void set_default_exception_handler(lua_State* L, exception_handler_function exf = &detail::default_exception_handler) { inline void set_default_exception_handler(lua_State* L, exception_handler_function exf = &detail::default_exception_handler) {
static_assert(sizeof(void*) >= sizeof(exception_handler_function), "void* storage is too small to transport the exception handler: please file a bug on the issue tracker"); static_assert(sizeof(void*) >= sizeof(exception_handler_function),
"void* storage is too small to transport the exception handler: please file a bug on the sol2 issue tracker to get this looked at!");
void* storage; void* storage;
std::memcpy(&storage, &exf, sizeof(exception_handler_function)); std::memcpy(&storage, &exf, sizeof(exception_handler_function));
lua_pushlightuserdata(L, storage); lua_pushlightuserdata(L, storage);
lua_setglobal(L, detail::default_exception_handler_name()); lua_setglobal(L, detail::default_exception_handler_name());
} }
} // sol } // namespace sol
#endif // SOL_TRAMPOLINE_HPP #endif // SOL_TRAMPOLINE_HPP

View File

@ -50,20 +50,25 @@ namespace sol {
typedef std::reverse_iterator<iterator> reverse_iterator; typedef std::reverse_iterator<iterator> reverse_iterator;
typedef std::reverse_iterator<const_iterator> const_reverse_iterator; typedef std::reverse_iterator<const_iterator> const_reverse_iterator;
unsafe_function_result() = default; unsafe_function_result() noexcept = default;
unsafe_function_result(lua_State* Ls, int idx = -1, int retnum = 0) unsafe_function_result(lua_State* Ls, int idx = -1, int retnum = 0) noexcept : L(Ls), index(idx), returncount(retnum) {
: L(Ls), index(idx), returncount(retnum) {
} }
unsafe_function_result(const unsafe_function_result&) = default;
unsafe_function_result& operator=(const unsafe_function_result&) = default;
unsafe_function_result(unsafe_function_result&& o) // We do not want anyone to copy these around willy-nilly
: L(o.L), index(o.index), returncount(o.returncount) { // Will likely break people, but also will probably get rid of quiet bugs that have
// been lurking. (E.g., Vanilla Lua will just quietly discard over-pops and under-pops:
// LuaJIT and other Lua engines will implode and segfault at random later times.)
unsafe_function_result(const unsafe_function_result&) = delete;
unsafe_function_result& operator=(const unsafe_function_result&) = delete;
unsafe_function_result(unsafe_function_result&& o) noexcept : L(o.L), index(o.index), returncount(o.returncount) {
// Must be manual, otherwise destructor will screw us // Must be manual, otherwise destructor will screw us
// return count being 0 is enough to keep things clean // return count being 0 is enough to keep things clean
// but will be thorough // but will be thorough
o.abandon(); o.abandon();
} }
unsafe_function_result& operator=(unsafe_function_result&& o) { unsafe_function_result& operator=(unsafe_function_result&& o) noexcept {
L = o.L; L = o.L;
index = o.index; index = o.index;
returncount = o.returncount; returncount = o.returncount;
@ -148,7 +153,7 @@ namespace sol {
return returncount; return returncount;
}; };
void abandon() noexcept { void abandon() noexcept {
//L = nullptr; // L = nullptr;
index = 0; index = 0;
returncount = 0; returncount = 0;
} }

View File

@ -68,6 +68,12 @@
#define SOL_COMPILER_VCXX_I_ SOL_OFF #define SOL_COMPILER_VCXX_I_ SOL_OFF
#endif #endif
#if defined(__MINGW32__)
#define SOL_COMPILER_FRONTEND_MINGW_I_ SOL_ON
#else
#define SOL_COMPILER_FRONTEND_MINGW_I_ SOL_OFF
#endif
#if SIZE_MAX <= 0xFFFFULL #if SIZE_MAX <= 0xFFFFULL
#define SOL_PLATFORM_X16_I_ SOL_ON #define SOL_PLATFORM_X16_I_ SOL_ON
#define SOL_PLATFORM_X86_I_ SOL_OFF #define SOL_PLATFORM_X86_I_ SOL_OFF
@ -125,7 +131,7 @@
#define SOL_DEBUG_BUILD_I_ SOL_OFF #define SOL_DEBUG_BUILD_I_ SOL_OFF
#endif #endif
#else #else
#define SOL_DEBUG_BUILD_I_ SOL_OFF #define SOL_DEBUG_BUILD_I_ SOL_DEFAULT_OFF
#endif // We are in a debug mode of some sort #endif // We are in a debug mode of some sort
#if defined(SOL_NO_EXCEPTIONS) #if defined(SOL_NO_EXCEPTIONS)
@ -147,7 +153,7 @@
#define SOL_EXCEPTIONS_I_ SOL_ON #define SOL_EXCEPTIONS_I_ SOL_ON
#endif #endif
#else #else
#define SOL_EXCEPTIONS_I_ SOL_ON #define SOL_EXCEPTIONS_I_ SOL_DEFAULT_ON
#endif #endif
@ -170,7 +176,7 @@
#define SOL_RTTI_I_ SOL_ON #define SOL_RTTI_I_ SOL_ON
#endif #endif
#else #else
#define SOL_EXCEPTIONS_I_ SOL_ON #define SOL_RTTI_I_ SOL_DEFAULT_ON
#endif #endif
#if defined(SOL_NO_THREAD_LOCAL) && (SOL_NO_THREAD_LOCAL != 0) #if defined(SOL_NO_THREAD_LOCAL) && (SOL_NO_THREAD_LOCAL != 0)
@ -182,7 +188,7 @@
#if defined(SOL_ALL_SAFETIES_ON) && (SOL_ALL_SAFETIES_ON != 0) #if defined(SOL_ALL_SAFETIES_ON) && (SOL_ALL_SAFETIES_ON != 0)
#define SOL_ALL_SAFETIES_ON_I_ SOL_ON #define SOL_ALL_SAFETIES_ON_I_ SOL_ON
#else #else
#define SOL_ALL_SAFETIES_ON_I_ SOL_OFF #define SOL_ALL_SAFETIES_ON_I_ SOL_DEFAULT_OFF
#endif #endif
#if defined(SOL_SAFE_GETTER) && (SOL_SAFE_GETTER != 0) #if defined(SOL_SAFE_GETTER) && (SOL_SAFE_GETTER != 0)
@ -193,7 +199,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_GETTER_I_ SOL_DEFAULT_ON #define SOL_SAFE_GETTER_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_GETTER_I_ SOL_OFF #define SOL_SAFE_GETTER_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -205,7 +211,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_USERTYPE_I_ SOL_DEFAULT_ON #define SOL_SAFE_USERTYPE_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_USERTYPE_I_ SOL_OFF #define SOL_SAFE_USERTYPE_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -217,7 +223,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_REFERENCES_I_ SOL_DEFAULT_ON #define SOL_SAFE_REFERENCES_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_REFERENCES_I_ SOL_OFF #define SOL_SAFE_REFERENCES_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -230,7 +236,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_FUNCTION_OBJECTS_I_ SOL_DEFAULT_ON #define SOL_SAFE_FUNCTION_OBJECTS_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_FUNCTION_OBJECTS_I_ SOL_OFF #define SOL_SAFE_FUNCTION_OBJECTS_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -242,7 +248,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_FUNCTION_CALLS_I_ SOL_DEFAULT_ON #define SOL_SAFE_FUNCTION_CALLS_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_FUNCTION_CALLS_I_ SOL_OFF #define SOL_SAFE_FUNCTION_CALLS_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -254,7 +260,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_PROXIES_I_ SOL_DEFAULT_ON #define SOL_SAFE_PROXIES_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_PROXIES_I_ SOL_OFF #define SOL_SAFE_PROXIES_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -266,7 +272,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_NUMERICS_I_ SOL_DEFAULT_ON #define SOL_SAFE_NUMERICS_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_NUMERICS_I_ SOL_OFF #define SOL_SAFE_NUMERICS_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -278,7 +284,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_STACK_CHECK_I_ SOL_DEFAULT_ON #define SOL_SAFE_STACK_CHECK_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_STACK_CHECK_I_ SOL_OFF #define SOL_SAFE_STACK_CHECK_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -288,10 +294,12 @@
#else #else
#if SOL_IS_ON(SOL_ALL_SAFETIES_ON_I_) #if SOL_IS_ON(SOL_ALL_SAFETIES_ON_I_)
#define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_ON #define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_ON
#elif SOL_IS_ON(SOL_SAFE_NUMERICS_I_)
#define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_ON
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_DEFAULT_ON #define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_DEFAULT_ON
#else #else
#define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_OFF #define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -302,14 +310,14 @@
#define SOL_STRINGS_ARE_NUMBERS_I_ SOL_OFF #define SOL_STRINGS_ARE_NUMBERS_I_ SOL_OFF
#endif #endif
#else #else
#define SOL_STRINGS_ARE_NUMBERS_I_ SOL_OFF #define SOL_STRINGS_ARE_NUMBERS_I_ SOL_DEFAULT_OFF
#endif #endif
#if defined(SOL_ENABLE_INTEROP) && (SOL_ENABLE_INTEROP != 0) \ #if defined(SOL_ENABLE_INTEROP) && (SOL_ENABLE_INTEROP != 0) \
|| defined(SOL_USE_INTEROP) && (SOL_USE_INTEROP != 0) || defined(SOL_USE_INTEROP) && (SOL_USE_INTEROP != 0)
#define SOL_USE_INTEROP_I_ SOL_ON #define SOL_USE_INTEROP_I_ SOL_ON
#else #else
#define SOL_USE_INTEROP_I_ SOL_OFF #define SOL_USE_INTEROP_I_ SOL_DEFAULT_OFF
#endif #endif
#if defined(SOL_NO_NIL) #if defined(SOL_NO_NIL)
@ -319,7 +327,7 @@
#define SOL_NIL_I_ SOL_ON #define SOL_NIL_I_ SOL_ON
#endif #endif
#elif defined(__MAC_OS_X_VERSION_MAX_ALLOWED) || defined(__OBJC__) || defined(nil) #elif defined(__MAC_OS_X_VERSION_MAX_ALLOWED) || defined(__OBJC__) || defined(nil)
#define SOL_NIL_I_ SOL_OFF #define SOL_NIL_I_ SOL_DEFAULT_OFF
#else #else
#define SOL_NIL_I_ SOL_DEFAULT_ON #define SOL_NIL_I_ SOL_DEFAULT_ON
#endif #endif
@ -413,8 +421,12 @@
#define SOL_FILE_ID_SIZE_I_ 2048 #define SOL_FILE_ID_SIZE_I_ 2048
#endif #endif
#if defined(SOL_PRINT_ERRORS) && (SOL_PRINT_ERRORS != 0) #if defined(SOL_PRINT_ERRORS)
#define SOL_PRINT_ERRORS_I_ SOL_ON #if (SOL_PRINT_ERRORS != 0)
#define SOL_PRINT_ERRORS_I_ SOL_ON
#else
#define SOL_PRINT_ERRORS_I_ SOL_OFF
#endif
#else #else
#if SOL_IS_ON(SOL_ALL_SAFETIES_ON_I_) #if SOL_IS_ON(SOL_ALL_SAFETIES_ON_I_)
#define SOL_PRINT_ERRORS_I_ SOL_ON #define SOL_PRINT_ERRORS_I_ SOL_ON
@ -526,6 +538,37 @@
#else #else
#define SOL_USE_UNSAFE_BASE_LOOKUP_I_ SOL_OFF #define SOL_USE_UNSAFE_BASE_LOOKUP_I_ SOL_OFF
#endif #endif
#if defined(SOL_INSIDE_UNREAL)
#if (SOL_INSIDE_UNREAL != 0)
#define SOL_INSIDE_UNREAL_ENGINE_I_ SOL_ON
#else
#define SOL_INSIDE_UNREAL_ENGINE_I_ SOL_OFF
#endif
#else
#if defined(UE_BUILD_DEBUG) || defined(UE_BUILD_DEVELOPMENT) || defined(UE_BUILD_TEST) || defined(UE_BUILD_SHIPPING) || defined(UE_SERVER)
#define SOL_INSIDE_UNREAL_ENGINE_I_ SOL_ON
#else
#define SOL_INSIDE_UNREAL_ENGINE_I_ SOL_DEFAULT_OFF
#endif
#endif
#if defined(SOL_NO_COMPAT)
#if (SOL_NO_COMPAT != 0)
#define SOL_USE_COMPATIBILITY_LAYER_I_ SOL_OFF
#else
#define SOL_USE_COMPATIBILITY_LAYER_I_ SOL_ON
#endif
#else
#define SOL_USE_COMPATIBILITY_LAYER_I_ SOL_DEFAULT_ON
#endif
#if SOL_IS_ON(SOL_COMPILER_FRONTEND_MINGW_I_) && defined(__GNUC__) && (__GNUC__ < 6)
// MinGW is off its rocker in some places...
#define SOL_MINGW_CCTYPE_IS_POISONED_I_ SOL_ON
#else
#define SOL_MINGW_CCTYPE_IS_POISONED_I_ SOL_DEFAULT_OFF
#endif
// clang-format on // clang-format on
#endif // SOL_VERSION_HPP #endif // SOL_VERSION_HPP

View File

@ -20,8 +20,8 @@
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
// This file was generated with a script. // This file was generated with a script.
// Generated 2020-09-09 00:46:22.609996 UTC // Generated 2020-09-26 10:44:02.641191 UTC
// This header was generated with sol v3.2.1 (revision e4f588d) // This header was generated with sol v3.2.1 (revision e89b6ac)
// https://github.com/ThePhD/sol2 // https://github.com/ThePhD/sol2
#ifndef SOL_SINGLE_CONFIG_HPP #ifndef SOL_SINGLE_CONFIG_HPP

View File

@ -20,8 +20,8 @@
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
// This file was generated with a script. // This file was generated with a script.
// Generated 2020-09-09 00:46:22.606997 UTC // Generated 2020-09-26 10:44:02.626193 UTC
// This header was generated with sol v3.2.1 (revision e4f588d) // This header was generated with sol v3.2.1 (revision e89b6ac)
// https://github.com/ThePhD/sol2 // https://github.com/ThePhD/sol2
#ifndef SOL_SINGLE_INCLUDE_FORWARD_HPP #ifndef SOL_SINGLE_INCLUDE_FORWARD_HPP
@ -76,6 +76,12 @@
#define SOL_COMPILER_VCXX_I_ SOL_OFF #define SOL_COMPILER_VCXX_I_ SOL_OFF
#endif #endif
#if defined(__MINGW32__)
#define SOL_COMPILER_FRONTEND_MINGW_I_ SOL_ON
#else
#define SOL_COMPILER_FRONTEND_MINGW_I_ SOL_OFF
#endif
#if SIZE_MAX <= 0xFFFFULL #if SIZE_MAX <= 0xFFFFULL
#define SOL_PLATFORM_X16_I_ SOL_ON #define SOL_PLATFORM_X16_I_ SOL_ON
#define SOL_PLATFORM_X86_I_ SOL_OFF #define SOL_PLATFORM_X86_I_ SOL_OFF
@ -132,7 +138,7 @@
#define SOL_DEBUG_BUILD_I_ SOL_OFF #define SOL_DEBUG_BUILD_I_ SOL_OFF
#endif #endif
#else #else
#define SOL_DEBUG_BUILD_I_ SOL_OFF #define SOL_DEBUG_BUILD_I_ SOL_DEFAULT_OFF
#endif // We are in a debug mode of some sort #endif // We are in a debug mode of some sort
#if defined(SOL_NO_EXCEPTIONS) #if defined(SOL_NO_EXCEPTIONS)
@ -154,7 +160,7 @@
#define SOL_EXCEPTIONS_I_ SOL_ON #define SOL_EXCEPTIONS_I_ SOL_ON
#endif #endif
#else #else
#define SOL_EXCEPTIONS_I_ SOL_ON #define SOL_EXCEPTIONS_I_ SOL_DEFAULT_ON
#endif #endif
#if defined(SOL_NO_RTTI) #if defined(SOL_NO_RTTI)
@ -176,7 +182,7 @@
#define SOL_RTTI_I_ SOL_ON #define SOL_RTTI_I_ SOL_ON
#endif #endif
#else #else
#define SOL_EXCEPTIONS_I_ SOL_ON #define SOL_RTTI_I_ SOL_DEFAULT_ON
#endif #endif
#if defined(SOL_NO_THREAD_LOCAL) && (SOL_NO_THREAD_LOCAL != 0) #if defined(SOL_NO_THREAD_LOCAL) && (SOL_NO_THREAD_LOCAL != 0)
@ -188,7 +194,7 @@
#if defined(SOL_ALL_SAFETIES_ON) && (SOL_ALL_SAFETIES_ON != 0) #if defined(SOL_ALL_SAFETIES_ON) && (SOL_ALL_SAFETIES_ON != 0)
#define SOL_ALL_SAFETIES_ON_I_ SOL_ON #define SOL_ALL_SAFETIES_ON_I_ SOL_ON
#else #else
#define SOL_ALL_SAFETIES_ON_I_ SOL_OFF #define SOL_ALL_SAFETIES_ON_I_ SOL_DEFAULT_OFF
#endif #endif
#if defined(SOL_SAFE_GETTER) && (SOL_SAFE_GETTER != 0) #if defined(SOL_SAFE_GETTER) && (SOL_SAFE_GETTER != 0)
@ -199,7 +205,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_GETTER_I_ SOL_DEFAULT_ON #define SOL_SAFE_GETTER_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_GETTER_I_ SOL_OFF #define SOL_SAFE_GETTER_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -211,7 +217,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_USERTYPE_I_ SOL_DEFAULT_ON #define SOL_SAFE_USERTYPE_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_USERTYPE_I_ SOL_OFF #define SOL_SAFE_USERTYPE_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -223,7 +229,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_REFERENCES_I_ SOL_DEFAULT_ON #define SOL_SAFE_REFERENCES_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_REFERENCES_I_ SOL_OFF #define SOL_SAFE_REFERENCES_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -236,7 +242,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_FUNCTION_OBJECTS_I_ SOL_DEFAULT_ON #define SOL_SAFE_FUNCTION_OBJECTS_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_FUNCTION_OBJECTS_I_ SOL_OFF #define SOL_SAFE_FUNCTION_OBJECTS_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -248,7 +254,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_FUNCTION_CALLS_I_ SOL_DEFAULT_ON #define SOL_SAFE_FUNCTION_CALLS_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_FUNCTION_CALLS_I_ SOL_OFF #define SOL_SAFE_FUNCTION_CALLS_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -260,7 +266,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_PROXIES_I_ SOL_DEFAULT_ON #define SOL_SAFE_PROXIES_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_PROXIES_I_ SOL_OFF #define SOL_SAFE_PROXIES_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -272,7 +278,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_NUMERICS_I_ SOL_DEFAULT_ON #define SOL_SAFE_NUMERICS_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_NUMERICS_I_ SOL_OFF #define SOL_SAFE_NUMERICS_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -284,7 +290,7 @@
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_SAFE_STACK_CHECK_I_ SOL_DEFAULT_ON #define SOL_SAFE_STACK_CHECK_I_ SOL_DEFAULT_ON
#else #else
#define SOL_SAFE_STACK_CHECK_I_ SOL_OFF #define SOL_SAFE_STACK_CHECK_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -294,10 +300,12 @@
#else #else
#if SOL_IS_ON(SOL_ALL_SAFETIES_ON_I_) #if SOL_IS_ON(SOL_ALL_SAFETIES_ON_I_)
#define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_ON #define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_ON
#elif SOL_IS_ON(SOL_SAFE_NUMERICS_I_)
#define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_ON
#elif SOL_IS_ON(SOL_DEBUG_BUILD_I_) #elif SOL_IS_ON(SOL_DEBUG_BUILD_I_)
#define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_DEFAULT_ON #define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_DEFAULT_ON
#else #else
#define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_OFF #define SOL_NUMBER_PRECISION_CHECKS_I_ SOL_DEFAULT_OFF
#endif #endif
#endif #endif
@ -308,14 +316,14 @@
#define SOL_STRINGS_ARE_NUMBERS_I_ SOL_OFF #define SOL_STRINGS_ARE_NUMBERS_I_ SOL_OFF
#endif #endif
#else #else
#define SOL_STRINGS_ARE_NUMBERS_I_ SOL_OFF #define SOL_STRINGS_ARE_NUMBERS_I_ SOL_DEFAULT_OFF
#endif #endif
#if defined(SOL_ENABLE_INTEROP) && (SOL_ENABLE_INTEROP != 0) \ #if defined(SOL_ENABLE_INTEROP) && (SOL_ENABLE_INTEROP != 0) \
|| defined(SOL_USE_INTEROP) && (SOL_USE_INTEROP != 0) || defined(SOL_USE_INTEROP) && (SOL_USE_INTEROP != 0)
#define SOL_USE_INTEROP_I_ SOL_ON #define SOL_USE_INTEROP_I_ SOL_ON
#else #else
#define SOL_USE_INTEROP_I_ SOL_OFF #define SOL_USE_INTEROP_I_ SOL_DEFAULT_OFF
#endif #endif
#if defined(SOL_NO_NIL) #if defined(SOL_NO_NIL)
@ -325,7 +333,7 @@
#define SOL_NIL_I_ SOL_ON #define SOL_NIL_I_ SOL_ON
#endif #endif
#elif defined(__MAC_OS_X_VERSION_MAX_ALLOWED) || defined(__OBJC__) || defined(nil) #elif defined(__MAC_OS_X_VERSION_MAX_ALLOWED) || defined(__OBJC__) || defined(nil)
#define SOL_NIL_I_ SOL_OFF #define SOL_NIL_I_ SOL_DEFAULT_OFF
#else #else
#define SOL_NIL_I_ SOL_DEFAULT_ON #define SOL_NIL_I_ SOL_DEFAULT_ON
#endif #endif
@ -419,8 +427,12 @@
#define SOL_FILE_ID_SIZE_I_ 2048 #define SOL_FILE_ID_SIZE_I_ 2048
#endif #endif
#if defined(SOL_PRINT_ERRORS) && (SOL_PRINT_ERRORS != 0) #if defined(SOL_PRINT_ERRORS)
#define SOL_PRINT_ERRORS_I_ SOL_ON #if (SOL_PRINT_ERRORS != 0)
#define SOL_PRINT_ERRORS_I_ SOL_ON
#else
#define SOL_PRINT_ERRORS_I_ SOL_OFF
#endif
#else #else
#if SOL_IS_ON(SOL_ALL_SAFETIES_ON_I_) #if SOL_IS_ON(SOL_ALL_SAFETIES_ON_I_)
#define SOL_PRINT_ERRORS_I_ SOL_ON #define SOL_PRINT_ERRORS_I_ SOL_ON
@ -533,6 +545,37 @@
#define SOL_USE_UNSAFE_BASE_LOOKUP_I_ SOL_OFF #define SOL_USE_UNSAFE_BASE_LOOKUP_I_ SOL_OFF
#endif #endif
#if defined(SOL_INSIDE_UNREAL)
#if (SOL_INSIDE_UNREAL != 0)
#define SOL_INSIDE_UNREAL_ENGINE_I_ SOL_ON
#else
#define SOL_INSIDE_UNREAL_ENGINE_I_ SOL_OFF
#endif
#else
#if defined(UE_BUILD_DEBUG) || defined(UE_BUILD_DEVELOPMENT) || defined(UE_BUILD_TEST) || defined(UE_BUILD_SHIPPING) || defined(UE_SERVER)
#define SOL_INSIDE_UNREAL_ENGINE_I_ SOL_ON
#else
#define SOL_INSIDE_UNREAL_ENGINE_I_ SOL_DEFAULT_OFF
#endif
#endif
#if defined(SOL_NO_COMPAT)
#if (SOL_NO_COMPAT != 0)
#define SOL_USE_COMPATIBILITY_LAYER_I_ SOL_OFF
#else
#define SOL_USE_COMPATIBILITY_LAYER_I_ SOL_ON
#endif
#else
#define SOL_USE_COMPATIBILITY_LAYER_I_ SOL_DEFAULT_ON
#endif
#if SOL_IS_ON(SOL_COMPILER_FRONTEND_MINGW_I_) && defined(__GNUC__) && (__GNUC__ < 6)
// MinGW is off its rocker in some places...
#define SOL_MINGW_CCTYPE_IS_POISONED_I_ SOL_ON
#else
#define SOL_MINGW_CCTYPE_IS_POISONED_I_ SOL_DEFAULT_OFF
#endif
// end of sol/version.hpp // end of sol/version.hpp
#include <utility> #include <utility>

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,20 @@
#define SOL_ALL_SAFETIES_ON 1
#include <sol/sol.hpp>
struct foo1000 {
static void register_into(sol::table& table) {
table.new_usertype<foo1000>("foo1000", "id", sol::readonly(&foo1000::foo));
}
int foo;
};
int regression_1000() {
sol::state lua;
lua.create_named_table("t");
sol::table t = lua["t"];
foo1000::register_into(t);
return 0;
}

View File

@ -1,10 +1,11 @@
#include <cstddef> #include <cstddef>
extern int regression_1008(); extern int regression_1008();
extern int regression_1000();
int main(int, char*[]) { int main(int, char*[]) {
using f_ptr = int (*)(); using f_ptr = int (*)();
const f_ptr regressions[] = { &regression_1008 }; const f_ptr regressions[] = { &regression_1008, &regression_1000 };
const int sizeof_regressions = sizeof(regressions) / sizeof(regressions[0]); const int sizeof_regressions = sizeof(regressions) / sizeof(regressions[0]);
int r = 0; int r = 0;
for (std::size_t i = 0; i < sizeof_regressions; ++i) { for (std::size_t i = 0; i < sizeof_regressions; ++i) {

View File

@ -30,13 +30,12 @@
template <typename T> template <typename T>
T va_func(sol::variadic_args va, T first) { T va_func(sol::variadic_args va, T first) {
(void)first;
T s = 0; T s = 0;
for (auto arg : va) { for (auto arg : va) {
T v = arg; T v = arg;
s += v; s += v;
} }
std::cout << first << std::endl;
std::cout << s << std::endl;
return s; return s;
} }
@ -231,7 +230,7 @@ end )",
REQUIRE((bool)testv); REQUIRE((bool)testv);
REQUIRE_FALSE((bool)testn); REQUIRE_FALSE((bool)testn);
REQUIRE(testv.value() == 29); REQUIRE(testv.value() == 29);
sol::optional<thing> v = lua_bark(sol::optional<thing>(thing{ 29 })); sol::optional<thing> v = lua_bark(sol::optional<thing>(thing { 29 }));
REQUIRE_NOTHROW([&] { REQUIRE_NOTHROW([&] {
sol::lua_nil_t n = lua_bark(sol::nullopt); sol::lua_nil_t n = lua_bark(sol::nullopt);
return n; return n;

View File

@ -29,7 +29,7 @@
#include <numeric> #include <numeric>
#include <iostream> #include <iostream>
struct T {}; struct T { };
TEST_CASE("operators/default", "test that generic equality operators and all sorts of equality tests can be used") { TEST_CASE("operators/default", "test that generic equality operators and all sorts of equality tests can be used") {
struct U { struct U {
@ -56,10 +56,10 @@ TEST_CASE("operators/default", "test that generic equality operators and all sor
T& t2 = t1; T& t2 = t1;
T t3; T t3;
U u1; U u1;
U u2{ 30 }; U u2 { 30 };
U u3; U u3;
V v1; V v1;
V v2{ 30 }; V v2 { 30 };
V v3; V v3;
lua["t1"] = &t1; lua["t1"] = &t1;
lua["t2"] = &t2; lua["t2"] = &t2;
@ -74,55 +74,55 @@ TEST_CASE("operators/default", "test that generic equality operators and all sor
SECTION("plain") { SECTION("plain") {
// Can only compare identity here // Can only compare identity here
{ {
auto result1 = lua.safe_script( sol::optional<sol::error> result1 = lua.safe_script(
"assert(t1 == t1)" "assert(t1 == t1)"
"assert(t2 == t2)" "assert(t2 == t2)"
"assert(t3 == t3)", "assert(t3 == t3)",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE_FALSE(result1.has_value());
} }
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"assert(t1 == t2)" "assert(t1 == t2)"
"assert(not (t1 == t3))" "assert(not (t1 == t3))"
"assert(not (t2 == t3))", "assert(not (t2 == t3))",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
} }
// Object should compare equal to themselves // Object should compare equal to themselves
// (and not invoke operator==; pointer test should be sufficient) // (and not invoke operator==; pointer test should be sufficient)
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"assert(u1 == u1)" "assert(u1 == u1)"
"assert(u2 == u2)" "assert(u2 == u2)"
"assert(u3 == u3)", "assert(u3 == u3)",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
} }
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"assert(not (u1 == u2))" "assert(not (u1 == u2))"
"assert(u1 == u3)" "assert(u1 == u3)"
"assert(not (u2 == u3))", "assert(not (u2 == u3))",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
} }
// Object should compare equal to themselves // Object should compare equal to themselves
// (and not invoke operator==; pointer test should be sufficient) // (and not invoke operator==; pointer test should be sufficient)
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"assert(v1 == v1)" "assert(v1 == v1)"
"assert(v2 == v2)" "assert(v2 == v2)"
"assert(v3 == v3)", "assert(v3 == v3)",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
} }
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"assert(not (v1 == v2))" "assert(not (v1 == v2))"
"assert(v1 == v3)" "assert(v1 == v3)"
"assert(not (v2 == v3))", "assert(not (v2 == v3))",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
} }
} }
@ -134,54 +134,54 @@ TEST_CASE("operators/default", "test that generic equality operators and all sor
// Can only compare identity here // Can only compare identity here
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"assert(t1 == t1)" "assert(t1 == t1)"
"assert(t2 == t2)" "assert(t2 == t2)"
"assert(t3 == t3)", "assert(t3 == t3)",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
} }
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"assert(t1 == t2)" "assert(t1 == t2)"
"assert(not (t1 == t3))" "assert(not (t1 == t3))"
"assert(not (t2 == t3))", "assert(not (t2 == t3))",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
} }
// Object should compare equal to themselves // Object should compare equal to themselves
// (and not invoke operator==; pointer test should be sufficient) // (and not invoke operator==; pointer test should be sufficient)
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"assert(u1 == u1)" "assert(u1 == u1)"
"assert(u2 == u2)" "assert(u2 == u2)"
"assert(u3 == u3)", "assert(u3 == u3)",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
} }
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"assert(not (u1 == u2))" "assert(not (u1 == u2))"
"assert(u1 == u3)" "assert(u1 == u3)"
"assert(not (u2 == u3))", "assert(not (u2 == u3))",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
} }
// Object should compare equal to themselves // Object should compare equal to themselves
// (and not invoke operator==; pointer test should be sufficient) // (and not invoke operator==; pointer test should be sufficient)
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"assert(v1 == v1)" "assert(v1 == v1)"
"assert(v2 == v2)" "assert(v2 == v2)"
"assert(v3 == v3)", "assert(v3 == v3)",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
} }
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"assert(not (v1 == v2))" "assert(not (v1 == v2))"
"assert(v1 == v3)" "assert(v1 == v3)"
"assert(not (v2 == v3))", "assert(not (v2 == v3))",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
} }
} }
@ -240,9 +240,9 @@ TEST_CASE("operators/call", "test call operator generation") {
lua.new_usertype<callable>("callable"); lua.new_usertype<callable>("callable");
{ {
auto result1 = lua.safe_script( auto result1 = lua.safe_script(
"obj = callable.new()\n" "obj = callable.new()\n"
"v = obj(2, 'bark woof')", "v = obj(2, 'bark woof')",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
int v = lua["v"]; int v = lua["v"];
REQUIRE(v == 11); REQUIRE(v == 11);
@ -310,7 +310,7 @@ TEST_CASE("operators/stringable", "test std::ostream stringability") {
{ {
auto result1 = lua.safe_script(R"(obj = stringable.new() auto result1 = lua.safe_script(R"(obj = stringable.new()
print(obj) )", print(obj) )",
sol::script_pass_on_error); sol::script_pass_on_error);
REQUIRE(result1.valid()); REQUIRE(result1.valid());
stringable& obj = lua["obj"]; stringable& obj = lua["obj"];
REQUIRE(stringable::last_print_ptr == &obj); REQUIRE(stringable::last_print_ptr == &obj);