mirror of
https://github.com/DarkPlacesEngine/gmqcc.git
synced 2025-01-20 23:30:42 +00:00
ast_unary::make: safer double-negation optimization check
This commit is contained in:
parent
896d4c53a3
commit
6d4539814e
1 changed files with 14 additions and 10 deletions
20
ast.cpp
20
ast.cpp
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue