genmatch.c (add_operator): Allow CONSTRUCTOR.
authorRichard Biener <rguenther@suse.de>
Fri, 14 Nov 2014 08:37:41 +0000 (08:37 +0000)
committerRichard Biener <rguenth@gcc.gnu.org>
Fri, 14 Nov 2014 08:37:41 +0000 (08:37 +0000)
2014-11-14  Richard Biener  <rguenther@suse.de>

* genmatch.c (add_operator): Allow CONSTRUCTOR.
(dt_node::gen_kids): Handle CONSTRUCTOR not as GENERIC.
(parser::parse_op): Allow to iterate over predicates.

From-SVN: r217541

gcc/ChangeLog
gcc/genmatch.c

index 682f6fd1e33509bdc6368122546232ec07ba4928..07c321ac733c775d76dd811d80fcca303df2019f 100644 (file)
@@ -1,3 +1,9 @@
+2014-11-14  Richard Biener  <rguenther@suse.de>
+
+       * genmatch.c (add_operator): Allow CONSTRUCTOR.
+       (dt_node::gen_kids): Handle CONSTRUCTOR not as GENERIC.
+       (parser::parse_op): Allow to iterate over predicates.
+
 2014-11-14  Jakub Jelinek  <jakub@redhat.com>
 
        * configure.ac (--with-diagnostics-color): New configure
index 6a2f8942a270f5e9a67d83d4d2241ff49c557378..fdd02a5358ac04879b2d15e5b551cf3e0512bb50 100644 (file)
@@ -310,7 +310,9 @@ add_operator (enum tree_code code, const char *id,
       /* For {REAL,IMAG}PART_EXPR and VIEW_CONVERT_EXPR.  */
       && strcmp (tcc, "tcc_reference") != 0
       /* To have INTEGER_CST and friends as "predicate operators".  */
-      && strcmp (tcc, "tcc_constant") != 0)
+      && strcmp (tcc, "tcc_constant") != 0
+      /* And allow CONSTRUCTOR for vector initializers.  */
+      && !(code == CONSTRUCTOR))
     return;
   operator_id *op = new operator_id (code, id, nargs, tcc);
   id_base **slot = operators->find_slot_with_hash (op, op->hashval, INSERT);
@@ -2013,7 +2015,8 @@ dt_node::gen_kids (FILE *f, bool gimple)
          dt_operand *op = as_a<dt_operand *> (kids[i]);
          if (expr *e = dyn_cast <expr *> (op->op))
            {
-             if (e->ops.length () == 0)
+             if (e->ops.length () == 0
+                 && (!gimple || !(*e->operation == CONSTRUCTOR)))
                generic_exprs.safe_push (op);
              else if (e->operation->kind == id_base::FN)
                {
@@ -3030,6 +3033,14 @@ parser::parse_op ()
                 expression.  */
              op = new expr (opr);
            }
+         else if (user_id *code = dyn_cast <user_id *> (opr))
+           {
+             if (code->nargs != 0)
+               fatal_at (token, "using an operator with operands as predicate");
+             /* Parse the zero-operand operator "predicates" as
+                expression.  */
+             op = new expr (opr);
+           }
          else if (predicate_id *p = dyn_cast <predicate_id *> (opr))
            op = new predicate (p);
          else