Merge pull request #560 from Abextm/script-opcode-injection
Raw injector for script VM
This commit is contained in:
@@ -45,8 +45,6 @@ import net.runelite.api.PacketBuffer;
|
|||||||
import net.runelite.api.Point;
|
import net.runelite.api.Point;
|
||||||
import net.runelite.api.Projectile;
|
import net.runelite.api.Projectile;
|
||||||
import net.runelite.api.Region;
|
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.RuneLite;
|
||||||
import net.runelite.client.chat.ChatMessageManager;
|
import net.runelite.client.chat.ChatMessageManager;
|
||||||
import net.runelite.client.game.DeathChecker;
|
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)
|
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.
|
/* Along the way, the RuneScape client may change a menuAction by incrementing it with 2000.
|
||||||
|
|||||||
@@ -25,7 +25,6 @@
|
|||||||
package net.runelite.client.callback;
|
package net.runelite.client.callback;
|
||||||
|
|
||||||
import com.google.common.eventbus.EventBus;
|
import com.google.common.eventbus.EventBus;
|
||||||
import net.runelite.api.Script;
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -38,9 +37,4 @@ public class Hooks
|
|||||||
public static Logger log;
|
public static Logger log;
|
||||||
|
|
||||||
public static EventBus eventBus;
|
public static EventBus eventBus;
|
||||||
|
|
||||||
public static int runeliteExecute(int opcode, Script script, boolean isOne)
|
|
||||||
{
|
|
||||||
throw new RuntimeException();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -230,8 +230,8 @@ LABEL198:
|
|||||||
6202
|
6202
|
||||||
get_varc 73
|
get_varc 73
|
||||||
load_int 195
|
load_int 195
|
||||||
;load_string "fixedOuterZoomLimit"
|
load_string "fixedOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
if_icmpge LABEL210
|
if_icmpge LABEL210
|
||||||
jump LABEL226
|
jump LABEL226
|
||||||
LABEL210:
|
LABEL210:
|
||||||
@@ -242,8 +242,8 @@ LABEL210:
|
|||||||
LABEL214:
|
LABEL214:
|
||||||
get_varc 74
|
get_varc 74
|
||||||
load_int 175
|
load_int 175
|
||||||
;load_string "resizableOuterZoomLimit"
|
load_string "resizableOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
if_icmpge LABEL218
|
if_icmpge LABEL218
|
||||||
jump LABEL226
|
jump LABEL226
|
||||||
LABEL218:
|
LABEL218:
|
||||||
|
|||||||
@@ -34,14 +34,14 @@ LABEL5:
|
|||||||
istore 2
|
istore 2
|
||||||
load_int 715
|
load_int 715
|
||||||
load_int 175
|
load_int 175
|
||||||
;load_string "resizableOuterZoomLimit"
|
load_string "resizableOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
isub
|
isub
|
||||||
istore 6
|
istore 6
|
||||||
load_int 700
|
load_int 700
|
||||||
load_int 195
|
load_int 195
|
||||||
;load_string "fixedOuterZoomLimit"
|
load_string "fixedOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
isub
|
isub
|
||||||
istore 7
|
istore 7
|
||||||
iload 2
|
iload 2
|
||||||
@@ -50,8 +50,8 @@ LABEL5:
|
|||||||
iload 5
|
iload 5
|
||||||
idiv
|
idiv
|
||||||
load_int 175
|
load_int 175
|
||||||
;load_string "resizableOuterZoomLimit"
|
load_string "resizableOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
iadd
|
iadd
|
||||||
istore 3
|
istore 3
|
||||||
iload 2
|
iload 2
|
||||||
@@ -60,8 +60,8 @@ LABEL5:
|
|||||||
iload 5
|
iload 5
|
||||||
idiv
|
idiv
|
||||||
load_int 195
|
load_int 195
|
||||||
;load_string "fixedOuterZoomLimit"
|
load_string "fixedOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
iadd
|
iadd
|
||||||
istore 4
|
istore 4
|
||||||
iload 4
|
iload 4
|
||||||
|
|||||||
@@ -5,14 +5,14 @@
|
|||||||
.string_var_count 0
|
.string_var_count 0
|
||||||
load_int 715
|
load_int 715
|
||||||
load_int 175
|
load_int 175
|
||||||
;load_string "resizableOuterZoomLimit"
|
load_string "resizableOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
isub
|
isub
|
||||||
istore 0
|
istore 0
|
||||||
load_int 700
|
load_int 700
|
||||||
load_int 195
|
load_int 195
|
||||||
;load_string "fixedOuterZoomLimit"
|
load_string "fixedOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
isub
|
isub
|
||||||
istore 1
|
istore 1
|
||||||
load_int 17104904
|
load_int 17104904
|
||||||
@@ -37,8 +37,8 @@
|
|||||||
LABEL27:
|
LABEL27:
|
||||||
get_varc 74
|
get_varc 74
|
||||||
load_int 175
|
load_int 175
|
||||||
;load_string "resizableOuterZoomLimit"
|
load_string "resizableOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
isub
|
isub
|
||||||
iload 2
|
iload 2
|
||||||
imul
|
imul
|
||||||
@@ -49,8 +49,8 @@ LABEL27:
|
|||||||
LABEL36:
|
LABEL36:
|
||||||
get_varc 73
|
get_varc 73
|
||||||
load_int 195
|
load_int 195
|
||||||
;load_string "fixedOuterZoomLimit"
|
load_string "fixedOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
isub
|
isub
|
||||||
iload 2
|
iload 2
|
||||||
imul
|
imul
|
||||||
|
|||||||
@@ -15,8 +15,8 @@ LABEL5:
|
|||||||
invoke 1046
|
invoke 1046
|
||||||
istore 0
|
istore 0
|
||||||
load_int 195
|
load_int 195
|
||||||
;load_string "fixedOuterZoomLimit"
|
load_string "fixedOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
iload 0
|
iload 0
|
||||||
invoke 1045
|
invoke 1045
|
||||||
istore 0
|
istore 0
|
||||||
@@ -25,8 +25,8 @@ LABEL5:
|
|||||||
invoke 1046
|
invoke 1046
|
||||||
istore 1
|
istore 1
|
||||||
load_int 175
|
load_int 175
|
||||||
;load_string "resizableOuterZoomLimit"
|
load_string "resizableOuterZoomLimit"
|
||||||
;runelite_callback
|
runelite_callback
|
||||||
iload 1
|
iload 1
|
||||||
invoke 1045
|
invoke 1045
|
||||||
istore 1
|
istore 1
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018, Adam <Adam@sigterm.info>
|
* Copyright (c) 2018 Abex
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* 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
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
* 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;
|
public interface RSScriptEvent
|
||||||
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
|
|
||||||
{
|
{
|
||||||
@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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user