diff options
author | Michael Gottesman <mgottesman@apple.com> | 2016-01-13 05:59:13 +0000 |
---|---|---|
committer | Michael Gottesman <mgottesman@apple.com> | 2016-01-13 05:59:13 +0000 |
commit | e9a1c31ebf8d33ac378bb37fe3d3bc0b2051b173 (patch) | |
tree | be6a9d173e78bef36813e7266861fe6f3862650b /llvm/unittests/ADT/PointerIntPairTest.cpp | |
parent | d2d8ffd7582be8454f0719d6640e73461c734811 (diff) | |
download | bcm5719-llvm-e9a1c31ebf8d33ac378bb37fe3d3bc0b2051b173.tar.gz bcm5719-llvm-e9a1c31ebf8d33ac378bb37fe3d3bc0b2051b173.zip |
Fix PointerIntPair so that it can use an enum class as its integer template argument.
Summary:
The problem here is that an enum class can not be implicitly converted to an
integer. That assumption snuck back into PointerIntPair. This commit fixes the
issue and more importantly adds some unittests to make sure that we do not break
this again.
rdar://23594806
Reviewers: gribozavr
Subscribers: llvm-commits
Differential Revision: http://reviews.llvm.org/D16131
llvm-svn: 257574
Diffstat (limited to 'llvm/unittests/ADT/PointerIntPairTest.cpp')
-rw-r--r-- | llvm/unittests/ADT/PointerIntPairTest.cpp | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/llvm/unittests/ADT/PointerIntPairTest.cpp b/llvm/unittests/ADT/PointerIntPairTest.cpp index e27a5823a51..13680c78b9b 100644 --- a/llvm/unittests/ADT/PointerIntPairTest.cpp +++ b/llvm/unittests/ADT/PointerIntPairTest.cpp @@ -35,6 +35,33 @@ TEST(PointerIntPairTest, GetSet) { Pair.setPointerAndInt(&s, 3U); EXPECT_EQ(&s, Pair.getPointer()); EXPECT_EQ(3U, Pair.getInt()); + + // Make sure that we can perform all of our operations on enum classes. + // + // The concern is that enum classes are only explicitly convertible to + // integers. This means that if we assume in PointerIntPair this, a + // compilation error will result. This group of tests exercises the enum class + // code to make sure that we do not run into such issues in the future. + enum class E : unsigned { + Case1, + Case2, + Case3, + }; + PointerIntPair<S *, 2, E> Pair2(&s, E::Case1); + EXPECT_EQ(&s, Pair2.getPointer()); + EXPECT_EQ(E::Case1, Pair2.getInt()); + + Pair2.setInt(E::Case2); + EXPECT_EQ(&s, Pair2.getPointer()); + EXPECT_EQ(E::Case2, Pair2.getInt()); + + Pair2.setPointer(nullptr); + EXPECT_EQ(nullptr, Pair2.getPointer()); + EXPECT_EQ(E::Case2, Pair2.getInt()); + + Pair2.setPointerAndInt(&s, E::Case3); + EXPECT_EQ(&s, Pair2.getPointer()); + EXPECT_EQ(E::Case3, Pair2.getInt()); } TEST(PointerIntPairTest, DefaultInitialize) { |