Fix conversion of negative integers to char literals

Signed-off-by: Graham <gpe@openrs2.dev>
bzip2
Graham 4 years ago
parent d9922da1c5
commit 9c80ff1c6e
  1. 11
      deob-ast/src/main/java/dev/openrs2/deob/ast/transform/CharLiteralTransformer.kt

@ -14,9 +14,11 @@ import com.github.javaparser.ast.expr.BinaryExpr.Operator.PLUS
import com.github.javaparser.ast.expr.CharLiteralExpr import com.github.javaparser.ast.expr.CharLiteralExpr
import com.github.javaparser.ast.expr.Expression import com.github.javaparser.ast.expr.Expression
import com.github.javaparser.ast.expr.IntegerLiteralExpr import com.github.javaparser.ast.expr.IntegerLiteralExpr
import com.github.javaparser.ast.expr.UnaryExpr
import com.github.javaparser.resolution.types.ResolvedPrimitiveType import com.github.javaparser.resolution.types.ResolvedPrimitiveType
import dev.openrs2.deob.ast.Library import dev.openrs2.deob.ast.Library
import dev.openrs2.deob.ast.LibraryGroup import dev.openrs2.deob.ast.LibraryGroup
import dev.openrs2.deob.ast.util.checkedAsInt
import dev.openrs2.deob.ast.util.walk import dev.openrs2.deob.ast.util.walk
import java.lang.Character.CONTROL import java.lang.Character.CONTROL
import java.lang.Character.FORMAT import java.lang.Character.FORMAT
@ -49,7 +51,14 @@ class CharLiteralTransformer : Transformer() {
return return
} }
b.replace(CharLiteralExpr(escape(b.asNumber().toChar()))) val n = b.checkedAsInt()
if (n < 0) {
val char = (-n).toChar()
b.replace(UnaryExpr(CharLiteralExpr(escape(char)), UnaryExpr.Operator.MINUS))
} else {
val char = n.toChar()
b.replace(CharLiteralExpr(escape(char)))
}
} }
private fun escape(c: Char): String { private fun escape(c: Char): String {

Loading…
Cancel
Save