re PR c++/92648 (Handling of unknown attributes)
authorJakub Jelinek <jakub@redhat.com>
Tue, 26 Nov 2019 21:58:22 +0000 (22:58 +0100)
committerJakub Jelinek <jakub@gcc.gnu.org>
Tue, 26 Nov 2019 21:58:22 +0000 (22:58 +0100)
PR c++/92648
* parser.c (cp_parser_std_attribute): For unknown attributes,
skip balanced token seq instead of trying to parse
attribute-argument-clause as expression list.  Formatting fix.

* g++.dg/cpp0x/gen-attrs-71.C: New test.

From-SVN: r278737

gcc/cp/ChangeLog
gcc/cp/parser.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/cpp0x/gen-attrs-71.C [new file with mode: 0644]

index be36daaa516c8226f54407781544e0f517691fbb..a7c0bca9e312070ddefdb0ff07e30b8fb5b7686f 100644 (file)
@@ -1,5 +1,10 @@
 2019-11-26  Jakub Jelinek  <jakub@redhat.com>
 
+       PR c++/92648
+       * parser.c (cp_parser_std_attribute): For unknown attributes,
+       skip balanced token seq instead of trying to parse
+       attribute-argument-clause as expression list.  Formatting fix.
+
        PR c++/61414
        * class.c (enum_to_min_precision): New hash_map.
        (enum_min_precision): New function.
index be3128634b1f7a676ee9fa4a959fb0ddfdec2c23..d0c9ff01d9ee30aaf11f9c79f80e777e9884904b 100644 (file)
@@ -26629,6 +26629,15 @@ cp_parser_std_attribute (cp_parser *parser, tree attr_ns)
       /* A GNU attribute that takes an identifier in parameter.  */
       attr_flag = id_attr;
 
+    if (as == NULL)
+      {
+       /* For unknown attributes, just skip balanced tokens instead of
+          trying to parse the arguments.  */
+       for (size_t n = cp_parser_skip_balanced_tokens (parser, 1) - 1; n; --n)
+         cp_lexer_consume_token (parser->lexer);
+       return attribute;
+      }
+
     vec = cp_parser_parenthesized_expression_list
       (parser, attr_flag, /*cast_p=*/false,
        /*allow_expansion_p=*/true,
@@ -26637,7 +26646,7 @@ cp_parser_std_attribute (cp_parser *parser, tree attr_ns)
       arguments = error_mark_node;
     else
       {
-       if (vec->is_empty())
+       if (vec->is_empty ())
          /* e.g. [[attr()]].  */
          error_at (token->location, "parentheses must be omitted if "
                    "%qE attribute argument list is empty",
index 6a777328d5059ee9d2339e22d8dea2f859b4be27..32ba76b21f76ef2ef69625b343b06c97c4276491 100644 (file)
@@ -1,5 +1,8 @@
 2019-11-26  Jakub Jelinek  <jakub@redhat.com>
 
+       PR c++/92648
+       * g++.dg/cpp0x/gen-attrs-71.C: New test.
+
        PR c++/61414
        * g++.dg/cpp0x/enum23.C: Remove xfail.
        * g++.dg/cpp0x/enum28.C: New test.
diff --git a/gcc/testsuite/g++.dg/cpp0x/gen-attrs-71.C b/gcc/testsuite/g++.dg/cpp0x/gen-attrs-71.C
new file mode 100644 (file)
index 0000000..7876a2f
--- /dev/null
@@ -0,0 +1,7 @@
+// PR c++/92648
+// { dg-do compile { target c++11 } }
+
+int a [[gnu::no_such_attribute(![!(!)!]!,;;)]];        // { dg-warning "ignored" }
+int b [[no_such_namespace::nonexisting_attribute(linear(c, d : 2), reduction(*:e), linear(uval (f)))]];        // { dg-warning "ignored" }
+int c [[gnu::nonexisting_attribute()]];        // { dg-warning "ignored" }
+int d [[gnu::another_nonexistent_attr(1,"abcd",g+6)]]; // { dg-warning "ignored" }