// Copyright 2024 Christian Mazakas // Distributed under the Boost Software License, Version 1.0. // https://www.boost.org/LICENSE_1_0.txt #if defined(__GNUC__) && __GNUC__ == 7 #pragma GCC diagnostic ignored "-Wnoexcept-type" #endif #include #if !defined(BOOST_COMPAT_HAS_AUTO_NTTP) #include BOOST_PRAGMA_MESSAGE("no support for placeholder NTTPs detected, skipping this test") int main() {} #else #include #include #include #include struct F1 { std::unique_ptr p_; F1() : p_(new int(1)) {} int m1() { return *p_ + -1; } int m2(int x1) noexcept { return 10 * *p_ + x1; } int m3(int x1, int x2) const { return 100 * *p_ + 10 * x1 + x2; } int m4(int x1, int x2, int x3) const noexcept { return 1000 * *p_ + 100 * x1 + 10 * x2 + x3; } }; namespace compat = boost::compat; int main() { { BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m1>>)); BOOST_TEST_TRAIT_TRUE( (std::is_constructible, compat::nontype_t<&F1::m2>>)); BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m3>>)); BOOST_TEST_TRAIT_TRUE( (std::is_constructible, compat::nontype_t<&F1::m4>>)); } { F1 f1; compat::function_ref fn2(compat::nontype_t<&F1::m2>{}); BOOST_TEST_EQ(fn2(f1, 2), 12); compat::function_ref fn4(compat::nontype_t<&F1::m4>{}); BOOST_TEST_EQ(fn4(f1, 2, 3, 4), 1234); } { BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m1>>)); BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m3>>)); F1 f1; compat::function_ref fn2(compat::nontype_t<&F1::m2>{}); BOOST_TEST_EQ(fn2(f1, 2), 12); compat::function_ref fn4(compat::nontype_t<&F1::m4>{}); BOOST_TEST_EQ(fn4(f1, 2, 3, 4), 1234); } { BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m1>>)); BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m2>>)); BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m3>>)); F1 f1; compat::function_ref fn4(compat::nontype_t<&F1::m4>{}); BOOST_TEST_EQ(fn4(f1, 2, 3, 4), 1234); } { BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m1>, F1&>)); BOOST_TEST_TRAIT_TRUE( (std::is_constructible, compat::nontype_t<&F1::m2>, F1&>)); BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m3>, F1&>)); BOOST_TEST_TRAIT_TRUE( (std::is_constructible, compat::nontype_t<&F1::m4>, F1&>)); F1 f1; compat::function_ref fn2(compat::nontype_t<&F1::m2>{}, f1); BOOST_TEST_EQ(fn2(2), 12); compat::function_ref fn4(compat::nontype_t<&F1::m4>{}, f1); BOOST_TEST_EQ(fn4(2, 3, 4), 1234); } { BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m1>, F1 const&>)); BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m2>, F1 const&>)); BOOST_TEST_TRAIT_FALSE((std::is_constructible, compat::nontype_t<&F1::m3>, F1 const&>)); F1 f1; compat::function_ref fn4(compat::nontype_t<&F1::m4>{}, f1); BOOST_TEST_EQ(fn4(2, 3, 4), 1234); auto const& f1_2 = f1; compat::function_ref fn4_2(compat::nontype_t<&F1::m4>{}, f1_2); BOOST_TEST_EQ(fn4_2(2, 3, 4), 1234); } { BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m1>, F1*>)); BOOST_TEST_TRAIT_TRUE( (std::is_constructible, compat::nontype_t<&F1::m2>, F1*>)); BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m3>, F1*>)); BOOST_TEST_TRAIT_TRUE( (std::is_constructible, compat::nontype_t<&F1::m4>, F1*>)); F1 f1; compat::function_ref fn2(compat::nontype_t<&F1::m2>{}, &f1); BOOST_TEST_EQ(fn2(2), 12); compat::function_ref fn4(compat::nontype_t<&F1::m4>{}, &f1); BOOST_TEST_EQ(fn4(2, 3, 4), 1234); } { BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m1>, F1 const*>)); BOOST_TEST_TRAIT_FALSE( (std::is_constructible, compat::nontype_t<&F1::m2>, F1 const*>)); BOOST_TEST_TRAIT_FALSE((std::is_constructible, compat::nontype_t<&F1::m3>, F1 const*>)); F1 const f1; compat::function_ref fn4(compat::nontype_t<&F1::m4>{}, &f1); BOOST_TEST_EQ(fn4(2, 3, 4), 1234); auto const& f1_2 = f1; compat::function_ref fn4_2(compat::nontype_t<&F1::m4>{}, &f1_2); BOOST_TEST_EQ(fn4_2(2, 3, 4), 1234); } return boost::report_errors(); } #endif