annotate llvm/test/TableGen/defvar.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 1f2b6ac9f198
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 // RUN: not llvm-tblgen -DERROR1 %s 2>&1 | FileCheck --check-prefix=ERROR1 %s
anatofuz
parents:
diff changeset
3 // RUN: not llvm-tblgen -DERROR2 %s 2>&1 | FileCheck --check-prefix=ERROR2 %s
anatofuz
parents:
diff changeset
4 // RUN: not llvm-tblgen -DERROR3 %s 2>&1 | FileCheck --check-prefix=ERROR3 %s
anatofuz
parents:
diff changeset
5
anatofuz
parents:
diff changeset
6 #ifdef ERROR1
anatofuz
parents:
diff changeset
7 // Refer to a variable we haven't defined *yet*, expecting an error.
anatofuz
parents:
diff changeset
8 // ERROR1: [[@LINE+1]]:22: error: Variable not defined: 'myvar'
anatofuz
parents:
diff changeset
9 def bad { dag x = (? myvar); }
anatofuz
parents:
diff changeset
10 #endif
anatofuz
parents:
diff changeset
11
anatofuz
parents:
diff changeset
12 // Define a global variable.
anatofuz
parents:
diff changeset
13 defvar myvar = "foo";
anatofuz
parents:
diff changeset
14
anatofuz
parents:
diff changeset
15 #ifdef ERROR2
anatofuz
parents:
diff changeset
16 // Demonstrate an error when a global variable is redefined.
anatofuz
parents:
diff changeset
17 // ERROR2: [[@LINE+1]]:8: error: def or global variable of this name already exists
anatofuz
parents:
diff changeset
18 defvar myvar = "another value";
anatofuz
parents:
diff changeset
19 #endif
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 multiclass Test<int x> {
anatofuz
parents:
diff changeset
22 // Refer to a global variable, while inside a local scope like a multiclass.
anatofuz
parents:
diff changeset
23 def _with_global_string { string s = myvar; }
anatofuz
parents:
diff changeset
24
anatofuz
parents:
diff changeset
25 // Define some variables local to this multiclass, and prove we can refer to
anatofuz
parents:
diff changeset
26 // those too.
anatofuz
parents:
diff changeset
27 defvar myvar = !add(x, 100);
anatofuz
parents:
diff changeset
28 defvar myvar2 = "string of " # myvar;
anatofuz
parents:
diff changeset
29 def _with_local_int { int i = myvar; string s = myvar2; }
anatofuz
parents:
diff changeset
30
anatofuz
parents:
diff changeset
31 #ifdef ERROR3
anatofuz
parents:
diff changeset
32 // Demonstrate an error when a local variable is redefined.
anatofuz
parents:
diff changeset
33 // ERROR3: [[@LINE+1]]:10: error: local variable of this name already exists
anatofuz
parents:
diff changeset
34 defvar myvar = "another value";
anatofuz
parents:
diff changeset
35 #endif
anatofuz
parents:
diff changeset
36 }
anatofuz
parents:
diff changeset
37
anatofuz
parents:
diff changeset
38 // Instantiate the above multiclass, and expect all the right outputs.
anatofuz
parents:
diff changeset
39
anatofuz
parents:
diff changeset
40 // CHECK: def aaa_with_global_string {
anatofuz
parents:
diff changeset
41 // CHECK-NEXT: string s = "foo";
anatofuz
parents:
diff changeset
42 // CHECK: def aaa_with_local_int {
anatofuz
parents:
diff changeset
43 // CHECK-NEXT: int i = 101;
anatofuz
parents:
diff changeset
44 // CHECK-NEXT: string s = "string of 101";
anatofuz
parents:
diff changeset
45 // CHECK: def bbb_with_global_string {
anatofuz
parents:
diff changeset
46 // CHECK-NEXT: string s = "foo";
anatofuz
parents:
diff changeset
47 // CHECK: def bbb_with_local_int {
anatofuz
parents:
diff changeset
48 // CHECK-NEXT: int i = 102;
anatofuz
parents:
diff changeset
49 // CHECK-NEXT: string s = "string of 102";
anatofuz
parents:
diff changeset
50 defm aaa: Test<1>;
anatofuz
parents:
diff changeset
51 defm bbb: Test<2>;
anatofuz
parents:
diff changeset
52
anatofuz
parents:
diff changeset
53 // Test that local variables can be defined inside a foreach block, and inside
anatofuz
parents:
diff changeset
54 // an object body.
anatofuz
parents:
diff changeset
55 //
anatofuz
parents:
diff changeset
56 // The scopes nest (you can refer to variables in an outer block from an inner
anatofuz
parents:
diff changeset
57 // one), and the variables go out of scope again at the end of the block (in
anatofuz
parents:
diff changeset
58 // particular, you don't get a redefinition error the next time round the
anatofuz
parents:
diff changeset
59 // loop).
anatofuz
parents:
diff changeset
60
anatofuz
parents:
diff changeset
61 // CHECK: def nest_f1_s3 {
anatofuz
parents:
diff changeset
62 // CHECK-NEXT: int member = 113;
anatofuz
parents:
diff changeset
63 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
64 // CHECK: def nest_f1_s4 {
anatofuz
parents:
diff changeset
65 // CHECK-NEXT: int member = 114;
anatofuz
parents:
diff changeset
66 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
67 // CHECK: def nest_f2_s3 {
anatofuz
parents:
diff changeset
68 // CHECK-NEXT: int member = 123;
anatofuz
parents:
diff changeset
69 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
70 // CHECK: def nest_f2_s4 {
anatofuz
parents:
diff changeset
71 // CHECK-NEXT: int member = 124;
anatofuz
parents:
diff changeset
72 // CHECK-NEXT: }
anatofuz
parents:
diff changeset
73 foreach first = [ 1, 2 ] in {
anatofuz
parents:
diff changeset
74 defvar firstStr = "f" # first;
anatofuz
parents:
diff changeset
75 foreach second = [ 3, 4 ] in {
anatofuz
parents:
diff changeset
76 defvar secondStr = "s" # second;
anatofuz
parents:
diff changeset
77 def "nest_" # firstStr # "_" # secondStr {
anatofuz
parents:
diff changeset
78 defvar defLocalVariable = !add(!mul(first, 10), second);
anatofuz
parents:
diff changeset
79 int member = !add(100, defLocalVariable);
anatofuz
parents:
diff changeset
80 }
anatofuz
parents:
diff changeset
81 }
anatofuz
parents:
diff changeset
82 }
anatofuz
parents:
diff changeset
83 defvar firstStr = "now define this at the top level and still expect no error";
anatofuz
parents:
diff changeset
84
anatofuz
parents:
diff changeset
85 // Test that you can shadow an outer declaration with an inner one. Here, we
anatofuz
parents:
diff changeset
86 // expect all the shadowOuter records (both above and below the inner foreach)
anatofuz
parents:
diff changeset
87 // to get the value 1 from the outer definition of shadowedVariable, and the
anatofuz
parents:
diff changeset
88 // shadowInner ones to get 2 from the inner definition.
anatofuz
parents:
diff changeset
89
anatofuz
parents:
diff changeset
90 // CHECK: def shadowInner11 {
anatofuz
parents:
diff changeset
91 // CHECK-NEXT: int var = 2;
anatofuz
parents:
diff changeset
92 // CHECK: def shadowInner12 {
anatofuz
parents:
diff changeset
93 // CHECK-NEXT: int var = 2;
anatofuz
parents:
diff changeset
94 // CHECK: def shadowInner21 {
anatofuz
parents:
diff changeset
95 // CHECK-NEXT: int var = 2;
anatofuz
parents:
diff changeset
96 // CHECK: def shadowInner22 {
anatofuz
parents:
diff changeset
97 // CHECK-NEXT: int var = 2;
anatofuz
parents:
diff changeset
98 // CHECK: def shadowInnerIf1 {
anatofuz
parents:
diff changeset
99 // CHECK-NEXT: int var = 3;
anatofuz
parents:
diff changeset
100 // CHECK: def shadowOuterAbove1 {
anatofuz
parents:
diff changeset
101 // CHECK-NEXT: int var = 1;
anatofuz
parents:
diff changeset
102 // CHECK: def shadowOuterAbove2 {
anatofuz
parents:
diff changeset
103 // CHECK-NEXT: int var = 1;
anatofuz
parents:
diff changeset
104 // CHECK: def shadowOuterBelowForeach1 {
anatofuz
parents:
diff changeset
105 // CHECK-NEXT: int var = 1;
anatofuz
parents:
diff changeset
106 // CHECK: def shadowOuterBelowForeach2 {
anatofuz
parents:
diff changeset
107 // CHECK-NEXT: int var = 1;
anatofuz
parents:
diff changeset
108 // CHECK: def shadowOuterBelowIf1 {
anatofuz
parents:
diff changeset
109 // CHECK-NEXT: int var = 1;
anatofuz
parents:
diff changeset
110 // CHECK: def shadowOuterBelowIf2 {
anatofuz
parents:
diff changeset
111 // CHECK-NEXT: int var = 1;
anatofuz
parents:
diff changeset
112
anatofuz
parents:
diff changeset
113 foreach first = [ 1, 2 ] in {
anatofuz
parents:
diff changeset
114 defvar shadowedVariable = 1;
anatofuz
parents:
diff changeset
115 def shadowOuterAbove # first { int var = shadowedVariable; }
anatofuz
parents:
diff changeset
116
anatofuz
parents:
diff changeset
117 // The foreach statement opens a new scope, in which a new variable of the
anatofuz
parents:
diff changeset
118 // same name can be defined without clashing with the outer one.
anatofuz
parents:
diff changeset
119 foreach second = [ 1, 2 ] in {
anatofuz
parents:
diff changeset
120 defvar shadowedVariable = 2;
anatofuz
parents:
diff changeset
121 def shadowInner # first # second { int var = shadowedVariable; }
anatofuz
parents:
diff changeset
122 }
anatofuz
parents:
diff changeset
123
anatofuz
parents:
diff changeset
124 // Now the outer variable is back in scope.
anatofuz
parents:
diff changeset
125 def shadowOuterBelowForeach # first { int var = shadowedVariable; }
anatofuz
parents:
diff changeset
126
anatofuz
parents:
diff changeset
127 // An if statement also opens a new scope.
anatofuz
parents:
diff changeset
128 if !eq(first, 1) then {
anatofuz
parents:
diff changeset
129 defvar shadowedVariable = 3;
anatofuz
parents:
diff changeset
130 def shadowInnerIf # first { int var = shadowedVariable; }
anatofuz
parents:
diff changeset
131 }
anatofuz
parents:
diff changeset
132
anatofuz
parents:
diff changeset
133 // Now the outer variable is back in scope again.
anatofuz
parents:
diff changeset
134 def shadowOuterBelowIf # first { int var = shadowedVariable; }
anatofuz
parents:
diff changeset
135 }
anatofuz
parents:
diff changeset
136
anatofuz
parents:
diff changeset
137 // Test that a top-level let statement also makes a variable scope (on the
anatofuz
parents:
diff changeset
138 // general principle of consistency, because it defines a braced sub-block).
anatofuz
parents:
diff changeset
139
anatofuz
parents:
diff changeset
140 let someVariable = "some value" in {
anatofuz
parents:
diff changeset
141 defvar myvar = "override the definition from above and expect no error";
anatofuz
parents:
diff changeset
142 }
anatofuz
parents:
diff changeset
143 // CHECK: def topLevelLetTest {
anatofuz
parents:
diff changeset
144 // CHECK-NEXT: string val = "foo";
anatofuz
parents:
diff changeset
145 def topLevelLetTest { string val = myvar; }