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

LLVM12
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 08 Jun 2021 06:07:14 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
207
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 // RUN: llvm-tblgen %s | FileCheck %s
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 // RUN: not llvm-tblgen -DERROR1 %s 2>&1 | FileCheck --check-prefix=ERROR1 %s
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 defvar claim = "This is the end of the world!";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6 // CHECK: def Rec1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 // CHECK: fullNoLength = "This is the end of the world!";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 // CHECK: fullLength = "This is the end of the world!";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9 // CHECK: thisIsTheEnd = "This is the end";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 // CHECK: DoorsSong = "the end";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11 // CHECK: finalNoLength = "end of the world!";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12 // CHECK: finalLength = "end of the world!";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 def Rec1 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 string fullNoLength = !substr(claim, 0);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 string fullLength = !substr(claim, 0, 999);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
17 string thisIsTheEnd = !substr(claim, 0, 15);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 string DoorsSong = !substr(claim, 8, 7);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
19 string finalNoLength = !substr(claim, 12);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 string finalLength = !substr(claim, 12, !sub(!size(claim), 12));
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
21 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
22
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 // CHECK: def Rec2 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 // CHECK: lastName = "Flintstone";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 def Rec2 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
27 string firstName = "Fred";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 string name = firstName # " " # "Flintstone";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
29 string lastName = !substr(name, !add(!size(firstName), 1));
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
30 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
31
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 // CHECK: def Rec3 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 // CHECK: test1 = "";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 // CHECK: test2 = "";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 // CHECK: test3 = "";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 // CHECK: test4 = "h";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 // CHECK: test5 = "hello";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 // CHECK: test6 = "";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 def Rec3 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 string test1 = !substr("", 0, 0);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 string test2 = !substr("", 0, 9);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 string test3 = !substr("hello", 0, 0);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 string test4 = !substr("hello", 0, 1);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 string test5 = !substr("hello", 0, 99);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 string test6 = !substr("hello", 5, 99);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
48
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 // CHECK: def Rec4
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 // CHECK: message = "This is the end of the world!";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 // CHECK: messagePrefix = "This is th...";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 // CHECK: warning = "Bad message: 'This is th...'";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
53
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 class C<string msg> {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
55 string message = msg;
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 string messagePrefix = !substr(message, 0, 10) # "...";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
58
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 def Rec4 : C<claim> {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 string warning = "Bad message: '" # messagePrefix # "'";
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 #ifdef ERROR1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 // ERROR1: expected string, got type 'int'
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 // ERROR1: expected int, got type 'bits<3>'
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 // ERROR1: expected int, got type 'string'
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
68 // ERROR1: !substr start position is out of range 0...29: 30
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 // ERROR1: !substr length must be nonnegative
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
70
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 def Rec8 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
72 string claim1 = !substr(42, 0, 3);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
73 string claim2 = !substr(claim, 0b101);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74 string claim3 = !substr(claim, 0, "oops");
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 def Rec9 {
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 string claim1 = !substr(claim, !add(!size(claim), 1));
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 string claim2 = !substr(claim, 0, -13);
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
80 }
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
diff changeset
81 #endif