mirror of
				https://github.com/SquidDev-CC/CC-Tweaked
				synced 2025-10-26 11:27:38 +00:00 
			
		
		
		
	Store additional state in WiredModemPeripheral
This means wired peripherals now correctly track their current mounts and attached state, rather than inheriting from the origin wired modem. Closes #890
This commit is contained in:
		| @@ -5,6 +5,7 @@ | |||||||
|  */ |  */ | ||||||
| package dan200.computercraft.core.apis; | package dan200.computercraft.core.apis; | ||||||
| 
 | 
 | ||||||
|  | import dan200.computercraft.ComputerCraft; | ||||||
| import dan200.computercraft.api.filesystem.IMount; | import dan200.computercraft.api.filesystem.IMount; | ||||||
| import dan200.computercraft.api.filesystem.IWritableMount; | import dan200.computercraft.api.filesystem.IWritableMount; | ||||||
| import dan200.computercraft.api.peripheral.IComputerAccess; | import dan200.computercraft.api.peripheral.IComputerAccess; | ||||||
| @@ -30,6 +31,11 @@ public abstract class ComputerAccess implements IComputerAccess | |||||||
|     public void unmountAll() |     public void unmountAll() | ||||||
|     { |     { | ||||||
|         FileSystem fileSystem = environment.getFileSystem(); |         FileSystem fileSystem = environment.getFileSystem(); | ||||||
|  |         if( !mounts.isEmpty() ) | ||||||
|  |         { | ||||||
|  |             ComputerCraft.log.warn( "Peripheral or API called mount but did not call unmount for {}", mounts ); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         for( String mount : mounts ) |         for( String mount : mounts ) | ||||||
|         { |         { | ||||||
|             fileSystem.unmount( mount ); |             fileSystem.unmount( mount ); | ||||||
|   | |||||||
| @@ -6,6 +6,7 @@ | |||||||
| package dan200.computercraft.shared.peripheral.modem.wired; | package dan200.computercraft.shared.peripheral.modem.wired; | ||||||
| 
 | 
 | ||||||
| import com.google.common.collect.ImmutableMap; | import com.google.common.collect.ImmutableMap; | ||||||
|  | import dan200.computercraft.ComputerCraft; | ||||||
| import dan200.computercraft.api.filesystem.IMount; | import dan200.computercraft.api.filesystem.IMount; | ||||||
| import dan200.computercraft.api.filesystem.IWritableMount; | import dan200.computercraft.api.filesystem.IWritableMount; | ||||||
| import dan200.computercraft.api.lua.*; | import dan200.computercraft.api.lua.*; | ||||||
| @@ -15,6 +16,7 @@ import dan200.computercraft.api.network.wired.IWiredSender; | |||||||
| 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.api.peripheral.IWorkMonitor; | import dan200.computercraft.api.peripheral.IWorkMonitor; | ||||||
|  | import dan200.computercraft.api.peripheral.NotAttachedException; | ||||||
| import dan200.computercraft.core.apis.PeripheralAPI; | import dan200.computercraft.core.apis.PeripheralAPI; | ||||||
| import dan200.computercraft.core.asm.PeripheralMethod; | import dan200.computercraft.core.asm.PeripheralMethod; | ||||||
| import dan200.computercraft.shared.peripheral.modem.ModemPeripheral; | import dan200.computercraft.shared.peripheral.modem.ModemPeripheral; | ||||||
| @@ -23,10 +25,7 @@ import net.minecraft.world.World; | |||||||
| 
 | 
 | ||||||
| import javax.annotation.Nonnull; | import javax.annotation.Nonnull; | ||||||
| import javax.annotation.Nullable; | import javax.annotation.Nullable; | ||||||
| import java.util.Collection; | import java.util.*; | ||||||
| import java.util.HashMap; |  | ||||||
| import java.util.Map; |  | ||||||
| import java.util.Objects; |  | ||||||
| import java.util.concurrent.ConcurrentHashMap; | import java.util.concurrent.ConcurrentHashMap; | ||||||
| import java.util.concurrent.ConcurrentMap; | import java.util.concurrent.ConcurrentMap; | ||||||
| 
 | 
 | ||||||
| @@ -311,6 +310,9 @@ public abstract class WiredModemPeripheral extends ModemPeripheral implements IW | |||||||
|         private final String type; |         private final String type; | ||||||
|         private final Map<String, PeripheralMethod> methodMap; |         private final Map<String, PeripheralMethod> methodMap; | ||||||
| 
 | 
 | ||||||
|  |         private volatile boolean attached; | ||||||
|  |         private final Set<String> mounts = new HashSet<>(); | ||||||
|  | 
 | ||||||
|         RemotePeripheralWrapper( WiredModemElement element, IPeripheral peripheral, IComputerAccess computer, String name ) |         RemotePeripheralWrapper( WiredModemElement element, IPeripheral peripheral, IComputerAccess computer, String name ) | ||||||
|         { |         { | ||||||
|             this.element = element; |             this.element = element; | ||||||
| @@ -324,6 +326,7 @@ public abstract class WiredModemPeripheral extends ModemPeripheral implements IW | |||||||
| 
 | 
 | ||||||
|         public void attach() |         public void attach() | ||||||
|         { |         { | ||||||
|  |             attached = true; | ||||||
|             peripheral.attach( this ); |             peripheral.attach( this ); | ||||||
|             computer.queueEvent( "peripheral", getAttachmentName() ); |             computer.queueEvent( "peripheral", getAttachmentName() ); | ||||||
|         } |         } | ||||||
| @@ -332,6 +335,18 @@ public abstract class WiredModemPeripheral extends ModemPeripheral implements IW | |||||||
|         { |         { | ||||||
|             peripheral.detach( this ); |             peripheral.detach( this ); | ||||||
|             computer.queueEvent( "peripheral_detach", getAttachmentName() ); |             computer.queueEvent( "peripheral_detach", getAttachmentName() ); | ||||||
|  |             attached = false; | ||||||
|  | 
 | ||||||
|  |             synchronized( this ) | ||||||
|  |             { | ||||||
|  |                 if( !mounts.isEmpty() ) | ||||||
|  |                 { | ||||||
|  |                     ComputerCraft.log.warn( "Peripheral {} called mount but did not call unmount for {}", peripheral, mounts ); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 for( String mount : mounts ) computer.unmount( mount ); | ||||||
|  |                 mounts.clear(); | ||||||
|  |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public String getType() |         public String getType() | ||||||
| @@ -354,44 +369,60 @@ public abstract class WiredModemPeripheral extends ModemPeripheral implements IW | |||||||
|         // IComputerAccess implementation |         // IComputerAccess implementation | ||||||
| 
 | 
 | ||||||
|         @Override |         @Override | ||||||
|         public String mount( @Nonnull String desiredLocation, @Nonnull IMount mount ) |         public synchronized String mount( @Nonnull String desiredLocation, @Nonnull IMount mount ) | ||||||
|         { |         { | ||||||
|             return computer.mount( desiredLocation, mount, name ); |             if( !attached ) throw new NotAttachedException(); | ||||||
|  |             String mounted = computer.mount( desiredLocation, mount, name ); | ||||||
|  |             mounts.add( mounted ); | ||||||
|  |             return mounted; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         @Override |         @Override | ||||||
|         public String mount( @Nonnull String desiredLocation, @Nonnull IMount mount, @Nonnull String driveName ) |         public synchronized String mount( @Nonnull String desiredLocation, @Nonnull IMount mount, @Nonnull String driveName ) | ||||||
|         { |         { | ||||||
|             return computer.mount( desiredLocation, mount, driveName ); |             if( !attached ) throw new NotAttachedException(); | ||||||
|  |             String mounted = computer.mount( desiredLocation, mount, driveName ); | ||||||
|  |             mounts.add( mounted ); | ||||||
|  |             return mounted; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         @Override |         @Override | ||||||
|         public String mountWritable( @Nonnull String desiredLocation, @Nonnull IWritableMount mount ) |         public synchronized String mountWritable( @Nonnull String desiredLocation, @Nonnull IWritableMount mount ) | ||||||
|         { |         { | ||||||
|             return computer.mountWritable( desiredLocation, mount, name ); |             if( !attached ) throw new NotAttachedException(); | ||||||
|  |             String mounted = computer.mountWritable( desiredLocation, mount, name ); | ||||||
|  |             mounts.add( mounted ); | ||||||
|  |             return mounted; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         @Override |         @Override | ||||||
|         public String mountWritable( @Nonnull String desiredLocation, @Nonnull IWritableMount mount, @Nonnull String driveName ) |         public synchronized String mountWritable( @Nonnull String desiredLocation, @Nonnull IWritableMount mount, @Nonnull String driveName ) | ||||||
|         { |         { | ||||||
|             return computer.mountWritable( desiredLocation, mount, driveName ); |             if( !attached ) throw new NotAttachedException(); | ||||||
|  |             String mounted = computer.mountWritable( desiredLocation, mount, driveName ); | ||||||
|  |             mounts.add( mounted ); | ||||||
|  |             return mounted; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         @Override |         @Override | ||||||
|         public void unmount( String location ) |         public synchronized void unmount( String location ) | ||||||
|         { |         { | ||||||
|  |             if( !attached ) throw new NotAttachedException(); | ||||||
|             computer.unmount( location ); |             computer.unmount( location ); | ||||||
|  |             mounts.remove( location ); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         @Override |         @Override | ||||||
|         public int getID() |         public int getID() | ||||||
|         { |         { | ||||||
|  |             if( !attached ) throw new NotAttachedException(); | ||||||
|             return computer.getID(); |             return computer.getID(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         @Override |         @Override | ||||||
|         public void queueEvent( @Nonnull String event, Object... arguments ) |         public void queueEvent( @Nonnull String event, Object... arguments ) | ||||||
|         { |         { | ||||||
|  |             if( !attached ) throw new NotAttachedException(); | ||||||
|             computer.queueEvent( event, arguments ); |             computer.queueEvent( event, arguments ); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @@ -399,6 +430,7 @@ public abstract class WiredModemPeripheral extends ModemPeripheral implements IW | |||||||
|         @Override |         @Override | ||||||
|         public IWorkMonitor getMainThreadMonitor() |         public IWorkMonitor getMainThreadMonitor() | ||||||
|         { |         { | ||||||
|  |             if( !attached ) throw new NotAttachedException(); | ||||||
|             return computer.getMainThreadMonitor(); |             return computer.getMainThreadMonitor(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @@ -406,6 +438,7 @@ public abstract class WiredModemPeripheral extends ModemPeripheral implements IW | |||||||
|         @Override |         @Override | ||||||
|         public String getAttachmentName() |         public String getAttachmentName() | ||||||
|         { |         { | ||||||
|  |             if( !attached ) throw new NotAttachedException(); | ||||||
|             return name; |             return name; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @@ -413,6 +446,7 @@ public abstract class WiredModemPeripheral extends ModemPeripheral implements IW | |||||||
|         @Override |         @Override | ||||||
|         public Map<String, IPeripheral> getAvailablePeripherals() |         public Map<String, IPeripheral> getAvailablePeripherals() | ||||||
|         { |         { | ||||||
|  |             if( !attached ) throw new NotAttachedException(); | ||||||
|             synchronized( element.getRemotePeripherals() ) |             synchronized( element.getRemotePeripherals() ) | ||||||
|             { |             { | ||||||
|                 return ImmutableMap.copyOf( element.getRemotePeripherals() ); |                 return ImmutableMap.copyOf( element.getRemotePeripherals() ); | ||||||
| @@ -423,6 +457,7 @@ public abstract class WiredModemPeripheral extends ModemPeripheral implements IW | |||||||
|         @Override |         @Override | ||||||
|         public IPeripheral getAvailablePeripheral( @Nonnull String name ) |         public IPeripheral getAvailablePeripheral( @Nonnull String name ) | ||||||
|         { |         { | ||||||
|  |             if( !attached ) throw new NotAttachedException(); | ||||||
|             synchronized( element.getRemotePeripherals() ) |             synchronized( element.getRemotePeripherals() ) | ||||||
|             { |             { | ||||||
|                 return element.getRemotePeripherals().get( name ); |                 return element.getRemotePeripherals().get( name ); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Jonathan Coates
					Jonathan Coates