2018-09-27 22:27:38 -07:00
|
|
|
// sol3
|
2018-04-17 12:29:03 -04:00
|
|
|
|
|
|
|
// The MIT License (MIT)
|
|
|
|
|
2019-03-13 05:18:06 -04:00
|
|
|
// Copyright (c) 2013-2019 Rapptz, ThePhD and contributors
|
2018-04-17 12:29:03 -04:00
|
|
|
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
|
|
// this software and associated documentation files (the "Software"), to deal in
|
|
|
|
// the Software without restriction, including without limitation the rights to
|
|
|
|
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
|
|
|
|
// the Software, and to permit persons to whom the Software is furnished to do so,
|
|
|
|
// subject to the following conditions:
|
|
|
|
|
|
|
|
// The above copyright notice and this permission notice shall be included in all
|
|
|
|
// copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
|
|
|
|
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
|
|
|
|
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
|
|
|
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
|
|
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
|
|
|
|
#ifndef SOL_CONFIG_HPP
|
|
|
|
#define SOL_CONFIG_HPP
|
|
|
|
|
|
|
|
#ifdef _MSC_VER
|
|
|
|
#if defined(_DEBUG) && !defined(NDEBUG)
|
2018-12-19 23:17:15 -05:00
|
|
|
#ifndef SOL_IN_DEBUG_DETECTED
|
|
|
|
#define SOL_IN_DEBUG_DETECTED 1
|
|
|
|
#endif
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif // VC++ Debug macros
|
|
|
|
|
2018-12-19 23:17:15 -05:00
|
|
|
#if !defined(_CPPUNWIND)
|
|
|
|
#if !defined(SOL_NO_EXCEPTIONS)
|
|
|
|
#define SOL_NO_EXCEPTIONS 1
|
|
|
|
#endif
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif // Automatic Exceptions
|
|
|
|
|
2018-12-19 23:17:15 -05:00
|
|
|
#if !defined(_CPPRTTI)
|
|
|
|
#if !defined(SOL_NO_RTTI)
|
|
|
|
#define SOL_NO_RTTI 1
|
|
|
|
#endif
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif // Automatic RTTI
|
|
|
|
#elif defined(__GNUC__) || defined(__clang__)
|
|
|
|
|
|
|
|
#if !defined(NDEBUG) && !defined(__OPTIMIZE__)
|
2018-12-19 23:17:15 -05:00
|
|
|
#if !defined(SOL_IN_DEBUG_DETECTED)
|
|
|
|
#define SOL_IN_DEBUG_DETECTED 1
|
|
|
|
#endif
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif // Not Debug && g++ optimizer flag
|
|
|
|
|
2018-12-19 23:17:15 -05:00
|
|
|
#if !defined(__EXCEPTIONS)
|
|
|
|
#if !defined(SOL_NO_EXCEPTIONS)
|
|
|
|
#define SOL_NO_EXCEPTIONS 1
|
|
|
|
#endif
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif // No Exceptions
|
|
|
|
|
2018-12-19 23:17:15 -05:00
|
|
|
#if !defined(__GXX_RTTI)
|
|
|
|
#if !defined(SOL_NO_RTTI)
|
|
|
|
#define SOL_NO_RTTI 1
|
|
|
|
#endif
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif // No RTTI
|
|
|
|
|
|
|
|
#endif // vc++ || clang++/g++
|
|
|
|
|
2019-05-21 19:17:31 -04:00
|
|
|
// Compatibility Define
|
2019-11-24 18:06:52 -05:00
|
|
|
#if defined(SOL_CHECK_ARGUMENTS) && SOL_CHECK_ARGUMENTS != 0
|
2019-05-21 19:17:31 -04:00
|
|
|
#if defined(SOL_ALL_SAFETIES_ON)
|
|
|
|
#define SOL_ALL_SAFETIES_ON 1
|
|
|
|
#endif // turn all the safeties on
|
2019-11-24 18:06:52 -05:00
|
|
|
#endif // Compatibility Define for Safety
|
2019-05-21 19:17:31 -04:00
|
|
|
|
|
|
|
// If this is defined, turn on all the safety checks automatically
|
2019-11-24 18:06:52 -05:00
|
|
|
#if defined(SOL_ALL_SAFETIES_ON) && SOL_ALL_SAFETIES_ON != 0
|
2018-04-17 12:29:03 -04:00
|
|
|
|
|
|
|
// Checks low-level getter function
|
|
|
|
// (and thusly, affects nearly entire framework)
|
|
|
|
#if !defined(SOL_SAFE_GETTER)
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_SAFE_GETTER 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Checks access on usertype functions
|
|
|
|
// local my_obj = my_type.new()
|
|
|
|
// my_obj.my_member_function()
|
|
|
|
// -- bad syntax and crash
|
|
|
|
#if !defined(SOL_SAFE_USERTYPE)
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_SAFE_USERTYPE 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Checks sol::reference derived boundaries
|
|
|
|
// sol::function ref(L, 1);
|
|
|
|
// sol::userdata sref(L, 2);
|
|
|
|
#if !defined(SOL_SAFE_REFERENCES)
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_SAFE_REFERENCES 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Changes all typedefs of sol::function to point to the
|
|
|
|
// protected_function version, instead of unsafe_function
|
|
|
|
#if !defined(SOL_SAFE_FUNCTION)
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_SAFE_FUNCTION 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Checks function parameters and
|
|
|
|
// returns upon call into/from Lua
|
|
|
|
// local a = 1
|
|
|
|
// local b = "woof"
|
|
|
|
// my_c_function(a, b)
|
|
|
|
#if !defined(SOL_SAFE_FUNCTION_CALLS)
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_SAFE_FUNCTION_CALLS 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Checks conversions
|
|
|
|
// int v = lua["bark"];
|
|
|
|
// int v2 = my_sol_function();
|
|
|
|
#if !defined(SOL_SAFE_PROXIES)
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_SAFE_PROXIES 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Check overflowing number conversions
|
|
|
|
// for things like 64 bit integers that don't fit in a typical lua_Number
|
|
|
|
// for Lua 5.1 and 5.2
|
|
|
|
#if !defined(SOL_SAFE_NUMERICS)
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_SAFE_NUMERICS 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Turn off Number Precision Checks
|
|
|
|
// if this is defined, we do not do range
|
|
|
|
// checks on integers / unsigned integers that might
|
|
|
|
// be bigger than what Lua can represent
|
|
|
|
#if !defined(SOL_NO_CHECK_NUMBER_PRECISION)
|
|
|
|
// off by default
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_NO_CHECK_NUMBER_PRECISION 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Print any exceptions / errors that occur
|
|
|
|
// in debug mode to the default error stream / console
|
|
|
|
#if !defined(SOL_SAFE_STACK_CHECK)
|
|
|
|
#define SOL_SAFE_STACK_CHECK 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif // Turn on Safety for all if top-level macro is defined
|
|
|
|
|
|
|
|
// If we are in debug, turn on certain safety checks
|
2019-11-24 18:06:52 -05:00
|
|
|
#if defined(SOL_IN_DEBUG_DETECTED) && SOL_IN_DEBUG_DETECTED != 0
|
2018-04-17 12:29:03 -04:00
|
|
|
|
|
|
|
#if !defined(SOL_SAFE_REFERENCES)
|
|
|
|
// Ensure that references are forcefully type-checked upon construction
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_SAFE_REFERENCES 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Safe usertypes checks for errors such as
|
|
|
|
// obj = my_type.new()
|
|
|
|
// obj.f() -- note the '.' instead of ':'
|
|
|
|
// usertypes should be safe no matter what
|
|
|
|
#if !defined(SOL_SAFE_USERTYPE)
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_SAFE_USERTYPE 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if !defined(SOL_SAFE_FUNCTION_CALLS)
|
|
|
|
// Function calls from Lua should be automatically safe in debug mode
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_SAFE_FUNCTION_CALLS 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Print any exceptions / errors that occur
|
|
|
|
// in debug mode to the default error stream / console
|
|
|
|
#if !defined(SOL_PRINT_ERRORS)
|
2018-12-19 23:17:15 -05:00
|
|
|
#define SOL_PRINT_ERRORS 1
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Print any exceptions / errors that occur
|
|
|
|
// in debug mode to the default error stream / console
|
|
|
|
#if !defined(SOL_SAFE_STACK_CHECK)
|
|
|
|
#define SOL_SAFE_STACK_CHECK 1
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif
|
|
|
|
|
2018-12-19 23:17:15 -05:00
|
|
|
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif // DEBUG: Turn on all debug safety features for VC++ / g++ / clang++ and similar
|
|
|
|
|
|
|
|
// Print any exceptions / errors that occur
|
|
|
|
// This is normally off due to relying on
|
|
|
|
// <iostream> to get std::cerr / std::cout
|
|
|
|
// so it is only defined in debug modes
|
|
|
|
#if !defined(SOL_PRINT_ERRORS)
|
|
|
|
// off by default here
|
|
|
|
#define SOL_PRINT_ERRORS 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// The default on_error handler should not throw/assert/print/abort,
|
|
|
|
// but simply pass the value through back to the user
|
|
|
|
// problematic due to not having a stable [[nodiscard]] attribute in C++11,
|
|
|
|
// off by default
|
|
|
|
#if !defined(SOL_DEFAULT_PASS_ON_ERROR)
|
|
|
|
// off by default here
|
|
|
|
#define SOL_DEFAULT_PASS_ON_ERROR 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Interop allows userdata from external systems
|
|
|
|
// with external memory layout and metatable names
|
|
|
|
// to be registered. It costs something to perform
|
2019-05-21 19:17:31 -04:00
|
|
|
// the interop_checker / differentiation for sol3 usertypes versus
|
2018-04-17 12:29:03 -04:00
|
|
|
// external ones however, so this is off by default
|
|
|
|
#if !defined(SOL_ENABLE_INTEROP)
|
|
|
|
// off by default here
|
|
|
|
#define SOL_ENABLE_INTEROP 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Mac OSX and Objective C define a nil keyword
|
|
|
|
// we cannot use that for the sol::type::nil define
|
|
|
|
#if defined(__MAC_OS_X_VERSION_MAX_ALLOWED) || defined(__OBJC__) || defined(nil)
|
|
|
|
#if !defined(SOL_NO_NIL)
|
|
|
|
#define SOL_NO_NIL 1
|
|
|
|
#endif
|
|
|
|
#endif // avoiding nil defines / keywords
|
|
|
|
|
|
|
|
// If we are using boost, there are a number of optimizations we can perform
|
|
|
|
// Boost has unordered_map with Compatible Key and CompatibleHash
|
|
|
|
// Boost also has a decent optional, and we check for this later
|
|
|
|
// and define our optional to use boost in that scenario
|
2018-12-19 23:17:15 -05:00
|
|
|
// DEPRECATED
|
|
|
|
// NOTE: left here for introspection, but NO LONGER USED
|
2018-04-17 12:29:03 -04:00
|
|
|
#if defined(SOL_USE_BOOST) && SOL_USE_BOOST
|
2018-12-19 23:17:15 -05:00
|
|
|
#if !defined(SOL_UNORDERED_MAP_COMPATIBLE_HASH)
|
2018-04-17 12:29:03 -04:00
|
|
|
#define SOL_UNORDERED_MAP_COMPATIBLE_HASH 1
|
|
|
|
#endif // SOL_UNORDERED_MAP_COMPATIBLE_HASH
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// For strings being serialized and
|
|
|
|
// deserialized from and to utf8
|
|
|
|
// this controls the size of the buffer we create on the stack,
|
|
|
|
// in # of utf8 code units
|
|
|
|
// a buffer of 1KB covers almost all the strings
|
|
|
|
// we care about: anything larger and the user should know better
|
|
|
|
#ifndef SOL_STACK_STRING_OPTIMIZATION_SIZE
|
|
|
|
#define SOL_STACK_STRING_OPTIMIZATION_SIZE 1024
|
|
|
|
#endif // Optimized conversion routines using a KB or so off the stack
|
|
|
|
|
2018-12-19 23:17:15 -05:00
|
|
|
// This macro ensures that we check the stack
|
|
|
|
// on every push of a value.
|
2019-05-21 19:17:31 -04:00
|
|
|
// This is only for sol3: if you want safety in your customization
|
2018-12-19 23:17:15 -05:00
|
|
|
// points, you need to build it into each and every customization point you use,
|
|
|
|
// by using luaL_checkstack or lua_checkstack
|
|
|
|
// this is off by default,
|
|
|
|
// but on by default for debug builds
|
|
|
|
#if !defined(SOL_SAFE_STACK_CHECK)
|
|
|
|
#define SOL_SAFE_STACK_CHECK 0
|
|
|
|
#endif // use luaL_checkstack to check stack overflow / overrun
|
|
|
|
|
2018-04-17 12:29:03 -04:00
|
|
|
#endif // SOL_CONFIG_HPP
|