forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			102 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TableGen
		
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TableGen
		
	
	
	
// RUN: llvm-tblgen %s | FileCheck %s
 | 
						|
// XFAIL: vg_leak
 | 
						|
 | 
						|
// CHECK: def B0a {
 | 
						|
// CHECK:   string e = "B0";
 | 
						|
// CHECK: }
 | 
						|
 | 
						|
// CHECK: def B0ba {
 | 
						|
// CHECK:   string a = "B0b";
 | 
						|
// CHECK:   string b = "B0";
 | 
						|
// CHECK: }
 | 
						|
 | 
						|
// CHECK: def B0bys {
 | 
						|
// CHECK:   string f = "B0b";
 | 
						|
// CHECK:   string g = "B0";
 | 
						|
// CHECK: }
 | 
						|
 | 
						|
// CHECK: def B0cza {
 | 
						|
// CHECK:   string a = "B0cz";
 | 
						|
// CHECK:   string b = "B0";
 | 
						|
// CHECK: }
 | 
						|
 | 
						|
// CHECK: def B0czyt {
 | 
						|
// CHECK:   string f = "B0cz";
 | 
						|
// CHECK:   string g = "B0";
 | 
						|
// CHECK: }
 | 
						|
 | 
						|
// CHECK: def C0 {
 | 
						|
// CHECK:   string a = "C0";
 | 
						|
// CHECK:   string b = "C0";
 | 
						|
// CHECK:   string c = "a";
 | 
						|
// CHECK: }
 | 
						|
 | 
						|
// CHECK: def D0a {
 | 
						|
// CHECK:   string a = "D0a";
 | 
						|
// CHECK:   string b = "D0a";
 | 
						|
// CHECK:   string c = "D0";
 | 
						|
// CHECK: }
 | 
						|
 | 
						|
// CHECK: def D0b {
 | 
						|
// CHECK:   string a = "D0b";
 | 
						|
// CHECK:   string b = "D0b";
 | 
						|
// CHECK:   string c = "a";
 | 
						|
// CHECK: }
 | 
						|
 | 
						|
// CHECK: def xB0b {
 | 
						|
// CHECK:   string c = "B0b";
 | 
						|
// CHECK:   string d = "B0";
 | 
						|
// CHECK: }
 | 
						|
 | 
						|
// CHECK: def xB0cz {
 | 
						|
// CHECK:   string c = "B0cz";
 | 
						|
// CHECK:   string d = "B0";
 | 
						|
// CHECK: }
 | 
						|
 | 
						|
multiclass A<string p, string q> {
 | 
						|
  def a {
 | 
						|
    string a = NAME;
 | 
						|
    string b = p;
 | 
						|
  }
 | 
						|
 | 
						|
  def x # NAME {
 | 
						|
    string c = NAME;
 | 
						|
    string d = p;
 | 
						|
  }
 | 
						|
 | 
						|
  def y # q {
 | 
						|
    string f = NAME;
 | 
						|
    string g = p;
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
multiclass B<string name, string t> {
 | 
						|
  def a {
 | 
						|
    string e = NAME;
 | 
						|
  }
 | 
						|
 | 
						|
  defm b : A<NAME, "s">;
 | 
						|
 | 
						|
  defm NAME # c # name : A<NAME, t>;
 | 
						|
}
 | 
						|
 | 
						|
defm B0 : B<"z", "t">;
 | 
						|
 | 
						|
class Cbase {
 | 
						|
  string a = NAME;
 | 
						|
}
 | 
						|
 | 
						|
class C<string arg> : Cbase {
 | 
						|
  string b = NAME;
 | 
						|
  string c = arg;
 | 
						|
}
 | 
						|
 | 
						|
def C0 : C<"a">;
 | 
						|
 | 
						|
multiclass D<string arg> {
 | 
						|
  def a : C<NAME>;
 | 
						|
  def b : C<arg>;
 | 
						|
}
 | 
						|
 | 
						|
defm D0 : D<"a">;
 |