mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-13 07:50:50 +00:00
bbd301d97a
The TargetRegistry is just a namespace-like class, instantiated in one place to use a range-based for loop. Instead, expose access to the registry via a range-based 'targets()' function instead. This makes most uses a bit awkward/more verbose - but eventually we should just add a range-based find_if function which will streamline these functions. I'm happy to mkae them a bit awkward in the interim as encouragement to improve the algorithms in time. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@237059 91177308-0d34-0410-b5e6-96231b3b80d8
43 lines
1.3 KiB
C++
43 lines
1.3 KiB
C++
//===- unittests/Support/TargetRegistry.cpp - -----------------------------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/Support/TargetRegistry.h"
|
|
#include "llvm/Support/TargetSelect.h"
|
|
#include "gtest/gtest.h"
|
|
|
|
using namespace llvm;
|
|
|
|
namespace {
|
|
|
|
TEST(TargetRegistry, TargetHasArchType) {
|
|
// Presence of at least one target will be asserted when done with the loop,
|
|
// else this would pass by accident if InitializeAllTargetInfos were omitted.
|
|
int Count = 0;
|
|
|
|
llvm::InitializeAllTargetInfos();
|
|
|
|
for (const Target &T : TargetRegistry::targets()) {
|
|
StringRef Name = T.getName();
|
|
// There is really no way (at present) to ask a Target whether it targets
|
|
// a specific architecture, because the logic for that is buried in a
|
|
// predicate.
|
|
// We can't ask the predicate "Are you a function that always returns
|
|
// false?"
|
|
// So given that the cpp backend truly has no target arch, it is skipped.
|
|
if (Name != "cpp") {
|
|
Triple::ArchType Arch = Triple::getArchTypeForLLVMName(Name);
|
|
EXPECT_NE(Arch, Triple::UnknownArch);
|
|
++Count;
|
|
}
|
|
}
|
|
ASSERT_NE(Count, 0);
|
|
}
|
|
|
|
} // end namespace
|