diff options
author | Steven Le Rouzic <steven.lerouzic@gmail.com> | 2025-03-11 23:51:51 +0100 |
---|---|---|
committer | Steven Le Rouzic <steven.lerouzic@gmail.com> | 2025-03-11 23:51:51 +0100 |
commit | af4e29f8c071b089fb46b5d8b964dd2b1fb3f57a (patch) | |
tree | 13d2607d79b54750bca4d7ef11220faa9e4eecc0 /asl/base/meta_tests.cpp | |
parent | 636882316b5191931e144212d93665c10859ac95 (diff) |
Remake deref
Diffstat (limited to 'asl/base/meta_tests.cpp')
-rw-r--r-- | asl/base/meta_tests.cpp | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/asl/base/meta_tests.cpp b/asl/base/meta_tests.cpp index 774f9bc..6c8efab 100644 --- a/asl/base/meta_tests.cpp +++ b/asl/base/meta_tests.cpp @@ -255,16 +255,22 @@ static_assert(asl::is_enum<Enum2>); static_assert(asl::derefs_as<int, int>); static_assert(asl::derefs_as<int*, int>); +static_assert(!asl::derefs_as<const int*, int>); static_assert(asl::derefs_as<int&, int>); +static_assert(!asl::derefs_as<const int&, int>); static_assert(asl::derefs_as<asl::box<int>, int>); static_assert(asl::derefs_as<Derived, Base>); +static_assert(!asl::derefs_as<Base, Derived>); static_assert(asl::derefs_as<Derived*, Base>); static_assert(asl::derefs_as<Derived&, Base>); +static_assert(!asl::derefs_as<Base&, Derived>); static_assert(asl::derefs_as<asl::box<Derived>, Base>); +static_assert(asl::derefs_as<asl::box<Derived>, Derived>); +static_assert(asl::derefs_as<asl::box<Base>, Base>); static void wants_int(int) {} -static void wants_base(Base&) {} +static void wants_base(const Base&) {} static void wants_base_ptr(Base*) {} ASL_TEST(deref) @@ -285,10 +291,11 @@ ASL_TEST(deref) wants_base(asl::deref<Base>(&c)); wants_base(asl::deref<Base>(d)); - wants_base_ptr(&asl::deref<Base>(Derived{})); wants_base_ptr(&asl::deref<Base>(c)); wants_base_ptr(&asl::deref<Base>(&c)); wants_base_ptr(&asl::deref<Base>(d)); + + wants_base(asl::deref<Base>(std::move(d))); } static_assert(asl::same_as<asl::copy_cref_t<int, float>, float>); |