From: Eli Friedman Date: Thu, 11 Jun 2009 00:33:41 +0000 (+0000) Subject: PR4364: fix parsing 'typename' in an expression. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2e0cdb4e5442c2f1976dcf8f304bfa6b5f90f728;p=clang PR4364: fix parsing 'typename' in an expression. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@73177 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Parse/ParseExpr.cpp b/lib/Parse/ParseExpr.cpp index cd62c64276..3fee78bb71 100644 --- a/lib/Parse/ParseExpr.cpp +++ b/lib/Parse/ParseExpr.cpp @@ -749,7 +749,13 @@ Parser::OwningExprResult Parser::ParseCastExpression(bool isUnaryExpression, Diag(Tok, diag::err_expected_expression); return ExprError(); } - + + if (SavedKind == tok::kw_typename) { + // postfix-expression: typename-specifier '(' expression-list[opt] ')' + if (!TryAnnotateTypeOrScopeToken()) + return ExprError(); + } + // postfix-expression: simple-type-specifier '(' expression-list[opt] ')' // DeclSpec DS; diff --git a/test/SemaCXX/typename-expression.cpp b/test/SemaCXX/typename-expression.cpp new file mode 100644 index 0000000000..8dde6095e5 --- /dev/null +++ b/test/SemaCXX/typename-expression.cpp @@ -0,0 +1,19 @@ +// RUN: clang-cc -fsyntax-only -verify %s + +// PR4364 +template struct a { + T b() { + return typename T::x(); + } +}; +struct B { + typedef B x; +}; +B c() { + a x; + return x.b(); +} + +// Some extra tests for invalid cases +template struct test2 { T b() { return typename T::a; } }; // expected-error{{expected '(' for function-style cast or type construction}} +template struct test3 { T b() { return typename a; } }; // expected-error{{expected a qualified name after 'typename'}}