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 | db36b9b962a86d1e13224a27049fc8b6e52d4065 (patch) | |
| tree | 8436605cdc4a42faf41887781a28d0b0c89205b5 /clang/lib/Parse/ParseExprCXX.cpp | |
| parent | fb5df7235a8e4192f07d942f2f0162f167f676f9 (diff) | |
| download | bcm5719-llvm-db36b9b962a86d1e13224a27049fc8b6e52d4065.tar.gz bcm5719-llvm-db36b9b962a86d1e13224a27049fc8b6e52d4065.zip | |
Make the parser handle ::new and ::delete correctly.
llvm-svn: 60421
Diffstat (limited to 'clang/lib/Parse/ParseExprCXX.cpp')
| -rw-r--r-- | clang/lib/Parse/ParseExprCXX.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/clang/lib/Parse/ParseExprCXX.cpp b/clang/lib/Parse/ParseExprCXX.cpp index d995b887f26..5d790fa34cd 100644 --- a/clang/lib/Parse/ParseExprCXX.cpp +++ b/clang/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()); |

