2018-02-22 23:27:03 +08:00
|
|
|
// RUN: llvm-tblgen %s | FileCheck %s
|
2020-11-25 02:09:02 +08:00
|
|
|
// RUN: not llvm-tblgen -DERROR1 %s 2>&1 | FileCheck --check-prefix=ERROR1 %s
|
2018-02-22 23:27:03 +08:00
|
|
|
// XFAIL: vg_leak
|
|
|
|
|
2020-11-25 02:09:02 +08:00
|
|
|
// CHECK: def A1
|
|
|
|
// CHECK: code CodeCode = [{code here;}]
|
|
|
|
// CHECK: code StringCode = [{code here;}]
|
2018-02-22 23:27:03 +08:00
|
|
|
|
2020-11-25 02:09:02 +08:00
|
|
|
// CHECK: def A2
|
|
|
|
// CHECK: string CodeCode = "string here"
|
|
|
|
// CHECK: string StringCode = "string here"
|
2018-02-22 23:27:03 +08:00
|
|
|
|
2020-11-25 02:09:02 +08:00
|
|
|
// CHECK: def B1
|
|
|
|
// CHECK: string CodeCode = "with paste 7"
|
|
|
|
// CHECK: string StringCode = "with paste 7"
|
|
|
|
|
|
|
|
// CHECK: def C1
|
|
|
|
// CHECK: code CodeCode = [{with concat 42}]
|
|
|
|
// CHECK: code StringCode = [{with concat 42}]
|
|
|
|
|
|
|
|
// CHECK: def D1
|
|
|
|
// CHECK: code CodeCode = [{with concat 108!}]
|
|
|
|
// CHECK: code StringCode = [{with concat 108!}]
|
2018-02-22 23:27:03 +08:00
|
|
|
|
|
|
|
class A<code c> {
|
2020-11-25 02:09:02 +08:00
|
|
|
code CodeCode = c;
|
|
|
|
string StringCode = c;
|
2018-02-22 23:27:03 +08:00
|
|
|
}
|
|
|
|
|
2020-11-25 02:09:02 +08:00
|
|
|
def A1 : A<[{code here;}]>;
|
|
|
|
def A2 : A<"string here">;
|
|
|
|
|
|
|
|
class B<int i> : A<"with paste " # i>;
|
|
|
|
class C<int i> : A<!strconcat([{with concat }], !cast<string>(i))>;
|
|
|
|
class D<int i> : A<!strconcat([{with concat }], !cast<string>(i), "!")>;
|
|
|
|
|
|
|
|
def B1 : B<7>;
|
|
|
|
def C1 : C<42>;
|
|
|
|
def D1 : D<108>;
|
2018-02-22 23:27:03 +08:00
|
|
|
|
2020-11-25 02:09:02 +08:00
|
|
|
#ifdef ERROR1
|
|
|
|
|
|
|
|
// ERROR1: the 'code' type is not allowed
|
|
|
|
|
|
|
|
def Zerror1 {
|
|
|
|
code Code = !cast<code>("i = 0;");
|
|
|
|
}
|
2018-02-22 23:27:03 +08:00
|
|
|
|
2020-11-25 02:09:02 +08:00
|
|
|
#endif
|