diff options
author | Sebastian Redl <sebastian.redl@getdesigned.at> | 2008-12-02 16:35:44 +0000 |
---|---|---|
committer | Sebastian Redl <sebastian.redl@getdesigned.at> | 2008-12-02 16:35:44 +0000 |
commit | fb4ccd7152723ac6190eb379250cfe7516cfd1b8 (patch) | |
tree | 46da48592c78914eccea2f229892af1fc18869b3 /lib/Parse/ParseExprCXX.cpp | |
parent | 3425c99aa2324579921fadf45f4d24b8ba18c0ec (diff) |
Make the parser handle ::new and ::delete correctly.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@60421 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Parse/ParseExprCXX.cpp')
-rw-r--r-- | lib/Parse/ParseExprCXX.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/lib/Parse/ParseExprCXX.cpp b/lib/Parse/ParseExprCXX.cpp index d995b887f2..5d790fa34c 100644 --- a/lib/Parse/ParseExprCXX.cpp +++ b/lib/Parse/ParseExprCXX.cpp @@ -38,6 +38,12 @@ bool Parser::MaybeParseCXXScopeSpecifier(CXXScopeSpec &SS) { (Tok.isNot(tok::identifier) || NextToken().isNot(tok::coloncolon))) return false; + // Don't parse ::new and ::delete as scope specifiers. It would only make + // things a lot more complicated. + if (Tok.is(tok::coloncolon) && (NextToken().is(tok::kw_new) || + NextToken().is(tok::kw_delete))) + return false; + if (Tok.is(tok::annot_cxxscope)) { SS.setScopeRep(Tok.getAnnotationValue()); SS.setRange(Tok.getAnnotationRange()); |