From 1ee2c43bc0c281b60b29f1883e1e206cae28aed6 Mon Sep 17 00:00:00 2001 From: Argyrios Kyrtzidis Date: Sun, 5 Oct 2008 14:27:18 +0000 Subject: [PATCH] Consider GNU attributes when doing ambiguity resolution. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@57108 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Parse/ParseTentative.cpp | 21 +++++++++++++++------ test/SemaCXX/decl-expr-ambiguity.cpp | 1 + 2 files changed, 16 insertions(+), 6 deletions(-) diff --git a/lib/Parse/ParseTentative.cpp b/lib/Parse/ParseTentative.cpp index 414f1f51f7..5e4888f699 100644 --- a/lib/Parse/ParseTentative.cpp +++ b/lib/Parse/ParseTentative.cpp @@ -164,12 +164,13 @@ Parser::TentativeParsingResult Parser::TryParseSimpleDeclaration() { return TPR_ambiguous; } -/// init-declarator-list: -/// init-declarator -/// init-declarator-list ',' init-declarator +/// init-declarator-list: +/// init-declarator +/// init-declarator-list ',' init-declarator /// -/// init-declarator: -/// declarator initializer[opt] +/// init-declarator: +/// declarator initializer[opt] +/// [GNU] declarator simple-asm-expr[opt] attributes[opt] initializer[opt] /// /// initializer: /// '=' initializer-clause @@ -195,6 +196,10 @@ Parser::TentativeParsingResult Parser::TryParseInitDeclaratorList() { if (TPR != TPR_ambiguous) return TPR; + // [GNU] simple-asm-expr[opt] attributes[opt] + if (Tok.is(tok::kw_asm) || Tok.is(tok::kw___attribute)) + return TPR_true; + // initializer[opt] if (Tok.is(tok::l_paren)) { // Parse through the parens. @@ -230,6 +235,7 @@ Parser::TentativeParsingResult Parser::TryParseInitDeclaratorList() { /// cv-qualifier-seq[opt] exception-specification[opt] /// direct-declarator '[' constant-expression[opt] ']' /// '(' declarator ')' +/// [GNU] '(' attributes declarator ')' /// /// abstract-declarator: /// ptr-operator abstract-declarator[opt] @@ -302,8 +308,11 @@ Parser::TentativeParsingResult Parser::TryParseDeclarator(bool mayBeAbstract) { return TPR; } else { // '(' declarator ')' + // '(' attributes declarator ')' // '(' abstract-declarator ')' - ConsumeParen(); + ConsumeParen(); + if (Tok.is(tok::kw___attribute)) + return TPR_true; // attributes indicate declaration TentativeParsingResult TPR = TryParseDeclarator(mayBeAbstract); if (TPR != TPR_ambiguous) return TPR; diff --git a/test/SemaCXX/decl-expr-ambiguity.cpp b/test/SemaCXX/decl-expr-ambiguity.cpp index b9e824dff0..48e132097e 100644 --- a/test/SemaCXX/decl-expr-ambiguity.cpp +++ b/test/SemaCXX/decl-expr-ambiguity.cpp @@ -17,4 +17,5 @@ void f() { T(d)[5]; // expected-warning {{statement was disambiguated as declaration}} expected-error {{redefinition of 'd'}} typeof(int[])(f) = { 1, 2 }; // expected-warning {{statement was disambiguated as declaration}} void(b)(int); + int(d2) __attribute__(()); // expected-warning {{statement was disambiguated as declaration}} } -- 2.50.1