// The MIT License (MIT) // Copyright (c) 2013 Danny Y., Rapptz // Permission is hereby granted, free of charge, to any person obtaining a copy of // this software and associated documentation files (the "Software"), to deal in // the Software without restriction, including without limitation the rights to // use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of // the Software, and to permit persons to whom the Software is furnished to do so, // subject to the following conditions: // The above copyright notice and this permission notice shall be included in all // copies or substantial portions of the Software. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS // FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR // COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER // IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN // CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. #ifndef SOL_TRAITS_HPP #define SOL_TRAITS_HPP #include namespace sol { template using EnableIf = typename std::enable_if::type; template using DisableIf = typename std::enable_if::type; template using Unqualified = typename std::remove_reference::type>::type; template using Decay = typename std::decay::type; namespace detail { // code borrowed from Gears // https://github.com/Rapptz/Gears/ template>::value> struct is_function_impl : std::is_function::type> {}; template struct is_function_impl { using yes = char; using no = struct { char s[2]; }; struct F { void operator()(); }; struct Derived : T, F { }; template struct Check; template static no test(Check*); template static yes test(...); static const bool value = sizeof(test(0)) == sizeof(yes); }; } // detail template using Bool = std::integral_constant; template struct Function : Bool::value> {}; template struct function_traits; template struct function_traits { static const std::size_t arity = sizeof...(Args); static const bool is_member_function = true; typedef std::tuple arg_tuple_type; typedef types args_type; typedef R(T::* function_pointer_type)(Args...); typedef typename std::remove_pointer::type function_type; typedef R(*free_function_pointer_type)(Args...); typedef R return_type; template using arg = typename std::tuple_element::type; }; template struct function_traits { static const std::size_t arity = sizeof...(Args); static const bool is_member_function = true; typedef std::tuple arg_tuple_type; typedef types args_type; typedef R(T::* function_pointer_type)(Args...); typedef typename std::remove_pointer::type function_type; typedef R(*free_function_pointer_type)(Args...); typedef R return_type; template using arg = typename std::tuple_element::type; }; template struct function_traits { static const std::size_t arity = sizeof...(Args); static const bool is_member_function = false; typedef std::tuple arg_tuple_type; typedef types args_type; typedef R(function_type)(Args...); typedef R(*function_pointer_type)(Args...); typedef R(*free_function_pointer_type)(Args...); typedef R return_type; template using arg = typename std::tuple_element::type; }; template struct function_traits { static const std::size_t arity = sizeof...(Args); static const bool is_member_function = false; typedef std::tuple arg_tuple_type; typedef types args_type; typedef R(function_type)(Args...); typedef R(*function_pointer_type)(Args...); typedef R(*free_function_pointer_type)(Args...); typedef R return_type; template using arg = typename std::tuple_element::type; }; } // sol #endif // SOL_TRAITS_HPP