parent
fc00d69539
commit
130a05956e
@ -1,104 +0,0 @@ |
|||||||
package dev.openrs2.deob.ast.util; |
|
||||||
|
|
||||||
import com.github.javaparser.ast.expr.BinaryExpr; |
|
||||||
import com.github.javaparser.ast.expr.BooleanLiteralExpr; |
|
||||||
import com.github.javaparser.ast.expr.Expression; |
|
||||||
import com.github.javaparser.ast.expr.IntegerLiteralExpr; |
|
||||||
import com.github.javaparser.ast.expr.LongLiteralExpr; |
|
||||||
import com.github.javaparser.ast.expr.UnaryExpr; |
|
||||||
|
|
||||||
public final class ExprUtils { |
|
||||||
public static boolean isIntegerOrLongLiteral(Expression expr) { |
|
||||||
return expr.isIntegerLiteralExpr() || expr.isLongLiteralExpr(); |
|
||||||
} |
|
||||||
|
|
||||||
public static LongLiteralExpr createLong(long value) { |
|
||||||
return new LongLiteralExpr(Long.toString(value).concat("L")); |
|
||||||
} |
|
||||||
|
|
||||||
public static Expression negate(Expression expr) { |
|
||||||
if (expr.isUnaryExpr() && expr.asUnaryExpr().getOperator() == UnaryExpr.Operator.MINUS) { |
|
||||||
return expr.asUnaryExpr().getExpression().clone(); |
|
||||||
} else if (expr.isIntegerLiteralExpr()) { |
|
||||||
return new IntegerLiteralExpr(-expr.asIntegerLiteralExpr().asInt()); |
|
||||||
} else if (expr.isLongLiteralExpr()) { |
|
||||||
return createLong(-expr.asLongLiteralExpr().asLong()); |
|
||||||
} else { |
|
||||||
throw new IllegalArgumentException(); |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
public static Expression not(Expression expr) { |
|
||||||
if (expr.isUnaryExpr()) { |
|
||||||
var unary = expr.asUnaryExpr(); |
|
||||||
if (unary.getOperator() == UnaryExpr.Operator.LOGICAL_COMPLEMENT) { |
|
||||||
return unary.getExpression().clone(); |
|
||||||
} |
|
||||||
} else if (expr.isBinaryExpr()) { |
|
||||||
var binary = expr.asBinaryExpr(); |
|
||||||
|
|
||||||
var left = binary.getLeft(); |
|
||||||
var right = binary.getRight(); |
|
||||||
|
|
||||||
switch (binary.getOperator()) { |
|
||||||
case EQUALS: |
|
||||||
return new BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.NOT_EQUALS); |
|
||||||
case NOT_EQUALS: |
|
||||||
return new BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.EQUALS); |
|
||||||
case GREATER: |
|
||||||
return new BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.LESS_EQUALS); |
|
||||||
case GREATER_EQUALS: |
|
||||||
return new BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.LESS); |
|
||||||
case LESS: |
|
||||||
return new BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.GREATER_EQUALS); |
|
||||||
case LESS_EQUALS: |
|
||||||
return new BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.GREATER); |
|
||||||
case AND: |
|
||||||
return new BinaryExpr(not(left), not(right), BinaryExpr.Operator.OR); |
|
||||||
case OR: |
|
||||||
return new BinaryExpr(not(left), not(right), BinaryExpr.Operator.AND); |
|
||||||
} |
|
||||||
} else if (expr.isBooleanLiteralExpr()) { |
|
||||||
return new BooleanLiteralExpr(!expr.asBooleanLiteralExpr().getValue()); |
|
||||||
} |
|
||||||
return new UnaryExpr(expr.clone(), UnaryExpr.Operator.LOGICAL_COMPLEMENT); |
|
||||||
} |
|
||||||
|
|
||||||
public static int countNots(Expression expr) { |
|
||||||
int count = 0; |
|
||||||
|
|
||||||
if (expr.isUnaryExpr() && expr.asUnaryExpr().getOperator() == UnaryExpr.Operator.LOGICAL_COMPLEMENT) { |
|
||||||
count++; |
|
||||||
} else if (expr.isBinaryExpr() && expr.asBinaryExpr().getOperator() == BinaryExpr.Operator.NOT_EQUALS) { |
|
||||||
count++; |
|
||||||
} |
|
||||||
|
|
||||||
for (Expression child : expr.findAll(Expression.class)) { |
|
||||||
if (child != expr) { |
|
||||||
count += countNots(child); |
|
||||||
} |
|
||||||
} |
|
||||||
|
|
||||||
return count; |
|
||||||
} |
|
||||||
|
|
||||||
public static boolean hasSideEffects(Expression expr) { |
|
||||||
if (expr.isLiteralExpr() || expr.isNameExpr() | expr.isFieldAccessExpr()) { |
|
||||||
return false; |
|
||||||
} else if (expr.isUnaryExpr()) { |
|
||||||
return hasSideEffects(expr.asUnaryExpr().getExpression()); |
|
||||||
} else if (expr.isBinaryExpr()) { |
|
||||||
var binary = expr.asBinaryExpr(); |
|
||||||
return hasSideEffects(binary.getLeft()) || hasSideEffects(binary.getRight()); |
|
||||||
} else if (expr.isArrayAccessExpr()) { |
|
||||||
var access = expr.asArrayAccessExpr(); |
|
||||||
return hasSideEffects(access.getName()) || hasSideEffects(access.getIndex()); |
|
||||||
} |
|
||||||
// TODO(gpe): more cases
|
|
||||||
return true; |
|
||||||
} |
|
||||||
|
|
||||||
private ExprUtils() { |
|
||||||
/* empty */ |
|
||||||
} |
|
||||||
} |
|
@ -0,0 +1,94 @@ |
|||||||
|
package dev.openrs2.deob.ast.util |
||||||
|
|
||||||
|
import com.github.javaparser.ast.expr.* |
||||||
|
|
||||||
|
fun Expression.isIntegerOrLongLiteral(): Boolean { |
||||||
|
return isIntegerLiteralExpr || isLongLiteralExpr |
||||||
|
} |
||||||
|
|
||||||
|
fun createLong(value: Long): LongLiteralExpr { |
||||||
|
return LongLiteralExpr(java.lang.Long.toString(value) + "L") |
||||||
|
} |
||||||
|
|
||||||
|
fun Expression.negate(): Expression { |
||||||
|
return if (isUnaryExpr && asUnaryExpr().operator == UnaryExpr.Operator.MINUS) { |
||||||
|
asUnaryExpr().expression.clone() |
||||||
|
} else if (isIntegerLiteralExpr) { |
||||||
|
IntegerLiteralExpr(-asIntegerLiteralExpr().asInt()) |
||||||
|
} else if (isLongLiteralExpr) { |
||||||
|
createLong(-asLongLiteralExpr().asLong()) |
||||||
|
} else { |
||||||
|
throw IllegalArgumentException() |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
fun Expression.not(): Expression { |
||||||
|
if (isUnaryExpr) { |
||||||
|
val unary = asUnaryExpr() |
||||||
|
if (unary.operator == UnaryExpr.Operator.LOGICAL_COMPLEMENT) { |
||||||
|
return unary.expression.clone() |
||||||
|
} |
||||||
|
} else if (isBinaryExpr) { |
||||||
|
val binary = asBinaryExpr() |
||||||
|
|
||||||
|
val left = binary.left |
||||||
|
val right = binary.right |
||||||
|
|
||||||
|
@Suppress("NON_EXHAUSTIVE_WHEN") |
||||||
|
when (binary.operator) { |
||||||
|
BinaryExpr.Operator.EQUALS -> |
||||||
|
return BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.NOT_EQUALS) |
||||||
|
BinaryExpr.Operator.NOT_EQUALS -> |
||||||
|
return BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.EQUALS) |
||||||
|
BinaryExpr.Operator.GREATER -> |
||||||
|
return BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.LESS_EQUALS) |
||||||
|
BinaryExpr.Operator.GREATER_EQUALS -> |
||||||
|
return BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.LESS) |
||||||
|
BinaryExpr.Operator.LESS -> |
||||||
|
return BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.GREATER_EQUALS) |
||||||
|
BinaryExpr.Operator.LESS_EQUALS -> |
||||||
|
return BinaryExpr(left.clone(), right.clone(), BinaryExpr.Operator.GREATER) |
||||||
|
BinaryExpr.Operator.AND -> |
||||||
|
return BinaryExpr(left.not(), right.not(), BinaryExpr.Operator.OR) |
||||||
|
BinaryExpr.Operator.OR -> |
||||||
|
return BinaryExpr(left.not(), right.not(), BinaryExpr.Operator.AND) |
||||||
|
} |
||||||
|
} else if (isBooleanLiteralExpr) { |
||||||
|
return BooleanLiteralExpr(!asBooleanLiteralExpr().value) |
||||||
|
} |
||||||
|
return UnaryExpr(clone(), UnaryExpr.Operator.LOGICAL_COMPLEMENT) |
||||||
|
} |
||||||
|
|
||||||
|
fun Expression.countNots(): Int { |
||||||
|
var count = 0 |
||||||
|
|
||||||
|
if (isUnaryExpr && asUnaryExpr().operator == UnaryExpr.Operator.LOGICAL_COMPLEMENT) { |
||||||
|
count++ |
||||||
|
} else if (isBinaryExpr && asBinaryExpr().operator == BinaryExpr.Operator.NOT_EQUALS) { |
||||||
|
count++ |
||||||
|
} |
||||||
|
|
||||||
|
for (child in findAll(Expression::class.java)) { |
||||||
|
if (child !== this) { |
||||||
|
count += child.countNots() |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return count |
||||||
|
} |
||||||
|
|
||||||
|
fun Expression.hasSideEffects(): Boolean { |
||||||
|
if (isLiteralExpr || isNameExpr || isFieldAccessExpr) { |
||||||
|
return false |
||||||
|
} else if (isUnaryExpr) { |
||||||
|
return asUnaryExpr().expression.hasSideEffects() |
||||||
|
} else if (isBinaryExpr) { |
||||||
|
val binary = asBinaryExpr() |
||||||
|
return binary.left.hasSideEffects() || binary.right.hasSideEffects() |
||||||
|
} else if (isArrayAccessExpr) { |
||||||
|
val access = asArrayAccessExpr() |
||||||
|
return access.name.hasSideEffects() || access.index.hasSideEffects() |
||||||
|
} |
||||||
|
// TODO(gpe): more cases |
||||||
|
return true |
||||||
|
} |
Loading…
Reference in new issue