]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
backport: re PR c++/92648 (Handling of unknown attributes)
authorJakub Jelinek <jakub@redhat.com>
Fri, 20 Dec 2019 17:01:08 +0000 (18:01 +0100)
committerJakub Jelinek <jakub@gcc.gnu.org>
Fri, 20 Dec 2019 17:01:08 +0000 (18:01 +0100)
Backported from mainline
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.

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

From-SVN: r279655

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 98aada5425939b10e4a4b0c7b807650666678edd..01dad30b3ef60c0c3fd555cb3def74e203175359 100644 (file)
@@ -3,6 +3,11 @@
        Backported from mainline
        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.
+
        PR c++/61414
        * class.c (enum_to_min_precision): New hash_map.
        (enum_min_precision): New function.
index 91702a50324fcc3b969c096805cfd6fd22b00416..8b5fa4cbd5ff28645a1a147287af027d679be63c 100644 (file)
@@ -2650,6 +2650,7 @@ static bool cp_parser_init_statement_p
   (cp_parser *);
 static bool cp_parser_skip_to_closing_square_bracket
   (cp_parser *);
+static size_t cp_parser_skip_balanced_tokens (cp_parser *, size_t);
 
 /* Concept-related syntactic transformations */
 
@@ -26189,6 +26190,17 @@ cp_parser_std_attribute (cp_parser *parser, tree attr_ns)
       /* A GNU attribute that takes an identifier in parameter.  */
       attr_flag = id_attr;
 
+    const attribute_spec *as
+      = lookup_attribute_spec (TREE_PURPOSE (attribute));
+    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,
index 54cf7e5feb81baeeb3e311712d818e556a7e989e..57d96f0439caf3b460b36e7a2cd278ae9e0b91dd 100644 (file)
@@ -3,6 +3,9 @@
        Backported from mainline
        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" }