Home | History | Annotate | Download | only in TableGen
      1 // RUN: llvm-tblgen %s | FileCheck %s
      2 // XFAIL: vg_leak
      3 
      4 // CHECK: --- Defs ---
      5 
      6 // CHECK: def A0 {
      7 // CHECK:   dag ret = (ops);
      8 // CHECK: }
      9 
     10 // CHECK: def A1 {
     11 // CHECK:   dag ret = (ops ?:$a, 1:$b, 2);
     12 // CHECK: }
     13 
     14 // CHECK: def A2 {
     15 // CHECK:   dag ret = (ops (ops ?:$name):$a, (ops 1):$b, (ops "foo"):$c);
     16 // CHECK: }
     17 
     18 // CHECK: def A3 {
     19 // CHECK:   dag ret = (ops NodeA0:$a, NodeB0:$b);
     20 // CHECK: }
     21 
     22 // CHECK: def A4 {
     23 // CHECK:   dag ret = (ops NodeA0, NodeB0);
     24 // CHECK: }
     25 
     26 // CHECK: def B0 {
     27 // CHECK:   dag ret = (ops);
     28 // CHECK: }
     29 
     30 // CHECK: def B1 {
     31 // CHECK:   dag ret = (ops 1:$a, 2:$b);
     32 // CHECK: }
     33 
     34 // CHECK: def C0 {
     35 // CHECK:   dag ret1 = (ops ?:$a, ?:$b);
     36 // CHECK:   dag ret2 = (ops 1, 2);
     37 // CHECK: }
     38 
     39 // CHECK: def D {
     40 // CHECK:   dag d1 = (ops 1, ?:$name1, 2, 3);
     41 // CHECK: }
     42 
     43 // CHECK: def E0 {
     44 // CHECK:   dag ret = (ops 1, 2);
     45 // CHECK: }
     46 
     47 class Ops;
     48 
     49 def ops : Ops;
     50 
     51 class Node<int val, string name> {
     52   int Val = val;
     53   string Name = name;
     54 }
     55 
     56 class Aint<list<int> nodes, list<string> names> {
     57   dag ret = !dag(ops, nodes, names);
     58 }
     59 
     60 class Adag<list<dag> nodes, list<string> names> {
     61   dag ret = !dag(ops, nodes, names);
     62 }
     63 
     64 class NodeBase;
     65 
     66 class NodeA<int val> : NodeBase {
     67   int x = val;
     68 }
     69 
     70 class NodeB<int val> : NodeBase {
     71   int y = val;
     72 }
     73 
     74 class Anode<list<NodeBase> nodes, list<string> names> {
     75   dag ret = !dag(ops, nodes, names);
     76 }
     77 
     78 class B<list<Node> nodes> {
     79   dag ret = !foldl((ops), nodes, lhs, rhs, !con(lhs, !dag(ops, [rhs.Val], [rhs.Name])));
     80 }
     81 
     82 def A0 : Aint<[], []>;
     83 def A1 : Aint<[?, 1, 2], ["a", "b", ?]>;
     84 
     85 def A2 : Adag<[(ops $name), (ops 1), (ops "foo")], ["a", "b", "c"]>;
     86 
     87 def NodeA0 : NodeA<0>;
     88 def NodeB0 : NodeB<0>;
     89 
     90 def A3 : Anode<[NodeA0, NodeB0], ["a", "b"]>;
     91 
     92 def A4 {
     93   // Like A3, but with a literal list directly in the !dag.
     94   dag ret = !dag(ops, [NodeA0, NodeB0], ?);
     95 }
     96 
     97 def B0 : B<[]>;
     98 def B1 : B<[Node<1, "a">, Node<2, "b">]>;
     99 
    100 class C<list<int> nodes, list<string> names> {
    101   dag ret1 = !dag(ops, ?, names);
    102   dag ret2 = !dag(ops, nodes, ?);
    103 }
    104 
    105 def C0 : C<[1, 2], ["a", "b"]>;
    106 
    107 def D {
    108   dag d1 = !con((ops 1), (ops $name1), (ops), (ops 2, 3));
    109 }
    110 
    111 class E<Ops op> {
    112   // Allow concatenation of DAG nodes with operators from template arguments.
    113   dag ret = !con((op 1), (op 2));
    114 }
    115 
    116 def E0 : E<ops>;
    117