mirror of
https://github.com/BlackMATov/meta.hpp.git
synced 2025-12-13 11:17:06 +07:00
fix internal class vs const class types resolving
This commit is contained in:
52
develop/untests/meta_issues/random_issue_2.cpp
Normal file
52
develop/untests/meta_issues/random_issue_2.cpp
Normal file
@@ -0,0 +1,52 @@
|
||||
/*******************************************************************************
|
||||
* This file is part of the "https://github.com/blackmatov/meta.hpp"
|
||||
* For conditions of distribution and use, see copyright notice in LICENSE.md
|
||||
* Copyright (C) 2021-2023, by Matvey Cherevko (blackmatov@gmail.com)
|
||||
******************************************************************************/
|
||||
|
||||
#include <meta.hpp/meta_all.hpp>
|
||||
#include <doctest/doctest.h>
|
||||
|
||||
namespace
|
||||
{
|
||||
struct A {};
|
||||
enum class E {};
|
||||
}
|
||||
|
||||
TEST_CASE("meta/meta_issues/random/2") {
|
||||
namespace meta = meta_hpp;
|
||||
|
||||
CHECK(meta::resolve_type<A[]>() == meta::resolve_type<const A[]>());
|
||||
CHECK(meta::resolve_type<A[]>() == meta::resolve_type<volatile A[]>());
|
||||
CHECK(meta::resolve_type<A[]>() == meta::resolve_type<const volatile A[]>());
|
||||
|
||||
CHECK(meta::resolve_type<A>() == meta::resolve_type<const A>());
|
||||
CHECK(meta::resolve_type<A>() == meta::resolve_type<volatile A>());
|
||||
CHECK(meta::resolve_type<A>() == meta::resolve_type<const volatile A>());
|
||||
|
||||
CHECK(meta::resolve_type<E>() == meta::resolve_type<const E>());
|
||||
CHECK(meta::resolve_type<E>() == meta::resolve_type<volatile E>());
|
||||
CHECK(meta::resolve_type<E>() == meta::resolve_type<const volatile E>());
|
||||
|
||||
CHECK(meta::resolve_type<int>() == meta::resolve_type<const int>());
|
||||
CHECK(meta::resolve_type<int>() == meta::resolve_type<volatile int>());
|
||||
CHECK(meta::resolve_type<int>() == meta::resolve_type<const volatile int>());
|
||||
|
||||
meta::detail::type_registry& r = meta::detail::type_registry::instance();
|
||||
|
||||
CHECK(r.resolve_array_type<A[]>() == r.resolve_array_type<const A[]>());
|
||||
CHECK(r.resolve_array_type<A[]>() == r.resolve_array_type<volatile A[]>());
|
||||
CHECK(r.resolve_array_type<A[]>() == r.resolve_array_type<const volatile A[]>());
|
||||
|
||||
CHECK(r.resolve_class_type<A>() == r.resolve_class_type<const A>());
|
||||
CHECK(r.resolve_class_type<A>() == r.resolve_class_type<volatile A>());
|
||||
CHECK(r.resolve_class_type<A>() == r.resolve_class_type<const volatile A>());
|
||||
|
||||
CHECK(r.resolve_enum_type<E>() == r.resolve_enum_type<const E>());
|
||||
CHECK(r.resolve_enum_type<E>() == r.resolve_enum_type<volatile E>());
|
||||
CHECK(r.resolve_enum_type<E>() == r.resolve_enum_type<const volatile E>());
|
||||
|
||||
CHECK(r.resolve_number_type<int>() == r.resolve_number_type<const int>());
|
||||
CHECK(r.resolve_number_type<int>() == r.resolve_number_type<volatile int>());
|
||||
CHECK(r.resolve_number_type<int>() == r.resolve_number_type<const volatile int>());
|
||||
}
|
||||
Reference in New Issue
Block a user