Merge remote-tracking branch 'runelite/master'
This commit is contained in:
@@ -28,9 +28,8 @@ package net.runelite.cache.script;
|
|||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import static net.runelite.cache.script.Opcodes.*;
|
|
||||||
|
|
||||||
public class Instructions
|
public class Instructions implements Opcodes
|
||||||
{
|
{
|
||||||
private final Map<Integer, Instruction> instructions = new HashMap<>();
|
private final Map<Integer, Instruction> instructions = new HashMap<>();
|
||||||
private final Map<String, Instruction> instructionsByName = new HashMap<>();
|
private final Map<String, Instruction> instructionsByName = new HashMap<>();
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -22,12 +22,9 @@
|
|||||||
* (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.script;
|
package net.runelite.cache.script;
|
||||||
|
|
||||||
import static net.runelite.api.Opcodes.RUNELITE_EXECUTE;
|
public class RuneLiteInstructions extends Instructions implements RuneLiteOpcodes
|
||||||
import net.runelite.cache.script.Instructions;
|
|
||||||
|
|
||||||
public class RuneLiteInstructions extends Instructions
|
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void init()
|
public void init()
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018, Adam <Adam@sigterm.info>
|
* Copyright (c) 2021, Adam <Adam@sigterm.info>
|
||||||
* 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,25 +22,12 @@
|
|||||||
* (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.api;
|
package net.runelite.cache.script;
|
||||||
|
|
||||||
/**
|
public interface RuneLiteOpcodes extends Opcodes
|
||||||
* Utility class containing ASM opcodes used by the RuneLite client.
|
|
||||||
*/
|
|
||||||
public class Opcodes
|
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* opcode used to return from scripts.
|
|
||||||
*/
|
|
||||||
public static final int RETURN = 21;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* opcode used to invoke scripts.
|
|
||||||
*/
|
|
||||||
public static final int INVOKE = 40;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* RuneLite execution opcode used to inject scripts.
|
* RuneLite execution opcode used to inject scripts.
|
||||||
*/
|
*/
|
||||||
public static final int RUNELITE_EXECUTE = 6599;
|
int RUNELITE_EXECUTE = 6599;
|
||||||
}
|
}
|
||||||
@@ -32,7 +32,6 @@ dependencies {
|
|||||||
|
|
||||||
compileOnly(group = "org.projectlombok", name = "lombok", version = ProjectVersions.lombokVersion)
|
compileOnly(group = "org.projectlombok", name = "lombok", version = ProjectVersions.lombokVersion)
|
||||||
|
|
||||||
implementation(project(":runelite-api"))
|
|
||||||
implementation(group = "com.google.code.gson", name = "gson", version = "2.8.5")
|
implementation(group = "com.google.code.gson", name = "gson", version = "2.8.5")
|
||||||
implementation(group = "com.google.guava", name = "guava", version = "30.1.1-jre")
|
implementation(group = "com.google.guava", name = "guava", version = "30.1.1-jre")
|
||||||
implementation(group = "com.squareup.okhttp3", name = "okhttp", version = "4.9.1")
|
implementation(group = "com.squareup.okhttp3", name = "okhttp", version = "4.9.1")
|
||||||
|
|||||||
@@ -30,6 +30,8 @@ dependencies {
|
|||||||
|
|
||||||
compileOnly(group = "org.projectlombok", name = "lombok", version = ProjectVersions.lombokVersion)
|
compileOnly(group = "org.projectlombok", name = "lombok", version = ProjectVersions.lombokVersion)
|
||||||
|
|
||||||
|
api(project(":cache"))
|
||||||
|
|
||||||
implementation(group = "com.google.code.findbugs", name = "jsr305", version = "3.0.2")
|
implementation(group = "com.google.code.findbugs", name = "jsr305", version = "3.0.2")
|
||||||
implementation(group = "com.google.guava", name = "guava", version = "30.1.1-jre")
|
implementation(group = "com.google.guava", name = "guava", version = "30.1.1-jre")
|
||||||
implementation(group = "org.apache.commons", name = "commons-text", version = "1.9")
|
implementation(group = "org.apache.commons", name = "commons-text", version = "1.9")
|
||||||
|
|||||||
@@ -776,6 +776,12 @@ public class GpuPlugin extends Plugin implements DrawCallbacks
|
|||||||
final Scene scene = client.getScene();
|
final Scene scene = client.getScene();
|
||||||
scene.setDrawDistance(getDrawDistance());
|
scene.setDrawDistance(getDrawDistance());
|
||||||
|
|
||||||
|
// Only reset the target buffer offset right before drawing the scene. That way if there are frames
|
||||||
|
// after this that don't involve a scene draw, like during LOADING/HOPPING/CONNECTION_LOST, we can
|
||||||
|
// still redraw the previous frame's scene to emulate the client behavior of not painting over the
|
||||||
|
// viewport buffer.
|
||||||
|
targetBufferOffset = 0;
|
||||||
|
|
||||||
invokeOnMainThread(() ->
|
invokeOnMainThread(() ->
|
||||||
{
|
{
|
||||||
// UBO. Only the first 32 bytes get modified here, the rest is the constant sin/cos table.
|
// UBO. Only the first 32 bytes get modified here, the rest is the constant sin/cos table.
|
||||||
@@ -1029,21 +1035,9 @@ public class GpuPlugin extends Plugin implements DrawCallbacks
|
|||||||
|
|
||||||
private void drawFrame(int overlayColor)
|
private void drawFrame(int overlayColor)
|
||||||
{
|
{
|
||||||
if (jawtWindow.getAWTComponent() != client.getCanvas())
|
// We inject code in the game engine mixin to prevent the client from doing canvas replacement,
|
||||||
{
|
// so this should not ever be tripped
|
||||||
// We inject code in the game engine mixin to prevent the client from doing canvas replacement,
|
assert jawtWindow.getAWTComponent() == client.getCanvas() : "canvas invalidated";
|
||||||
// so this should not ever be hit
|
|
||||||
log.warn("Canvas invalidated!");
|
|
||||||
shutDown();
|
|
||||||
startUp();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (client.getGameState() == GameState.LOADING || client.getGameState() == GameState.HOPPING)
|
|
||||||
{
|
|
||||||
// While the client is loading it doesn't draw
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
final int canvasHeight = client.getCanvasHeight();
|
final int canvasHeight = client.getCanvasHeight();
|
||||||
final int canvasWidth = client.getCanvasWidth();
|
final int canvasWidth = client.getCanvasWidth();
|
||||||
@@ -1105,7 +1099,8 @@ public class GpuPlugin extends Plugin implements DrawCallbacks
|
|||||||
|
|
||||||
// Draw 3d scene
|
// Draw 3d scene
|
||||||
final TextureProvider textureProvider = client.getTextureProvider();
|
final TextureProvider textureProvider = client.getTextureProvider();
|
||||||
if (textureProvider != null)
|
final GameState gameState = client.getGameState();
|
||||||
|
if (textureProvider != null && gameState.getState() >= GameState.LOADING.getState())
|
||||||
{
|
{
|
||||||
if (textureArrayId == -1)
|
if (textureArrayId == -1)
|
||||||
{
|
{
|
||||||
@@ -1265,7 +1260,6 @@ public class GpuPlugin extends Plugin implements DrawCallbacks
|
|||||||
modelBufferSmall.clear();
|
modelBufferSmall.clear();
|
||||||
modelBufferUnordered.clear();
|
modelBufferUnordered.clear();
|
||||||
|
|
||||||
targetBufferOffset = 0;
|
|
||||||
smallModels = largeModels = unorderedModels = 0;
|
smallModels = largeModels = unorderedModels = 0;
|
||||||
tempOffset = 0;
|
tempOffset = 0;
|
||||||
tempUvOffset = 0;
|
tempUvOffset = 0;
|
||||||
|
|||||||
@@ -272,19 +272,15 @@ class SkillCalculator extends JPanel
|
|||||||
|
|
||||||
private void adjustCheckboxes(JCheckBox target, SkillBonus bonus)
|
private void adjustCheckboxes(JCheckBox target, SkillBonus bonus)
|
||||||
{
|
{
|
||||||
adjustXPBonus(0);
|
for (JCheckBox otherSelectedCheckbox : bonusCheckBoxes)
|
||||||
bonusCheckBoxes.forEach(otherSelectedCheckbox ->
|
|
||||||
{
|
{
|
||||||
if (otherSelectedCheckbox != target)
|
if (otherSelectedCheckbox != target)
|
||||||
{
|
{
|
||||||
otherSelectedCheckbox.setSelected(false);
|
otherSelectedCheckbox.setSelected(false);
|
||||||
}
|
}
|
||||||
});
|
|
||||||
|
|
||||||
if (target.isSelected())
|
|
||||||
{
|
|
||||||
adjustXPBonus(bonus.getValue());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
adjustXPBonus(target.isSelected() ? bonus.getValue() : 0f);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void renderActionSlots()
|
private void renderActionSlots()
|
||||||
@@ -347,7 +343,8 @@ class SkillCalculator extends JPanel
|
|||||||
int actionCount = 0;
|
int actionCount = 0;
|
||||||
int neededXP = targetXP - currentXP;
|
int neededXP = targetXP - currentXP;
|
||||||
SkillAction action = slot.getAction();
|
SkillAction action = slot.getAction();
|
||||||
double xp = (action.isIgnoreBonus()) ? action.getXp() : action.getXp() * xpFactor;
|
final float bonus = action.isIgnoreBonus() ? 1f : xpFactor;
|
||||||
|
final double xp = Math.round(action.getXp() * bonus * 10f) / 10d;
|
||||||
|
|
||||||
if (neededXP > 0)
|
if (neededXP > 0)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -86,4 +86,15 @@ public interface SpecialCounterConfig extends Config
|
|||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ConfigItem(
|
||||||
|
position = 5,
|
||||||
|
keyName = "bulwarkThreshold",
|
||||||
|
name = "Dinh's Bulwark",
|
||||||
|
description = "Threshold for Dinh's Bulwark (0 to disable)"
|
||||||
|
)
|
||||||
|
default int bulwarkThreshold()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -40,7 +40,7 @@ enum SpecialWeapon
|
|||||||
BARRELCHEST_ANCHOR("Barrelchest Anchor", new int[]{ItemID.BARRELCHEST_ANCHOR}, true, (c) -> 0),
|
BARRELCHEST_ANCHOR("Barrelchest Anchor", new int[]{ItemID.BARRELCHEST_ANCHOR}, true, (c) -> 0),
|
||||||
BONE_DAGGER("Bone Dagger", new int[]{ItemID.BONE_DAGGER, ItemID.BONE_DAGGER_P, ItemID.BONE_DAGGER_P_8876, ItemID.BONE_DAGGER_P_8878}, true, (c) -> 0),
|
BONE_DAGGER("Bone Dagger", new int[]{ItemID.BONE_DAGGER, ItemID.BONE_DAGGER_P, ItemID.BONE_DAGGER_P_8876, ItemID.BONE_DAGGER_P_8878}, true, (c) -> 0),
|
||||||
DORGESHUUN_CROSSBOW("Dorgeshuun Crossbow", new int[]{ItemID.DORGESHUUN_CROSSBOW}, true, (c) -> 0),
|
DORGESHUUN_CROSSBOW("Dorgeshuun Crossbow", new int[]{ItemID.DORGESHUUN_CROSSBOW}, true, (c) -> 0),
|
||||||
BULWARK("Dinh's Bulwark", new int[]{ItemID.DINHS_BULWARK}, false, c -> 0);
|
BULWARK("Dinh's Bulwark", new int[]{ItemID.DINHS_BULWARK}, false, SpecialCounterConfig::bulwarkThreshold);
|
||||||
|
|
||||||
private final String name;
|
private final String name;
|
||||||
private final int[] itemID;
|
private final int[] itemID;
|
||||||
|
|||||||
@@ -28,6 +28,7 @@ import net.runelite.client.config.Config;
|
|||||||
import net.runelite.client.config.ConfigGroup;
|
import net.runelite.client.config.ConfigGroup;
|
||||||
import net.runelite.client.config.ConfigItem;
|
import net.runelite.client.config.ConfigItem;
|
||||||
import net.runelite.client.config.Units;
|
import net.runelite.client.config.Units;
|
||||||
|
import net.runelite.client.plugins.woodcutting.config.ClueNestTier;
|
||||||
|
|
||||||
@ConfigGroup("woodcutting")
|
@ConfigGroup("woodcutting")
|
||||||
public interface WoodcuttingConfig extends Config
|
public interface WoodcuttingConfig extends Config
|
||||||
@@ -57,6 +58,17 @@ public interface WoodcuttingConfig extends Config
|
|||||||
|
|
||||||
@ConfigItem(
|
@ConfigItem(
|
||||||
position = 3,
|
position = 3,
|
||||||
|
keyName = "clueNestNotifyTier",
|
||||||
|
name = "Clue nest notification",
|
||||||
|
description = "Configures the clue tier from which to start notifying of a clue nest spawn"
|
||||||
|
)
|
||||||
|
default ClueNestTier clueNestNotifyTier()
|
||||||
|
{
|
||||||
|
return ClueNestTier.BEGINNER;
|
||||||
|
}
|
||||||
|
|
||||||
|
@ConfigItem(
|
||||||
|
position = 4,
|
||||||
keyName = "showWoodcuttingStats",
|
keyName = "showWoodcuttingStats",
|
||||||
name = "Show session stats",
|
name = "Show session stats",
|
||||||
description = "Configures whether to display woodcutting session stats"
|
description = "Configures whether to display woodcutting session stats"
|
||||||
@@ -67,7 +79,7 @@ public interface WoodcuttingConfig extends Config
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ConfigItem(
|
@ConfigItem(
|
||||||
position = 4,
|
position = 5,
|
||||||
keyName = "showRedwoods",
|
keyName = "showRedwoods",
|
||||||
name = "Show Redwood trees",
|
name = "Show Redwood trees",
|
||||||
description = "Configures whether to show a indicator for redwood trees"
|
description = "Configures whether to show a indicator for redwood trees"
|
||||||
@@ -78,7 +90,7 @@ public interface WoodcuttingConfig extends Config
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ConfigItem(
|
@ConfigItem(
|
||||||
position = 5,
|
position = 6,
|
||||||
keyName = "showRespawnTimers",
|
keyName = "showRespawnTimers",
|
||||||
name = "Show respawn timers",
|
name = "Show respawn timers",
|
||||||
description = "Configures whether to display the respawn timer overlay"
|
description = "Configures whether to display the respawn timer overlay"
|
||||||
|
|||||||
@@ -51,6 +51,7 @@ import net.runelite.api.events.GameObjectDespawned;
|
|||||||
import net.runelite.api.events.GameObjectSpawned;
|
import net.runelite.api.events.GameObjectSpawned;
|
||||||
import net.runelite.api.events.GameStateChanged;
|
import net.runelite.api.events.GameStateChanged;
|
||||||
import net.runelite.api.events.GameTick;
|
import net.runelite.api.events.GameTick;
|
||||||
|
import net.runelite.api.events.ItemSpawned;
|
||||||
import net.runelite.client.Notifier;
|
import net.runelite.client.Notifier;
|
||||||
import net.runelite.client.config.ConfigManager;
|
import net.runelite.client.config.ConfigManager;
|
||||||
import net.runelite.client.eventbus.Subscribe;
|
import net.runelite.client.eventbus.Subscribe;
|
||||||
@@ -58,6 +59,7 @@ import net.runelite.client.events.OverlayMenuClicked;
|
|||||||
import net.runelite.client.plugins.Plugin;
|
import net.runelite.client.plugins.Plugin;
|
||||||
import net.runelite.client.plugins.PluginDependency;
|
import net.runelite.client.plugins.PluginDependency;
|
||||||
import net.runelite.client.plugins.PluginDescriptor;
|
import net.runelite.client.plugins.PluginDescriptor;
|
||||||
|
import net.runelite.client.plugins.woodcutting.config.ClueNestTier;
|
||||||
import net.runelite.client.plugins.xptracker.XpTrackerPlugin;
|
import net.runelite.client.plugins.xptracker.XpTrackerPlugin;
|
||||||
import net.runelite.client.ui.overlay.OverlayManager;
|
import net.runelite.client.ui.overlay.OverlayManager;
|
||||||
import net.runelite.client.ui.overlay.OverlayMenuEntry;
|
import net.runelite.client.ui.overlay.OverlayMenuEntry;
|
||||||
@@ -107,6 +109,7 @@ public class WoodcuttingPlugin extends Plugin
|
|||||||
private final List<TreeRespawn> respawns = new ArrayList<>();
|
private final List<TreeRespawn> respawns = new ArrayList<>();
|
||||||
private boolean recentlyLoggedIn;
|
private boolean recentlyLoggedIn;
|
||||||
private int currentPlane;
|
private int currentPlane;
|
||||||
|
private ClueNestTier clueTierSpawned;
|
||||||
|
|
||||||
@Provides
|
@Provides
|
||||||
WoodcuttingConfig getConfig(ConfigManager configManager)
|
WoodcuttingConfig getConfig(ConfigManager configManager)
|
||||||
@@ -130,6 +133,7 @@ public class WoodcuttingPlugin extends Plugin
|
|||||||
treeObjects.clear();
|
treeObjects.clear();
|
||||||
session = null;
|
session = null;
|
||||||
axe = null;
|
axe = null;
|
||||||
|
clueTierSpawned = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Subscribe
|
@Subscribe
|
||||||
@@ -148,6 +152,7 @@ public class WoodcuttingPlugin extends Plugin
|
|||||||
public void onGameTick(GameTick gameTick)
|
public void onGameTick(GameTick gameTick)
|
||||||
{
|
{
|
||||||
recentlyLoggedIn = false;
|
recentlyLoggedIn = false;
|
||||||
|
clueTierSpawned = null;
|
||||||
currentPlane = client.getPlane();
|
currentPlane = client.getPlane();
|
||||||
|
|
||||||
respawns.removeIf(TreeRespawn::isExpired);
|
respawns.removeIf(TreeRespawn::isExpired);
|
||||||
@@ -190,11 +195,26 @@ public class WoodcuttingPlugin extends Plugin
|
|||||||
|
|
||||||
if (event.getMessage().contains("A bird's nest falls out of the tree") && config.showNestNotification())
|
if (event.getMessage().contains("A bird's nest falls out of the tree") && config.showNestNotification())
|
||||||
{
|
{
|
||||||
notifier.notify("A bird nest has spawned!");
|
if (clueTierSpawned == null || clueTierSpawned.ordinal() >= config.clueNestNotifyTier().ordinal())
|
||||||
|
{
|
||||||
|
notifier.notify("A bird nest has spawned!");
|
||||||
|
}
|
||||||
|
// Clear the clue tier that has previously spawned
|
||||||
|
clueTierSpawned = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Subscribe
|
||||||
|
public void onItemSpawned(ItemSpawned itemSpawned)
|
||||||
|
{
|
||||||
|
if (clueTierSpawned == null)
|
||||||
|
{
|
||||||
|
// This will be set only if one of the clue nests has spawned. It will then be reset the next game tick.
|
||||||
|
clueTierSpawned = ClueNestTier.getTierFromItem(itemSpawned.getItem().getId());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Subscribe
|
@Subscribe
|
||||||
public void onGameObjectSpawned(final GameObjectSpawned event)
|
public void onGameObjectSpawned(final GameObjectSpawned event)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -0,0 +1,52 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2021, Tal <https://github.com/talsk>
|
||||||
|
* 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.client.plugins.woodcutting.config;
|
||||||
|
|
||||||
|
import com.google.common.collect.ImmutableMap;
|
||||||
|
import net.runelite.api.ItemID;
|
||||||
|
|
||||||
|
public enum ClueNestTier
|
||||||
|
{
|
||||||
|
BEGINNER,
|
||||||
|
EASY,
|
||||||
|
MEDIUM,
|
||||||
|
HARD,
|
||||||
|
ELITE,
|
||||||
|
DISABLED;
|
||||||
|
|
||||||
|
|
||||||
|
private static final ImmutableMap<Integer, ClueNestTier> CLUE_NEST_ID_TO_TIER = new ImmutableMap.Builder<Integer, ClueNestTier>()
|
||||||
|
.put(ItemID.CLUE_NEST_ELITE, ClueNestTier.ELITE)
|
||||||
|
.put(ItemID.CLUE_NEST_HARD, ClueNestTier.HARD)
|
||||||
|
.put(ItemID.CLUE_NEST_MEDIUM, ClueNestTier.MEDIUM)
|
||||||
|
.put(ItemID.CLUE_NEST_EASY, ClueNestTier.EASY)
|
||||||
|
.put(ItemID.CLUE_NEST_BEGINNER, ClueNestTier.BEGINNER)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
static public ClueNestTier getTierFromItem(int itemId)
|
||||||
|
{
|
||||||
|
return CLUE_NEST_ID_TO_TIER.get(itemId);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,252 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2020, Jordan Zomerlei <https://github.com/JZomerlei>
|
||||||
|
* Copyright (c) 2019, Adam <Adam@sigterm.info>
|
||||||
|
* 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.client.plugins.woodcutting;
|
||||||
|
|
||||||
|
import com.google.inject.Guice;
|
||||||
|
import com.google.inject.testing.fieldbinder.Bind;
|
||||||
|
import com.google.inject.testing.fieldbinder.BoundFieldModule;
|
||||||
|
import javax.inject.Inject;
|
||||||
|
import net.runelite.api.ChatMessageType;
|
||||||
|
import net.runelite.api.Client;
|
||||||
|
import net.runelite.api.ItemID;
|
||||||
|
import net.runelite.api.Tile;
|
||||||
|
import net.runelite.api.TileItem;
|
||||||
|
import net.runelite.api.events.ChatMessage;
|
||||||
|
import net.runelite.api.events.ItemSpawned;
|
||||||
|
import net.runelite.client.Notifier;
|
||||||
|
import net.runelite.client.plugins.woodcutting.config.ClueNestTier;
|
||||||
|
import net.runelite.client.ui.overlay.OverlayManager;
|
||||||
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Mock;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.verifyNoInteractions;
|
||||||
|
import static org.mockito.Mockito.verifyNoMoreInteractions;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
import org.mockito.junit.MockitoJUnitRunner;
|
||||||
|
|
||||||
|
@RunWith(MockitoJUnitRunner.class)
|
||||||
|
public class WoodcuttingPluginTest
|
||||||
|
{
|
||||||
|
private static final String BIRDS_NEST_MESSAGE = "A bird's nest falls out of the tree.";
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
WoodcuttingPlugin woodcuttingPlugin;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
WoodcuttingConfig woodcuttingConfig;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
Notifier notifier;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
Client client;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
WoodcuttingOverlay woodcuttingOverlay;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
WoodcuttingTreesOverlay woodcuttingTreesOverlay;
|
||||||
|
|
||||||
|
@Mock
|
||||||
|
@Bind
|
||||||
|
OverlayManager overlayManager;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void before()
|
||||||
|
{
|
||||||
|
Guice.createInjector(BoundFieldModule.of(this)).injectMembers(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testLogs()
|
||||||
|
{
|
||||||
|
ChatMessage chatMessage = new ChatMessage(null, ChatMessageType.SPAM, "", "You get some logs.", "", 0);
|
||||||
|
woodcuttingPlugin.onChatMessage(chatMessage);
|
||||||
|
assertNotNull(woodcuttingPlugin.getSession());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testOakLogs()
|
||||||
|
{
|
||||||
|
ChatMessage chatMessage = new ChatMessage(null, ChatMessageType.SPAM, "", "You get some oak logs.", "", 0);
|
||||||
|
woodcuttingPlugin.onChatMessage(chatMessage);
|
||||||
|
assertNotNull(woodcuttingPlugin.getSession());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testArcticLogs()
|
||||||
|
{
|
||||||
|
ChatMessage chatMessage = new ChatMessage(null, ChatMessageType.SPAM, "", "You get an arctic log.", "", 0);
|
||||||
|
woodcuttingPlugin.onChatMessage(chatMessage);
|
||||||
|
assertNotNull(woodcuttingPlugin.getSession());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testMushrooms()
|
||||||
|
{
|
||||||
|
ChatMessage chatMessage = new ChatMessage(null, ChatMessageType.SPAM, "", "You get some mushrooms.", "", 0);
|
||||||
|
woodcuttingPlugin.onChatMessage(chatMessage);
|
||||||
|
assertNotNull(woodcuttingPlugin.getSession());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testBirdsNest()
|
||||||
|
{
|
||||||
|
ChatMessage chatMessage = new ChatMessage(null, ChatMessageType.GAMEMESSAGE, "", BIRDS_NEST_MESSAGE, "", 0);
|
||||||
|
|
||||||
|
when(woodcuttingConfig.showNestNotification()).thenReturn(true);
|
||||||
|
woodcuttingPlugin.onChatMessage(chatMessage);
|
||||||
|
verify(notifier).notify("A bird nest has spawned!");
|
||||||
|
|
||||||
|
when(woodcuttingConfig.showNestNotification()).thenReturn(false);
|
||||||
|
woodcuttingPlugin.onChatMessage(chatMessage);
|
||||||
|
verifyNoMoreInteractions(notifier);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testClueNestConfigSameAsSpawn()
|
||||||
|
{
|
||||||
|
ChatMessage nestChatMessage = new ChatMessage(null, ChatMessageType.GAMEMESSAGE, "", BIRDS_NEST_MESSAGE, "", 0);
|
||||||
|
Tile tile = mock(Tile.class);
|
||||||
|
TileItem beginnerTileItem = mock(TileItem.class);
|
||||||
|
when(beginnerTileItem.getId()).thenReturn(ItemID.CLUE_NEST_BEGINNER);
|
||||||
|
ItemSpawned beginnerClueSpawned = new ItemSpawned(tile, beginnerTileItem);
|
||||||
|
|
||||||
|
when(woodcuttingConfig.showNestNotification()).thenReturn(true);
|
||||||
|
when(woodcuttingConfig.clueNestNotifyTier()).thenReturn(ClueNestTier.BEGINNER);
|
||||||
|
woodcuttingPlugin.onItemSpawned(beginnerClueSpawned);
|
||||||
|
woodcuttingPlugin.onChatMessage(nestChatMessage);
|
||||||
|
woodcuttingPlugin.onGameTick(null);
|
||||||
|
verify(notifier).notify("A bird nest has spawned!");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testClueNestConfigSmallerThanSpawn()
|
||||||
|
{
|
||||||
|
ChatMessage nestChatMessage = new ChatMessage(null, ChatMessageType.GAMEMESSAGE, "", BIRDS_NEST_MESSAGE, "", 0);
|
||||||
|
Tile tile = mock(Tile.class);
|
||||||
|
TileItem eliteTileItem = mock(TileItem.class);
|
||||||
|
when(eliteTileItem.getId()).thenReturn(ItemID.CLUE_NEST_ELITE);
|
||||||
|
ItemSpawned eliteClueSpawned = new ItemSpawned(tile, eliteTileItem);
|
||||||
|
|
||||||
|
when(woodcuttingConfig.showNestNotification()).thenReturn(true);
|
||||||
|
when(woodcuttingConfig.clueNestNotifyTier()).thenReturn(ClueNestTier.BEGINNER);
|
||||||
|
woodcuttingPlugin.onItemSpawned(eliteClueSpawned);
|
||||||
|
woodcuttingPlugin.onChatMessage(nestChatMessage);
|
||||||
|
woodcuttingPlugin.onGameTick(null);
|
||||||
|
verify(notifier).notify("A bird nest has spawned!");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testClueNestDisabledConfig()
|
||||||
|
{
|
||||||
|
ChatMessage nestChatMessage = new ChatMessage(null, ChatMessageType.GAMEMESSAGE, "", BIRDS_NEST_MESSAGE, "", 0);
|
||||||
|
Tile tile = mock(Tile.class);
|
||||||
|
TileItem eliteTileItem = mock(TileItem.class);
|
||||||
|
when(eliteTileItem.getId()).thenReturn(ItemID.CLUE_NEST_ELITE);
|
||||||
|
ItemSpawned eliteClueSpawned = new ItemSpawned(tile, eliteTileItem);
|
||||||
|
|
||||||
|
when(woodcuttingConfig.showNestNotification()).thenReturn(true);
|
||||||
|
when(woodcuttingConfig.clueNestNotifyTier()).thenReturn(ClueNestTier.DISABLED);
|
||||||
|
woodcuttingPlugin.onItemSpawned(eliteClueSpawned);
|
||||||
|
woodcuttingPlugin.onChatMessage(nestChatMessage);
|
||||||
|
woodcuttingPlugin.onGameTick(null);
|
||||||
|
verifyNoInteractions(notifier);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testClueNestConfigLargerThanSpawn()
|
||||||
|
{
|
||||||
|
ChatMessage nestChatMessage = new ChatMessage(null, ChatMessageType.GAMEMESSAGE, "", BIRDS_NEST_MESSAGE, "", 0);
|
||||||
|
Tile tile = mock(Tile.class);
|
||||||
|
TileItem beginnerTileItem = mock(TileItem.class);
|
||||||
|
when(beginnerTileItem.getId()).thenReturn(ItemID.CLUE_NEST_BEGINNER);
|
||||||
|
ItemSpawned beginnerClueSpawned = new ItemSpawned(tile, beginnerTileItem);
|
||||||
|
|
||||||
|
when(woodcuttingConfig.showNestNotification()).thenReturn(true);
|
||||||
|
when(woodcuttingConfig.clueNestNotifyTier()).thenReturn(ClueNestTier.HARD);
|
||||||
|
woodcuttingPlugin.onItemSpawned(beginnerClueSpawned);
|
||||||
|
woodcuttingPlugin.onChatMessage(nestChatMessage);
|
||||||
|
woodcuttingPlugin.onGameTick(null);
|
||||||
|
verifyNoInteractions(notifier);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testClueNestPlayerDrop()
|
||||||
|
{
|
||||||
|
ChatMessage nestChatMessage = new ChatMessage(null, ChatMessageType.GAMEMESSAGE, "", BIRDS_NEST_MESSAGE, "", 0);
|
||||||
|
Tile tile = mock(Tile.class);
|
||||||
|
TileItem beginnerTileItem = mock(TileItem.class);
|
||||||
|
when(beginnerTileItem.getId()).thenReturn(ItemID.CLUE_NEST_BEGINNER);
|
||||||
|
ItemSpawned beginnerClueSpawned = new ItemSpawned(tile, beginnerTileItem);
|
||||||
|
TileItem nestTileItem = mock(TileItem.class);
|
||||||
|
when(nestTileItem.getId()).thenReturn(ItemID.BIRD_NEST_22798);
|
||||||
|
ItemSpawned regularNestSpawned = new ItemSpawned(tile, nestTileItem);
|
||||||
|
|
||||||
|
when(woodcuttingConfig.showNestNotification()).thenReturn(true);
|
||||||
|
|
||||||
|
// Player drops clue nest
|
||||||
|
woodcuttingPlugin.onItemSpawned(beginnerClueSpawned);
|
||||||
|
woodcuttingPlugin.onGameTick(null);
|
||||||
|
verifyNoInteractions(notifier);
|
||||||
|
// A regular nest has spawned
|
||||||
|
woodcuttingPlugin.onItemSpawned(regularNestSpawned);
|
||||||
|
woodcuttingPlugin.onChatMessage(nestChatMessage);
|
||||||
|
woodcuttingPlugin.onGameTick(null);
|
||||||
|
verify(notifier).notify("A bird nest has spawned!");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testClueNestOtherItemSpawn()
|
||||||
|
{
|
||||||
|
ChatMessage nestChatMessage = new ChatMessage(null, ChatMessageType.GAMEMESSAGE, "", BIRDS_NEST_MESSAGE, "", 0);
|
||||||
|
Tile tile = mock(Tile.class);
|
||||||
|
TileItem beginnerTileItem = mock(TileItem.class);
|
||||||
|
when(beginnerTileItem.getId()).thenReturn(ItemID.CLUE_NEST_BEGINNER);
|
||||||
|
ItemSpawned beginnerClueSpawned = new ItemSpawned(tile, beginnerTileItem);
|
||||||
|
TileItem anotherItemTileItem = mock(TileItem.class);
|
||||||
|
ItemSpawned anotherItemSpawned = new ItemSpawned(tile, anotherItemTileItem);
|
||||||
|
|
||||||
|
when(woodcuttingConfig.showNestNotification()).thenReturn(true);
|
||||||
|
when(woodcuttingConfig.clueNestNotifyTier()).thenReturn(ClueNestTier.BEGINNER);
|
||||||
|
|
||||||
|
woodcuttingPlugin.onItemSpawned(beginnerClueSpawned);
|
||||||
|
woodcuttingPlugin.onItemSpawned(anotherItemSpawned);
|
||||||
|
|
||||||
|
woodcuttingPlugin.onChatMessage(nestChatMessage);
|
||||||
|
woodcuttingPlugin.onGameTick(null);
|
||||||
|
verify(notifier).notify("A bird nest has spawned!");
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -27,7 +27,6 @@ package net.runelite.mixins;
|
|||||||
|
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
import static net.runelite.api.Opcodes.*;
|
|
||||||
import net.runelite.api.events.ScriptCallbackEvent;
|
import net.runelite.api.events.ScriptCallbackEvent;
|
||||||
import net.runelite.api.events.ScriptPostFired;
|
import net.runelite.api.events.ScriptPostFired;
|
||||||
import net.runelite.api.events.ScriptPreFired;
|
import net.runelite.api.events.ScriptPreFired;
|
||||||
@@ -37,6 +36,9 @@ import net.runelite.api.mixins.Mixin;
|
|||||||
import net.runelite.api.mixins.Replace;
|
import net.runelite.api.mixins.Replace;
|
||||||
import net.runelite.api.mixins.Shadow;
|
import net.runelite.api.mixins.Shadow;
|
||||||
import net.runelite.api.widgets.JavaScriptCallback;
|
import net.runelite.api.widgets.JavaScriptCallback;
|
||||||
|
import static net.runelite.cache.script.Opcodes.INVOKE;
|
||||||
|
import static net.runelite.cache.script.Opcodes.RETURN;
|
||||||
|
import static net.runelite.cache.script.RuneLiteOpcodes.RUNELITE_EXECUTE;
|
||||||
import net.runelite.rs.api.RSClient;
|
import net.runelite.rs.api.RSClient;
|
||||||
import net.runelite.rs.api.RSScript;
|
import net.runelite.rs.api.RSScript;
|
||||||
import net.runelite.rs.api.RSScriptEvent;
|
import net.runelite.rs.api.RSScriptEvent;
|
||||||
|
|||||||
@@ -33,6 +33,7 @@ import java.io.IOException;
|
|||||||
import net.runelite.cache.IndexType;
|
import net.runelite.cache.IndexType;
|
||||||
import net.runelite.cache.definitions.ScriptDefinition;
|
import net.runelite.cache.definitions.ScriptDefinition;
|
||||||
import net.runelite.cache.definitions.savers.ScriptSaver;
|
import net.runelite.cache.definitions.savers.ScriptSaver;
|
||||||
|
import net.runelite.cache.script.RuneLiteInstructions;
|
||||||
import net.runelite.cache.script.assembler.Assembler;
|
import net.runelite.cache.script.assembler.Assembler;
|
||||||
import org.apache.maven.plugin.AbstractMojo;
|
import org.apache.maven.plugin.AbstractMojo;
|
||||||
import org.apache.maven.plugin.MojoExecutionException;
|
import org.apache.maven.plugin.MojoExecutionException;
|
||||||
|
|||||||
Reference in New Issue
Block a user