forked from OSchip/llvm-project
Make the parser handle ::new and ::delete correctly.
llvm-svn: 60421
This commit is contained in:
parent
fb5df7235a
commit
db36b9b962
|
@ -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
|
||||
|
|
|
@ -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());
|
||||
|
|
|
@ -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}}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue