mirror of
https://github.com/ThePhD/sol2.git
synced 2024-03-22 13:10:44 +08:00
Force constness on ostream operator.
Automatically disable magic for variant types.
This commit is contained in:
parent
e26475e75b
commit
b0c74207d8
|
@ -39,8 +39,7 @@
|
||||||
#include <iosfwd>
|
#include <iosfwd>
|
||||||
|
|
||||||
|
|
||||||
namespace sol {
|
namespace sol { namespace meta {
|
||||||
namespace meta {
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct unwrapped {
|
struct unwrapped {
|
||||||
typedef T type;
|
typedef T type;
|
||||||
|
@ -191,11 +190,11 @@ namespace sol {
|
||||||
template <template <typename...> class When, std::size_t Limit, std::size_t I, template <typename...> class Pred, typename... Ts>
|
template <template <typename...> class When, std::size_t Limit, std::size_t I, template <typename...> class Pred, typename... Ts>
|
||||||
struct count_when_for_pack : std::integral_constant<std::size_t, 0> {};
|
struct count_when_for_pack : std::integral_constant<std::size_t, 0> {};
|
||||||
template <template <typename...> class When, std::size_t Limit, std::size_t I, template <typename...> class Pred, typename T, typename... Ts>
|
template <template <typename...> class When, std::size_t Limit, std::size_t I, template <typename...> class Pred, typename T, typename... Ts>
|
||||||
struct count_when_for_pack<When, Limit, I, Pred, T, Ts...> : conditional_t<
|
struct count_when_for_pack<When, Limit, I, Pred, T, Ts...> : conditional_t < sizeof...(Ts)
|
||||||
sizeof...(Ts) == 0 || Limit < 2,
|
== 0
|
||||||
std::integral_constant<std::size_t, I + static_cast<std::size_t>(Limit != 0 && Pred<T>::value)>,
|
|| Limit<2, std::integral_constant<std::size_t, I + static_cast<std::size_t>(Limit != 0 && Pred<T>::value)>,
|
||||||
count_when_for_pack<When, Limit - static_cast<std::size_t>(When<T, std::integral_constant<std::size_t, I>>::value), I + static_cast<std::size_t>(When<T, std::integral_constant<std::size_t, I>>::value && Pred<T>::value), Pred, Ts...>
|
count_when_for_pack<When, Limit - static_cast<std::size_t>(When<T, std::integral_constant<std::size_t, I>>::value),
|
||||||
> {};
|
I + static_cast<std::size_t>(When<T, std::integral_constant<std::size_t, I>>::value&& Pred<T>::value), Pred, Ts...>> {};
|
||||||
} // namespace meta_detail
|
} // namespace meta_detail
|
||||||
|
|
||||||
template <template <typename...> class Pred, typename... Ts>
|
template <template <typename...> class Pred, typename... Ts>
|
||||||
|
@ -470,8 +469,8 @@ namespace sol {
|
||||||
template <typename T, typename U, typename = decltype(std::declval<T&>() <= std::declval<U&>())>
|
template <typename T, typename U, typename = decltype(std::declval<T&>() <= std::declval<U&>())>
|
||||||
std::true_type supports_op_less_equal_test(std::reference_wrapper<T>, std::reference_wrapper<U>);
|
std::true_type supports_op_less_equal_test(std::reference_wrapper<T>, std::reference_wrapper<U>);
|
||||||
std::false_type supports_op_less_equal_test(...);
|
std::false_type supports_op_less_equal_test(...);
|
||||||
template <typename T, typename OS, typename = decltype(std::declval<OS&>() << std::declval<T&>())>
|
template <typename T, typename OS, typename = decltype(std::declval<OS&>() << std::declval<const T&>())>
|
||||||
std::true_type supports_ostream_op(std::reference_wrapper<T>, std::reference_wrapper<OS>);
|
std::true_type supports_ostream_op(std::reference_wrapper<const T>, std::reference_wrapper<OS>);
|
||||||
std::false_type supports_ostream_op(...);
|
std::false_type supports_ostream_op(...);
|
||||||
template <typename T, typename = decltype(to_string(std::declval<T&>()))>
|
template <typename T, typename = decltype(to_string(std::declval<T&>()))>
|
||||||
std::true_type supports_adl_to_string(std::reference_wrapper<T>);
|
std::true_type supports_adl_to_string(std::reference_wrapper<T>);
|
||||||
|
@ -486,7 +485,7 @@ namespace sol {
|
||||||
template <typename T, typename U, typename = decltype(std::declval<T&>() <= std::declval<U&>())>
|
template <typename T, typename U, typename = decltype(std::declval<T&>() <= std::declval<U&>())>
|
||||||
std::true_type supports_op_less_equal_test(const T&, const U&);
|
std::true_type supports_op_less_equal_test(const T&, const U&);
|
||||||
std::false_type supports_op_less_equal_test(...);
|
std::false_type supports_op_less_equal_test(...);
|
||||||
template <typename T, typename OS, typename = decltype(std::declval<OS&>() << std::declval<T&>())>
|
template <typename T, typename OS, typename = decltype(std::declval<OS&>() << std::declval<const T&>())>
|
||||||
std::true_type supports_ostream_op(const T&, const OS&);
|
std::true_type supports_ostream_op(const T&, const OS&);
|
||||||
std::false_type supports_ostream_op(...);
|
std::false_type supports_ostream_op(...);
|
||||||
template <typename T, typename = decltype(to_string(std::declval<T&>()))>
|
template <typename T, typename = decltype(to_string(std::declval<T&>()))>
|
||||||
|
@ -514,7 +513,7 @@ namespace sol {
|
||||||
= decltype(meta_detail::supports_op_less_equal_test(std::declval<meta_detail::non_void_t<T>&>(), std::declval<meta_detail::non_void_t<U>&>()));
|
= decltype(meta_detail::supports_op_less_equal_test(std::declval<meta_detail::non_void_t<T>&>(), std::declval<meta_detail::non_void_t<U>&>()));
|
||||||
template <typename T, typename U = std::ostream>
|
template <typename T, typename U = std::ostream>
|
||||||
using supports_ostream_op
|
using supports_ostream_op
|
||||||
= decltype(meta_detail::supports_ostream_op(std::declval<meta_detail::non_void_t<T>&>(), std::declval<meta_detail::non_void_t<U>&>()));
|
= decltype(meta_detail::supports_ostream_op(std::declval<meta_detail::non_void_t<T>&>(), std::declval<const meta_detail::non_void_t<U>&>()));
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using supports_adl_to_string = decltype(meta_detail::supports_adl_to_string(std::declval<meta_detail::non_void_t<T>&>()));
|
using supports_adl_to_string = decltype(meta_detail::supports_adl_to_string(std::declval<meta_detail::non_void_t<T>&>()));
|
||||||
|
|
||||||
|
@ -669,8 +668,7 @@ namespace sol {
|
||||||
constexpr inline bool is_c_str_v = is_c_str<T>::value;
|
constexpr inline bool is_c_str_v = is_c_str<T>::value;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct is_move_only
|
struct is_move_only : all<neg<std::is_reference<T>>, neg<std::is_copy_constructible<unqualified_t<T>>>, std::is_move_constructible<unqualified_t<T>>> {};
|
||||||
: all<neg<std::is_reference<T>>, neg<std::is_copy_constructible<unqualified_t<T>>>, std::is_move_constructible<unqualified_t<T>>> {};
|
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using is_not_move_only = neg<is_move_only<T>>;
|
using is_not_move_only = neg<is_move_only<T>>;
|
||||||
|
@ -702,7 +700,6 @@ namespace sol {
|
||||||
using type = typename std::iterator_traits<T>::iterator_category;
|
using type = typename std::iterator_traits<T>::iterator_category;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace meta
|
}} // namespace sol::meta
|
||||||
} // namespace sol
|
|
||||||
|
|
||||||
#endif // SOL_TRAITS_HPP
|
#endif // SOL_TRAITS_HPP
|
||||||
|
|
|
@ -1308,7 +1308,13 @@ namespace sol {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct is_automagical
|
struct is_automagical
|
||||||
: std::integral_constant<bool,
|
: std::integral_constant<bool,
|
||||||
std::is_array_v<meta::unqualified_t<T>> || !std::is_same_v<meta::unqualified_t<T>, state> || !std::is_same_v<meta::unqualified_t<T>, state_view>> {
|
#if defined(SOL_CXX17_FEATURES) && SOL_CXX17_FEATURES
|
||||||
|
#if defined(SOL_STD_VARIANT) && SOL_STD_VARIANT != 0
|
||||||
|
!meta::is_specialization_of_v<meta::unqualified_t<T>, std::variant> &&
|
||||||
|
#endif // std::variant borked in places
|
||||||
|
#endif // C++17 Features
|
||||||
|
std::is_array_v<
|
||||||
|
meta::unqualified_t<T>> || (!std::is_same_v<meta::unqualified_t<T>, state> && !std::is_same_v<meta::unqualified_t<T>, state_view>)> {
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
|
|
|
@ -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 2019-11-29 18:08:19.653548 UTC
|
// Generated 2019-12-01 22:39:33.269777 UTC
|
||||||
// This header was generated with sol v3.0.3 (revision 21c0309)
|
// This header was generated with sol v3.2.0 (revision e26475e)
|
||||||
// https://github.com/ThePhD/sol2
|
// https://github.com/ThePhD/sol2
|
||||||
|
|
||||||
#ifndef SOL_SINGLE_INCLUDE_FORWARD_HPP
|
#ifndef SOL_SINGLE_INCLUDE_FORWARD_HPP
|
||||||
|
|
|
@ -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 2019-11-29 18:08:19.142496 UTC
|
// Generated 2019-12-01 22:39:31.432773 UTC
|
||||||
// This header was generated with sol v3.0.3 (revision 21c0309)
|
// This header was generated with sol v3.2.0 (revision e26475e)
|
||||||
// https://github.com/ThePhD/sol2
|
// https://github.com/ThePhD/sol2
|
||||||
|
|
||||||
#ifndef SOL_SINGLE_INCLUDE_HPP
|
#ifndef SOL_SINGLE_INCLUDE_HPP
|
||||||
|
@ -1413,8 +1413,7 @@ namespace sol {
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
#include <iosfwd>
|
#include <iosfwd>
|
||||||
|
|
||||||
namespace sol {
|
namespace sol { namespace meta {
|
||||||
namespace meta {
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct unwrapped {
|
struct unwrapped {
|
||||||
typedef T type;
|
typedef T type;
|
||||||
|
@ -1565,11 +1564,11 @@ namespace sol {
|
||||||
template <template <typename...> class When, std::size_t Limit, std::size_t I, template <typename...> class Pred, typename... Ts>
|
template <template <typename...> class When, std::size_t Limit, std::size_t I, template <typename...> class Pred, typename... Ts>
|
||||||
struct count_when_for_pack : std::integral_constant<std::size_t, 0> {};
|
struct count_when_for_pack : std::integral_constant<std::size_t, 0> {};
|
||||||
template <template <typename...> class When, std::size_t Limit, std::size_t I, template <typename...> class Pred, typename T, typename... Ts>
|
template <template <typename...> class When, std::size_t Limit, std::size_t I, template <typename...> class Pred, typename T, typename... Ts>
|
||||||
struct count_when_for_pack<When, Limit, I, Pred, T, Ts...> : conditional_t<
|
struct count_when_for_pack<When, Limit, I, Pred, T, Ts...> : conditional_t < sizeof...(Ts)
|
||||||
sizeof...(Ts) == 0 || Limit < 2,
|
== 0
|
||||||
std::integral_constant<std::size_t, I + static_cast<std::size_t>(Limit != 0 && Pred<T>::value)>,
|
|| Limit<2, std::integral_constant<std::size_t, I + static_cast<std::size_t>(Limit != 0 && Pred<T>::value)>,
|
||||||
count_when_for_pack<When, Limit - static_cast<std::size_t>(When<T, std::integral_constant<std::size_t, I>>::value), I + static_cast<std::size_t>(When<T, std::integral_constant<std::size_t, I>>::value && Pred<T>::value), Pred, Ts...>
|
count_when_for_pack<When, Limit - static_cast<std::size_t>(When<T, std::integral_constant<std::size_t, I>>::value),
|
||||||
> {};
|
I + static_cast<std::size_t>(When<T, std::integral_constant<std::size_t, I>>::value&& Pred<T>::value), Pred, Ts...>> {};
|
||||||
} // namespace meta_detail
|
} // namespace meta_detail
|
||||||
|
|
||||||
template <template <typename...> class Pred, typename... Ts>
|
template <template <typename...> class Pred, typename... Ts>
|
||||||
|
@ -1844,8 +1843,8 @@ namespace sol {
|
||||||
template <typename T, typename U, typename = decltype(std::declval<T&>() <= std::declval<U&>())>
|
template <typename T, typename U, typename = decltype(std::declval<T&>() <= std::declval<U&>())>
|
||||||
std::true_type supports_op_less_equal_test(std::reference_wrapper<T>, std::reference_wrapper<U>);
|
std::true_type supports_op_less_equal_test(std::reference_wrapper<T>, std::reference_wrapper<U>);
|
||||||
std::false_type supports_op_less_equal_test(...);
|
std::false_type supports_op_less_equal_test(...);
|
||||||
template <typename T, typename OS, typename = decltype(std::declval<OS&>() << std::declval<T&>())>
|
template <typename T, typename OS, typename = decltype(std::declval<OS&>() << std::declval<const T&>())>
|
||||||
std::true_type supports_ostream_op(std::reference_wrapper<T>, std::reference_wrapper<OS>);
|
std::true_type supports_ostream_op(std::reference_wrapper<const T>, std::reference_wrapper<OS>);
|
||||||
std::false_type supports_ostream_op(...);
|
std::false_type supports_ostream_op(...);
|
||||||
template <typename T, typename = decltype(to_string(std::declval<T&>()))>
|
template <typename T, typename = decltype(to_string(std::declval<T&>()))>
|
||||||
std::true_type supports_adl_to_string(std::reference_wrapper<T>);
|
std::true_type supports_adl_to_string(std::reference_wrapper<T>);
|
||||||
|
@ -1860,7 +1859,7 @@ namespace sol {
|
||||||
template <typename T, typename U, typename = decltype(std::declval<T&>() <= std::declval<U&>())>
|
template <typename T, typename U, typename = decltype(std::declval<T&>() <= std::declval<U&>())>
|
||||||
std::true_type supports_op_less_equal_test(const T&, const U&);
|
std::true_type supports_op_less_equal_test(const T&, const U&);
|
||||||
std::false_type supports_op_less_equal_test(...);
|
std::false_type supports_op_less_equal_test(...);
|
||||||
template <typename T, typename OS, typename = decltype(std::declval<OS&>() << std::declval<T&>())>
|
template <typename T, typename OS, typename = decltype(std::declval<OS&>() << std::declval<const T&>())>
|
||||||
std::true_type supports_ostream_op(const T&, const OS&);
|
std::true_type supports_ostream_op(const T&, const OS&);
|
||||||
std::false_type supports_ostream_op(...);
|
std::false_type supports_ostream_op(...);
|
||||||
template <typename T, typename = decltype(to_string(std::declval<T&>()))>
|
template <typename T, typename = decltype(to_string(std::declval<T&>()))>
|
||||||
|
@ -1888,7 +1887,7 @@ namespace sol {
|
||||||
= decltype(meta_detail::supports_op_less_equal_test(std::declval<meta_detail::non_void_t<T>&>(), std::declval<meta_detail::non_void_t<U>&>()));
|
= decltype(meta_detail::supports_op_less_equal_test(std::declval<meta_detail::non_void_t<T>&>(), std::declval<meta_detail::non_void_t<U>&>()));
|
||||||
template <typename T, typename U = std::ostream>
|
template <typename T, typename U = std::ostream>
|
||||||
using supports_ostream_op
|
using supports_ostream_op
|
||||||
= decltype(meta_detail::supports_ostream_op(std::declval<meta_detail::non_void_t<T>&>(), std::declval<meta_detail::non_void_t<U>&>()));
|
= decltype(meta_detail::supports_ostream_op(std::declval<meta_detail::non_void_t<T>&>(), std::declval<const meta_detail::non_void_t<U>&>()));
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using supports_adl_to_string = decltype(meta_detail::supports_adl_to_string(std::declval<meta_detail::non_void_t<T>&>()));
|
using supports_adl_to_string = decltype(meta_detail::supports_adl_to_string(std::declval<meta_detail::non_void_t<T>&>()));
|
||||||
|
|
||||||
|
@ -2043,8 +2042,7 @@ namespace sol {
|
||||||
constexpr inline bool is_c_str_v = is_c_str<T>::value;
|
constexpr inline bool is_c_str_v = is_c_str<T>::value;
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct is_move_only
|
struct is_move_only : all<neg<std::is_reference<T>>, neg<std::is_copy_constructible<unqualified_t<T>>>, std::is_move_constructible<unqualified_t<T>>> {};
|
||||||
: all<neg<std::is_reference<T>>, neg<std::is_copy_constructible<unqualified_t<T>>>, std::is_move_constructible<unqualified_t<T>>> {};
|
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
using is_not_move_only = neg<is_move_only<T>>;
|
using is_not_move_only = neg<is_move_only<T>>;
|
||||||
|
@ -2076,8 +2074,7 @@ namespace sol {
|
||||||
using type = typename std::iterator_traits<T>::iterator_category;
|
using type = typename std::iterator_traits<T>::iterator_category;
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace meta
|
}} // namespace sol::meta
|
||||||
} // namespace sol
|
|
||||||
|
|
||||||
// end of sol/traits.hpp
|
// end of sol/traits.hpp
|
||||||
|
|
||||||
|
@ -7565,7 +7562,13 @@ namespace sol {
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct is_automagical
|
struct is_automagical
|
||||||
: std::integral_constant<bool,
|
: std::integral_constant<bool,
|
||||||
std::is_array_v<meta::unqualified_t<T>> || !std::is_same_v<meta::unqualified_t<T>, state> || !std::is_same_v<meta::unqualified_t<T>, state_view>> {
|
#if defined(SOL_CXX17_FEATURES) && SOL_CXX17_FEATURES
|
||||||
|
#if defined(SOL_STD_VARIANT) && SOL_STD_VARIANT != 0
|
||||||
|
!meta::is_specialization_of_v<meta::unqualified_t<T>, std::variant> &&
|
||||||
|
#endif // std::variant borked in places
|
||||||
|
#endif // C++17 Features
|
||||||
|
std::is_array_v<
|
||||||
|
meta::unqualified_t<T>> || (!std::is_same_v<meta::unqualified_t<T>, state> && !std::is_same_v<meta::unqualified_t<T>, state_view>)> {
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user