// RUN: llvm-tblgen %s | FileCheck %s | |
// XFAIL: vg_leak | |
defvar LongList = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; | |
defvar EmptyStr = ""; | |
// Test !empty(dag). | |
// CHECK: def Drec1 { | |
// CHECK: bit Empty = 1; | |
// CHECK: bit NotEmpty = 0; | |
// CHECK: def Drec2 { | |
// CHECK: bit Empty = 0; | |
// CHECK: bit NotEmpty = 1; | |
// CHECK: def Drec3 { | |
// CHECK: bit Empty = 0; | |
// CHECK: bit NotEmpty = 1; | |
class D<dag ADag> { | |
bit Empty = !empty(ADag); | |
bit NotEmpty = !not(!empty(ADag)); | |
} | |
def op; | |
def Drec1 : D<(op)>; | |
def Drec2 : D<(op "string")>; | |
def Drec3 : D<(op "string", 42)>; | |
// Test !empty(list). | |
// CHECK: def Lrec1 { | |
// CHECK: bit Empty = 1; | |
// CHECK: bit NotEmpty = 0; | |
// CHECK: def Lrec2 { | |
// CHECK: bit Empty = 0; | |
// CHECK: bit NotEmpty = 1; | |
// CHECK: def Lrec3 { | |
// CHECK: bit Empty = 0; | |
// CHECK: bit NotEmpty = 1; | |
class L<list<int> Ints> { | |
bit Empty = !empty(Ints); | |
bit NotEmpty = !not(!empty(Ints)); | |
} | |
def Lrec1 : L<[]>; | |
def Lrec2 : L<[1]>; | |
def Lrec3 : L<LongList>; | |
// Test !empty(string). | |
// CHECK: def Srec1 { | |
// CHECK: bit Empty = 1; | |
// CHECK: bit NotEmpty = 0; | |
// CHECK: def Srec2 { | |
// CHECK: bit Empty = 0; | |
// CHECK: bit NotEmpty = 1; | |
// CHECK: def Srec3 { | |
// CHECK: bit Empty = 0; | |
// CHECK: bit NotEmpty = 1; | |
class S<string Str> { | |
bit Empty = !empty(Str); | |
bit NotEmpty = !not(!empty(Str)); | |
} | |
def Srec1 : S<EmptyStr>; | |
def Srec2 : S<"a">; | |
def Srec3 : S<"ab">; | |