diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2008-11-08 01:09:16 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2008-11-08 01:09:16 +0000 |
commit | 99163252709b0c8334d8a49388344aaa2f0f3361 (patch) | |
tree | f5c3c3593a3c6c037c3d5ddd7ed53e238faa6169 /lib/Parse/ParseDecl.cpp | |
parent | 1a4d34fea72f327c78fad86dd8803ad2cdae9334 (diff) |
In a declarator, consider an identifier a constructor only if it is followed by '('.
Previously:
class C {
int C; // Declarator::SetConstructor was called here.
};
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@58880 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Parse/ParseDecl.cpp')
-rw-r--r-- | lib/Parse/ParseDecl.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/lib/Parse/ParseDecl.cpp b/lib/Parse/ParseDecl.cpp index 2b18be02a3..39d3acc0f9 100644 --- a/lib/Parse/ParseDecl.cpp +++ b/lib/Parse/ParseDecl.cpp @@ -1363,7 +1363,8 @@ void Parser::ParseDirectDeclarator(Declarator &D) { // Determine whether this identifier is a C++ constructor name or // a normal identifier. if (getLang().CPlusPlus && - Actions.isCurrentClassName(*Tok.getIdentifierInfo(), CurScope)) + Actions.isCurrentClassName(*Tok.getIdentifierInfo(), CurScope) && + NextToken().is(tok::l_paren)) D.SetConstructor(Actions.isTypeName(*Tok.getIdentifierInfo(), CurScope), Tok.getIdentifierInfo(), Tok.getLocation()); else |