forked from OSchip/llvm-project
PR4364: fix parsing 'typename' in an expression.
llvm-svn: 73177
This commit is contained in:
parent
c43620dedf
commit
6d692cc2e8
|
@ -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;
|
||||
|
|
|
@ -0,0 +1,19 @@
|
|||
// RUN: clang-cc -fsyntax-only -verify %s
|
||||
|
||||
// PR4364
|
||||
template<class T> struct a {
|
||||
T b() {
|
||||
return typename T::x();
|
||||
}
|
||||
};
|
||||
struct B {
|
||||
typedef B x;
|
||||
};
|
||||
B c() {
|
||||
a<B> x;
|
||||
return x.b();
|
||||
}
|
||||
|
||||
// Some extra tests for invalid cases
|
||||
template<class T> struct test2 { T b() { return typename T::a; } }; // expected-error{{expected '(' for function-style cast or type construction}}
|
||||
template<class T> struct test3 { T b() { return typename a; } }; // expected-error{{expected a qualified name after 'typename'}}
|
Loading…
Reference in New Issue