summaryrefslogtreecommitdiffstats
path: root/llvm/test/TableGen/cast-multiclass.td
blob: 7c8ed5f1f048708b0400c5439409d999a548fb40 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
// RUN: llvm-tblgen %s | FileCheck %s

class AClass<bit C> {
  bit Cond = C;
}

def A0: AClass<0>;
def A1: AClass<1>;

class BoolToList<bit Value> {
  list<int> ret = !if(Value, [1]<int>, []<int>);
}

multiclass P<string AStr> {
  foreach i = BoolToList<!cast<AClass>(AStr).Cond>.ret in
    def SubDef;
}

// CHECK-NOT: def XSubDef
defm X : P<"A0">;

// CHECK: def YSubDef
defm Y : P<"A1">;
OpenPOWER on IntegriCloud