| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683 |
- #include <type_traits>
- #include <gtest/gtest.h>
- #include <entt/core/hashed_string.hpp>
- #include <entt/core/utility.hpp>
- #include <entt/meta/factory.hpp>
- #include <entt/meta/meta.hpp>
- enum class properties {
- prop_int,
- prop_bool
- };
- struct empty_type {
- virtual ~empty_type() = default;
- static void destroy(empty_type *) {
- ++counter;
- }
- inline static int counter = 0;
- };
- struct fat_type: empty_type {
- fat_type() = default;
- fat_type(int *value)
- : foo{value}, bar{value}
- {}
- int *foo{nullptr};
- int *bar{nullptr};
- bool operator==(const fat_type &other) const {
- return foo == other.foo && bar == other.bar;
- }
- };
- union union_type {
- int i;
- double d;
- };
- bool operator!=(const fat_type &lhs, const fat_type &rhs) {
- return !(lhs == rhs);
- }
- struct base_type {
- virtual ~base_type() = default;
- };
- struct derived_type: base_type {
- derived_type() = default;
- derived_type(const base_type &, int value, char character)
- : i{value}, c{character}
- {}
- const int i{};
- const char c{};
- };
- derived_type derived_factory(const base_type &, int value) {
- return {derived_type{}, value, 'c'};
- }
- struct data_type {
- int i{0};
- const int j{1};
- inline static int h{2};
- inline static const int k{3};
- empty_type empty{};
- };
- struct array_type {
- static inline int global[3];
- int local[3];
- };
- struct func_type {
- int f(const base_type &, int a, int b) { return f(a, b); }
- int f(int a, int b) { value = a; return b*b; }
- int f(int v) const { return v*v; }
- void g(int v) { value = v*v; }
- static int h(int v) { return v; }
- static void k(int v) { value = v; }
- inline static int value = 0;
- };
- struct setter_getter_type {
- int value{};
- int setter(int val) { return value = val; }
- int getter() { return value; }
- int setter_with_ref(const int &val) { return value = val; }
- const int & getter_with_ref() { return value; }
- static int static_setter(setter_getter_type *type, int value) { return type->value = value; }
- static int static_getter(const setter_getter_type *type) { return type->value; }
- };
- struct not_comparable_type {
- bool operator==(const not_comparable_type &) const = delete;
- };
- bool operator!=(const not_comparable_type &, const not_comparable_type &) = delete;
- struct an_abstract_type {
- virtual ~an_abstract_type() = default;
- void f(int v) { i = v; }
- virtual void g(int) = 0;
- int i{};
- };
- struct another_abstract_type {
- virtual ~another_abstract_type() = default;
- virtual void h(char) = 0;
- char j{};
- };
- struct concrete_type: an_abstract_type, another_abstract_type {
- void f(int v) { i = v*v; } // hide, it's ok :-)
- void g(int v) override { i = -v; }
- void h(char c) override { j = c; }
- };
- struct Meta: public ::testing::Test {
- static void SetUpTestCase() {
- entt::reflect<double>().conv<int>();
- entt::reflect<char>("char"_hs, std::make_pair(properties::prop_int, 42));
- entt::reflect<properties>()
- .data<properties::prop_bool>("prop_bool"_hs)
- .data<properties::prop_int>("prop_int"_hs);
- entt::reflect<unsigned int>().data<0u>("min"_hs).data<100u>("max"_hs);
- entt::reflect<base_type>("base"_hs);
- entt::reflect<derived_type>("derived"_hs, std::make_pair(properties::prop_int, 99))
- .base<base_type>()
- .ctor<const base_type &, int, char>(std::make_pair(properties::prop_bool, false))
- .ctor<&derived_factory>(std::make_pair(properties::prop_int, 42));
- entt::reflect<empty_type>("empty"_hs)
- .dtor<&empty_type::destroy>();
- entt::reflect<fat_type>("fat"_hs)
- .base<empty_type>()
- .dtor<&fat_type::destroy>();
- entt::reflect<data_type>("data"_hs)
- .data<&data_type::i>("i"_hs, std::make_pair(properties::prop_int, 0))
- .data<&data_type::j>("j"_hs, std::make_pair(properties::prop_int, 1))
- .data<&data_type::h>("h"_hs, std::make_pair(properties::prop_int, 2))
- .data<&data_type::k>("k"_hs, std::make_pair(properties::prop_int, 3))
- .data<&data_type::empty>("empty"_hs);
- entt::reflect<array_type>("array"_hs)
- .data<&array_type::global>("global"_hs)
- .data<&array_type::local>("local"_hs);
- entt::reflect<func_type>("func"_hs)
- .func<entt::overload<int(const base_type &, int, int)>(&func_type::f)>("f3"_hs)
- .func<entt::overload<int(int, int)>(&func_type::f)>("f2"_hs, std::make_pair(properties::prop_bool, false))
- .func<entt::overload<int(int) const>(&func_type::f)>("f1"_hs, std::make_pair(properties::prop_bool, false))
- .func<&func_type::g>("g"_hs, std::make_pair(properties::prop_bool, false))
- .func<&func_type::h>("h"_hs, std::make_pair(properties::prop_bool, false))
- .func<&func_type::k>("k"_hs, std::make_pair(properties::prop_bool, false));
- entt::reflect<setter_getter_type>("setter_getter"_hs)
- .data<&setter_getter_type::static_setter, &setter_getter_type::static_getter>("x"_hs)
- .data<&setter_getter_type::setter, &setter_getter_type::getter>("y"_hs)
- .data<&setter_getter_type::static_setter, &setter_getter_type::getter>("z"_hs)
- .data<&setter_getter_type::setter_with_ref, &setter_getter_type::getter_with_ref>("w"_hs);
- entt::reflect<an_abstract_type>("an_abstract_type"_hs, std::make_pair(properties::prop_bool, false))
- .data<&an_abstract_type::i>("i"_hs)
- .func<&an_abstract_type::f>("f"_hs)
- .func<&an_abstract_type::g>("g"_hs);
- entt::reflect<another_abstract_type>("another_abstract_type"_hs, std::make_pair(properties::prop_int, 42))
- .data<&another_abstract_type::j>("j"_hs)
- .func<&another_abstract_type::h>("h"_hs);
- entt::reflect<concrete_type>("concrete"_hs)
- .base<an_abstract_type>()
- .base<another_abstract_type>()
- .func<&concrete_type::f>("f"_hs);
- }
- static void SetUpAfterUnregistration() {
- entt::reflect<double>().conv<float>();
- entt::reflect<derived_type>("my_type"_hs, std::make_pair(properties::prop_bool, false))
- .ctor<>();
- entt::reflect<another_abstract_type>("your_type"_hs)
- .data<&another_abstract_type::j>("a_data_member"_hs)
- .func<&another_abstract_type::h>("a_member_function"_hs);
- }
- void SetUp() override {
- empty_type::counter = 0;
- func_type::value = 0;
- }
- };
- TEST_F(Meta, Resolve) {
- ASSERT_EQ(entt::resolve<derived_type>(), entt::resolve("derived"_hs));
- bool found = false;
- entt::resolve([&found](auto type) {
- found = found || type == entt::resolve<derived_type>();
- });
- ASSERT_TRUE(found);
- }
- TEST_F(Meta, MetaAnySBO) {
- entt::meta_any any{'c'};
- ASSERT_TRUE(any);
- ASSERT_FALSE(any.can_cast<void>());
- ASSERT_TRUE(any.can_cast<char>());
- ASSERT_EQ(any.cast<char>(), 'c');
- ASSERT_EQ(std::as_const(any).cast<char>(), 'c');
- ASSERT_NE(any.data(), nullptr);
- ASSERT_NE(std::as_const(any).data(), nullptr);
- ASSERT_EQ(any, entt::meta_any{'c'});
- ASSERT_NE(any, entt::meta_any{'h'});
- }
- TEST_F(Meta, MetaAnyNoSBO) {
- int value = 42;
- fat_type instance{&value};
- entt::meta_any any{instance};
- ASSERT_TRUE(any);
- ASSERT_FALSE(any.can_cast<void>());
- ASSERT_TRUE(any.can_cast<fat_type>());
- ASSERT_EQ(any.cast<fat_type>(), instance);
- ASSERT_EQ(std::as_const(any).cast<fat_type>(), instance);
- ASSERT_NE(any.data(), nullptr);
- ASSERT_NE(std::as_const(any).data(), nullptr);
- ASSERT_EQ(any, entt::meta_any{instance});
- ASSERT_NE(any, fat_type{});
- }
- TEST_F(Meta, MetaAnyEmpty) {
- entt::meta_any any{};
- ASSERT_FALSE(any);
- ASSERT_FALSE(any.type());
- ASSERT_FALSE(any.can_cast<void>());
- ASSERT_FALSE(any.can_cast<empty_type>());
- ASSERT_EQ(any.data(), nullptr);
- ASSERT_EQ(std::as_const(any).data(), nullptr);
- ASSERT_EQ(any, entt::meta_any{});
- ASSERT_NE(any, entt::meta_any{'c'});
- }
- TEST_F(Meta, MetaAnySBOInPlaceConstruction) {
- entt::meta_any any{std::in_place_type<int>, 42};
- ASSERT_TRUE(any);
- ASSERT_FALSE(any.can_cast<void>());
- ASSERT_TRUE(any.can_cast<int>());
- ASSERT_EQ(any.cast<int>(), 42);
- ASSERT_EQ(std::as_const(any).cast<int>(), 42);
- ASSERT_NE(any.data(), nullptr);
- ASSERT_NE(std::as_const(any).data(), nullptr);
- ASSERT_EQ(any, (entt::meta_any{std::in_place_type<int>, 42}));
- ASSERT_EQ(any, entt::meta_any{42});
- ASSERT_NE(any, entt::meta_any{3});
- }
- TEST_F(Meta, MetaAnySBOCopyConstruction) {
- entt::meta_any any{42};
- entt::meta_any other{any};
- ASSERT_TRUE(any);
- ASSERT_TRUE(other);
- ASSERT_FALSE(other.can_cast<void>());
- ASSERT_TRUE(other.can_cast<int>());
- ASSERT_EQ(other.cast<int>(), 42);
- ASSERT_EQ(std::as_const(other).cast<int>(), 42);
- ASSERT_EQ(other, entt::meta_any{42});
- ASSERT_NE(other, entt::meta_any{0});
- }
- TEST_F(Meta, MetaAnySBOCopyAssignment) {
- entt::meta_any any{42};
- entt::meta_any other{3};
- other = any;
- ASSERT_TRUE(any);
- ASSERT_TRUE(other);
- ASSERT_FALSE(other.can_cast<void>());
- ASSERT_TRUE(other.can_cast<int>());
- ASSERT_EQ(other.cast<int>(), 42);
- ASSERT_EQ(std::as_const(other).cast<int>(), 42);
- ASSERT_EQ(other, entt::meta_any{42});
- ASSERT_NE(other, entt::meta_any{0});
- }
- TEST_F(Meta, MetaAnySBOMoveConstruction) {
- entt::meta_any any{42};
- entt::meta_any other{std::move(any)};
- ASSERT_FALSE(any);
- ASSERT_TRUE(other);
- ASSERT_FALSE(other.can_cast<void>());
- ASSERT_TRUE(other.can_cast<int>());
- ASSERT_EQ(other.cast<int>(), 42);
- ASSERT_EQ(std::as_const(other).cast<int>(), 42);
- ASSERT_EQ(other, entt::meta_any{42});
- ASSERT_NE(other, entt::meta_any{0});
- }
- TEST_F(Meta, MetaAnySBOMoveAssignment) {
- entt::meta_any any{42};
- entt::meta_any other{3};
- other = std::move(any);
- ASSERT_FALSE(any);
- ASSERT_TRUE(other);
- ASSERT_FALSE(other.can_cast<void>());
- ASSERT_TRUE(other.can_cast<int>());
- ASSERT_EQ(other.cast<int>(), 42);
- ASSERT_EQ(std::as_const(other).cast<int>(), 42);
- ASSERT_EQ(other, entt::meta_any{42});
- ASSERT_NE(other, entt::meta_any{0});
- }
- TEST_F(Meta, MetaAnyNoSBOInPlaceConstruction) {
- int value = 42;
- fat_type instance{&value};
- entt::meta_any any{std::in_place_type<fat_type>, instance};
- ASSERT_TRUE(any);
- ASSERT_FALSE(any.can_cast<void>());
- ASSERT_TRUE(any.can_cast<fat_type>());
- ASSERT_EQ(any.cast<fat_type>(), instance);
- ASSERT_EQ(std::as_const(any).cast<fat_type>(), instance);
- ASSERT_NE(any.data(), nullptr);
- ASSERT_NE(std::as_const(any).data(), nullptr);
- ASSERT_EQ(any, (entt::meta_any{std::in_place_type<fat_type>, instance}));
- ASSERT_EQ(any, entt::meta_any{instance});
- ASSERT_NE(any, entt::meta_any{fat_type{}});
- }
- TEST_F(Meta, MetaAnyNoSBOCopyConstruction) {
- int value = 42;
- fat_type instance{&value};
- entt::meta_any any{instance};
- entt::meta_any other{any};
- ASSERT_TRUE(any);
- ASSERT_TRUE(other);
- ASSERT_FALSE(other.can_cast<void>());
- ASSERT_TRUE(other.can_cast<fat_type>());
- ASSERT_EQ(other.cast<fat_type>(), instance);
- ASSERT_EQ(std::as_const(other).cast<fat_type>(), instance);
- ASSERT_EQ(other, entt::meta_any{instance});
- ASSERT_NE(other, fat_type{});
- }
- TEST_F(Meta, MetaAnyNoSBOCopyAssignment) {
- int value = 42;
- fat_type instance{&value};
- entt::meta_any any{instance};
- entt::meta_any other{3};
- other = any;
- ASSERT_TRUE(any);
- ASSERT_TRUE(other);
- ASSERT_FALSE(other.can_cast<void>());
- ASSERT_TRUE(other.can_cast<fat_type>());
- ASSERT_EQ(other.cast<fat_type>(), instance);
- ASSERT_EQ(std::as_const(other).cast<fat_type>(), instance);
- ASSERT_EQ(other, entt::meta_any{instance});
- ASSERT_NE(other, fat_type{});
- }
- TEST_F(Meta, MetaAnyNoSBOMoveConstruction) {
- int value = 42;
- fat_type instance{&value};
- entt::meta_any any{instance};
- entt::meta_any other{std::move(any)};
- ASSERT_FALSE(any);
- ASSERT_TRUE(other);
- ASSERT_FALSE(other.can_cast<void>());
- ASSERT_TRUE(other.can_cast<fat_type>());
- ASSERT_EQ(other.cast<fat_type>(), instance);
- ASSERT_EQ(std::as_const(other).cast<fat_type>(), instance);
- ASSERT_EQ(other, entt::meta_any{instance});
- ASSERT_NE(other, fat_type{});
- }
- TEST_F(Meta, MetaAnyNoSBOMoveAssignment) {
- int value = 42;
- fat_type instance{&value};
- entt::meta_any any{instance};
- entt::meta_any other{3};
- other = std::move(any);
- ASSERT_FALSE(any);
- ASSERT_TRUE(other);
- ASSERT_FALSE(other.can_cast<void>());
- ASSERT_TRUE(other.can_cast<fat_type>());
- ASSERT_EQ(other.cast<fat_type>(), instance);
- ASSERT_EQ(std::as_const(other).cast<fat_type>(), instance);
- ASSERT_EQ(other, entt::meta_any{instance});
- ASSERT_NE(other, fat_type{});
- }
- TEST_F(Meta, MetaAnySBODestruction) {
- ASSERT_EQ(empty_type::counter, 0);
- { entt::meta_any any{empty_type{}}; }
- ASSERT_EQ(empty_type::counter, 1);
- }
- TEST_F(Meta, MetaAnyNoSBODestruction) {
- ASSERT_EQ(fat_type::counter, 0);
- { entt::meta_any any{fat_type{}}; }
- ASSERT_EQ(fat_type::counter, 1);
- }
- TEST_F(Meta, MetaAnyEmplace) {
- entt::meta_any any{};
- any.emplace<int>(42);
- ASSERT_TRUE(any);
- ASSERT_FALSE(any.can_cast<void>());
- ASSERT_TRUE(any.can_cast<int>());
- ASSERT_EQ(any.cast<int>(), 42);
- ASSERT_EQ(std::as_const(any).cast<int>(), 42);
- ASSERT_NE(any.data(), nullptr);
- ASSERT_NE(std::as_const(any).data(), nullptr);
- ASSERT_EQ(any, (entt::meta_any{std::in_place_type<int>, 42}));
- ASSERT_EQ(any, entt::meta_any{42});
- ASSERT_NE(any, entt::meta_any{3});
- }
- TEST_F(Meta, MetaAnySBOSwap) {
- entt::meta_any lhs{'c'};
- entt::meta_any rhs{42};
- std::swap(lhs, rhs);
- ASSERT_TRUE(lhs.can_cast<int>());
- ASSERT_EQ(lhs.cast<int>(), 42);
- ASSERT_TRUE(rhs.can_cast<char>());
- ASSERT_EQ(rhs.cast<char>(), 'c');
- }
- TEST_F(Meta, MetaAnyNoSBOSwap) {
- int i, j;
- entt::meta_any lhs{fat_type{&i}};
- entt::meta_any rhs{fat_type{&j}};
- std::swap(lhs, rhs);
- ASSERT_EQ(lhs.cast<fat_type>().foo, &j);
- ASSERT_EQ(rhs.cast<fat_type>().bar, &i);
- }
- TEST_F(Meta, MetaAnySBOWithNoSBOSwap) {
- int value = 42;
- entt::meta_any lhs{fat_type{&value}};
- entt::meta_any rhs{'c'};
- std::swap(lhs, rhs);
- ASSERT_TRUE(lhs.can_cast<char>());
- ASSERT_EQ(lhs.cast<char>(), 'c');
- ASSERT_TRUE(rhs.can_cast<fat_type>());
- ASSERT_EQ(rhs.cast<fat_type>().foo, &value);
- ASSERT_EQ(rhs.cast<fat_type>().bar, &value);
- }
- TEST_F(Meta, MetaAnySBOWithEmptySwap) {
- entt::meta_any lhs{'c'};
- entt::meta_any rhs{};
- std::swap(lhs, rhs);
- ASSERT_FALSE(lhs);
- ASSERT_TRUE(rhs.can_cast<char>());
- ASSERT_EQ(rhs.cast<char>(), 'c');
- std::swap(lhs, rhs);
- ASSERT_FALSE(rhs);
- ASSERT_TRUE(lhs.can_cast<char>());
- ASSERT_EQ(lhs.cast<char>(), 'c');
- }
- TEST_F(Meta, MetaAnyNoSBOWithEmptySwap) {
- int i;
- entt::meta_any lhs{fat_type{&i}};
- entt::meta_any rhs{};
- std::swap(lhs, rhs);
- ASSERT_EQ(rhs.cast<fat_type>().bar, &i);
- std::swap(lhs, rhs);
- ASSERT_EQ(lhs.cast<fat_type>().bar, &i);
- }
- TEST_F(Meta, MetaAnyComparable) {
- entt::meta_any any{'c'};
- ASSERT_EQ(any, any);
- ASSERT_EQ(any, entt::meta_any{'c'});
- ASSERT_NE(any, entt::meta_any{'a'});
- ASSERT_NE(any, entt::meta_any{});
- ASSERT_TRUE(any == any);
- ASSERT_TRUE(any == entt::meta_any{'c'});
- ASSERT_FALSE(any == entt::meta_any{'a'});
- ASSERT_TRUE(any != entt::meta_any{'a'});
- ASSERT_TRUE(any != entt::meta_any{});
- }
- TEST_F(Meta, MetaAnyNotComparable) {
- entt::meta_any any{not_comparable_type{}};
- ASSERT_EQ(any, any);
- ASSERT_NE(any, entt::meta_any{not_comparable_type{}});
- ASSERT_NE(any, entt::meta_any{});
- ASSERT_TRUE(any == any);
- ASSERT_FALSE(any == entt::meta_any{not_comparable_type{}});
- ASSERT_TRUE(any != entt::meta_any{});
- }
- TEST_F(Meta, MetaAnyCast) {
- entt::meta_any any{derived_type{}};
- entt::meta_handle handle{any};
- ASSERT_TRUE(any);
- ASSERT_EQ(any.type(), entt::resolve<derived_type>());
- ASSERT_FALSE(any.can_cast<void>());
- ASSERT_TRUE(any.can_cast<base_type>());
- ASSERT_TRUE(any.can_cast<derived_type>());
- ASSERT_EQ(&any.cast<base_type>(), handle.try_cast<base_type>());
- ASSERT_EQ(&any.cast<derived_type>(), handle.try_cast<derived_type>());
- ASSERT_EQ(&std::as_const(any).cast<base_type>(), handle.try_cast<base_type>());
- ASSERT_EQ(&std::as_const(any).cast<derived_type>(), handle.try_cast<derived_type>());
- }
- TEST_F(Meta, MetaAnyConvert) {
- entt::meta_any any{42.};
- ASSERT_TRUE(any);
- ASSERT_EQ(any.type(), entt::resolve<double>());
- ASSERT_FALSE(any.can_convert<char>());
- ASSERT_TRUE(any.can_convert<double>());
- ASSERT_TRUE(any.can_convert<int>());
- ASSERT_TRUE(any.convert<double>());
- ASSERT_FALSE(any.convert<char>());
- ASSERT_EQ(any.type(), entt::resolve<double>());
- ASSERT_EQ(any.cast<double>(), 42.);
- ASSERT_TRUE(any.convert<int>());
- ASSERT_EQ(any.type(), entt::resolve<int>());
- ASSERT_EQ(any.cast<int>(), 42);
- }
- TEST_F(Meta, MetaAnyConstConvert) {
- const entt::meta_any any{42.};
- ASSERT_TRUE(any);
- ASSERT_EQ(any.type(), entt::resolve<double>());
- ASSERT_FALSE(any.can_convert<char>());
- ASSERT_TRUE(any.can_convert<double>());
- ASSERT_TRUE(any.can_convert<int>());
- ASSERT_TRUE(any.convert<double>());
- ASSERT_FALSE(any.convert<char>());
- ASSERT_EQ(any.type(), entt::resolve<double>());
- ASSERT_EQ(any.cast<double>(), 42.);
- auto other = any.convert<int>();
- ASSERT_EQ(any.type(), entt::resolve<double>());
- ASSERT_EQ(any.cast<double>(), 42.);
- ASSERT_EQ(other.type(), entt::resolve<int>());
- ASSERT_EQ(other.cast<int>(), 42);
- }
- TEST_F(Meta, MetaHandleFromObject) {
- empty_type empty{};
- entt::meta_handle handle{empty};
- ASSERT_TRUE(handle);
- ASSERT_EQ(handle.type(), entt::resolve<empty_type>());
- ASSERT_EQ(handle.try_cast<void>(), nullptr);
- ASSERT_EQ(handle.try_cast<empty_type>(), &empty);
- ASSERT_EQ(std::as_const(handle).try_cast<empty_type>(), &empty);
- ASSERT_EQ(handle.data(), &empty);
- ASSERT_EQ(std::as_const(handle).data(), &empty);
- }
- TEST_F(Meta, MetaHandleFromMetaAny) {
- entt::meta_any any{42};
- entt::meta_handle handle{any};
- ASSERT_TRUE(handle);
- ASSERT_EQ(handle.type(), entt::resolve<int>());
- ASSERT_EQ(handle.try_cast<void>(), nullptr);
- ASSERT_EQ(handle.try_cast<int>(), any.data());
- ASSERT_EQ(std::as_const(handle).try_cast<int>(), any.data());
- ASSERT_EQ(handle.data(), any.data());
- ASSERT_EQ(std::as_const(handle).data(), any.data());
- }
- TEST_F(Meta, MetaHandleEmpty) {
- entt::meta_handle handle{};
- ASSERT_FALSE(handle);
- ASSERT_FALSE(handle.type());
- ASSERT_EQ(handle.try_cast<void>(), nullptr);
- ASSERT_EQ(handle.try_cast<empty_type>(), nullptr);
- ASSERT_EQ(handle.data(), nullptr);
- ASSERT_EQ(std::as_const(handle).data(), nullptr);
- }
- TEST_F(Meta, MetaHandleTryCast) {
- derived_type derived{};
- base_type *base = &derived;
- entt::meta_handle handle{derived};
- ASSERT_TRUE(handle);
- ASSERT_EQ(handle.type(), entt::resolve<derived_type>());
- ASSERT_EQ(handle.try_cast<void>(), nullptr);
- ASSERT_EQ(handle.try_cast<base_type>(), base);
- ASSERT_EQ(handle.try_cast<derived_type>(), &derived);
- ASSERT_EQ(std::as_const(handle).try_cast<base_type>(), base);
- ASSERT_EQ(std::as_const(handle).try_cast<derived_type>(), &derived);
- ASSERT_EQ(handle.data(), &derived);
- ASSERT_EQ(std::as_const(handle).data(), &derived);
- }
- TEST_F(Meta, MetaProp) {
- auto prop = entt::resolve<char>().prop(properties::prop_int);
- ASSERT_TRUE(prop);
- ASSERT_NE(prop, entt::meta_prop{});
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 42);
- }
- TEST_F(Meta, MetaBase) {
- auto base = entt::resolve<derived_type>().base("base"_hs);
- derived_type derived{};
- ASSERT_TRUE(base);
- ASSERT_NE(base, entt::meta_base{});
- ASSERT_EQ(base.parent(), entt::resolve("derived"_hs));
- ASSERT_EQ(base.type(), entt::resolve<base_type>());
- ASSERT_EQ(base.cast(&derived), static_cast<base_type *>(&derived));
- }
- TEST_F(Meta, MetaConv) {
- auto conv = entt::resolve<double>().conv<int>();
- double value = 3.;
- ASSERT_TRUE(conv);
- ASSERT_NE(conv, entt::meta_conv{});
- ASSERT_EQ(conv.parent(), entt::resolve<double>());
- ASSERT_EQ(conv.type(), entt::resolve<int>());
- auto any = conv.convert(&value);
- ASSERT_TRUE(any);
- ASSERT_EQ(any.type(), entt::resolve<int>());
- ASSERT_EQ(any.cast<int>(), 3);
- }
- TEST_F(Meta, MetaCtor) {
- auto ctor = entt::resolve<derived_type>().ctor<const base_type &, int, char>();
- ASSERT_TRUE(ctor);
- ASSERT_NE(ctor, entt::meta_ctor{});
- ASSERT_EQ(ctor.parent(), entt::resolve("derived"_hs));
- ASSERT_EQ(ctor.size(), entt::meta_ctor::size_type{3});
- ASSERT_EQ(ctor.arg(entt::meta_ctor::size_type{0}), entt::resolve<base_type>());
- ASSERT_EQ(ctor.arg(entt::meta_ctor::size_type{1}), entt::resolve<int>());
- ASSERT_EQ(ctor.arg(entt::meta_ctor::size_type{2}), entt::resolve<char>());
- ASSERT_FALSE(ctor.arg(entt::meta_ctor::size_type{3}));
- auto any = ctor.invoke(base_type{}, 42, 'c');
- auto empty = ctor.invoke();
- ASSERT_FALSE(empty);
- ASSERT_TRUE(any);
- ASSERT_TRUE(any.can_cast<derived_type>());
- ASSERT_EQ(any.cast<derived_type>().i, 42);
- ASSERT_EQ(any.cast<derived_type>().c, 'c');
- ctor.prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().template cast<bool>());
- });
- ASSERT_FALSE(ctor.prop(properties::prop_int));
- auto prop = ctor.prop(properties::prop_bool);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().template cast<bool>());
- }
- TEST_F(Meta, MetaCtorFunc) {
- auto ctor = entt::resolve<derived_type>().ctor<const base_type &, int>();
- ASSERT_TRUE(ctor);
- ASSERT_EQ(ctor.parent(), entt::resolve("derived"_hs));
- ASSERT_EQ(ctor.size(), entt::meta_ctor::size_type{2});
- ASSERT_EQ(ctor.arg(entt::meta_ctor::size_type{0}), entt::resolve<base_type>());
- ASSERT_EQ(ctor.arg(entt::meta_ctor::size_type{1}), entt::resolve<int>());
- ASSERT_FALSE(ctor.arg(entt::meta_ctor::size_type{2}));
- auto any = ctor.invoke(derived_type{}, 42);
- auto empty = ctor.invoke(3, 'c');
- ASSERT_FALSE(empty);
- ASSERT_TRUE(any);
- ASSERT_TRUE(any.can_cast<derived_type>());
- ASSERT_EQ(any.cast<derived_type>().i, 42);
- ASSERT_EQ(any.cast<derived_type>().c, 'c');
- ctor.prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 42);
- });
- ASSERT_FALSE(ctor.prop(properties::prop_bool));
- auto prop = ctor.prop(properties::prop_int);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 42);
- }
- TEST_F(Meta, MetaCtorMetaAnyArgs) {
- auto ctor = entt::resolve<derived_type>().ctor<const base_type &, int, char>();
- auto any = ctor.invoke(base_type{}, entt::meta_any{42}, entt::meta_any{'c'});
- ASSERT_TRUE(any);
- ASSERT_TRUE(any.can_cast<derived_type>());
- ASSERT_EQ(any.cast<derived_type>().i, 42);
- ASSERT_EQ(any.cast<derived_type>().c, 'c');
- }
- TEST_F(Meta, MetaCtorInvalidArgs) {
- auto ctor = entt::resolve<derived_type>().ctor<const base_type &, int, char>();
- ASSERT_FALSE(ctor.invoke(base_type{}, entt::meta_any{'c'}, entt::meta_any{42}));
- }
- TEST_F(Meta, MetaCtorCastAndConvert) {
- auto ctor = entt::resolve<derived_type>().ctor<const base_type &, int, char>();
- auto any = ctor.invoke(entt::meta_any{derived_type{}}, entt::meta_any{42.}, entt::meta_any{'c'});
- ASSERT_TRUE(any);
- ASSERT_TRUE(any.can_cast<derived_type>());
- ASSERT_EQ(any.cast<derived_type>().i, 42);
- ASSERT_EQ(any.cast<derived_type>().c, 'c');
- }
- TEST_F(Meta, MetaCtorFuncMetaAnyArgs) {
- auto ctor = entt::resolve<derived_type>().ctor<const base_type &, int>();
- auto any = ctor.invoke(base_type{}, entt::meta_any{42});
- ASSERT_TRUE(any);
- ASSERT_TRUE(any.can_cast<derived_type>());
- ASSERT_EQ(any.cast<derived_type>().i, 42);
- ASSERT_EQ(any.cast<derived_type>().c, 'c');
- }
- TEST_F(Meta, MetaCtorFuncInvalidArgs) {
- auto ctor = entt::resolve<derived_type>().ctor<const base_type &, int>();
- ASSERT_FALSE(ctor.invoke(base_type{}, entt::meta_any{'c'}));
- }
- TEST_F(Meta, MetaCtorFuncCastAndConvert) {
- auto ctor = entt::resolve<derived_type>().ctor<const base_type &, int>();
- auto any = ctor.invoke(entt::meta_any{derived_type{}}, entt::meta_any{42.});
- ASSERT_TRUE(any);
- ASSERT_TRUE(any.can_cast<derived_type>());
- ASSERT_EQ(any.cast<derived_type>().i, 42);
- ASSERT_EQ(any.cast<derived_type>().c, 'c');
- }
- TEST_F(Meta, MetaDtor) {
- auto dtor = entt::resolve<empty_type>().dtor();
- empty_type empty{};
- ASSERT_TRUE(dtor);
- ASSERT_NE(dtor, entt::meta_dtor{});
- ASSERT_EQ(dtor.parent(), entt::resolve("empty"_hs));
- ASSERT_EQ(empty_type::counter, 0);
- ASSERT_TRUE(dtor.invoke(empty));
- ASSERT_EQ(empty_type::counter, 1);
- }
- TEST_F(Meta, MetaDtorMetaAnyArg) {
- auto dtor = entt::resolve<empty_type>().dtor();
- entt::meta_any any{empty_type{}};
- ASSERT_EQ(empty_type::counter, 0);
- ASSERT_TRUE(dtor.invoke(any));
- ASSERT_EQ(empty_type::counter, 1);
- }
- TEST_F(Meta, MetaDtorMetaAnyInvalidArg) {
- ASSERT_FALSE(entt::resolve<empty_type>().dtor().invoke(int{}));
- }
- TEST_F(Meta, MetaData) {
- auto data = entt::resolve<data_type>().data("i"_hs);
- data_type instance{};
- ASSERT_TRUE(data);
- ASSERT_NE(data, entt::meta_data{});
- ASSERT_EQ(data.parent(), entt::resolve("data"_hs));
- ASSERT_EQ(data.type(), entt::resolve<int>());
- ASSERT_EQ(data.identifier(), "i"_hs);
- ASSERT_FALSE(data.is_const());
- ASSERT_FALSE(data.is_static());
- ASSERT_EQ(data.get(instance).cast<int>(), 0);
- ASSERT_TRUE(data.set(instance, 42));
- ASSERT_EQ(data.get(instance).cast<int>(), 42);
- data.prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 0);
- });
- ASSERT_FALSE(data.prop(properties::prop_bool));
- auto prop = data.prop(properties::prop_int);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 0);
- }
- TEST_F(Meta, MetaDataConst) {
- auto data = entt::resolve<data_type>().data("j"_hs);
- data_type instance{};
- ASSERT_TRUE(data);
- ASSERT_EQ(data.parent(), entt::resolve("data"_hs));
- ASSERT_EQ(data.type(), entt::resolve<int>());
- ASSERT_EQ(data.identifier(), "j"_hs);
- ASSERT_TRUE(data.is_const());
- ASSERT_FALSE(data.is_static());
- ASSERT_EQ(data.get(instance).cast<int>(), 1);
- ASSERT_FALSE(data.set(instance, 42));
- ASSERT_EQ(data.get(instance).cast<int>(), 1);
- data.prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 1);
- });
- ASSERT_FALSE(data.prop(properties::prop_bool));
- auto prop = data.prop(properties::prop_int);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 1);
- }
- TEST_F(Meta, MetaDataStatic) {
- auto data = entt::resolve<data_type>().data("h"_hs);
- ASSERT_TRUE(data);
- ASSERT_EQ(data.parent(), entt::resolve("data"_hs));
- ASSERT_EQ(data.type(), entt::resolve<int>());
- ASSERT_EQ(data.identifier(), "h"_hs);
- ASSERT_FALSE(data.is_const());
- ASSERT_TRUE(data.is_static());
- ASSERT_EQ(data.get({}).cast<int>(), 2);
- ASSERT_TRUE(data.set({}, 42));
- ASSERT_EQ(data.get({}).cast<int>(), 42);
- data.prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 2);
- });
- ASSERT_FALSE(data.prop(properties::prop_bool));
- auto prop = data.prop(properties::prop_int);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 2);
- }
- TEST_F(Meta, MetaDataConstStatic) {
- auto data = entt::resolve<data_type>().data("k"_hs);
- ASSERT_TRUE(data);
- ASSERT_EQ(data.parent(), entt::resolve("data"_hs));
- ASSERT_EQ(data.type(), entt::resolve<int>());
- ASSERT_EQ(data.identifier(), "k"_hs);
- ASSERT_TRUE(data.is_const());
- ASSERT_TRUE(data.is_static());
- ASSERT_EQ(data.get({}).cast<int>(), 3);
- ASSERT_FALSE(data.set({}, 42));
- ASSERT_EQ(data.get({}).cast<int>(), 3);
- data.prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 3);
- });
- ASSERT_FALSE(data.prop(properties::prop_bool));
- auto prop = data.prop(properties::prop_int);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 3);
- }
- TEST_F(Meta, MetaDataGetMetaAnyArg) {
- auto data = entt::resolve<data_type>().data("i"_hs);
- entt::meta_any any{data_type{}};
- any.cast<data_type>().i = 99;
- const auto value = data.get(any);
- ASSERT_TRUE(value);
- ASSERT_TRUE(value.can_cast<int>());
- ASSERT_EQ(value.cast<int>(), 99);
- }
- TEST_F(Meta, MetaDataGetInvalidArg) {
- ASSERT_FALSE(entt::resolve<data_type>().data("i"_hs).get(0));
- }
- TEST_F(Meta, MetaDataSetMetaAnyArg) {
- auto data = entt::resolve<data_type>().data("i"_hs);
- entt::meta_any any{data_type{}};
- entt::meta_any value{42};
- ASSERT_EQ(any.cast<data_type>().i, 0);
- ASSERT_TRUE(data.set(any, value));
- ASSERT_EQ(any.cast<data_type>().i, 42);
- }
- TEST_F(Meta, MetaDataSetInvalidArg) {
- ASSERT_FALSE(entt::resolve<data_type>().data("i"_hs).set({}, 'c'));
- }
- TEST_F(Meta, MetaDataSetCast) {
- auto data = entt::resolve<data_type>().data("empty"_hs);
- data_type instance{};
- ASSERT_EQ(empty_type::counter, 0);
- ASSERT_TRUE(data.set(instance, fat_type{}));
- ASSERT_EQ(empty_type::counter, 1);
- }
- TEST_F(Meta, MetaDataSetConvert) {
- auto data = entt::resolve<data_type>().data("i"_hs);
- data_type instance{};
- ASSERT_EQ(instance.i, 0);
- ASSERT_TRUE(data.set(instance, 3.));
- ASSERT_EQ(instance.i, 3);
- }
- TEST_F(Meta, MetaDataSetterGetterAsFreeFunctions) {
- auto data = entt::resolve<setter_getter_type>().data("x"_hs);
- setter_getter_type instance{};
- ASSERT_TRUE(data);
- ASSERT_NE(data, entt::meta_data{});
- ASSERT_EQ(data.parent(), entt::resolve("setter_getter"_hs));
- ASSERT_EQ(data.type(), entt::resolve<int>());
- ASSERT_EQ(data.identifier(), "x"_hs);
- ASSERT_FALSE(data.is_const());
- ASSERT_FALSE(data.is_static());
- ASSERT_EQ(data.get(instance).cast<int>(), 0);
- ASSERT_TRUE(data.set(instance, 42));
- ASSERT_EQ(data.get(instance).cast<int>(), 42);
- }
- TEST_F(Meta, MetaDataSetterGetterAsMemberFunctions) {
- auto data = entt::resolve<setter_getter_type>().data("y"_hs);
- setter_getter_type instance{};
- ASSERT_TRUE(data);
- ASSERT_NE(data, entt::meta_data{});
- ASSERT_EQ(data.parent(), entt::resolve("setter_getter"_hs));
- ASSERT_EQ(data.type(), entt::resolve<int>());
- ASSERT_EQ(data.identifier(), "y"_hs);
- ASSERT_FALSE(data.is_const());
- ASSERT_FALSE(data.is_static());
- ASSERT_EQ(data.get(instance).cast<int>(), 0);
- ASSERT_TRUE(data.set(instance, 42));
- ASSERT_EQ(data.get(instance).cast<int>(), 42);
- }
- TEST_F(Meta, MetaDataSetterGetterWithRefAsMemberFunctions) {
- auto data = entt::resolve<setter_getter_type>().data("w"_hs);
- setter_getter_type instance{};
- ASSERT_TRUE(data);
- ASSERT_NE(data, entt::meta_data{});
- ASSERT_EQ(data.parent(), entt::resolve("setter_getter"_hs));
- ASSERT_EQ(data.type(), entt::resolve<int>());
- ASSERT_EQ(data.identifier(), "w"_hs);
- ASSERT_FALSE(data.is_const());
- ASSERT_FALSE(data.is_static());
- ASSERT_EQ(data.get(instance).cast<int>(), 0);
- ASSERT_TRUE(data.set(instance, 42));
- ASSERT_EQ(data.get(instance).cast<int>(), 42);
- }
- TEST_F(Meta, MetaDataSetterGetterMixed) {
- auto data = entt::resolve<setter_getter_type>().data("z"_hs);
- setter_getter_type instance{};
- ASSERT_TRUE(data);
- ASSERT_NE(data, entt::meta_data{});
- ASSERT_EQ(data.parent(), entt::resolve("setter_getter"_hs));
- ASSERT_EQ(data.type(), entt::resolve<int>());
- ASSERT_EQ(data.identifier(), "z"_hs);
- ASSERT_FALSE(data.is_const());
- ASSERT_FALSE(data.is_static());
- ASSERT_EQ(data.get(instance).cast<int>(), 0);
- ASSERT_TRUE(data.set(instance, 42));
- ASSERT_EQ(data.get(instance).cast<int>(), 42);
- }
- TEST_F(Meta, MetaDataArrayStatic) {
- auto data = entt::resolve<array_type>().data("global"_hs);
- array_type::global[0] = 3;
- array_type::global[1] = 5;
- array_type::global[2] = 7;
- ASSERT_TRUE(data);
- ASSERT_NE(data, entt::meta_data{});
- ASSERT_EQ(data.parent(), entt::resolve("array"_hs));
- ASSERT_EQ(data.type(), entt::resolve<int[3]>());
- ASSERT_EQ(data.identifier(), "global"_hs);
- ASSERT_FALSE(data.is_const());
- ASSERT_TRUE(data.is_static());
- ASSERT_TRUE(data.type().is_array());
- ASSERT_EQ(data.type().extent(), 3);
- ASSERT_EQ(data.get(nullptr, 0).cast<int>(), 3);
- ASSERT_EQ(data.get(nullptr, 1).cast<int>(), 5);
- ASSERT_EQ(data.get(nullptr, 2).cast<int>(), 7);
- ASSERT_FALSE(data.set(nullptr, 0, 'c'));
- ASSERT_EQ(data.get(nullptr, 0).cast<int>(), 3);
- ASSERT_TRUE(data.set(nullptr, 0, data.get(nullptr, 0).cast<int>()+2));
- ASSERT_TRUE(data.set(nullptr, 1, data.get(nullptr, 1).cast<int>()+2));
- ASSERT_TRUE(data.set(nullptr, 2, data.get(nullptr, 2).cast<int>()+2));
- ASSERT_EQ(data.get(nullptr, 0).cast<int>(), 5);
- ASSERT_EQ(data.get(nullptr, 1).cast<int>(), 7);
- ASSERT_EQ(data.get(nullptr, 2).cast<int>(), 9);
- }
- TEST_F(Meta, MetaDataArray) {
- auto data = entt::resolve<array_type>().data("local"_hs);
- array_type instance;
- instance.local[0] = 3;
- instance.local[1] = 5;
- instance.local[2] = 7;
- ASSERT_TRUE(data);
- ASSERT_NE(data, entt::meta_data{});
- ASSERT_EQ(data.parent(), entt::resolve("array"_hs));
- ASSERT_EQ(data.type(), entt::resolve<int[3]>());
- ASSERT_EQ(data.identifier(), "local"_hs);
- ASSERT_FALSE(data.is_const());
- ASSERT_FALSE(data.is_static());
- ASSERT_TRUE(data.type().is_array());
- ASSERT_EQ(data.type().extent(), 3);
- ASSERT_EQ(data.get(instance, 0).cast<int>(), 3);
- ASSERT_EQ(data.get(instance, 1).cast<int>(), 5);
- ASSERT_EQ(data.get(instance, 2).cast<int>(), 7);
- ASSERT_FALSE(data.set(instance, 0, 'c'));
- ASSERT_EQ(data.get(instance, 0).cast<int>(), 3);
- ASSERT_TRUE(data.set(instance, 0, data.get(instance, 0).cast<int>()+2));
- ASSERT_TRUE(data.set(instance, 1, data.get(instance, 1).cast<int>()+2));
- ASSERT_TRUE(data.set(instance, 2, data.get(instance, 2).cast<int>()+2));
- ASSERT_EQ(data.get(instance, 0).cast<int>(), 5);
- ASSERT_EQ(data.get(instance, 1).cast<int>(), 7);
- ASSERT_EQ(data.get(instance, 2).cast<int>(), 9);
- }
- TEST_F(Meta, MetaFunc) {
- auto func = entt::resolve<func_type>().func("f2"_hs);
- func_type instance{};
- ASSERT_TRUE(func);
- ASSERT_NE(func, entt::meta_func{});
- ASSERT_EQ(func.parent(), entt::resolve("func"_hs));
- ASSERT_EQ(func.identifier(), "f2"_hs);
- ASSERT_EQ(func.size(), entt::meta_func::size_type{2});
- ASSERT_FALSE(func.is_const());
- ASSERT_FALSE(func.is_static());
- ASSERT_EQ(func.ret(), entt::resolve<int>());
- ASSERT_EQ(func.arg(entt::meta_func::size_type{0}), entt::resolve<int>());
- ASSERT_EQ(func.arg(entt::meta_func::size_type{1}), entt::resolve<int>());
- ASSERT_FALSE(func.arg(entt::meta_func::size_type{2}));
- auto any = func.invoke(instance, 3, 2);
- auto empty = func.invoke(instance);
- ASSERT_FALSE(empty);
- ASSERT_TRUE(any);
- ASSERT_EQ(any.type(), entt::resolve<int>());
- ASSERT_EQ(any.cast<int>(), 4);
- ASSERT_EQ(func_type::value, 3);
- func.prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().template cast<bool>());
- });
- ASSERT_FALSE(func.prop(properties::prop_int));
- auto prop = func.prop(properties::prop_bool);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().cast<bool>());
- }
- TEST_F(Meta, MetaFuncConst) {
- auto func = entt::resolve<func_type>().func("f1"_hs);
- func_type instance{};
- ASSERT_TRUE(func);
- ASSERT_EQ(func.parent(), entt::resolve("func"_hs));
- ASSERT_EQ(func.identifier(), "f1"_hs);
- ASSERT_EQ(func.size(), entt::meta_func::size_type{1});
- ASSERT_TRUE(func.is_const());
- ASSERT_FALSE(func.is_static());
- ASSERT_EQ(func.ret(), entt::resolve<int>());
- ASSERT_EQ(func.arg(entt::meta_func::size_type{0}), entt::resolve<int>());
- ASSERT_FALSE(func.arg(entt::meta_func::size_type{1}));
- auto any = func.invoke(instance, 4);
- auto empty = func.invoke(instance, 'c');
- ASSERT_FALSE(empty);
- ASSERT_TRUE(any);
- ASSERT_EQ(any.type(), entt::resolve<int>());
- ASSERT_EQ(any.cast<int>(), 16);
- func.prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().template cast<bool>());
- });
- ASSERT_FALSE(func.prop(properties::prop_int));
- auto prop = func.prop(properties::prop_bool);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().cast<bool>());
- }
- TEST_F(Meta, MetaFuncRetVoid) {
- auto func = entt::resolve<func_type>().func("g"_hs);
- func_type instance{};
- ASSERT_TRUE(func);
- ASSERT_EQ(func.parent(), entt::resolve("func"_hs));
- ASSERT_EQ(func.identifier(), "g"_hs);
- ASSERT_EQ(func.size(), entt::meta_func::size_type{1});
- ASSERT_FALSE(func.is_const());
- ASSERT_FALSE(func.is_static());
- ASSERT_EQ(func.ret(), entt::resolve<void>());
- ASSERT_EQ(func.arg(entt::meta_func::size_type{0}), entt::resolve<int>());
- ASSERT_FALSE(func.arg(entt::meta_func::size_type{1}));
- auto any = func.invoke(instance, 5);
- ASSERT_FALSE(any);
- ASSERT_EQ(func_type::value, 25);
- func.prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().template cast<bool>());
- });
- ASSERT_FALSE(func.prop(properties::prop_int));
- auto prop = func.prop(properties::prop_bool);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().cast<bool>());
- }
- TEST_F(Meta, MetaFuncStatic) {
- auto func = entt::resolve<func_type>().func("h"_hs);
- ASSERT_TRUE(func);
- ASSERT_EQ(func.parent(), entt::resolve("func"_hs));
- ASSERT_EQ(func.identifier(), "h"_hs);
- ASSERT_EQ(func.size(), entt::meta_func::size_type{1});
- ASSERT_FALSE(func.is_const());
- ASSERT_TRUE(func.is_static());
- ASSERT_EQ(func.ret(), entt::resolve<int>());
- ASSERT_EQ(func.arg(entt::meta_func::size_type{0}), entt::resolve<int>());
- ASSERT_FALSE(func.arg(entt::meta_func::size_type{1}));
- auto any = func.invoke({}, 42);
- auto empty = func.invoke({}, 'c');
- ASSERT_FALSE(empty);
- ASSERT_TRUE(any);
- ASSERT_EQ(any.type(), entt::resolve<int>());
- ASSERT_EQ(any.cast<int>(), 42);
- func.prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().template cast<bool>());
- });
- ASSERT_FALSE(func.prop(properties::prop_int));
- auto prop = func.prop(properties::prop_bool);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().cast<bool>());
- }
- TEST_F(Meta, MetaFuncStaticRetVoid) {
- auto func = entt::resolve<func_type>().func("k"_hs);
- ASSERT_TRUE(func);
- ASSERT_EQ(func.parent(), entt::resolve("func"_hs));
- ASSERT_EQ(func.identifier(), "k"_hs);
- ASSERT_EQ(func.size(), entt::meta_func::size_type{1});
- ASSERT_FALSE(func.is_const());
- ASSERT_TRUE(func.is_static());
- ASSERT_EQ(func.ret(), entt::resolve<void>());
- ASSERT_EQ(func.arg(entt::meta_func::size_type{0}), entt::resolve<int>());
- ASSERT_FALSE(func.arg(entt::meta_func::size_type{1}));
- auto any = func.invoke({}, 42);
- ASSERT_FALSE(any);
- ASSERT_EQ(func_type::value, 42);
- func.prop([](auto *prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop->key(), properties::prop_bool);
- ASSERT_FALSE(prop->value().template cast<bool>());
- });
- ASSERT_FALSE(func.prop(properties::prop_int));
- auto prop = func.prop(properties::prop_bool);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().cast<bool>());
- }
- TEST_F(Meta, MetaFuncMetaAnyArgs) {
- auto func = entt::resolve<func_type>().func("f1"_hs);
- auto any = func.invoke(func_type{}, entt::meta_any{3});
- ASSERT_TRUE(any);
- ASSERT_EQ(any.type(), entt::resolve<int>());
- ASSERT_EQ(any.cast<int>(), 9);
- }
- TEST_F(Meta, MetaFuncInvalidArgs) {
- auto func = entt::resolve<func_type>().func("f1"_hs);
- ASSERT_FALSE(func.invoke(empty_type{}, entt::meta_any{'c'}));
- }
- TEST_F(Meta, MetaFuncCastAndConvert) {
- auto func = entt::resolve<func_type>().func("f3"_hs);
- auto any = func.invoke(func_type{}, derived_type{}, 0, 3.);
- ASSERT_TRUE(any);
- ASSERT_EQ(any.type(), entt::resolve<int>());
- ASSERT_EQ(any.cast<int>(), 9);
- }
- TEST_F(Meta, MetaType) {
- auto type = entt::resolve<derived_type>();
- ASSERT_TRUE(type);
- ASSERT_NE(type, entt::meta_type{});
- ASSERT_EQ(type.identifier(), "derived"_hs);
- type.prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 99);
- });
- ASSERT_FALSE(type.prop(properties::prop_bool));
- auto prop = type.prop(properties::prop_int);
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_int);
- ASSERT_EQ(prop.value(), 99);
- }
- TEST_F(Meta, MetaTypeTraits) {
- ASSERT_TRUE(entt::resolve<void>().is_void());
- ASSERT_TRUE(entt::resolve<bool>().is_integral());
- ASSERT_TRUE(entt::resolve<double>().is_floating_point());
- ASSERT_TRUE(entt::resolve<properties>().is_enum());
- ASSERT_TRUE(entt::resolve<union_type>().is_union());
- ASSERT_TRUE(entt::resolve<derived_type>().is_class());
- ASSERT_TRUE(entt::resolve<int *>().is_pointer());
- ASSERT_TRUE(entt::resolve<decltype(empty_type::destroy)>().is_function());
- ASSERT_TRUE(entt::resolve<decltype(&data_type::i)>().is_member_object_pointer());
- ASSERT_TRUE(entt::resolve<decltype(&func_type::g)>().is_member_function_pointer());
- }
- TEST_F(Meta, MetaTypeRemovePointer) {
- ASSERT_EQ(entt::resolve<void *>().remove_pointer(), entt::resolve<void>());
- ASSERT_EQ(entt::resolve<int(*)(char, double)>().remove_pointer(), entt::resolve<int(char, double)>());
- ASSERT_EQ(entt::resolve<derived_type>().remove_pointer(), entt::resolve<derived_type>());
- }
- TEST_F(Meta, MetaTypeBase) {
- auto type = entt::resolve<derived_type>();
- bool iterate = false;
- type.base([&iterate](auto base) {
- ASSERT_EQ(base.type(), entt::resolve<base_type>());
- iterate = true;
- });
- ASSERT_TRUE(iterate);
- ASSERT_EQ(type.base("base"_hs).type(), entt::resolve<base_type>());
- }
- TEST_F(Meta, MetaTypeConv) {
- auto type = entt::resolve<double>();
- bool iterate = false;
- type.conv([&iterate](auto conv) {
- ASSERT_EQ(conv.type(), entt::resolve<int>());
- iterate = true;
- });
- ASSERT_TRUE(iterate);
- auto conv = type.conv<int>();
- ASSERT_EQ(conv.type(), entt::resolve<int>());
- ASSERT_FALSE(type.conv<char>());
- }
- TEST_F(Meta, MetaTypeCtor) {
- auto type = entt::resolve<derived_type>();
- int counter{};
- type.ctor([&counter](auto) {
- ++counter;
- });
- ASSERT_EQ(counter, 2);
- ASSERT_TRUE((type.ctor<const base_type &, int>()));
- ASSERT_TRUE((type.ctor<const derived_type &, double>()));
- }
- TEST_F(Meta, MetaTypeDtor) {
- ASSERT_TRUE(entt::resolve<fat_type>().dtor());
- ASSERT_FALSE(entt::resolve<int>().dtor());
- }
- TEST_F(Meta, MetaTypeData) {
- auto type = entt::resolve<data_type>();
- int counter{};
- type.data([&counter](auto) {
- ++counter;
- });
- ASSERT_EQ(counter, 5);
- ASSERT_TRUE(type.data("i"_hs));
- }
- TEST_F(Meta, MetaTypeFunc) {
- auto type = entt::resolve<func_type>();
- int counter{};
- type.func([&counter](auto) {
- ++counter;
- });
- ASSERT_EQ(counter, 6);
- ASSERT_TRUE(type.func("f1"_hs));
- }
- TEST_F(Meta, MetaTypeConstruct) {
- auto type = entt::resolve<derived_type>();
- auto any = type.construct(base_type{}, 42, 'c');
- ASSERT_TRUE(any);
- ASSERT_TRUE(any.can_cast<derived_type>());
- ASSERT_EQ(any.cast<derived_type>().i, 42);
- ASSERT_EQ(any.cast<derived_type>().c, 'c');
- }
- TEST_F(Meta, MetaTypeConstructMetaAnyArgs) {
- auto type = entt::resolve<derived_type>();
- auto any = type.construct(entt::meta_any{base_type{}}, entt::meta_any{42}, entt::meta_any{'c'});
- ASSERT_TRUE(any);
- ASSERT_TRUE(any.can_cast<derived_type>());
- ASSERT_EQ(any.cast<derived_type>().i, 42);
- ASSERT_EQ(any.cast<derived_type>().c, 'c');
- }
- TEST_F(Meta, MetaTypeConstructInvalidArgs) {
- auto type = entt::resolve<derived_type>();
- auto any = type.construct(entt::meta_any{base_type{}}, entt::meta_any{'c'}, entt::meta_any{42});
- ASSERT_FALSE(any);
- }
- TEST_F(Meta, MetaTypeLessArgs) {
- auto type = entt::resolve<derived_type>();
- auto any = type.construct(base_type{});
- ASSERT_FALSE(any);
- }
- TEST_F(Meta, MetaTypeConstructCastAndConvert) {
- auto type = entt::resolve<derived_type>();
- auto any = type.construct(entt::meta_any{derived_type{}}, entt::meta_any{42.}, entt::meta_any{'c'});
- ASSERT_TRUE(any);
- ASSERT_TRUE(any.can_cast<derived_type>());
- ASSERT_EQ(any.cast<derived_type>().i, 42);
- ASSERT_EQ(any.cast<derived_type>().c, 'c');
- }
- TEST_F(Meta, MetaTypeDestroyDtor) {
- auto type = entt::resolve<empty_type>();
- ASSERT_EQ(empty_type::counter, 0);
- ASSERT_TRUE(type.destroy(empty_type{}));
- ASSERT_EQ(empty_type::counter, 1);
- }
- TEST_F(Meta, MetaTypeDestroyDtorInvalidArg) {
- auto type = entt::resolve<empty_type>();
- ASSERT_EQ(empty_type::counter, 0);
- ASSERT_FALSE(type.destroy('c'));
- ASSERT_EQ(empty_type::counter, 0);
- }
- TEST_F(Meta, MetaTypeDestroyDtorCastAndConvert) {
- auto type = entt::resolve<empty_type>();
- ASSERT_EQ(empty_type::counter, 0);
- ASSERT_FALSE(type.destroy(fat_type{}));
- ASSERT_EQ(empty_type::counter, 0);
- ASSERT_FALSE(entt::resolve<int>().destroy(42.));
- }
- TEST_F(Meta, MetaTypeDestroyNoDtor) {
- ASSERT_TRUE(entt::resolve<char>().destroy('c'));
- }
- TEST_F(Meta, MetaTypeDestroyNoDtorInvalidArg) {
- ASSERT_FALSE(entt::resolve<char>().destroy(42));
- }
- TEST_F(Meta, MetaTypeDestroyNoDtorVoid) {
- ASSERT_FALSE(entt::resolve<void>().destroy({}));
- }
- TEST_F(Meta, MetaTypeDestroyNoDtorCastAndConvert) {
- ASSERT_FALSE(entt::resolve<int>().destroy(42.));
- }
- TEST_F(Meta, MetaDataFromBase) {
- auto type = entt::resolve<concrete_type>();
- concrete_type instance;
- ASSERT_TRUE(type.data("i"_hs));
- ASSERT_TRUE(type.data("j"_hs));
- ASSERT_EQ(instance.i, 0);
- ASSERT_EQ(instance.j, char{});
- ASSERT_TRUE(type.data("i"_hs).set(instance, 3));
- ASSERT_TRUE(type.data("j"_hs).set(instance, 'c'));
- ASSERT_EQ(instance.i, 3);
- ASSERT_EQ(instance.j, 'c');
- }
- TEST_F(Meta, MetaFuncFromBase) {
- auto type = entt::resolve<concrete_type>();
- auto base = entt::resolve<an_abstract_type>();
- concrete_type instance;
- ASSERT_TRUE(type.func("f"_hs));
- ASSERT_TRUE(type.func("g"_hs));
- ASSERT_TRUE(type.func("h"_hs));
- ASSERT_EQ(type.func("f"_hs).parent(), entt::resolve<concrete_type>());
- ASSERT_EQ(type.func("g"_hs).parent(), entt::resolve<an_abstract_type>());
- ASSERT_EQ(type.func("h"_hs).parent(), entt::resolve<another_abstract_type>());
- ASSERT_EQ(instance.i, 0);
- ASSERT_EQ(instance.j, char{});
- type.func("f"_hs).invoke(instance, 3);
- type.func("h"_hs).invoke(instance, 'c');
- ASSERT_EQ(instance.i, 9);
- ASSERT_EQ(instance.j, 'c');
- base.func("g"_hs).invoke(instance, 3);
- ASSERT_EQ(instance.i, -3);
- }
- TEST_F(Meta, MetaPropFromBase) {
- auto type = entt::resolve<concrete_type>();
- auto prop_bool = type.prop(properties::prop_bool);
- auto prop_int = type.prop(properties::prop_int);
- ASSERT_TRUE(prop_bool);
- ASSERT_TRUE(prop_int);
- ASSERT_FALSE(prop_bool.value().cast<bool>());
- ASSERT_EQ(prop_int.value().cast<int>(), 42);
- }
- TEST_F(Meta, AbstractClass) {
- auto type = entt::resolve<an_abstract_type>();
- concrete_type instance;
- ASSERT_EQ(instance.i, 0);
- type.func("f"_hs).invoke(instance, 3);
- ASSERT_EQ(instance.i, 3);
- type.func("g"_hs).invoke(instance, 3);
- ASSERT_EQ(instance.i, -3);
- }
- TEST_F(Meta, EnumAndNamedConstants) {
- auto type = entt::resolve<properties>();
- ASSERT_TRUE(type.data("prop_bool"_hs));
- ASSERT_TRUE(type.data("prop_int"_hs));
- ASSERT_EQ(type.data("prop_bool"_hs).type(), type);
- ASSERT_EQ(type.data("prop_int"_hs).type(), type);
- ASSERT_FALSE(type.data("prop_bool"_hs).set({}, properties::prop_int));
- ASSERT_FALSE(type.data("prop_int"_hs).set({}, properties::prop_bool));
- ASSERT_EQ(type.data("prop_bool"_hs).get({}).cast<properties>(), properties::prop_bool);
- ASSERT_EQ(type.data("prop_int"_hs).get({}).cast<properties>(), properties::prop_int);
- }
- TEST_F(Meta, ArithmeticTypeAndNamedConstants) {
- auto type = entt::resolve<unsigned int>();
- ASSERT_TRUE(type.data("min"_hs));
- ASSERT_TRUE(type.data("max"_hs));
- ASSERT_EQ(type.data("min"_hs).type(), type);
- ASSERT_EQ(type.data("max"_hs).type(), type);
- ASSERT_FALSE(type.data("min"_hs).set({}, 100u));
- ASSERT_FALSE(type.data("max"_hs).set({}, 0u));
- ASSERT_EQ(type.data("min"_hs).get({}).cast<unsigned int>(), 0u);
- ASSERT_EQ(type.data("max"_hs).get({}).cast<unsigned int>(), 100u);
- }
- TEST_F(Meta, Unregister) {
- ASSERT_FALSE(entt::unregister<float>());
- ASSERT_TRUE(entt::unregister<double>());
- ASSERT_TRUE(entt::unregister<char>());
- ASSERT_TRUE(entt::unregister<properties>());
- ASSERT_TRUE(entt::unregister<unsigned int>());
- ASSERT_TRUE(entt::unregister<base_type>());
- ASSERT_TRUE(entt::unregister<derived_type>());
- ASSERT_TRUE(entt::unregister<empty_type>());
- ASSERT_TRUE(entt::unregister<fat_type>());
- ASSERT_TRUE(entt::unregister<data_type>());
- ASSERT_TRUE(entt::unregister<func_type>());
- ASSERT_TRUE(entt::unregister<setter_getter_type>());
- ASSERT_TRUE(entt::unregister<an_abstract_type>());
- ASSERT_TRUE(entt::unregister<another_abstract_type>());
- ASSERT_TRUE(entt::unregister<concrete_type>());
- ASSERT_FALSE(entt::unregister<double>());
- ASSERT_FALSE(entt::resolve("char"_hs));
- ASSERT_FALSE(entt::resolve("base"_hs));
- ASSERT_FALSE(entt::resolve("derived"_hs));
- ASSERT_FALSE(entt::resolve("empty"_hs));
- ASSERT_FALSE(entt::resolve("fat"_hs));
- ASSERT_FALSE(entt::resolve("data"_hs));
- ASSERT_FALSE(entt::resolve("func"_hs));
- ASSERT_FALSE(entt::resolve("setter_getter"_hs));
- ASSERT_FALSE(entt::resolve("an_abstract_type"_hs));
- ASSERT_FALSE(entt::resolve("another_abstract_type"_hs));
- ASSERT_FALSE(entt::resolve("concrete"_hs));
- Meta::SetUpAfterUnregistration();
- entt::meta_any any{42.};
- ASSERT_TRUE(any);
- ASSERT_FALSE(any.can_convert<int>());
- ASSERT_TRUE(any.can_convert<float>());
- ASSERT_FALSE(entt::resolve("derived"_hs));
- ASSERT_TRUE(entt::resolve("my_type"_hs));
- entt::resolve<derived_type>().prop([](auto prop) {
- ASSERT_TRUE(prop);
- ASSERT_EQ(prop.key(), properties::prop_bool);
- ASSERT_FALSE(prop.value().template cast<bool>());
- });
- ASSERT_FALSE((entt::resolve<derived_type>().ctor<const base_type &, int, char>()));
- ASSERT_TRUE((entt::resolve<derived_type>().ctor<>()));
- ASSERT_TRUE(entt::resolve("your_type"_hs).data("a_data_member"_hs));
- ASSERT_FALSE(entt::resolve("your_type"_hs).data("another_data_member"_hs));
- ASSERT_TRUE(entt::resolve("your_type"_hs).func("a_member_function"_hs));
- ASSERT_FALSE(entt::resolve("your_type"_hs).func("another_member_function"_hs));
- }
|