mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-01-25 08:26:54 +00:00
Hide a few ServerComputer internals
This commit is contained in:
parent
898cb2a95d
commit
819a4f7231
@ -8,7 +8,7 @@ import dan200.computercraft.api.ComputerCraftAPI;
|
|||||||
import dan200.computercraft.api.filesystem.WritableMount;
|
import dan200.computercraft.api.filesystem.WritableMount;
|
||||||
import dan200.computercraft.api.lua.ILuaAPI;
|
import dan200.computercraft.api.lua.ILuaAPI;
|
||||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||||
import dan200.computercraft.core.apis.IAPIEnvironment;
|
import dan200.computercraft.api.peripheral.WorkMonitor;
|
||||||
import dan200.computercraft.core.computer.Computer;
|
import dan200.computercraft.core.computer.Computer;
|
||||||
import dan200.computercraft.core.computer.ComputerEnvironment;
|
import dan200.computercraft.core.computer.ComputerEnvironment;
|
||||||
import dan200.computercraft.core.computer.ComputerSide;
|
import dan200.computercraft.core.computer.ComputerSide;
|
||||||
@ -74,31 +74,20 @@ public class ServerComputer implements InputHandler, ComputerEnvironment {
|
|||||||
return level;
|
return level;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setLevel(ServerLevel level) {
|
|
||||||
this.level = level;
|
|
||||||
}
|
|
||||||
|
|
||||||
public BlockPos getPosition() {
|
public BlockPos getPosition() {
|
||||||
return position;
|
return position;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setPosition(BlockPos pos) {
|
public void setPosition(ServerLevel level, BlockPos pos) {
|
||||||
position = new BlockPos(pos);
|
this.level = level;
|
||||||
}
|
position = pos.immutable();
|
||||||
|
|
||||||
public IAPIEnvironment getAPIEnvironment() {
|
|
||||||
return computer.getAPIEnvironment();
|
|
||||||
}
|
|
||||||
|
|
||||||
public Computer getComputer() {
|
|
||||||
return computer;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void markTerminalChanged() {
|
protected void markTerminalChanged() {
|
||||||
terminalChanged.set(true);
|
terminalChanged.set(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void tickServer() {
|
protected void tickServer() {
|
||||||
ticksSincePing++;
|
ticksSincePing++;
|
||||||
computer.tick();
|
computer.tick();
|
||||||
if (terminalChanged.getAndSet(false)) onTerminalChanged();
|
if (terminalChanged.getAndSet(false)) onTerminalChanged();
|
||||||
@ -116,10 +105,15 @@ public class ServerComputer implements InputHandler, ComputerEnvironment {
|
|||||||
ticksSincePing = 0;
|
ticksSincePing = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean hasTimedOut() {
|
boolean hasTimedOut() {
|
||||||
return ticksSincePing > 100;
|
return ticksSincePing > 100;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a bitmask returning which sides on the computer have changed, resetting the internal state.
|
||||||
|
*
|
||||||
|
* @return What sides on the computer have changed.
|
||||||
|
*/
|
||||||
public int pollAndResetChanges() {
|
public int pollAndResetChanges() {
|
||||||
return computer.pollAndResetChanges();
|
return computer.pollAndResetChanges();
|
||||||
}
|
}
|
||||||
@ -189,25 +183,21 @@ public class ServerComputer implements InputHandler, ComputerEnvironment {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void turnOn() {
|
public void turnOn() {
|
||||||
// Turn on
|
|
||||||
computer.turnOn();
|
computer.turnOn();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void shutdown() {
|
public void shutdown() {
|
||||||
// Shutdown
|
|
||||||
computer.shutdown();
|
computer.shutdown();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void reboot() {
|
public void reboot() {
|
||||||
// Reboot
|
|
||||||
computer.reboot();
|
computer.reboot();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void queueEvent(String event, @Nullable Object[] arguments) {
|
public void queueEvent(String event, @Nullable Object[] arguments) {
|
||||||
// Queue event
|
|
||||||
computer.queueEvent(event, arguments);
|
computer.queueEvent(event, arguments);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -259,6 +249,10 @@ public class ServerComputer implements InputHandler, ComputerEnvironment {
|
|||||||
return metrics;
|
return metrics;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public WorkMonitor getMainThreadMonitor() {
|
||||||
|
return computer.getMainThreadMonitor();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @Nullable WritableMount createRootMount() {
|
public @Nullable WritableMount createRootMount() {
|
||||||
return ComputerCraftAPI.createSaveDirMount(level.getServer(), "computer/" + computer.getID(), Config.computerSpaceLimit);
|
return ComputerCraftAPI.createSaveDirMount(level.getServer(), "computer/" + computer.getID(), Config.computerSpaceLimit);
|
||||||
|
@ -132,10 +132,7 @@ public class PocketServerComputer extends ServerComputer implements IPocketAcces
|
|||||||
}
|
}
|
||||||
|
|
||||||
public synchronized void updateValues(@Nullable Entity entity, ItemStack stack, @Nullable IPocketUpgrade upgrade) {
|
public synchronized void updateValues(@Nullable Entity entity, ItemStack stack, @Nullable IPocketUpgrade upgrade) {
|
||||||
if (entity != null) {
|
if (entity != null) setPosition((ServerLevel) entity.level(), entity.blockPosition());
|
||||||
setLevel((ServerLevel) entity.getCommandSenderWorld());
|
|
||||||
setPosition(entity.blockPosition());
|
|
||||||
}
|
|
||||||
|
|
||||||
// If a new entity has picked it up then rebroadcast the terminal to them
|
// If a new entity has picked it up then rebroadcast the terminal to them
|
||||||
if (entity != this.entity && entity instanceof ServerPlayer) markTerminalChanged();
|
if (entity != this.entity && entity instanceof ServerPlayer) markTerminalChanged();
|
||||||
@ -150,7 +147,7 @@ public class PocketServerComputer extends ServerComputer implements IPocketAcces
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void tickServer() {
|
protected void tickServer() {
|
||||||
super.tickServer();
|
super.tickServer();
|
||||||
|
|
||||||
// Find any players which have gone missing and remove them from the tracking list.
|
// Find any players which have gone missing and remove them from the tracking list.
|
||||||
|
@ -72,10 +72,9 @@ public class PocketComputerItem extends Item implements IComputerItem, IMedia, I
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean tick(ItemStack stack, Level world, Entity entity, PocketServerComputer computer) {
|
private boolean tick(ItemStack stack, Entity entity, PocketServerComputer computer) {
|
||||||
var upgrade = getUpgrade(stack);
|
var upgrade = getUpgrade(stack);
|
||||||
|
|
||||||
computer.setLevel((ServerLevel) world);
|
|
||||||
computer.updateValues(entity, stack, upgrade);
|
computer.updateValues(entity, stack, upgrade);
|
||||||
|
|
||||||
var changed = false;
|
var changed = false;
|
||||||
@ -113,7 +112,7 @@ public class PocketComputerItem extends Item implements IComputerItem, IMedia, I
|
|||||||
var computer = createServerComputer((ServerLevel) world, entity, inventory, stack);
|
var computer = createServerComputer((ServerLevel) world, entity, inventory, stack);
|
||||||
computer.keepAlive();
|
computer.keepAlive();
|
||||||
|
|
||||||
var changed = tick(stack, world, entity, computer);
|
var changed = tick(stack, entity, computer);
|
||||||
if (changed && inventory != null) inventory.setChanged();
|
if (changed && inventory != null) inventory.setChanged();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -123,7 +122,7 @@ public class PocketComputerItem extends Item implements IComputerItem, IMedia, I
|
|||||||
if (level.isClientSide || level.getServer() == null) return false;
|
if (level.isClientSide || level.getServer() == null) return false;
|
||||||
|
|
||||||
var computer = getServerComputer(level.getServer(), stack);
|
var computer = getServerComputer(level.getServer(), stack);
|
||||||
if (computer != null && tick(stack, entity.level(), entity, computer)) entity.setItem(stack.copy());
|
if (computer != null && tick(stack, entity, computer)) entity.setItem(stack.copy());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -215,7 +214,7 @@ public class PocketComputerItem extends Item implements IComputerItem, IMedia, I
|
|||||||
|
|
||||||
if (inventory != null) inventory.setChanged();
|
if (inventory != null) inventory.setChanged();
|
||||||
}
|
}
|
||||||
computer.setLevel(level);
|
|
||||||
return computer;
|
return computer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,7 +25,7 @@ public class PocketModemPeripheral extends WirelessModemPeripheral {
|
|||||||
void setLocation(IPocketAccess access) {
|
void setLocation(IPocketAccess access) {
|
||||||
var entity = access.getEntity();
|
var entity = access.getEntity();
|
||||||
if (entity != null) {
|
if (entity != null) {
|
||||||
level = entity.getCommandSenderWorld();
|
level = entity.level();
|
||||||
position = entity.getEyePosition(1);
|
position = entity.getEyePosition(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,8 +9,9 @@ import dan200.computercraft.api.lua.*;
|
|||||||
import dan200.computercraft.api.turtle.TurtleCommand;
|
import dan200.computercraft.api.turtle.TurtleCommand;
|
||||||
import dan200.computercraft.api.turtle.TurtleCommandResult;
|
import dan200.computercraft.api.turtle.TurtleCommandResult;
|
||||||
import dan200.computercraft.api.turtle.TurtleSide;
|
import dan200.computercraft.api.turtle.TurtleSide;
|
||||||
import dan200.computercraft.core.apis.IAPIEnvironment;
|
|
||||||
import dan200.computercraft.core.metrics.Metrics;
|
import dan200.computercraft.core.metrics.Metrics;
|
||||||
|
import dan200.computercraft.core.metrics.MetricsObserver;
|
||||||
|
import dan200.computercraft.shared.computer.core.ServerComputer;
|
||||||
import dan200.computercraft.shared.peripheral.generic.methods.AbstractInventoryMethods;
|
import dan200.computercraft.shared.peripheral.generic.methods.AbstractInventoryMethods;
|
||||||
import dan200.computercraft.shared.turtle.core.*;
|
import dan200.computercraft.shared.turtle.core.*;
|
||||||
|
|
||||||
@ -64,11 +65,11 @@ import java.util.Optional;
|
|||||||
* @cc.since 1.3
|
* @cc.since 1.3
|
||||||
*/
|
*/
|
||||||
public class TurtleAPI implements ILuaAPI {
|
public class TurtleAPI implements ILuaAPI {
|
||||||
private final IAPIEnvironment environment;
|
private final MetricsObserver metrics;
|
||||||
private final TurtleAccessInternal turtle;
|
private final TurtleAccessInternal turtle;
|
||||||
|
|
||||||
public TurtleAPI(IAPIEnvironment environment, TurtleAccessInternal turtle) {
|
public TurtleAPI(ServerComputer computer, TurtleAccessInternal turtle) {
|
||||||
this.environment = environment;
|
this.metrics = computer.getMetrics();
|
||||||
this.turtle = turtle;
|
this.turtle = turtle;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -78,7 +79,7 @@ public class TurtleAPI implements ILuaAPI {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private MethodResult trackCommand(TurtleCommand command) {
|
private MethodResult trackCommand(TurtleCommand command) {
|
||||||
environment.observe(Metrics.TURTLE_OPS);
|
metrics.observe(Metrics.TURTLE_OPS);
|
||||||
return turtle.executeCommand(command);
|
return turtle.executeCommand(command);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -169,7 +170,7 @@ public class TurtleAPI implements ILuaAPI {
|
|||||||
*/
|
*/
|
||||||
@LuaFunction
|
@LuaFunction
|
||||||
public final MethodResult dig(Optional<TurtleSide> side) {
|
public final MethodResult dig(Optional<TurtleSide> side) {
|
||||||
environment.observe(Metrics.TURTLE_OPS);
|
metrics.observe(Metrics.TURTLE_OPS);
|
||||||
return trackCommand(TurtleToolCommand.dig(InteractDirection.FORWARD, side.orElse(null)));
|
return trackCommand(TurtleToolCommand.dig(InteractDirection.FORWARD, side.orElse(null)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -184,7 +185,7 @@ public class TurtleAPI implements ILuaAPI {
|
|||||||
*/
|
*/
|
||||||
@LuaFunction
|
@LuaFunction
|
||||||
public final MethodResult digUp(Optional<TurtleSide> side) {
|
public final MethodResult digUp(Optional<TurtleSide> side) {
|
||||||
environment.observe(Metrics.TURTLE_OPS);
|
metrics.observe(Metrics.TURTLE_OPS);
|
||||||
return trackCommand(TurtleToolCommand.dig(InteractDirection.UP, side.orElse(null)));
|
return trackCommand(TurtleToolCommand.dig(InteractDirection.UP, side.orElse(null)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -199,7 +200,7 @@ public class TurtleAPI implements ILuaAPI {
|
|||||||
*/
|
*/
|
||||||
@LuaFunction
|
@LuaFunction
|
||||||
public final MethodResult digDown(Optional<TurtleSide> side) {
|
public final MethodResult digDown(Optional<TurtleSide> side) {
|
||||||
environment.observe(Metrics.TURTLE_OPS);
|
metrics.observe(Metrics.TURTLE_OPS);
|
||||||
return trackCommand(TurtleToolCommand.dig(InteractDirection.DOWN, side.orElse(null)));
|
return trackCommand(TurtleToolCommand.dig(InteractDirection.DOWN, side.orElse(null)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ public class TurtleBlockEntity extends AbstractComputerBlockEntity implements Ba
|
|||||||
getFamily(), Config.turtleTermWidth,
|
getFamily(), Config.turtleTermWidth,
|
||||||
Config.turtleTermHeight
|
Config.turtleTermHeight
|
||||||
);
|
);
|
||||||
computer.addAPI(new TurtleAPI(computer.getAPIEnvironment(), brain));
|
computer.addAPI(new TurtleAPI(computer, brain));
|
||||||
brain.setupComputer(computer);
|
brain.setupComputer(computer);
|
||||||
return computer;
|
return computer;
|
||||||
}
|
}
|
||||||
|
@ -290,8 +290,7 @@ public class TurtleBrain implements TurtleAccessInternal {
|
|||||||
newTurtle.transferStateFrom(oldOwner);
|
newTurtle.transferStateFrom(oldOwner);
|
||||||
|
|
||||||
var computer = newTurtle.createServerComputer();
|
var computer = newTurtle.createServerComputer();
|
||||||
computer.setLevel((ServerLevel) world);
|
computer.setPosition((ServerLevel) world, pos);
|
||||||
computer.setPosition(pos);
|
|
||||||
|
|
||||||
// Remove the old turtle
|
// Remove the old turtle
|
||||||
oldWorld.removeBlock(oldPos, false);
|
oldWorld.removeBlock(oldPos, false);
|
||||||
@ -608,7 +607,7 @@ public class TurtleBrain implements TurtleAccessInternal {
|
|||||||
|
|
||||||
// If we've got a computer, ensure that we're allowed to perform work.
|
// If we've got a computer, ensure that we're allowed to perform work.
|
||||||
var computer = owner.getServerComputer();
|
var computer = owner.getServerComputer();
|
||||||
if (computer != null && !computer.getComputer().getMainThreadMonitor().canWork()) return;
|
if (computer != null && !computer.getMainThreadMonitor().canWork()) return;
|
||||||
|
|
||||||
// Pull a new command
|
// Pull a new command
|
||||||
var nextCommand = commandQueue.poll();
|
var nextCommand = commandQueue.poll();
|
||||||
@ -621,7 +620,7 @@ public class TurtleBrain implements TurtleAccessInternal {
|
|||||||
|
|
||||||
// Dispatch the callback
|
// Dispatch the callback
|
||||||
if (computer == null) return;
|
if (computer == null) return;
|
||||||
computer.getComputer().getMainThreadMonitor().trackWork(end - start, TimeUnit.NANOSECONDS);
|
computer.getMainThreadMonitor().trackWork(end - start, TimeUnit.NANOSECONDS);
|
||||||
var callbackID = nextCommand.callbackID();
|
var callbackID = nextCommand.callbackID();
|
||||||
if (callbackID < 0) return;
|
if (callbackID < 0) return;
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ public final class TurtlePlayer {
|
|||||||
|
|
||||||
var player = brain.cachedPlayer;
|
var player = brain.cachedPlayer;
|
||||||
if (player == null || player.player.getGameProfile() != getProfile(access.getOwningPlayer())
|
if (player == null || player.player.getGameProfile() != getProfile(access.getOwningPlayer())
|
||||||
|| player.player.getCommandSenderWorld() != access.getLevel()) {
|
|| player.player.level() != access.getLevel()) {
|
||||||
player = brain.cachedPlayer = create(brain);
|
player = brain.cachedPlayer = create(brain);
|
||||||
} else {
|
} else {
|
||||||
player.setState(access);
|
player.setState(access);
|
||||||
|
Loading…
Reference in New Issue
Block a user