2021-04-05 21:13:25 +08:00
|
|
|
// RUN: llvm-tblgen %s | FileCheck %s
|
2010-03-21 07:08:45 +08:00
|
|
|
// XFAIL: vg_leak
|
2004-07-27 09:00:56 +08:00
|
|
|
|
2021-04-05 21:13:25 +08:00
|
|
|
// This file has tests for the list slice suffix.
|
|
|
|
|
|
|
|
// Test defvars and literal lists.
|
|
|
|
|
|
|
|
// CHECK: def Rec00
|
|
|
|
// CHECK: list<int> ShowVar1 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
|
|
|
|
// CHECK: int ShowVar2 = 0
|
|
|
|
// CHECK: list<int> ShowVar3 = [2, 3, 4, 5]
|
2021-04-09 23:59:18 +08:00
|
|
|
// CHECK: int ShowVar4 = 2
|
2021-04-05 21:13:25 +08:00
|
|
|
// CHECK: list<int> ShowVar5 = [2, 3, 4, 5]
|
|
|
|
|
|
|
|
defvar Var1 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9];
|
|
|
|
defvar Var2 = Var1[0];
|
|
|
|
defvar Var3 = Var1[2...5];
|
|
|
|
|
2021-04-09 23:59:18 +08:00
|
|
|
defvar Var4 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9][2];
|
2021-04-05 21:13:25 +08:00
|
|
|
defvar Var5 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9][2...5];
|
|
|
|
|
|
|
|
def Rec00 { // Display the defvars.
|
|
|
|
list<int> ShowVar1 = Var1;
|
|
|
|
int ShowVar2 = Var2;
|
|
|
|
list<int> ShowVar3 = Var3;
|
|
|
|
int ShowVar4 = Var4;
|
|
|
|
list<int> ShowVar5 = Var5;
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK: def Rec01
|
|
|
|
// CHECK: int Zero = 0
|
|
|
|
// CHECK: list<int> TwoFive = [2, 3, 4, 5]
|
|
|
|
|
|
|
|
def Rec01 {
|
|
|
|
int Zero = Var1[0];
|
|
|
|
list<int> TwoFive = Var1[2...5];
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test class template arguments.
|
|
|
|
|
|
|
|
// CHECK: def Rec02
|
|
|
|
// CHECK: int Zero = 10
|
|
|
|
// CHECK: list<int> TwoFive = [12, 13, 14, 15]
|
|
|
|
|
|
|
|
class Class1<list<int> ids> {
|
|
|
|
int Zero = ids[0];
|
|
|
|
list<int> TwoFive = ids[2...5];
|
|
|
|
}
|
|
|
|
|
|
|
|
def Rec02 : Class1<[10, 11, 12, 13, 14, 15, 16, 17]>;
|
|
|
|
|
|
|
|
// Test anonymous record fetches.
|
|
|
|
|
|
|
|
// CHECK: def Rec03
|
|
|
|
// CHECK: int Zero = 20
|
|
|
|
// CHECK: list<int> TwoFive = [22, 23, 24, 25]
|
|
|
|
|
|
|
|
def Rec03 {
|
|
|
|
int Zero = Class1<[20, 21, 22, 23, 24, 25, 26]>.Zero;
|
|
|
|
list<int> TwoFive = Class1<[20, 21, 22, 23, 24, 25, 26]>.TwoFive;
|
2004-07-27 09:00:56 +08:00
|
|
|
}
|
|
|
|
|
2021-04-05 21:13:25 +08:00
|
|
|
// Test multiclass template arguments.
|
|
|
|
|
|
|
|
// CHECK: def Rec04_MC1
|
|
|
|
// CHECK: int Zero = 30
|
|
|
|
// CHECK: list<int> TwoFive = [32, 33, 34, 35]
|
|
|
|
// CHECK: def Rec05_MC1
|
|
|
|
// CHECK: int Zero = 30
|
|
|
|
// CHECK: list<int> TwoFive = [32, 33, 34, 35]
|
|
|
|
|
|
|
|
multiclass MC1<list<int> ids> {
|
|
|
|
def _MC1 {
|
|
|
|
int Zero = ids[0];
|
|
|
|
list<int> TwoFive = ids[2...5];
|
|
|
|
}
|
|
|
|
}
|
2004-07-27 09:00:56 +08:00
|
|
|
|
2021-04-05 21:13:25 +08:00
|
|
|
defm Rec04 : MC1<[30, 31, 32, 33, 34, 35, 36]>;
|
|
|
|
defm Rec05 : MC1<[30, 31, 32, 33, 34, 35]>;
|
|
|
|
|
|
|
|
// Test taking a complex subset of the list items from another record.
|
|
|
|
|
|
|
|
// CHECK: def Rec07
|
|
|
|
// CHECK: list<int> SomeValues = [40, 43, 44, 45, 40, 47, 49, 48, 47, 46, 40]
|
|
|
|
|
|
|
|
def Rec06 {
|
|
|
|
list<int> Values = [40, 41, 42, 43, 44, 45, 46, 47, 48, 49];
|
|
|
|
}
|
|
|
|
|
|
|
|
def Rec07 {
|
|
|
|
list<int> SomeValues = Rec06.Values[0, 3...5, 0, 7, 9...6, 0];
|
|
|
|
}
|
2004-07-27 09:00:56 +08:00
|
|
|
|
2021-04-05 21:13:25 +08:00
|
|
|
// Test a double subscript.
|
2004-07-27 09:00:56 +08:00
|
|
|
|
2021-04-05 21:13:25 +08:00
|
|
|
// CHECK: def Rec08
|
|
|
|
// CHECK: list<list<string>> Array = {{.*}}"foo", "bar", "snork"], ["zoo", "quux", "flarp"]]
|
2021-04-09 23:59:18 +08:00
|
|
|
// CHECK: string Flarp = "flarp"
|
2021-04-05 21:13:25 +08:00
|
|
|
// CHECK: list<string> ZooQuux = ["zoo", "quux"]
|
2004-07-27 09:00:56 +08:00
|
|
|
|
2021-04-05 21:13:25 +08:00
|
|
|
def Rec08 {
|
|
|
|
list<list<string>> Array = [["foo", "bar", "snork"],
|
|
|
|
["zoo", "quux", "flarp"]];
|
2021-04-09 23:59:18 +08:00
|
|
|
string Flarp = Array[1][2];
|
2021-04-05 21:13:25 +08:00
|
|
|
list<string> ZooQuux = Array[1][0...1];
|
2004-07-27 09:00:56 +08:00
|
|
|
}
|
2021-04-09 23:59:18 +08:00
|
|
|
|
|
|
|
// Test uninitialized list elements.
|
|
|
|
|
|
|
|
// CHECK: def Rec09
|
|
|
|
// CHECK: int Zero = ?;
|
|
|
|
// CHECK: list<int> TwoFive = [2, 3, ?, 5];
|
2021-04-14 02:14:30 +08:00
|
|
|
// We need CHECK-NEXT for these because otherwise it will match anonymous defs
|
|
|
|
// that appear later.
|
|
|
|
// CHECK: def Rec10 {
|
|
|
|
// CHECK-NEXT: int Zero = ?;
|
|
|
|
// CHECK-NEXT: list<int> TwoFive = [2, 3, ?, 5];
|
2021-04-09 23:59:18 +08:00
|
|
|
|
|
|
|
def Rec09 : Class1<[?, ?, 2, 3, ?, 5, ?]>;
|
|
|
|
|
|
|
|
def Rec10 {
|
|
|
|
int Zero = Class1<[?, ?, 2, 3, ?, 5, ?]>.Zero;
|
|
|
|
list<int> TwoFive = Class1<[?, ?, 2, 3, ?, 5, ?]>.TwoFive;
|
|
|
|
}
|