From: Sebastian Redl Date: Tue, 2 Dec 2008 16:35:44 +0000 (+0000) Subject: Make the parser handle ::new and ::delete correctly. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=fb4ccd7152723ac6190eb379250cfe7516cfd1b8;p=clang 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 --- diff --git a/lib/Parse/ParseExpr.cpp b/lib/Parse/ParseExpr.cpp index df46612b57..50b3a7a4ef 100644 --- a/lib/Parse/ParseExpr.cpp +++ b/lib/Parse/ParseExpr.cpp @@ -638,8 +638,13 @@ Parser::ExprResult Parser::ParseCastExpression(bool isUnaryExpression) { Res = ParseCXXIdExpression(); return ParsePostfixExpressionSuffix(Res); + case tok::coloncolon: // [C++] new-expression or [C++] delete-expression + if (NextToken().is(tok::kw_new)) + return ParseCXXNewExpression(); + else + return ParseCXXDeleteExpression(); + case tok::kw_new: // [C++] new-expression - // FIXME: ParseCXXIdExpression currently steals :: tokens. return ParseCXXNewExpression(); case tok::kw_delete: // [C++] delete-expression 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()); diff --git a/test/SemaCXX/new-delete.cpp b/test/SemaCXX/new-delete.cpp index 0a1a3aed31..d9b471362f 100644 --- a/test/SemaCXX/new-delete.cpp +++ b/test/SemaCXX/new-delete.cpp @@ -21,6 +21,7 @@ void good_news() ps = new (S[3])(1, 2, 3.4); typedef int ia4[4]; ia4 *pai = new (int[3][4]); + pi = ::new int; } void bad_news(int *ip) @@ -41,6 +42,7 @@ void bad_news(int *ip) // Undefined, but clang should reject it directly. (void)new int[-1]; // expected-error {{array size is negative}} (void)new int[*(S*)0]; // expected-error {{array size expression must have integral or enumerated type, not 'struct S'}} + (void)::S::new int; // expected-error {{expected unqualified-id}} // Some lacking cases due to lack of sema support. } @@ -49,6 +51,7 @@ void good_deletes() delete (int*)0; delete [](int*)0; delete (S*)0; + ::delete (int*)0; } void bad_deletes() @@ -58,4 +61,5 @@ void bad_deletes() // expected-note {{to match this '['}} delete (void*)0; // expected-error {{cannot delete expression}} delete (T*)0; // expected-warning {{deleting pointer to incomplete type}} + ::S::delete (int*)0; // expected-error {{expected unqualified-id}} }