// 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. #include "tuple.hpp" #ifndef SOL_FUNCTIONAL_HPP #define SOL_FUNCTIONAL_HPP namespace sol { namespace detail { 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; }; using std::get; template inline auto call(Function&& f, const Tuple& t, indices) -> decltype(f(get(t)...)) { return f(get(t)...); } } // detail template struct lua_return_type { typedef std::tuple type; }; template struct lua_return_type { typedef Ret type; }; template <> struct lua_return_type<> { typedef void type; }; template <> struct lua_return_type { typedef void type; }; template inline auto call(Function&& f, const std::tuple& t) -> decltype(detail::call(std::forward(f), t, build_indices{})) { return call(std::forward(f), t, build_indices{}); } } // sol #endif // SOL_FUNCTIONAL_HPP