improve traits

This commit is contained in:
ThePhD 2017-08-07 08:47:17 -04:00
parent 62b242bc96
commit 092fec7afb
2 changed files with 37 additions and 73 deletions

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 2017-08-07 06:26:17.141906 UTC // Generated 2017-08-07 12:34:45.380203 UTC
// This header was generated with sol v2.18.0 (revision ca685e0) // This header was generated with sol v2.18.0 (revision 62b242b)
// https://github.com/ThePhD/sol2 // https://github.com/ThePhD/sol2
#ifndef SOL_SINGLE_INCLUDE_HPP #ifndef SOL_SINGLE_INCLUDE_HPP
@ -1139,6 +1139,13 @@ namespace sol {
} // meta } // meta
namespace detail { namespace detail {
template <typename T>
struct is_pointer_like : std::is_pointer<T> {};
template <typename T, typename D>
struct is_pointer_like<std::unique_ptr<T, D>> : std::true_type {};
template <typename T>
struct is_pointer_like<std::shared_ptr<T>> : std::true_type {};
template <std::size_t I, typename Tuple> template <std::size_t I, typename Tuple>
decltype(auto) forward_get(Tuple&& tuple) { decltype(auto) forward_get(Tuple&& tuple) {
return std::forward<meta::tuple_element_t<I, Tuple>>(std::get<I>(tuple)); return std::forward<meta::tuple_element_t<I, Tuple>>(std::get<I>(tuple));
@ -1165,44 +1172,14 @@ namespace sol {
return arg.get(); return arg.get();
} }
template<typename T> template<typename T, meta::enable<meta::neg<is_pointer_like<meta::unqualified_t<T>>>> = meta::enabler>
auto deref(T&& item) -> decltype(std::forward<T>(item)) { auto deref(T&& item) -> decltype(std::forward<T>(item)) {
return std::forward<T>(item); return std::forward<T>(item);
} }
template<typename T> template<typename T, meta::enable<is_pointer_like<meta::unqualified_t<T>>> = meta::enabler>
inline auto& deref(T(&item)[5]) { inline auto& deref(T&& item) {
return item; return *std::forward<T>(item);
}
template<typename T>
inline auto& deref(const T(&item)[5]) {
return item;
}
template<typename T>
inline T& deref(T* item) {
return *item;
}
template<typename T, typename Dx>
inline std::add_lvalue_reference_t<T> deref(std::unique_ptr<T, Dx>& item) {
return *item;
}
template<typename T>
inline std::add_lvalue_reference_t<T> deref(std::shared_ptr<T>& item) {
return *item;
}
template<typename T, typename Dx>
inline std::add_lvalue_reference_t<T> deref(const std::unique_ptr<T, Dx>& item) {
return *item;
}
template<typename T>
inline std::add_lvalue_reference_t<T> deref(const std::shared_ptr<T>& item) {
return *item;
} }
template<typename T> template<typename T>
@ -8278,10 +8255,15 @@ namespace sol {
auto it = code.cbegin(); auto it = code.cbegin();
auto e = code.cend(); auto e = code.cend();
std::size_t i = 0; std::size_t i = 0;
static const std::size_t n = N - 1; static const std::size_t n = N - 4;
for (i = 0; i < n && it != e; ++i, ++it) { for (i = 0; i < n && it != e; ++i, ++it) {
basechunkname[i] = *it; basechunkname[i] = *it;
} }
if (it != e) {
for (std::size_t c = 0; c < 3; ++i, ++c) {
basechunkname[i] = '.';
}
}
basechunkname[i] = '\0'; basechunkname[i] = '\0';
return &basechunkname[0]; return &basechunkname[0];
} }
@ -14397,7 +14379,7 @@ namespace sol {
static int get(lua_State* L) { static int get(lua_State* L) {
T& self = get_src(L); T& self = get_src(L);
std::ptrdiff_t idx = stack::get<std::ptrdiff_t>(L, 2); std::ptrdiff_t idx = stack::get<std::ptrdiff_t>(L, 2);
if (idx > std::extent<T>::value || idx < 1) { if (idx > static_cast<std::ptrdiff_t>(std::extent<T>::value) || idx < 1) {
return stack::push(L, lua_nil); return stack::push(L, lua_nil);
} }
--idx; --idx;
@ -14411,7 +14393,7 @@ namespace sol {
static int set(lua_State* L) { static int set(lua_State* L) {
T& self = get_src(L); T& self = get_src(L);
std::ptrdiff_t idx = stack::get<std::ptrdiff_t>(L, 2); std::ptrdiff_t idx = stack::get<std::ptrdiff_t>(L, 2);
if (idx > std::extent<T>::value) { if (idx > static_cast<std::ptrdiff_t>(std::extent<T>::value)) {
return luaL_error(L, "sol: index out of bounds (too big) for set on '%s'", detail::demangle<T>().c_str()); return luaL_error(L, "sol: index out of bounds (too big) for set on '%s'", detail::demangle<T>().c_str());
} }
if (idx < 1) { if (idx < 1) {
@ -16079,7 +16061,12 @@ namespace sol {
load_result load(lua_Reader reader, void* data, const std::string& chunkname = detail::default_chunk_name(), load_mode mode = load_mode::any) { load_result load(lua_Reader reader, void* data, const std::string& chunkname = detail::default_chunk_name(), load_mode mode = load_mode::any) {
char basechunkname[17] = {}; char basechunkname[17] = {};
const char* chunknametarget = detail::make_chunk_name("lua_reader", chunkname, basechunkname); const char* chunknametarget = detail::make_chunk_name("lua_reader", chunkname, basechunkname);
#if SOL_LUA_VERSION > 501
load_status x = static_cast<load_status>(lua_load(L, reader, data, chunknametarget, to_string(mode).c_str())); load_status x = static_cast<load_status>(lua_load(L, reader, data, chunknametarget, to_string(mode).c_str()));
#else
(void)mode;
load_status x = static_cast<load_status>(lua_load(L, reader, data, chunknametarget));
#endif
return load_result(L, absolute_index(L, -1), 1, 1, x); return load_result(L, absolute_index(L, -1), 1, 1, x);
} }

View File

@ -487,6 +487,13 @@ namespace sol {
} // meta } // meta
namespace detail { namespace detail {
template <typename T>
struct is_pointer_like : std::is_pointer<T> {};
template <typename T, typename D>
struct is_pointer_like<std::unique_ptr<T, D>> : std::true_type {};
template <typename T>
struct is_pointer_like<std::shared_ptr<T>> : std::true_type {};
template <std::size_t I, typename Tuple> template <std::size_t I, typename Tuple>
decltype(auto) forward_get(Tuple&& tuple) { decltype(auto) forward_get(Tuple&& tuple) {
return std::forward<meta::tuple_element_t<I, Tuple>>(std::get<I>(tuple)); return std::forward<meta::tuple_element_t<I, Tuple>>(std::get<I>(tuple));
@ -513,44 +520,14 @@ namespace sol {
return arg.get(); return arg.get();
} }
template<typename T> template<typename T, meta::enable<meta::neg<is_pointer_like<meta::unqualified_t<T>>>> = meta::enabler>
auto deref(T&& item) -> decltype(std::forward<T>(item)) { auto deref(T&& item) -> decltype(std::forward<T>(item)) {
return std::forward<T>(item); return std::forward<T>(item);
} }
template<typename T> template<typename T, meta::enable<is_pointer_like<meta::unqualified_t<T>>> = meta::enabler>
inline auto& deref(T(&item)[5]) { inline auto& deref(T&& item) {
return item; return *std::forward<T>(item);
}
template<typename T>
inline auto& deref(const T(&item)[5]) {
return item;
}
template<typename T>
inline T& deref(T* item) {
return *item;
}
template<typename T, typename Dx>
inline std::add_lvalue_reference_t<T> deref(std::unique_ptr<T, Dx>& item) {
return *item;
}
template<typename T>
inline std::add_lvalue_reference_t<T> deref(std::shared_ptr<T>& item) {
return *item;
}
template<typename T, typename Dx>
inline std::add_lvalue_reference_t<T> deref(const std::unique_ptr<T, Dx>& item) {
return *item;
}
template<typename T>
inline std::add_lvalue_reference_t<T> deref(const std::shared_ptr<T>& item) {
return *item;
} }
template<typename T> template<typename T>