Skip to content

Commit

Permalink
Fix Variant move assign (#6806)
Browse files Browse the repository at this point in the history
  • Loading branch information
kghost authored May 14, 2021
1 parent f0e9f91 commit cc9fc8a
Show file tree
Hide file tree
Showing 2 changed files with 73 additions and 3 deletions.
2 changes: 2 additions & 0 deletions src/lib/support/Variant.h
Original file line number Diff line number Diff line change
Expand Up @@ -131,6 +131,8 @@ struct Variant
Curry::Destroy(mTypeId, &mData);
mTypeId = that.mTypeId;
Curry::Move(that.mTypeId, &that.mData, &mData);
Curry::Destroy(that.mTypeId, &that.mData);
that.mTypeId = kInvalidType;
return *this;
}

Expand Down
74 changes: 71 additions & 3 deletions src/lib/support/tests/TestVariant.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,12 @@ struct Count
Count() { ++created; }
~Count() { ++destroyed; }

Count(const Count &) { ++created; }
Count & operator=(Count &) = default;

Count(Count &&) { ++created; }
Count & operator=(Count &&) = default;

static int created;
static int destroyed;
};
Expand Down Expand Up @@ -123,15 +129,49 @@ void TestVariantCtorDtor(nlTestSuite * inSuite, void * inContext)
NL_TEST_ASSERT(inSuite, Count::destroyed == 1);
}
NL_TEST_ASSERT(inSuite, Count::destroyed == 2);

{
Variant<Simple, Count> v1;
v1.Set<Count>();
Variant<Simple, Count> v2(v1);
}
NL_TEST_ASSERT(inSuite, Count::created == 4);
NL_TEST_ASSERT(inSuite, Count::destroyed == 4);

{
Variant<Simple, Count> v1;
v1.Set<Count>();
Variant<Simple, Count> v2(std::move(v1));
}
NL_TEST_ASSERT(inSuite, Count::created == 6);
NL_TEST_ASSERT(inSuite, Count::destroyed == 6);

{
Variant<Simple, Count> v1, v2;
v1.Set<Count>();
v2 = v1;
}
NL_TEST_ASSERT(inSuite, Count::created == 8);
NL_TEST_ASSERT(inSuite, Count::destroyed == 8);

{
Variant<Simple, Count> v1, v2;
v1.Set<Count>();
v2 = std::move(v1);
}
NL_TEST_ASSERT(inSuite, Count::created == 10);
NL_TEST_ASSERT(inSuite, Count::destroyed == 10);
}

void TestVariantCopy(nlTestSuite * inSuite, void * inContext)
{
Variant<Simple, Pod> v1;
v1.Set<Pod>(5, 10);
Variant<Simple, Pod> v2 = v1;
NL_TEST_ASSERT(inSuite, v1.Valid());
NL_TEST_ASSERT(inSuite, v1.Get<Pod>().m1 == 5);
NL_TEST_ASSERT(inSuite, v1.Get<Pod>().m2 == 10);
NL_TEST_ASSERT(inSuite, v2.Valid());
NL_TEST_ASSERT(inSuite, v2.Get<Pod>().m1 == 5);
NL_TEST_ASSERT(inSuite, v2.Get<Pod>().m2 == 10);
}
Expand All @@ -142,10 +182,37 @@ void TestVariantMove(nlTestSuite * inSuite, void * inContext)
v1.Set<Movable>(5, 10);
Variant<Simple, Movable> v2 = std::move(v1);
NL_TEST_ASSERT(inSuite, !v1.Valid());
NL_TEST_ASSERT(inSuite, v2.Valid());
NL_TEST_ASSERT(inSuite, v2.Get<Movable>().m1 == 5);
NL_TEST_ASSERT(inSuite, v2.Get<Movable>().m2 == 10);
}

void TestVariantCopyAssign(nlTestSuite * inSuite, void * inContext)
{
Variant<Simple, Pod> v1;
Variant<Simple, Pod> v2;
v1.Set<Pod>(5, 10);
v2 = v1;
NL_TEST_ASSERT(inSuite, v1.Valid());
NL_TEST_ASSERT(inSuite, v1.Get<Pod>().m1 == 5);
NL_TEST_ASSERT(inSuite, v1.Get<Pod>().m2 == 10);
NL_TEST_ASSERT(inSuite, v2.Valid());
NL_TEST_ASSERT(inSuite, v2.Get<Pod>().m1 == 5);
NL_TEST_ASSERT(inSuite, v2.Get<Pod>().m2 == 10);
}

void TestVariantMoveAssign(nlTestSuite * inSuite, void * inContext)
{
Variant<Simple, Pod> v1;
Variant<Simple, Pod> v2;
v1.Set<Pod>(5, 10);
v2 = std::move(v1);
NL_TEST_ASSERT(inSuite, !v1.Valid());
NL_TEST_ASSERT(inSuite, v2.Valid());
NL_TEST_ASSERT(inSuite, v2.Get<Pod>().m1 == 5);
NL_TEST_ASSERT(inSuite, v2.Get<Pod>().m2 == 10);
}

int Setup(void * inContext)
{
return SUCCESS;
Expand All @@ -162,9 +229,10 @@ int Teardown(void * inContext)
/**
* Test Suite. It lists all the test functions.
*/
static const nlTest sTests[] = { NL_TEST_DEF_FN(TestVariantSimple), NL_TEST_DEF_FN(TestVariantMovable),
NL_TEST_DEF_FN(TestVariantCtorDtor), NL_TEST_DEF_FN(TestVariantCopy),
NL_TEST_DEF_FN(TestVariantMove), NL_TEST_SENTINEL() };
static const nlTest sTests[] = { NL_TEST_DEF_FN(TestVariantSimple), NL_TEST_DEF_FN(TestVariantMovable),
NL_TEST_DEF_FN(TestVariantCtorDtor), NL_TEST_DEF_FN(TestVariantCopy),
NL_TEST_DEF_FN(TestVariantMove), NL_TEST_DEF_FN(TestVariantCopyAssign),
NL_TEST_DEF_FN(TestVariantMoveAssign), NL_TEST_SENTINEL() };

int TestVariant()
{
Expand Down

0 comments on commit cc9fc8a

Please sign in to comment.