mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-14 15:39:00 +00:00
ac79468ce8
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@260652 91177308-0d34-0410-b5e6-96231b3b80d8
109 lines
2.9 KiB
C++
109 lines
2.9 KiB
C++
//===- llvm/unittests/ADT/OptionSetTest.cpp -------------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/ADT/OptionSet.h"
|
|
#include "gtest/gtest.h"
|
|
|
|
using namespace llvm;
|
|
|
|
TEST(OptionSet, contains) {
|
|
enum class Flags {
|
|
A = 1 << 0,
|
|
B = 1 << 1,
|
|
C = 1 << 2
|
|
};
|
|
|
|
OptionSet<Flags> emptySet;
|
|
OptionSet<Flags> aSet = Flags::A;
|
|
OptionSet<Flags> abSet = aSet | Flags::B;
|
|
OptionSet<Flags> abcSet = abSet | Flags::C;
|
|
OptionSet<Flags> bcSet = abcSet - Flags::A;
|
|
OptionSet<Flags> cSet = bcSet - Flags::B;
|
|
|
|
EXPECT_TRUE(emptySet.contains(emptySet));
|
|
EXPECT_FALSE(emptySet.contains(aSet));
|
|
EXPECT_FALSE(emptySet.contains(abSet));
|
|
EXPECT_FALSE(emptySet.contains(abcSet));
|
|
EXPECT_FALSE(emptySet.contains(bcSet));
|
|
EXPECT_FALSE(emptySet.contains(cSet));
|
|
|
|
EXPECT_TRUE(aSet.contains(emptySet));
|
|
EXPECT_TRUE(aSet.contains(aSet));
|
|
EXPECT_FALSE(aSet.contains(abSet));
|
|
EXPECT_FALSE(aSet.contains(abcSet));
|
|
EXPECT_FALSE(aSet.contains(bcSet));
|
|
EXPECT_FALSE(aSet.contains(cSet));
|
|
|
|
EXPECT_TRUE(abSet.contains(emptySet));
|
|
EXPECT_TRUE(abSet.contains(aSet));
|
|
EXPECT_TRUE(abSet.contains(abSet));
|
|
EXPECT_FALSE(abSet.contains(abcSet));
|
|
EXPECT_FALSE(abSet.contains(bcSet));
|
|
EXPECT_FALSE(abSet.contains(cSet));
|
|
|
|
EXPECT_TRUE(abcSet.contains(emptySet));
|
|
EXPECT_TRUE(abcSet.contains(aSet));
|
|
EXPECT_TRUE(abcSet.contains(abSet));
|
|
EXPECT_TRUE(abcSet.contains(abcSet));
|
|
EXPECT_TRUE(abcSet.contains(bcSet));
|
|
EXPECT_TRUE(abcSet.contains(cSet));
|
|
}
|
|
|
|
|
|
TEST(OptionSet, intptr_t) {
|
|
enum class Small : int8_t {
|
|
A = 1 << 0
|
|
};
|
|
|
|
OptionSet<Small> small = Small::A;
|
|
EXPECT_EQ(static_cast<intptr_t>(Small::A), static_cast<intptr_t>(small));
|
|
|
|
|
|
enum class UPtr : uintptr_t {
|
|
A = std::numeric_limits<uintptr_t>::max()
|
|
};
|
|
|
|
OptionSet<UPtr> uptr = UPtr::A;
|
|
EXPECT_EQ(static_cast<intptr_t>(UPtr::A), static_cast<intptr_t>(uptr));
|
|
|
|
|
|
enum class Ptr : intptr_t {
|
|
A = std::numeric_limits<intptr_t>::min()
|
|
};
|
|
|
|
OptionSet<Ptr> ptr = Ptr::A;
|
|
EXPECT_EQ(static_cast<intptr_t>(Ptr::A), static_cast<intptr_t>(ptr));
|
|
}
|
|
|
|
TEST(OptionSet, intptr_t_isConstructible) {
|
|
// First check that std::is_constructible counts explicit conversion
|
|
// operators.
|
|
class AlwaysConvertible {
|
|
public:
|
|
explicit operator intptr_t () const { return 0; }
|
|
};
|
|
|
|
if (!std::is_constructible<intptr_t, AlwaysConvertible>::value) {
|
|
// std::is_constructible doesn't test what we want it to. Just exit early.
|
|
return;
|
|
}
|
|
|
|
enum class LongLong : unsigned long long {
|
|
A = 1
|
|
};
|
|
bool isConvertible =
|
|
std::is_constructible<intptr_t, OptionSet<LongLong>>::value;
|
|
|
|
if (sizeof(intptr_t) < sizeof(long long)) {
|
|
EXPECT_FALSE(isConvertible);
|
|
} else {
|
|
EXPECT_TRUE(isConvertible);
|
|
}
|
|
}
|