// 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>;