Merge pull request #560 from Abextm/script-opcode-injection

Raw injector for script VM
This commit is contained in:
Adam
2018-02-09 23:43:54 -05:00
committed by GitHub
8 changed files with 124 additions and 79 deletions

View File

@@ -45,8 +45,6 @@ import net.runelite.api.PacketBuffer;
import net.runelite.api.Point;
import net.runelite.api.Projectile;
import net.runelite.api.Region;
import net.runelite.api.Script;
import net.runelite.api.events.ScriptEvent;
import net.runelite.client.RuneLite;
import net.runelite.client.chat.ChatMessageManager;
import net.runelite.client.game.DeathChecker;
@@ -170,28 +168,6 @@ public class Hooks
}
}
/**
*
* @param opcode
* @param script
* @param isOne
* @return 0 halts, 1 continues, 2 throws
*/
public static int runeliteExecute(int opcode, Script script, boolean isOne)
{
String[] stringStack = client.getStringStack();
int stackSize = client.getStringStackSize();
String eventName = stringStack[--stackSize];
client.setStringStackSize(stackSize);
ScriptEvent event = new ScriptEvent();
event.setScript(script);
event.setEventName(eventName);
eventBus.post(event);
return 1;
}
public static void menuActionHook(int actionParam, int widgetId, int menuAction, int id, String menuOption, String menuTarget, int var6, int var7)
{
/* Along the way, the RuneScape client may change a menuAction by incrementing it with 2000.

View File

@@ -25,7 +25,6 @@
package net.runelite.client.callback;
import com.google.common.eventbus.EventBus;
import net.runelite.api.Script;
import org.slf4j.Logger;
/**
@@ -38,9 +37,4 @@ public class Hooks
public static Logger log;
public static EventBus eventBus;
public static int runeliteExecute(int opcode, Script script, boolean isOne)
{
throw new RuntimeException();
}
}

View File

@@ -0,0 +1,97 @@
/*
* Copyright (c) 2018 Abex
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package net.runelite.mixins;
import net.runelite.api.Client;
import net.runelite.api.events.ScriptEvent;
import net.runelite.api.mixins.Copy;
import net.runelite.api.mixins.Inject;
import net.runelite.api.mixins.Mixin;
import net.runelite.api.mixins.Replace;
import net.runelite.api.mixins.Shadow;
import net.runelite.client.callback.Hooks;
import net.runelite.rs.api.RSClient;
import net.runelite.rs.api.RSScript;
import net.runelite.rs.api.RSScriptEvent;
import static net.runelite.api.Opcodes.RUNELITE_EXECUTE;
@Mixin(RSClient.class)
public abstract class ScriptVMMixin implements RSClient
{
@Shadow("clientInstance")
private static Client client;
// This field is set by the ScriptVM raw injector
@Inject
private static RSScript currentScript;
// This field is set by the ScriptVM raw injector
@Inject
private static int currentScriptPC;
// Call is injected into runScript by the ScriptVM raw injector
@Inject
static boolean vmExecuteOpcode(int opcode)
{
if (opcode == RUNELITE_EXECUTE)
{
if (currentScript.getInstructions()[currentScriptPC] != RUNELITE_EXECUTE)
{
throw new AssertionError("currentScriptPC is wrong");
}
int stringStackSize = client.getStringStackSize();
String stringOp = client.getStringStack()[--stringStackSize];
client.setStringStackSize(stringStackSize);
ScriptEvent event = new ScriptEvent();
event.setScript(currentScript);
event.setEventName(stringOp);
Hooks.eventBus.post(event);
return true;
}
return false;
}
@Copy("runScript")
static void rs$runScript(RSScriptEvent event, int maxExecutionTime)
{
throw new RuntimeException();
}
@Replace("runScript")
static void rl$runScript(RSScriptEvent event, int maxExecutionTime)
{
try
{
rs$runScript(event, maxExecutionTime);
}
finally
{
currentScript = null;
}
}
}

View File

@@ -230,8 +230,8 @@ LABEL198:
6202
get_varc 73
load_int 195
;load_string "fixedOuterZoomLimit"
;runelite_callback
load_string "fixedOuterZoomLimit"
runelite_callback
if_icmpge LABEL210
jump LABEL226
LABEL210:
@@ -242,8 +242,8 @@ LABEL210:
LABEL214:
get_varc 74
load_int 175
;load_string "resizableOuterZoomLimit"
;runelite_callback
load_string "resizableOuterZoomLimit"
runelite_callback
if_icmpge LABEL218
jump LABEL226
LABEL218:

View File

@@ -34,14 +34,14 @@ LABEL5:
istore 2
load_int 715
load_int 175
;load_string "resizableOuterZoomLimit"
;runelite_callback
load_string "resizableOuterZoomLimit"
runelite_callback
isub
istore 6
load_int 700
load_int 195
;load_string "fixedOuterZoomLimit"
;runelite_callback
load_string "fixedOuterZoomLimit"
runelite_callback
isub
istore 7
iload 2
@@ -50,8 +50,8 @@ LABEL5:
iload 5
idiv
load_int 175
;load_string "resizableOuterZoomLimit"
;runelite_callback
load_string "resizableOuterZoomLimit"
runelite_callback
iadd
istore 3
iload 2
@@ -60,8 +60,8 @@ LABEL5:
iload 5
idiv
load_int 195
;load_string "fixedOuterZoomLimit"
;runelite_callback
load_string "fixedOuterZoomLimit"
runelite_callback
iadd
istore 4
iload 4

View File

@@ -5,14 +5,14 @@
.string_var_count 0
load_int 715
load_int 175
;load_string "resizableOuterZoomLimit"
;runelite_callback
load_string "resizableOuterZoomLimit"
runelite_callback
isub
istore 0
load_int 700
load_int 195
;load_string "fixedOuterZoomLimit"
;runelite_callback
load_string "fixedOuterZoomLimit"
runelite_callback
isub
istore 1
load_int 17104904
@@ -37,8 +37,8 @@
LABEL27:
get_varc 74
load_int 175
;load_string "resizableOuterZoomLimit"
;runelite_callback
load_string "resizableOuterZoomLimit"
runelite_callback
isub
iload 2
imul
@@ -49,8 +49,8 @@ LABEL27:
LABEL36:
get_varc 73
load_int 195
;load_string "fixedOuterZoomLimit"
;runelite_callback
load_string "fixedOuterZoomLimit"
runelite_callback
isub
iload 2
imul

View File

@@ -15,8 +15,8 @@ LABEL5:
invoke 1046
istore 0
load_int 195
;load_string "fixedOuterZoomLimit"
;runelite_callback
load_string "fixedOuterZoomLimit"
runelite_callback
iload 0
invoke 1045
istore 0
@@ -25,8 +25,8 @@ LABEL5:
invoke 1046
istore 1
load_int 175
;load_string "resizableOuterZoomLimit"
;runelite_callback
load_string "resizableOuterZoomLimit"
runelite_callback
iload 1
invoke 1045
istore 1

View File

@@ -1,5 +1,5 @@
/*
* Copyright (c) 2018, Adam <Adam@sigterm.info>
* Copyright (c) 2018 Abex
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
@@ -22,30 +22,8 @@
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package net.runelite.mixins;
package net.runelite.rs.api;
import static net.runelite.api.Opcodes.RUNELITE_EXECUTE;
import net.runelite.api.Script;
import net.runelite.api.mixins.Copy;
import net.runelite.api.mixins.Replace;
import net.runelite.client.callback.Hooks;
//@Mixin(RSClient.class)
public abstract class VmMixin
public interface RSScriptEvent
{
@Copy("execute6500")
static int rs$execute6500(int opcode, Script script, boolean isOne)
{
throw new RuntimeException();
}
@Replace("execute6500")
static int rl$execute6500(int opcode, Script script, boolean isOne)
{
if (opcode == RUNELITE_EXECUTE)
{
return Hooks.runeliteExecute(opcode, script, isOne);
}
return rs$execute6500(opcode, script, isOne);
}
}