mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	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
 |