ast_unary::make: safer double-negation optimization check

This commit is contained in:
Wolfgang Bumiller 2015-02-01 12:13:05 +01:00
parent 896d4c53a3
commit 6d4539814e

20
ast.cpp
View file

@ -364,17 +364,21 @@ ast_binstore::~ast_binstore()
} }
ast_unary* ast_unary::make(lex_ctx_t ctx, int op, ast_expression *expr) ast_unary* ast_unary::make(lex_ctx_t ctx, int op, ast_expression *expr)
{
// handle double negation, double bitwise or logical not
if (op == opid2('!','P') ||
op == opid2('~','P') ||
op == opid2('-','P'))
{ {
if (ast_istype(expr, ast_unary) && OPTS_OPTIMIZATION(OPTIM_PEEPHOLE)) { if (ast_istype(expr, ast_unary) && OPTS_OPTIMIZATION(OPTIM_PEEPHOLE)) {
ast_unary *prev = (ast_unary*)((ast_unary*)expr)->m_operand; ast_unary *unary = reinterpret_cast<ast_unary*>(expr);
if (unary->m_op == op) {
/* Handle for double negation */ auto out = reinterpret_cast<ast_unary*>(unary->m_operand);
if (((ast_unary*)expr)->m_op == op) unary->m_operand = nullptr;
prev = (ast_unary*)((ast_unary*)expr)->m_operand; delete unary;
if (ast_istype(prev, ast_unary)) {
++opts_optimizationcount[OPTIM_PEEPHOLE]; ++opts_optimizationcount[OPTIM_PEEPHOLE];
return prev; return out;
}
} }
} }