| // RUN: not llvm-tblgen %s 2>&1 | FileCheck %s |
| // XFAIL: vg_leak |
| |
| // This test verifies that tablegen does fail if it can't resolve an unresolved |
| // !cast() during processing top-level defm. |
| |
| class A {} |
| class B<A a> { |
| A ba = a; |
| } |
| |
| multiclass M0<string s> { |
| // This should work fine. |
| def _m00 : B<!cast<A>(s)>; |
| // CHECK: error: Undefined reference to record: 'd1_r1_no_such_record' |
| def _m01: B<!cast<A>(s#"_no_such_record")>; |
| } |
| |
| multiclass M1<string s> { |
| def _r1 : A; |
| // It would be nice if we could refer to _r1's name without having to pass it |
| // explicitly via 's'. |
| // XCHECK-DAG: note: instantiated from multiclass |
| defm _m1: M0<s # "_r1">; |
| } |
| |
| // CHECK: def _m01: B |
| // CHECK: note: instantiated from multiclass |
| // CHECK: defm _m1: M0 |
| // CHECK: note: instantiated from multiclass |
| // CHECK: defm d1: M1 |
| defm d1: M1<"d1">; |