// RUN: llvm-tblgen %s | FileCheck %s | |
// XFAIL: vg_leak | |
// "zing = 4" x 28 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK: zing = 4 | |
// CHECK-NOT: zing = 4 | |
class C1<int A, string B> { | |
int bar = A; | |
string thestr = B; | |
int zing; | |
} | |
def T : C1<4, "blah">; | |
multiclass t1<int a1> { | |
def S1 : C1<a1, "foo"> { | |
int foo = 4; | |
let bar = 1; | |
} | |
def S2 : C1<a1, "bar">; | |
} | |
multiclass t2<int a2> { | |
def S3 : C1<a2, "foo"> { | |
int foo = 4; | |
let bar = 1; | |
} | |
def S4 : C1<a2, "bar">; | |
} | |
multiclass s1<int as1, int bs1> : t1<as1> { | |
def S5 : C1<bs1, "moo"> { | |
int moo = 3; | |
let bar = 1; | |
} | |
def S6 : C1<bs1, "baz">; | |
} | |
multiclass s2<int as2> : t1<as2>, t2<as2>; | |
multiclass s3<int as3, int bs3> : t1<as3>, t2<as3> { | |
def S7 : C1<bs3, "moo"> { | |
int moo = 3; | |
let bar = 1; | |
} | |
def S8 : C1<bs3, "baz">; | |
} | |
let zing = 4 in | |
defm FOO1 : s1<42, 24>; | |
let zing = 4 in | |
defm FOO2 : s2<99>; | |
let zing = 4 in | |
defm FOO3 : s3<84, 48>; | |
def T4 : C1<6, "foo">; | |
let zing = 4 in | |
defm BAZ1 : s1<3, 4>; | |
let zing = 4 in | |
defm BAZ2 : s2<5>; | |
let zing = 4 in | |
defm BAZ3 : s3<6, 7>; | |