mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-01-28 18:04:47 +00:00
Remove ClientTerminal/ServerTerminal
They bring very little to the table now that computers do their own thing! This also helps simplify the code in ServerMonitor a bit - turns out we had two "dirty" flags in the implementation!
This commit is contained in:
parent
cf05ab1db1
commit
c0d20b72c9
@ -25,7 +25,7 @@ import javax.annotation.Nonnull;
|
|||||||
*/
|
*/
|
||||||
public class PocketComputerData
|
public class PocketComputerData
|
||||||
{
|
{
|
||||||
private Terminal terminal;
|
private final Terminal terminal;
|
||||||
private ComputerState state = ComputerState.OFF;
|
private ComputerState state = ComputerState.OFF;
|
||||||
private int lightColour = -1;
|
private int lightColour = -1;
|
||||||
|
|
||||||
@ -58,13 +58,6 @@ public class PocketComputerData
|
|||||||
|
|
||||||
public void setTerminal( TerminalState state )
|
public void setTerminal( TerminalState state )
|
||||||
{
|
{
|
||||||
if( state.width != terminal.getWidth() || state.height != terminal.getHeight() || state.colour != terminal.isColour() )
|
state.apply( terminal );
|
||||||
{
|
|
||||||
terminal = state.create();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
state.apply( terminal );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,71 +0,0 @@
|
|||||||
/*
|
|
||||||
* This file is part of ComputerCraft - http://www.computercraft.info
|
|
||||||
* Copyright Daniel Ratcliffe, 2011-2022. Do not distribute without permission.
|
|
||||||
* Send enquiries to dratcliffe@gmail.com
|
|
||||||
*/
|
|
||||||
package dan200.computercraft.shared.common;
|
|
||||||
|
|
||||||
import dan200.computercraft.core.terminal.Terminal;
|
|
||||||
import dan200.computercraft.shared.network.client.TerminalState;
|
|
||||||
|
|
||||||
public class ClientTerminal
|
|
||||||
{
|
|
||||||
private boolean colour;
|
|
||||||
private Terminal terminal;
|
|
||||||
private boolean terminalChanged;
|
|
||||||
|
|
||||||
public ClientTerminal( boolean colour )
|
|
||||||
{
|
|
||||||
this.colour = colour;
|
|
||||||
terminal = null;
|
|
||||||
terminalChanged = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean pollTerminalChanged()
|
|
||||||
{
|
|
||||||
boolean changed = terminalChanged;
|
|
||||||
terminalChanged = false;
|
|
||||||
return changed;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Terminal getTerminal()
|
|
||||||
{
|
|
||||||
return terminal;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void read( TerminalState state )
|
|
||||||
{
|
|
||||||
colour = state.colour;
|
|
||||||
if( state.hasTerminal() )
|
|
||||||
{
|
|
||||||
resizeTerminal( state.width, state.height );
|
|
||||||
state.apply( terminal );
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
deleteTerminal();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void resizeTerminal( int width, int height )
|
|
||||||
{
|
|
||||||
if( terminal == null )
|
|
||||||
{
|
|
||||||
terminal = new Terminal( width, height, colour, () -> terminalChanged = true );
|
|
||||||
terminalChanged = true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
terminal.resize( width, height );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void deleteTerminal()
|
|
||||||
{
|
|
||||||
if( terminal != null )
|
|
||||||
{
|
|
||||||
terminal = null;
|
|
||||||
terminalChanged = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,72 +0,0 @@
|
|||||||
/*
|
|
||||||
* This file is part of ComputerCraft - http://www.computercraft.info
|
|
||||||
* Copyright Daniel Ratcliffe, 2011-2022. Do not distribute without permission.
|
|
||||||
* Send enquiries to dratcliffe@gmail.com
|
|
||||||
*/
|
|
||||||
package dan200.computercraft.shared.common;
|
|
||||||
|
|
||||||
import dan200.computercraft.core.terminal.Terminal;
|
|
||||||
import dan200.computercraft.shared.network.client.TerminalState;
|
|
||||||
|
|
||||||
import javax.annotation.Nullable;
|
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
|
||||||
|
|
||||||
public class ServerTerminal
|
|
||||||
{
|
|
||||||
private final boolean colour;
|
|
||||||
private @Nullable Terminal terminal;
|
|
||||||
private final AtomicBoolean terminalChanged = new AtomicBoolean( false );
|
|
||||||
private boolean terminalChangedLastFrame = false;
|
|
||||||
|
|
||||||
public ServerTerminal( boolean colour )
|
|
||||||
{
|
|
||||||
this.colour = colour;
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void resize( int width, int height )
|
|
||||||
{
|
|
||||||
if( terminal == null )
|
|
||||||
{
|
|
||||||
terminal = new Terminal( width, height, colour, this::markTerminalChanged );
|
|
||||||
markTerminalChanged();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
terminal.resize( width, height );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void delete()
|
|
||||||
{
|
|
||||||
if( terminal != null )
|
|
||||||
{
|
|
||||||
terminal = null;
|
|
||||||
markTerminalChanged();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void markTerminalChanged()
|
|
||||||
{
|
|
||||||
terminalChanged.set( true );
|
|
||||||
}
|
|
||||||
|
|
||||||
public void tickServer()
|
|
||||||
{
|
|
||||||
terminalChangedLastFrame = terminalChanged.getAndSet( false );
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean hasTerminalChanged()
|
|
||||||
{
|
|
||||||
return terminalChangedLastFrame;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Terminal getTerminal()
|
|
||||||
{
|
|
||||||
return terminal;
|
|
||||||
}
|
|
||||||
|
|
||||||
public TerminalState write()
|
|
||||||
{
|
|
||||||
return new TerminalState( terminal );
|
|
||||||
}
|
|
||||||
}
|
|
@ -118,6 +118,7 @@ public class TerminalState
|
|||||||
public void apply( Terminal terminal )
|
public void apply( Terminal terminal )
|
||||||
{
|
{
|
||||||
if( buffer == null ) throw new NullPointerException( "buffer" );
|
if( buffer == null ) throw new NullPointerException( "buffer" );
|
||||||
|
terminal.resize( width, height );
|
||||||
terminal.read( new PacketBuffer( buffer ) );
|
terminal.read( new PacketBuffer( buffer ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,7 +9,8 @@ import com.mojang.blaze3d.platform.GlStateManager;
|
|||||||
import com.mojang.blaze3d.systems.RenderSystem;
|
import com.mojang.blaze3d.systems.RenderSystem;
|
||||||
import dan200.computercraft.client.util.DirectBuffers;
|
import dan200.computercraft.client.util.DirectBuffers;
|
||||||
import dan200.computercraft.client.util.DirectVertexBuffer;
|
import dan200.computercraft.client.util.DirectVertexBuffer;
|
||||||
import dan200.computercraft.shared.common.ClientTerminal;
|
import dan200.computercraft.core.terminal.Terminal;
|
||||||
|
import dan200.computercraft.shared.network.client.TerminalState;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.minecraftforge.api.distmarker.Dist;
|
||||||
import net.minecraftforge.api.distmarker.OnlyIn;
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
||||||
@ -22,7 +23,7 @@ import java.util.HashSet;
|
|||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
public final class ClientMonitor extends ClientTerminal
|
public final class ClientMonitor
|
||||||
{
|
{
|
||||||
private static final Set<ClientMonitor> allMonitors = new HashSet<>();
|
private static final Set<ClientMonitor> allMonitors = new HashSet<>();
|
||||||
|
|
||||||
@ -35,10 +36,11 @@ public final class ClientMonitor extends ClientTerminal
|
|||||||
public int tboTexture;
|
public int tboTexture;
|
||||||
public int tboUniform;
|
public int tboUniform;
|
||||||
public DirectVertexBuffer buffer;
|
public DirectVertexBuffer buffer;
|
||||||
|
private Terminal terminal;
|
||||||
|
private boolean terminalChanged;
|
||||||
|
|
||||||
public ClientMonitor( boolean colour, TileMonitor origin )
|
public ClientMonitor( TileMonitor origin )
|
||||||
{
|
{
|
||||||
super( colour );
|
|
||||||
this.origin = origin;
|
this.origin = origin;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -156,4 +158,34 @@ public final class ClientMonitor extends ClientTerminal
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean pollTerminalChanged()
|
||||||
|
{
|
||||||
|
boolean changed = terminalChanged;
|
||||||
|
terminalChanged = false;
|
||||||
|
return changed;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Terminal getTerminal()
|
||||||
|
{
|
||||||
|
return terminal;
|
||||||
|
}
|
||||||
|
|
||||||
|
void read( TerminalState state )
|
||||||
|
{
|
||||||
|
if( state.hasTerminal() )
|
||||||
|
{
|
||||||
|
if( terminal == null ) terminal = new Terminal( state.width, state.height, state.colour );
|
||||||
|
state.apply( terminal );
|
||||||
|
terminalChanged = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if( terminal != null )
|
||||||
|
{
|
||||||
|
terminal = null;
|
||||||
|
terminalChanged = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -123,7 +123,7 @@ public final class MonitorWatcher
|
|||||||
private static TerminalState getState( TileMonitor tile, ServerMonitor monitor )
|
private static TerminalState getState( TileMonitor tile, ServerMonitor monitor )
|
||||||
{
|
{
|
||||||
TerminalState state = tile.cached;
|
TerminalState state = tile.cached;
|
||||||
if( state == null ) state = tile.cached = monitor.write();
|
if( state == null ) state = tile.cached = new TerminalState( monitor.getTerminal() );
|
||||||
return state;
|
return state;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,26 +5,30 @@
|
|||||||
*/
|
*/
|
||||||
package dan200.computercraft.shared.peripheral.monitor;
|
package dan200.computercraft.shared.peripheral.monitor;
|
||||||
|
|
||||||
|
import com.google.common.annotations.VisibleForTesting;
|
||||||
import dan200.computercraft.core.terminal.Terminal;
|
import dan200.computercraft.core.terminal.Terminal;
|
||||||
import dan200.computercraft.shared.common.ServerTerminal;
|
|
||||||
import dan200.computercraft.shared.util.TickScheduler;
|
import dan200.computercraft.shared.util.TickScheduler;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
|
|
||||||
public class ServerMonitor extends ServerTerminal
|
public class ServerMonitor
|
||||||
{
|
{
|
||||||
private final TileMonitor origin;
|
private final TileMonitor origin;
|
||||||
|
|
||||||
|
private final boolean colour;
|
||||||
private int textScale = 2;
|
private int textScale = 2;
|
||||||
|
private @Nullable Terminal terminal;
|
||||||
private final AtomicBoolean resized = new AtomicBoolean( false );
|
private final AtomicBoolean resized = new AtomicBoolean( false );
|
||||||
private final AtomicBoolean changed = new AtomicBoolean( false );
|
private final AtomicBoolean changed = new AtomicBoolean( false );
|
||||||
|
|
||||||
public ServerMonitor( boolean colour, TileMonitor origin )
|
ServerMonitor( boolean colour, TileMonitor origin )
|
||||||
{
|
{
|
||||||
super( colour );
|
this.colour = colour;
|
||||||
this.origin = origin;
|
this.origin = origin;
|
||||||
}
|
}
|
||||||
|
|
||||||
public synchronized void rebuild()
|
synchronized void rebuild()
|
||||||
{
|
{
|
||||||
Terminal oldTerm = getTerminal();
|
Terminal oldTerm = getTerminal();
|
||||||
int oldWidth = oldTerm == null ? -1 : oldTerm.getWidth();
|
int oldWidth = oldTerm == null ? -1 : oldTerm.getWidth();
|
||||||
@ -40,52 +44,55 @@ public class ServerMonitor extends ServerTerminal
|
|||||||
1.0
|
1.0
|
||||||
);
|
);
|
||||||
|
|
||||||
resize( termWidth, termHeight );
|
if( terminal == null )
|
||||||
|
{
|
||||||
|
terminal = new Terminal( termWidth, termHeight, colour, this::markChanged );
|
||||||
|
markChanged();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
terminal.resize( termWidth, termHeight );
|
||||||
|
}
|
||||||
|
|
||||||
if( oldWidth != termWidth || oldHeight != termHeight )
|
if( oldWidth != termWidth || oldHeight != termHeight )
|
||||||
{
|
{
|
||||||
getTerminal().clear();
|
terminal.clear();
|
||||||
resized.set( true );
|
resized.set( true );
|
||||||
markChanged();
|
markChanged();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void markTerminalChanged()
|
|
||||||
{
|
|
||||||
super.markTerminalChanged();
|
|
||||||
markChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void markChanged()
|
private void markChanged()
|
||||||
{
|
{
|
||||||
if( !changed.getAndSet( true ) ) TickScheduler.schedule( origin );
|
if( !changed.getAndSet( true ) ) TickScheduler.schedule( origin );
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void clearChanged()
|
int getTextScale()
|
||||||
{
|
|
||||||
changed.set( false );
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getTextScale()
|
|
||||||
{
|
{
|
||||||
return textScale;
|
return textScale;
|
||||||
}
|
}
|
||||||
|
|
||||||
public synchronized void setTextScale( int textScale )
|
synchronized void setTextScale( int textScale )
|
||||||
{
|
{
|
||||||
if( this.textScale == textScale ) return;
|
if( this.textScale == textScale ) return;
|
||||||
this.textScale = textScale;
|
this.textScale = textScale;
|
||||||
rebuild();
|
rebuild();
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean pollResized()
|
boolean pollResized()
|
||||||
{
|
{
|
||||||
return resized.getAndSet( false );
|
return resized.getAndSet( false );
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean pollTerminalChanged()
|
boolean pollTerminalChanged()
|
||||||
{
|
{
|
||||||
tickServer();
|
return changed.getAndSet( false );
|
||||||
return hasTerminalChanged();
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
@VisibleForTesting
|
||||||
|
public Terminal getTerminal()
|
||||||
|
{
|
||||||
|
return terminal;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5,11 +5,11 @@
|
|||||||
*/
|
*/
|
||||||
package dan200.computercraft.shared.peripheral.monitor;
|
package dan200.computercraft.shared.peripheral.monitor;
|
||||||
|
|
||||||
|
import com.google.common.annotations.VisibleForTesting;
|
||||||
import dan200.computercraft.ComputerCraft;
|
import dan200.computercraft.ComputerCraft;
|
||||||
import dan200.computercraft.api.peripheral.IComputerAccess;
|
import dan200.computercraft.api.peripheral.IComputerAccess;
|
||||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||||
import dan200.computercraft.core.terminal.Terminal;
|
import dan200.computercraft.core.terminal.Terminal;
|
||||||
import dan200.computercraft.shared.common.ServerTerminal;
|
|
||||||
import dan200.computercraft.shared.common.TileGeneric;
|
import dan200.computercraft.shared.common.TileGeneric;
|
||||||
import dan200.computercraft.shared.network.client.TerminalState;
|
import dan200.computercraft.shared.network.client.TerminalState;
|
||||||
import dan200.computercraft.shared.util.CapabilityUtil;
|
import dan200.computercraft.shared.util.CapabilityUtil;
|
||||||
@ -171,8 +171,6 @@ public class TileMonitor extends TileGeneric
|
|||||||
|
|
||||||
if( xIndex != 0 || yIndex != 0 || serverMonitor == null ) return;
|
if( xIndex != 0 || yIndex != 0 || serverMonitor == null ) return;
|
||||||
|
|
||||||
serverMonitor.clearChanged();
|
|
||||||
|
|
||||||
if( serverMonitor.pollResized() ) eachComputer( c -> c.queueEvent( "monitor_resize", c.getAttachmentName() ) );
|
if( serverMonitor.pollResized() ) eachComputer( c -> c.queueEvent( "monitor_resize", c.getAttachmentName() ) );
|
||||||
if( serverMonitor.pollTerminalChanged() ) MonitorWatcher.enqueue( this );
|
if( serverMonitor.pollTerminalChanged() ) MonitorWatcher.enqueue( this );
|
||||||
}
|
}
|
||||||
@ -199,6 +197,7 @@ public class TileMonitor extends TileGeneric
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
|
@VisibleForTesting
|
||||||
public ServerMonitor getCachedServerMonitor()
|
public ServerMonitor getCachedServerMonitor()
|
||||||
{
|
{
|
||||||
return serverMonitor;
|
return serverMonitor;
|
||||||
@ -305,7 +304,7 @@ public class TileMonitor extends TileGeneric
|
|||||||
if( xIndex == 0 && yIndex == 0 )
|
if( xIndex == 0 && yIndex == 0 )
|
||||||
{
|
{
|
||||||
// If we're the origin terminal then create it.
|
// If we're the origin terminal then create it.
|
||||||
if( clientMonitor == null ) clientMonitor = new ClientMonitor( advanced, this );
|
if( clientMonitor == null ) clientMonitor = new ClientMonitor( this );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -317,7 +316,7 @@ public class TileMonitor extends TileGeneric
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( clientMonitor == null ) clientMonitor = new ClientMonitor( advanced, this );
|
if( clientMonitor == null ) clientMonitor = new ClientMonitor( this );
|
||||||
clientMonitor.read( state );
|
clientMonitor.read( state );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -588,7 +587,7 @@ public class TileMonitor extends TileGeneric
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ServerTerminal serverTerminal = getServerMonitor();
|
ServerMonitor serverTerminal = getServerMonitor();
|
||||||
if( serverTerminal == null ) return;
|
if( serverTerminal == null ) return;
|
||||||
|
|
||||||
Terminal originTerminal = serverTerminal.getTerminal();
|
Terminal originTerminal = serverTerminal.getTerminal();
|
||||||
|
@ -55,7 +55,7 @@ class Monitor_Test {
|
|||||||
val monitor = helper.getBlockEntity(BlockPos(2, 2, 3)) as TileMonitor
|
val monitor = helper.getBlockEntity(BlockPos(2, 2, 3)) as TileMonitor
|
||||||
monitor.getCapability(Capabilities.CAPABILITY_PERIPHERAL)
|
monitor.getCapability(Capabilities.CAPABILITY_PERIPHERAL)
|
||||||
|
|
||||||
val terminal = monitor.cachedServerMonitor!!.terminal
|
val terminal = monitor.cachedServerMonitor!!.terminal!!
|
||||||
terminal.write("Hello, world!")
|
terminal.write("Hello, world!")
|
||||||
terminal.setCursorPos(1, 2)
|
terminal.setCursorPos(1, 2)
|
||||||
terminal.textColour = 2
|
terminal.textColour = 2
|
||||||
|
Loading…
Reference in New Issue
Block a user