mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-11-04 05:17:07 +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
 |