Need to split aeq from ieq
This commit is contained in:
@@ -105,7 +105,8 @@ public abstract class If0 extends Instruction implements JumpingInstruction, Com
|
|||||||
|
|
||||||
// we can map these if they are getfield instructions?
|
// we can map these if they are getfield instructions?
|
||||||
|
|
||||||
assert ctx.getInstruction().getClass().equals(other.getInstruction().getClass());
|
// this is already checked before this
|
||||||
|
//assert ctx.getInstruction().getClass().equals(other.getInstruction().getClass());
|
||||||
|
|
||||||
Frame branch1 = ctx.getBranches().get(0),
|
Frame branch1 = ctx.getBranches().get(0),
|
||||||
branch2 = other.getBranches().get(0);
|
branch2 = other.getBranches().get(0);
|
||||||
|
|||||||
@@ -3,7 +3,9 @@ package net.runelite.deob.attributes.code.instructions;
|
|||||||
import net.runelite.deob.attributes.code.InstructionType;
|
import net.runelite.deob.attributes.code.InstructionType;
|
||||||
import net.runelite.deob.attributes.code.Instructions;
|
import net.runelite.deob.attributes.code.Instructions;
|
||||||
import net.runelite.deob.attributes.code.instruction.types.MappableInstruction;
|
import net.runelite.deob.attributes.code.instruction.types.MappableInstruction;
|
||||||
|
import net.runelite.deob.attributes.code.instruction.types.PushConstantInstruction;
|
||||||
import net.runelite.deob.execution.InstructionContext;
|
import net.runelite.deob.execution.InstructionContext;
|
||||||
|
import net.runelite.deob.execution.StackContext;
|
||||||
|
|
||||||
public class IfNe extends If0
|
public class IfNe extends If0
|
||||||
{
|
{
|
||||||
@@ -21,6 +23,29 @@ public class IfNe extends If0
|
|||||||
if (otherIc.getInstruction() instanceof IfCmpNe)
|
if (otherIc.getInstruction() instanceof IfCmpNe)
|
||||||
{
|
{
|
||||||
// check for one side being 0
|
// check for one side being 0
|
||||||
|
StackContext s1 = otherIc.getPops().get(0),
|
||||||
|
s2 = otherIc.getPops().get(1);
|
||||||
|
|
||||||
|
if (s1.getPushed().getInstruction() instanceof PushConstantInstruction)
|
||||||
|
{
|
||||||
|
PushConstantInstruction pci = (PushConstantInstruction) s1.getPushed().getInstruction();
|
||||||
|
Object o = pci.getConstant().getObject();
|
||||||
|
|
||||||
|
if (o.equals(0))
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (s2.getPushed().getInstruction() instanceof PushConstantInstruction)
|
||||||
|
{
|
||||||
|
PushConstantInstruction pci = (PushConstantInstruction) s2.getPushed().getInstruction();
|
||||||
|
Object o = pci.getConstant().getObject();
|
||||||
|
|
||||||
|
if (o.equals(0))
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
|||||||
@@ -2,6 +2,8 @@ package net.runelite.deob.attributes.code.instructions;
|
|||||||
|
|
||||||
import net.runelite.deob.attributes.code.InstructionType;
|
import net.runelite.deob.attributes.code.InstructionType;
|
||||||
import net.runelite.deob.attributes.code.Instructions;
|
import net.runelite.deob.attributes.code.Instructions;
|
||||||
|
import net.runelite.deob.execution.InstructionContext;
|
||||||
|
import net.runelite.deob.execution.StackContext;
|
||||||
|
|
||||||
public class IfNull extends If0
|
public class IfNull extends If0
|
||||||
{
|
{
|
||||||
@@ -10,4 +12,27 @@ public class IfNull extends If0
|
|||||||
super(instructions, type, pc);
|
super(instructions, type, pc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isSame(InstructionContext thisIc, InstructionContext otherIc)
|
||||||
|
{
|
||||||
|
if (super.isSame(thisIc, otherIc))
|
||||||
|
return true;
|
||||||
|
|
||||||
|
if (otherIc.getInstruction() instanceof IfCmpEq)
|
||||||
|
{
|
||||||
|
StackContext s1 = otherIc.getPops().get(0),
|
||||||
|
s2 = otherIc.getPops().get(1);
|
||||||
|
|
||||||
|
if (s1.getPushed().getInstruction() instanceof AConstNull)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (s2.getPushed().getInstruction() instanceof AConstNull)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user