mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-01-25 08:26:54 +00:00
Add get/setUpgrade to IPocketAccess
We have similar methods in ITurtleAccess, so makes sense for them to be here too.
This commit is contained in:
parent
7285c32d58
commit
6c8e64ffcd
@ -6,10 +6,12 @@ package dan200.computercraft.api.pocket;
|
|||||||
|
|
||||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||||
import dan200.computercraft.api.upgrades.UpgradeBase;
|
import dan200.computercraft.api.upgrades.UpgradeBase;
|
||||||
|
import dan200.computercraft.api.upgrades.UpgradeData;
|
||||||
import net.minecraft.nbt.CompoundTag;
|
import net.minecraft.nbt.CompoundTag;
|
||||||
import net.minecraft.resources.ResourceLocation;
|
import net.minecraft.resources.ResourceLocation;
|
||||||
import net.minecraft.world.entity.Entity;
|
import net.minecraft.world.entity.Entity;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.ItemStack;
|
||||||
|
import org.jetbrains.annotations.ApiStatus;
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
import javax.annotation.Nullable;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
@ -17,6 +19,7 @@ import java.util.Map;
|
|||||||
/**
|
/**
|
||||||
* Wrapper class for pocket computers.
|
* Wrapper class for pocket computers.
|
||||||
*/
|
*/
|
||||||
|
@ApiStatus.NonExtendable
|
||||||
public interface IPocketAccess {
|
public interface IPocketAccess {
|
||||||
/**
|
/**
|
||||||
* Gets the entity holding this item.
|
* Gets the entity holding this item.
|
||||||
@ -64,6 +67,26 @@ public interface IPocketAccess {
|
|||||||
*/
|
*/
|
||||||
void setLight(int colour);
|
void setLight(int colour);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the currently equipped upgrade.
|
||||||
|
*
|
||||||
|
* @return The currently equipped upgrade.
|
||||||
|
* @see #getUpgradeNBTData()
|
||||||
|
* @see #setUpgrade(UpgradeData)
|
||||||
|
*/
|
||||||
|
@Nullable
|
||||||
|
UpgradeData<IPocketUpgrade> getUpgrade();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the upgrade for this pocket computer, also updating the item stack.
|
||||||
|
* <p>
|
||||||
|
* Note this method is not thread safe - it must be called from the server thread.
|
||||||
|
*
|
||||||
|
* @param upgrade The new upgrade to set it to, may be {@code null}.
|
||||||
|
* @see #getUpgrade()
|
||||||
|
*/
|
||||||
|
void setUpgrade(@Nullable UpgradeData<IPocketUpgrade> upgrade);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the upgrade-specific NBT.
|
* Get the upgrade-specific NBT.
|
||||||
* <p>
|
* <p>
|
||||||
@ -73,6 +96,7 @@ public interface IPocketAccess {
|
|||||||
* @see #updateUpgradeNBTData()
|
* @see #updateUpgradeNBTData()
|
||||||
* @see UpgradeBase#getUpgradeItem(CompoundTag)
|
* @see UpgradeBase#getUpgradeItem(CompoundTag)
|
||||||
* @see UpgradeBase#getUpgradeData(ItemStack)
|
* @see UpgradeBase#getUpgradeData(ItemStack)
|
||||||
|
* @see #getUpgrade()
|
||||||
*/
|
*/
|
||||||
CompoundTag getUpgradeNBTData();
|
CompoundTag getUpgradeNBTData();
|
||||||
|
|
||||||
|
@ -6,10 +6,10 @@ package dan200.computercraft.shared.pocket.apis;
|
|||||||
|
|
||||||
import dan200.computercraft.api.lua.ILuaAPI;
|
import dan200.computercraft.api.lua.ILuaAPI;
|
||||||
import dan200.computercraft.api.lua.LuaFunction;
|
import dan200.computercraft.api.lua.LuaFunction;
|
||||||
|
import dan200.computercraft.api.pocket.IPocketAccess;
|
||||||
import dan200.computercraft.api.pocket.IPocketUpgrade;
|
import dan200.computercraft.api.pocket.IPocketUpgrade;
|
||||||
import dan200.computercraft.api.upgrades.UpgradeData;
|
import dan200.computercraft.api.upgrades.UpgradeData;
|
||||||
import dan200.computercraft.impl.PocketUpgrades;
|
import dan200.computercraft.impl.PocketUpgrades;
|
||||||
import dan200.computercraft.shared.pocket.core.PocketServerComputer;
|
|
||||||
import net.minecraft.core.NonNullList;
|
import net.minecraft.core.NonNullList;
|
||||||
import net.minecraft.world.entity.player.Player;
|
import net.minecraft.world.entity.player.Player;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.ItemStack;
|
||||||
@ -34,10 +34,10 @@ import java.util.Objects;
|
|||||||
* @cc.module pocket
|
* @cc.module pocket
|
||||||
*/
|
*/
|
||||||
public class PocketAPI implements ILuaAPI {
|
public class PocketAPI implements ILuaAPI {
|
||||||
private final PocketServerComputer computer;
|
private final IPocketAccess pocket;
|
||||||
|
|
||||||
public PocketAPI(PocketServerComputer computer) {
|
public PocketAPI(IPocketAccess pocket) {
|
||||||
this.computer = computer;
|
this.pocket = pocket;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -56,10 +56,10 @@ public class PocketAPI implements ILuaAPI {
|
|||||||
*/
|
*/
|
||||||
@LuaFunction(mainThread = true)
|
@LuaFunction(mainThread = true)
|
||||||
public final Object[] equipBack() {
|
public final Object[] equipBack() {
|
||||||
var entity = computer.getEntity();
|
var entity = pocket.getEntity();
|
||||||
if (!(entity instanceof Player player)) return new Object[]{ false, "Cannot find player" };
|
if (!(entity instanceof Player player)) return new Object[]{ false, "Cannot find player" };
|
||||||
var inventory = player.getInventory();
|
var inventory = player.getInventory();
|
||||||
var previousUpgrade = computer.getUpgrade();
|
var previousUpgrade = pocket.getUpgrade();
|
||||||
|
|
||||||
// Attempt to find the upgrade, starting in the main segment, and then looking in the opposite
|
// Attempt to find the upgrade, starting in the main segment, and then looking in the opposite
|
||||||
// one. We start from the position the item is currently in and loop round to the start.
|
// one. We start from the position the item is currently in and loop round to the start.
|
||||||
@ -73,7 +73,7 @@ public class PocketAPI implements ILuaAPI {
|
|||||||
if (previousUpgrade != null) storeItem(player, previousUpgrade.getUpgradeItem());
|
if (previousUpgrade != null) storeItem(player, previousUpgrade.getUpgradeItem());
|
||||||
|
|
||||||
// Set the new upgrade
|
// Set the new upgrade
|
||||||
computer.setUpgrade(newUpgrade);
|
pocket.setUpgrade(newUpgrade);
|
||||||
|
|
||||||
return new Object[]{ true };
|
return new Object[]{ true };
|
||||||
}
|
}
|
||||||
@ -87,13 +87,13 @@ public class PocketAPI implements ILuaAPI {
|
|||||||
*/
|
*/
|
||||||
@LuaFunction(mainThread = true)
|
@LuaFunction(mainThread = true)
|
||||||
public final Object[] unequipBack() {
|
public final Object[] unequipBack() {
|
||||||
var entity = computer.getEntity();
|
var entity = pocket.getEntity();
|
||||||
if (!(entity instanceof Player player)) return new Object[]{ false, "Cannot find player" };
|
if (!(entity instanceof Player player)) return new Object[]{ false, "Cannot find player" };
|
||||||
var previousUpgrade = computer.getUpgrade();
|
var previousUpgrade = pocket.getUpgrade();
|
||||||
|
|
||||||
if (previousUpgrade == null) return new Object[]{ false, "Nothing to unequip" };
|
if (previousUpgrade == null) return new Object[]{ false, "Nothing to unequip" };
|
||||||
|
|
||||||
computer.setUpgrade(null);
|
pocket.setUpgrade(null);
|
||||||
|
|
||||||
storeItem(player, previousUpgrade.getUpgradeItem());
|
storeItem(player, previousUpgrade.getUpgradeItem());
|
||||||
|
|
||||||
|
@ -111,6 +111,7 @@ public class PocketServerComputer extends ServerComputer implements IPocketAcces
|
|||||||
return upgrade == null ? Map.of() : Collections.singletonMap(upgrade.getUpgradeID(), getPeripheral(ComputerSide.BACK));
|
return upgrade == null ? Map.of() : Collections.singletonMap(upgrade.getUpgradeID(), getPeripheral(ComputerSide.BACK));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public @Nullable UpgradeData<IPocketUpgrade> getUpgrade() {
|
public @Nullable UpgradeData<IPocketUpgrade> getUpgrade() {
|
||||||
return upgrade == null ? null : UpgradeData.of(upgrade, getUpgradeNBTData());
|
return upgrade == null ? null : UpgradeData.of(upgrade, getUpgradeNBTData());
|
||||||
}
|
}
|
||||||
@ -122,6 +123,7 @@ public class PocketServerComputer extends ServerComputer implements IPocketAcces
|
|||||||
*
|
*
|
||||||
* @param upgrade The new upgrade to set it to, may be {@code null}.
|
* @param upgrade The new upgrade to set it to, may be {@code null}.
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void setUpgrade(@Nullable UpgradeData<IPocketUpgrade> upgrade) {
|
public void setUpgrade(@Nullable UpgradeData<IPocketUpgrade> upgrade) {
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
PocketComputerItem.setUpgrade(stack, upgrade);
|
PocketComputerItem.setUpgrade(stack, upgrade);
|
||||||
|
Loading…
Reference in New Issue
Block a user