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 | |
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
-rw-r--r-- | lib/Parse/ParseExpr.cpp | 7 | ||||
-rw-r--r-- | lib/Parse/ParseExprCXX.cpp | 6 | ||||
-rw-r--r-- | test/SemaCXX/new-delete.cpp | 4 |
3 files changed, 16 insertions, 1 deletions
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}} } |