From 1c9a724a2fa61fde8ee39c373e277f144655eab5 Mon Sep 17 00:00:00 2001 From: Roberto Raggi <roberto.raggi@nokia.com> Date: Thu, 4 Jun 2009 12:54:15 +0200 Subject: [PATCH] Check new-expressions. --- src/shared/cplusplus/CheckExpression.cpp | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/src/shared/cplusplus/CheckExpression.cpp b/src/shared/cplusplus/CheckExpression.cpp index 6e83ce47bf4..08801a5b542 100644 --- a/src/shared/cplusplus/CheckExpression.cpp +++ b/src/shared/cplusplus/CheckExpression.cpp @@ -210,17 +210,30 @@ bool CheckExpression::visit(TemplateIdAST *ast) bool CheckExpression::visit(NewExpressionAST *ast) { - // ### FIXME - // ### process ast->new_placement + if (ast->new_placement) { + for (ExpressionListAST *it = ast->new_placement->expression_list; it; it = it->next) { + FullySpecifiedType exprTy = semantic()->check(it->expression, _scope); + Q_UNUSED(exprTy); + } + } FullySpecifiedType typeIdTy = semantic()->check(ast->type_id, _scope); if (ast->new_type_id) { FullySpecifiedType ty = semantic()->check(ast->new_type_id->type_specifier, _scope); - // ### process ast->new_type_id + Q_UNUSED(ty); + + for (NewArrayDeclaratorAST *it = ast->new_type_id->new_array_declarators; it; it = it->next) { + FullySpecifiedType exprTy = semantic()->check(it->expression, _scope); + Q_UNUSED(exprTy); + } } // ### process new-initializer + if (ast->new_initializer) { + FullySpecifiedType exprTy = semantic()->check(ast->new_initializer->expression, _scope); + Q_UNUSED(exprTy); + } return false; } -- GitLab