annotate llvm/test/TableGen/AnonDefinitionOnDemand.td @ 207:2e18cbf3894f

LLVM12
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 08 Jun 2021 06:07:14 +0900
parents 1d019706d866
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 // RUN: llvm-tblgen %s | FileCheck %s
anatofuz
parents:
diff changeset
2 // XFAIL: vg_leak
anatofuz
parents:
diff changeset
3
anatofuz
parents:
diff changeset
4 // CHECK: --- Defs ---
anatofuz
parents:
diff changeset
5
anatofuz
parents:
diff changeset
6 // CHECK: def X {
anatofuz
parents:
diff changeset
7 // CHECK: foo Y = anonymous_0;
anatofuz
parents:
diff changeset
8 // CHECK: }
anatofuz
parents:
diff changeset
9
anatofuz
parents:
diff changeset
10 // CHECK: def ZD {
anatofuz
parents:
diff changeset
11 // CHECK: foo Z = anonymous_1;
anatofuz
parents:
diff changeset
12 // CHECK: }
anatofuz
parents:
diff changeset
13
anatofuz
parents:
diff changeset
14 // CHECK: def anonymous_0 {
anatofuz
parents:
diff changeset
15 // CHECK: int THEVAL = 1;
anatofuz
parents:
diff changeset
16 // CHECK: }
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 // CHECK: def anonymous_1 {
anatofuz
parents:
diff changeset
19 // CHECK: int THEVAL = 42;
anatofuz
parents:
diff changeset
20 // CHECK: }
anatofuz
parents:
diff changeset
21
anatofuz
parents:
diff changeset
22 class foo<int X> { int THEVAL = X; }
anatofuz
parents:
diff changeset
23 def foo_imp : foo<1>;
anatofuz
parents:
diff changeset
24
anatofuz
parents:
diff changeset
25 def x {
anatofuz
parents:
diff changeset
26 foo Y = foo_imp; // This works.
anatofuz
parents:
diff changeset
27 }
anatofuz
parents:
diff changeset
28
anatofuz
parents:
diff changeset
29 def X {
anatofuz
parents:
diff changeset
30 foo Y = foo<1>; // This should work too, synthesizing a new foo<1>.
anatofuz
parents:
diff changeset
31 }
anatofuz
parents:
diff changeset
32
anatofuz
parents:
diff changeset
33 class Z<int X> {
anatofuz
parents:
diff changeset
34 foo Z = foo<X>;
anatofuz
parents:
diff changeset
35 }
anatofuz
parents:
diff changeset
36
anatofuz
parents:
diff changeset
37 def ZD : Z<42>;