summaryrefslogtreecommitdiffstats
path: root/clang/lib/Parse/ParseExprCXX.cpp
diff options
context:
space:
mode:
authorSebastian Redl <sebastian.redl@getdesigned.at>2008-12-02 16:35:44 +0000
committerSebastian Redl <sebastian.redl@getdesigned.at>2008-12-02 16:35:44 +0000
commitdb36b9b962a86d1e13224a27049fc8b6e52d4065 (patch)
tree8436605cdc4a42faf41887781a28d0b0c89205b5 /clang/lib/Parse/ParseExprCXX.cpp
parentfb5df7235a8e4192f07d942f2f0162f167f676f9 (diff)
downloadbcm5719-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.cpp6
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());
OpenPOWER on IntegriCloud