33 lines
		
	
	
		
			842 B
		
	
	
	
		
			TableGen
		
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			842 B
		
	
	
	
		
			TableGen
		
	
	
	
| // RUN: not llvm-tblgen %s 2>&1 | FileCheck %s
 | |
| // XFAIL: vg_leak
 | |
| 
 | |
| // This test verifies that tablegen does fail if it can't resolve an unresolved
 | |
| // !cast() during processing top-level defm.
 | |
| 
 | |
| class A {}
 | |
| class B<A a> {
 | |
|   A ba = a;
 | |
| }
 | |
| 
 | |
| multiclass M0<string s> {
 | |
|   // This should work fine.
 | |
|   def _m00 : B<!cast<A>(s)>;
 | |
|   // CHECK: error: Undefined reference to record: 'd1_r1_no_such_record'
 | |
|   def _m01: B<!cast<A>(s#"_no_such_record")>;
 | |
| }
 | |
| 
 | |
| multiclass M1<string s> {
 | |
|   def _r1 : A;
 | |
|   // It would be nice if we could refer to _r1's name without having to pass it
 | |
|   // explicitly via 's'.
 | |
|   // XCHECK-DAG: note: instantiated from multiclass
 | |
|   defm _m1: M0<s # "_r1">;
 | |
| }
 | |
| 
 | |
| // CHECK: def _m01: B
 | |
| // CHECK: note: instantiated from multiclass
 | |
| // CHECK: defm _m1: M0
 | |
| // CHECK: note: instantiated from multiclass
 | |
| // CHECK: defm d1: M1
 | |
| defm d1: M1<"d1">;
 |