mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-04-05 18:26:58 +00:00
Move API registration into separate classes
There's several reasons for this change: - Try to make ComputerCraft.java less monolithic by moving functionality into separate module-specific classes. - Hopefully make the core class less Minecraft dependent, meaning emulators are a little less dependent on anything outside of /core. Note we still need /some/ methods in the main ComputerCraft class in order to maintain backwards compatibility with Plethora and Computronics.
This commit is contained in:
parent
57fb77d7fe
commit
41a320e9a4
@ -16,21 +16,20 @@ import dan200.computercraft.api.media.IMediaProvider;
|
||||
import dan200.computercraft.api.network.IPacketNetwork;
|
||||
import dan200.computercraft.api.network.wired.IWiredElement;
|
||||
import dan200.computercraft.api.network.wired.IWiredNode;
|
||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||
import dan200.computercraft.api.peripheral.IPeripheralProvider;
|
||||
import dan200.computercraft.api.permissions.ITurtlePermissionProvider;
|
||||
import dan200.computercraft.api.pocket.IPocketUpgrade;
|
||||
import dan200.computercraft.api.redstone.IBundledRedstoneProvider;
|
||||
import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
||||
import dan200.computercraft.api.turtle.event.TurtleAction;
|
||||
import dan200.computercraft.client.FrameInfo;
|
||||
import dan200.computercraft.core.apis.AddressPredicate;
|
||||
import dan200.computercraft.core.apis.ApiFactories;
|
||||
import dan200.computercraft.core.filesystem.ComboMount;
|
||||
import dan200.computercraft.core.filesystem.FileMount;
|
||||
import dan200.computercraft.core.filesystem.FileSystemMount;
|
||||
import dan200.computercraft.core.terminal.Terminal;
|
||||
import dan200.computercraft.core.tracking.Tracking;
|
||||
import dan200.computercraft.shared.common.DefaultBundledRedstoneProvider;
|
||||
import dan200.computercraft.shared.*;
|
||||
import dan200.computercraft.shared.computer.blocks.BlockCommandComputer;
|
||||
import dan200.computercraft.shared.computer.blocks.BlockComputer;
|
||||
import dan200.computercraft.shared.computer.blocks.TileComputer;
|
||||
@ -61,8 +60,6 @@ import dan200.computercraft.shared.turtle.blocks.TileTurtle;
|
||||
import dan200.computercraft.shared.turtle.upgrades.*;
|
||||
import dan200.computercraft.shared.util.CreativeTabMain;
|
||||
import dan200.computercraft.shared.util.IDAssigner;
|
||||
import dan200.computercraft.shared.util.InventoryUtil;
|
||||
import dan200.computercraft.shared.util.RecordUtil;
|
||||
import dan200.computercraft.shared.wired.CapabilityWiredElement;
|
||||
import dan200.computercraft.shared.wired.WiredNode;
|
||||
import io.netty.buffer.Unpooled;
|
||||
@ -75,8 +72,6 @@ import net.minecraft.server.MinecraftServer;
|
||||
import net.minecraft.tileentity.TileEntity;
|
||||
import net.minecraft.util.EnumFacing;
|
||||
import net.minecraft.util.EnumHand;
|
||||
import net.minecraft.util.NonNullList;
|
||||
import net.minecraft.util.SoundEvent;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.world.IBlockAccess;
|
||||
import net.minecraft.world.World;
|
||||
@ -94,7 +89,6 @@ import net.minecraftforge.fml.relauncher.Side;
|
||||
import org.apache.commons.io.IOUtils;
|
||||
import org.apache.logging.log4j.Logger;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import java.io.*;
|
||||
import java.net.MalformedURLException;
|
||||
import java.net.URISyntaxException;
|
||||
@ -102,15 +96,14 @@ import java.net.URL;
|
||||
import java.nio.file.FileSystem;
|
||||
import java.nio.file.FileSystems;
|
||||
import java.nio.file.Files;
|
||||
import java.util.*;
|
||||
import java.util.ArrayList;
|
||||
import java.util.EnumSet;
|
||||
import java.util.List;
|
||||
import java.util.ServiceConfigurationError;
|
||||
import java.util.function.Function;
|
||||
import java.util.zip.ZipEntry;
|
||||
import java.util.zip.ZipFile;
|
||||
|
||||
///////////////
|
||||
// UNIVERSAL //
|
||||
///////////////
|
||||
|
||||
@Mod(
|
||||
modid = ComputerCraft.MOD_ID, name = "CC: Tweaked", version = "${version}",
|
||||
guiFactory = "dan200.computercraft.client.gui.GuiConfigCC$Factory",
|
||||
@ -268,13 +261,8 @@ public class ComputerCraft
|
||||
// Logging
|
||||
public static Logger log;
|
||||
|
||||
// API users
|
||||
private static List<IPeripheralProvider> peripheralProviders = new ArrayList<>();
|
||||
private static List<IBundledRedstoneProvider> bundledRedstoneProviders = new ArrayList<>();
|
||||
private static List<IMediaProvider> mediaProviders = new ArrayList<>();
|
||||
private static List<ITurtlePermissionProvider> permissionProviders = new ArrayList<>();
|
||||
private static final Map<String, IPocketUpgrade> pocketUpgrades = new HashMap<>();
|
||||
private static final Set<ILuaAPIFactory> apiFactories = new LinkedHashSet<>();
|
||||
// Peripheral providers. This is still here to ensure compatibility with Plethora and Computronics
|
||||
public static List<IPeripheralProvider> peripheralProviders = new ArrayList<>();
|
||||
|
||||
// Implementation
|
||||
@Mod.Instance( value = ComputerCraft.MOD_ID )
|
||||
@ -552,12 +540,12 @@ public class ComputerCraft
|
||||
);
|
||||
}
|
||||
|
||||
public static File getBaseDir()
|
||||
private static File getBaseDir()
|
||||
{
|
||||
return FMLCommonHandler.instance().getMinecraftServerInstance().getFile( "." );
|
||||
return FMLCommonHandler.instance().getMinecraftServerInstance().getDataDirectory();
|
||||
}
|
||||
|
||||
public static File getResourcePackDir()
|
||||
private static File getResourcePackDir()
|
||||
{
|
||||
return new File( getBaseDir(), "resourcepacks" );
|
||||
}
|
||||
@ -609,136 +597,49 @@ public class ComputerCraft
|
||||
return false;
|
||||
}
|
||||
|
||||
public static boolean isPlayerOpped( EntityPlayer player )
|
||||
{
|
||||
MinecraftServer server = player.getServer();
|
||||
if( server != null )
|
||||
{
|
||||
return server.getPlayerList().getOppedPlayers().getEntry( player.getGameProfile() ) != null;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static void registerPermissionProvider( ITurtlePermissionProvider provider )
|
||||
{
|
||||
if( provider != null && !permissionProviders.contains( provider ) )
|
||||
{
|
||||
permissionProviders.add( provider );
|
||||
}
|
||||
}
|
||||
|
||||
public static boolean isBlockEnterable( World world, BlockPos pos, EntityPlayer player )
|
||||
{
|
||||
MinecraftServer server = player.getServer();
|
||||
if( server != null && !world.isRemote )
|
||||
{
|
||||
if( server.isBlockProtected( world, pos, player ) )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
for( ITurtlePermissionProvider provider : permissionProviders )
|
||||
{
|
||||
if( !provider.isBlockEnterable( world, pos ) )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
public static boolean isBlockEditable( World world, BlockPos pos, EntityPlayer player )
|
||||
{
|
||||
MinecraftServer server = player.getServer();
|
||||
if( server != null && !world.isRemote )
|
||||
{
|
||||
if( server.isBlockProtected( world, pos, player ) )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
for( ITurtlePermissionProvider provider : permissionProviders )
|
||||
{
|
||||
if( !provider.isBlockEditable( world, pos ) )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
TurtlePermissions.register( provider );
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static void registerPocketUpgrade( IPocketUpgrade upgrade )
|
||||
{
|
||||
String id = upgrade.getUpgradeID().toString();
|
||||
IPocketUpgrade existing = pocketUpgrades.get( id );
|
||||
if( existing != null )
|
||||
{
|
||||
throw new RuntimeException( "Error registering '" + upgrade.getUnlocalisedAdjective() + " pocket computer'. UpgradeID '" + id + "' is already registered by '" + existing.getUnlocalisedAdjective() + " pocket computer'" );
|
||||
}
|
||||
|
||||
pocketUpgrades.put( id, upgrade );
|
||||
dan200.computercraft.shared.PocketUpgrades.register( upgrade );
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static void registerPeripheralProvider( IPeripheralProvider provider )
|
||||
{
|
||||
if( provider != null && !peripheralProviders.contains( provider ) )
|
||||
{
|
||||
peripheralProviders.add( provider );
|
||||
}
|
||||
Peripherals.register( provider );
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static void registerBundledRedstoneProvider( IBundledRedstoneProvider provider )
|
||||
{
|
||||
if( provider != null && !bundledRedstoneProviders.contains( provider ) )
|
||||
{
|
||||
bundledRedstoneProviders.add( provider );
|
||||
}
|
||||
BundledRedstone.register( provider );
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static void registerMediaProvider( IMediaProvider provider )
|
||||
{
|
||||
if( provider != null && !mediaProviders.contains( provider ) )
|
||||
{
|
||||
mediaProviders.add( provider );
|
||||
}
|
||||
MediaProviders.register( provider );
|
||||
}
|
||||
|
||||
public static void registerAPIFactory( ILuaAPIFactory provider )
|
||||
@Deprecated
|
||||
public static void registerAPIFactory( ILuaAPIFactory factory )
|
||||
{
|
||||
if( provider != null )
|
||||
{
|
||||
apiFactories.add( provider );
|
||||
}
|
||||
ApiFactories.register( factory );
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static IWiredNode createWiredNodeForElement( IWiredElement element )
|
||||
{
|
||||
return new WiredNode( element );
|
||||
}
|
||||
|
||||
public static IPeripheral getPeripheralAt( World world, BlockPos pos, EnumFacing side )
|
||||
{
|
||||
// Try the handlers in order:
|
||||
for( IPeripheralProvider peripheralProvider : peripheralProviders )
|
||||
{
|
||||
try
|
||||
{
|
||||
IPeripheral peripheral = peripheralProvider.getPeripheral( world, pos, side );
|
||||
if( peripheral != null )
|
||||
{
|
||||
return peripheral;
|
||||
}
|
||||
}
|
||||
catch( Exception e )
|
||||
{
|
||||
ComputerCraft.log.error( "Peripheral provider " + peripheralProvider + " errored.", e );
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static IWiredElement getWiredElementAt( IBlockAccess world, BlockPos pos, EnumFacing side )
|
||||
{
|
||||
TileEntity tile = world.getTileEntity( pos );
|
||||
@ -747,118 +648,25 @@ public class ComputerCraft
|
||||
: null;
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static int getDefaultBundledRedstoneOutput( World world, BlockPos pos, EnumFacing side )
|
||||
{
|
||||
return world.isValid( pos ) ? DefaultBundledRedstoneProvider.getDefaultBundledRedstoneOutput( world, pos, side ) : -1;
|
||||
}
|
||||
|
||||
public static int getBundledRedstoneOutput( World world, BlockPos pos, EnumFacing side )
|
||||
{
|
||||
if( !world.isValid( pos ) ) return -1;
|
||||
|
||||
// Try the handlers in order:
|
||||
int combinedSignal = -1;
|
||||
for( IBundledRedstoneProvider bundledRedstoneProvider : bundledRedstoneProviders )
|
||||
{
|
||||
try
|
||||
{
|
||||
int signal = bundledRedstoneProvider.getBundledRedstoneOutput( world, pos, side );
|
||||
if( signal >= 0 )
|
||||
{
|
||||
if( combinedSignal < 0 )
|
||||
{
|
||||
combinedSignal = (signal & 0xffff);
|
||||
}
|
||||
else
|
||||
{
|
||||
combinedSignal = combinedSignal | (signal & 0xffff);
|
||||
}
|
||||
}
|
||||
}
|
||||
catch( Exception e )
|
||||
{
|
||||
ComputerCraft.log.error( "Bundled redstone provider " + bundledRedstoneProvider + " errored.", e );
|
||||
}
|
||||
}
|
||||
return combinedSignal;
|
||||
}
|
||||
|
||||
public static IMedia getMedia( @Nonnull ItemStack stack )
|
||||
{
|
||||
if( !stack.isEmpty() )
|
||||
{
|
||||
// Try the handlers in order:
|
||||
for( IMediaProvider mediaProvider : mediaProviders )
|
||||
{
|
||||
try
|
||||
{
|
||||
IMedia media = mediaProvider.getMedia( stack );
|
||||
if( media != null )
|
||||
{
|
||||
return media;
|
||||
}
|
||||
}
|
||||
catch( Exception e )
|
||||
{
|
||||
// mod misbehaved, ignore it
|
||||
ComputerCraft.log.error( "Media provider " + mediaProvider + " errored.", e );
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public static IPocketUpgrade getPocketUpgrade( String id )
|
||||
{
|
||||
return pocketUpgrades.get( id );
|
||||
}
|
||||
|
||||
public static IPocketUpgrade getPocketUpgrade( @Nonnull ItemStack stack )
|
||||
{
|
||||
if( stack.isEmpty() ) return null;
|
||||
|
||||
for( IPocketUpgrade upgrade : pocketUpgrades.values() )
|
||||
{
|
||||
ItemStack craftingStack = upgrade.getCraftingItem();
|
||||
if( !craftingStack.isEmpty() && InventoryUtil.areItemsStackable( stack, craftingStack ) )
|
||||
{
|
||||
return upgrade;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public static Iterable<IPocketUpgrade> getVanillaPocketUpgrades()
|
||||
{
|
||||
List<IPocketUpgrade> upgrades = new ArrayList<>();
|
||||
for( IPocketUpgrade upgrade : pocketUpgrades.values() )
|
||||
{
|
||||
if( upgrade instanceof PocketModem || upgrade instanceof PocketSpeaker )
|
||||
{
|
||||
upgrades.add( upgrade );
|
||||
}
|
||||
}
|
||||
|
||||
return upgrades;
|
||||
return BundledRedstone.getDefaultOutput( world, pos, side );
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static IPacketNetwork getWirelessNetwork()
|
||||
{
|
||||
return WirelessNetwork.getUniversal();
|
||||
}
|
||||
|
||||
public static Iterable<ILuaAPIFactory> getAPIFactories()
|
||||
{
|
||||
return apiFactories;
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static int createUniqueNumberedSaveDir( World world, String parentSubPath )
|
||||
{
|
||||
return IDAssigner.getNextIDFromDirectory( new File( getWorldDir( world ), parentSubPath ) );
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static IWritableMount createSaveDirMount( World world, String subPath, long capacity )
|
||||
{
|
||||
try
|
||||
@ -871,6 +679,7 @@ public class ComputerCraft
|
||||
}
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static IMount createResourceMount( Class<?> modClass, String domain, String subPath )
|
||||
{
|
||||
// Start building list of mounts
|
||||
@ -1073,36 +882,13 @@ public class ComputerCraft
|
||||
{
|
||||
String path = modClass.getProtectionDomain().getCodeSource().getLocation().getPath();
|
||||
int bangIndex = path.indexOf( "!" );
|
||||
if( bangIndex >= 0 )
|
||||
{
|
||||
return null;
|
||||
}
|
||||
return new File( new File( path ).getParentFile(), "../.." );
|
||||
return bangIndex >= 0 ? null : new File( new File( path ).getParentFile(), "../.." );
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static void registerTurtleUpgrade( ITurtleUpgrade upgrade )
|
||||
{
|
||||
turtleProxy.registerTurtleUpgrade( upgrade );
|
||||
}
|
||||
|
||||
public static ITurtleUpgrade getTurtleUpgrade( String id )
|
||||
{
|
||||
return turtleProxy.getTurtleUpgrade( id );
|
||||
}
|
||||
|
||||
public static ITurtleUpgrade getTurtleUpgrade( int legacyID )
|
||||
{
|
||||
return turtleProxy.getTurtleUpgrade( legacyID );
|
||||
}
|
||||
|
||||
public static ITurtleUpgrade getTurtleUpgrade( @Nonnull ItemStack item )
|
||||
{
|
||||
return turtleProxy.getTurtleUpgrade( item );
|
||||
}
|
||||
|
||||
public static void addAllUpgradedTurtles( NonNullList<ItemStack> list )
|
||||
{
|
||||
turtleProxy.addAllUpgradedTurtles( list );
|
||||
TurtleUpgrades.register( upgrade );
|
||||
}
|
||||
|
||||
public static void setDropConsumer( Entity entity, Function<ItemStack, ItemStack> consumer )
|
||||
@ -1119,4 +905,24 @@ public class ComputerCraft
|
||||
{
|
||||
return turtleProxy.clearDropConsumer();
|
||||
}
|
||||
|
||||
//region Compatibility
|
||||
@Deprecated
|
||||
public static IMedia getMedia( ItemStack stack )
|
||||
{
|
||||
return MediaProviders.get( stack );
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static IPocketUpgrade getPocketUpgrade( ItemStack stack )
|
||||
{
|
||||
return dan200.computercraft.shared.PocketUpgrades.get( stack );
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public static ITurtleUpgrade getTurtleUpgrade( ItemStack stack )
|
||||
{
|
||||
return TurtleUpgrades.get( stack );
|
||||
}
|
||||
//endregion
|
||||
}
|
||||
|
@ -494,11 +494,7 @@ public final class ComputerCraftAPI
|
||||
{
|
||||
try
|
||||
{
|
||||
if( computerCraft != null )
|
||||
{
|
||||
return computerCraft.getMethod( name, args );
|
||||
}
|
||||
return null;
|
||||
return computerCraft != null ? computerCraft.getMethod( name, args ) : null;
|
||||
}
|
||||
catch( NoSuchMethodException e )
|
||||
{
|
||||
|
@ -0,0 +1,36 @@
|
||||
/*
|
||||
* This file is part of ComputerCraft - http://www.computercraft.info
|
||||
* Copyright Daniel Ratcliffe, 2011-2018. Do not distribute without permission.
|
||||
* Send enquiries to dratcliffe@gmail.com
|
||||
*/
|
||||
|
||||
package dan200.computercraft.core.apis;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import dan200.computercraft.api.lua.ILuaAPIFactory;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import java.util.Collection;
|
||||
import java.util.Collections;
|
||||
import java.util.LinkedHashSet;
|
||||
|
||||
public final class ApiFactories
|
||||
{
|
||||
private ApiFactories()
|
||||
{
|
||||
}
|
||||
|
||||
private static final Collection<ILuaAPIFactory> factories = new LinkedHashSet<>();
|
||||
private static final Collection<ILuaAPIFactory> factoriesView = Collections.unmodifiableCollection( factories );
|
||||
|
||||
public static void register( @Nonnull ILuaAPIFactory factory )
|
||||
{
|
||||
Preconditions.checkNotNull( factory, "provider cannot be null" );
|
||||
factories.add( factory );
|
||||
}
|
||||
|
||||
public static Iterable<ILuaAPIFactory> getAll()
|
||||
{
|
||||
return factoriesView;
|
||||
}
|
||||
}
|
@ -719,14 +719,11 @@ public class Computer
|
||||
m_apis.add( new HTTPAPI( m_apiEnvironment ) );
|
||||
}
|
||||
|
||||
for( ILuaAPIFactory factory : ComputerCraft.getAPIFactories() )
|
||||
for( ILuaAPIFactory factory : ApiFactories.getAll() )
|
||||
{
|
||||
ComputerSystem system = new ComputerSystem( m_apiEnvironment );
|
||||
ILuaAPI api = factory.create( system );
|
||||
if( api != null )
|
||||
{
|
||||
m_apis.add( api );
|
||||
}
|
||||
if( api != null ) m_apis.add( api );
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -0,0 +1,66 @@
|
||||
/*
|
||||
* This file is part of ComputerCraft - http://www.computercraft.info
|
||||
* Copyright Daniel Ratcliffe, 2011-2018. Do not distribute without permission.
|
||||
* Send enquiries to dratcliffe@gmail.com
|
||||
*/
|
||||
|
||||
package dan200.computercraft.shared;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.redstone.IBundledRedstoneProvider;
|
||||
import dan200.computercraft.shared.common.DefaultBundledRedstoneProvider;
|
||||
import net.minecraft.util.EnumFacing;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.world.World;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import java.util.LinkedHashSet;
|
||||
import java.util.Set;
|
||||
|
||||
public final class BundledRedstone
|
||||
{
|
||||
private static final Set<IBundledRedstoneProvider> providers = new LinkedHashSet<>();
|
||||
|
||||
public static void register( @Nonnull IBundledRedstoneProvider provider )
|
||||
{
|
||||
Preconditions.checkNotNull( provider, "provider cannot be null" );
|
||||
providers.add( provider );
|
||||
}
|
||||
|
||||
public static int getDefaultOutput( @Nonnull World world, @Nonnull BlockPos pos, @Nonnull EnumFacing side )
|
||||
{
|
||||
return world.isValid( pos ) ? DefaultBundledRedstoneProvider.getDefaultBundledRedstoneOutput( world, pos, side ) : -1;
|
||||
}
|
||||
|
||||
private static int getUnmaskedOutput( World world, BlockPos pos, EnumFacing side )
|
||||
{
|
||||
if( !world.isValid( pos ) ) return -1;
|
||||
|
||||
// Try the providers in order:
|
||||
int combinedSignal = -1;
|
||||
for( IBundledRedstoneProvider bundledRedstoneProvider : providers )
|
||||
{
|
||||
try
|
||||
{
|
||||
int signal = bundledRedstoneProvider.getBundledRedstoneOutput( world, pos, side );
|
||||
if( signal >= 0 )
|
||||
{
|
||||
combinedSignal = combinedSignal < 0 ? signal & 0xffff : combinedSignal | (signal & 0xffff);
|
||||
}
|
||||
}
|
||||
catch( Exception e )
|
||||
{
|
||||
ComputerCraft.log.error( "Bundled redstone provider " + bundledRedstoneProvider + " errored.", e );
|
||||
}
|
||||
}
|
||||
|
||||
return combinedSignal;
|
||||
}
|
||||
|
||||
public static int getOutput( World world, BlockPos pos, EnumFacing side )
|
||||
{
|
||||
int signal = getUnmaskedOutput( world, pos, side );
|
||||
return signal >= 0 ? signal : 0;
|
||||
}
|
||||
}
|
@ -0,0 +1,49 @@
|
||||
/*
|
||||
* This file is part of ComputerCraft - http://www.computercraft.info
|
||||
* Copyright Daniel Ratcliffe, 2011-2018. Do not distribute without permission.
|
||||
* Send enquiries to dratcliffe@gmail.com
|
||||
*/
|
||||
|
||||
package dan200.computercraft.shared;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.media.IMedia;
|
||||
import dan200.computercraft.api.media.IMediaProvider;
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import java.util.LinkedHashSet;
|
||||
import java.util.Set;
|
||||
|
||||
public final class MediaProviders
|
||||
{
|
||||
private static final Set<IMediaProvider> providers = new LinkedHashSet<>();
|
||||
|
||||
public static void register( @Nonnull IMediaProvider provider )
|
||||
{
|
||||
Preconditions.checkNotNull( provider, "provider cannot be null" );
|
||||
providers.add( provider );
|
||||
}
|
||||
|
||||
public static IMedia get( @Nonnull ItemStack stack )
|
||||
{
|
||||
if( stack.isEmpty() ) return null;
|
||||
|
||||
// Try the handlers in order:
|
||||
for( IMediaProvider mediaProvider : providers )
|
||||
{
|
||||
try
|
||||
{
|
||||
IMedia media = mediaProvider.getMedia( stack );
|
||||
if( media != null ) return media;
|
||||
}
|
||||
catch( Exception e )
|
||||
{
|
||||
// mod misbehaved, ignore it
|
||||
ComputerCraft.log.error( "Media provider " + mediaProvider + " errored.", e );
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
}
|
54
src/main/java/dan200/computercraft/shared/Peripherals.java
Normal file
54
src/main/java/dan200/computercraft/shared/Peripherals.java
Normal file
@ -0,0 +1,54 @@
|
||||
/*
|
||||
* This file is part of ComputerCraft - http://www.computercraft.info
|
||||
* Copyright Daniel Ratcliffe, 2011-2018. Do not distribute without permission.
|
||||
* Send enquiries to dratcliffe@gmail.com
|
||||
*/
|
||||
|
||||
package dan200.computercraft.shared;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||
import dan200.computercraft.api.peripheral.IPeripheralProvider;
|
||||
import net.minecraft.util.EnumFacing;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.world.World;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import java.util.Collection;
|
||||
|
||||
public final class Peripherals
|
||||
{
|
||||
private static final Collection<IPeripheralProvider> providers = ComputerCraft.peripheralProviders;
|
||||
|
||||
public static void register( @Nonnull IPeripheralProvider provider )
|
||||
{
|
||||
Preconditions.checkNotNull( provider, "provider cannot be null" );
|
||||
if( !providers.contains( provider ) ) providers.add( provider );
|
||||
}
|
||||
|
||||
public static IPeripheral getPeripheral( World world, BlockPos pos, EnumFacing side )
|
||||
{
|
||||
return world.isValid( pos ) && !world.isRemote ? getPeripheralAt( world, pos, side ) : null;
|
||||
}
|
||||
|
||||
private static IPeripheral getPeripheralAt( World world, BlockPos pos, EnumFacing side )
|
||||
{
|
||||
// Try the handlers in order:
|
||||
for( IPeripheralProvider peripheralProvider : providers )
|
||||
{
|
||||
try
|
||||
{
|
||||
IPeripheral peripheral = peripheralProvider.getPeripheral( world, pos, side );
|
||||
if( peripheral != null ) return peripheral;
|
||||
}
|
||||
catch( Exception e )
|
||||
{
|
||||
ComputerCraft.log.error( "Peripheral provider " + peripheralProvider + " errored.", e );
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,71 @@
|
||||
/*
|
||||
* This file is part of ComputerCraft - http://www.computercraft.info
|
||||
* Copyright Daniel Ratcliffe, 2011-2018. Do not distribute without permission.
|
||||
* Send enquiries to dratcliffe@gmail.com
|
||||
*/
|
||||
|
||||
package dan200.computercraft.shared;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.pocket.IPocketUpgrade;
|
||||
import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||
import dan200.computercraft.shared.util.InventoryUtil;
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
public final class PocketUpgrades
|
||||
{
|
||||
private static final Map<String, IPocketUpgrade> upgrades = new HashMap<>();
|
||||
|
||||
public static void register( @Nonnull IPocketUpgrade upgrade )
|
||||
{
|
||||
Preconditions.checkNotNull( upgrade, "upgrade cannot be null" );
|
||||
|
||||
String id = upgrade.getUpgradeID().toString();
|
||||
IPocketUpgrade existing = upgrades.get( id );
|
||||
if( existing != null )
|
||||
{
|
||||
throw new IllegalStateException( "Error registering '" + upgrade.getUnlocalisedAdjective() + " pocket computer'. UpgradeID '" + id + "' is already registered by '" + existing.getUnlocalisedAdjective() + " pocket computer'" );
|
||||
}
|
||||
|
||||
upgrades.put( id, upgrade );
|
||||
}
|
||||
|
||||
|
||||
public static IPocketUpgrade get( String id )
|
||||
{
|
||||
return upgrades.get( id );
|
||||
}
|
||||
|
||||
public static IPocketUpgrade get( @Nonnull ItemStack stack )
|
||||
{
|
||||
if( stack.isEmpty() ) return null;
|
||||
|
||||
for( IPocketUpgrade upgrade : upgrades.values() )
|
||||
{
|
||||
ItemStack craftingStack = upgrade.getCraftingItem();
|
||||
if( !craftingStack.isEmpty() && InventoryUtil.areItemsStackable( stack, craftingStack ) )
|
||||
{
|
||||
return upgrade;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public static Iterable<IPocketUpgrade> getVanillaUpgrades()
|
||||
{
|
||||
List<IPocketUpgrade> vanilla = new ArrayList<>();
|
||||
vanilla.add( ComputerCraft.PocketUpgrades.wirelessModem );
|
||||
vanilla.add( ComputerCraft.PocketUpgrades.advancedModem );
|
||||
vanilla.add( ComputerCraft.PocketUpgrades.pocketSpeaker );
|
||||
return vanilla;
|
||||
}
|
||||
}
|
@ -0,0 +1,60 @@
|
||||
/*
|
||||
* This file is part of ComputerCraft - http://www.computercraft.info
|
||||
* Copyright Daniel Ratcliffe, 2011-2018. Do not distribute without permission.
|
||||
* Send enquiries to dratcliffe@gmail.com
|
||||
*/
|
||||
|
||||
package dan200.computercraft.shared;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import dan200.computercraft.api.permissions.ITurtlePermissionProvider;
|
||||
import net.minecraft.entity.player.EntityPlayer;
|
||||
import net.minecraft.server.MinecraftServer;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.world.World;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import java.util.Collection;
|
||||
import java.util.LinkedHashSet;
|
||||
|
||||
public final class TurtlePermissions
|
||||
{
|
||||
private static final Collection<ITurtlePermissionProvider> providers = new LinkedHashSet<>();
|
||||
|
||||
public static void register( @Nonnull ITurtlePermissionProvider upgrade )
|
||||
{
|
||||
Preconditions.checkNotNull( upgrade, "upgrade cannot be null" );
|
||||
|
||||
providers.add( upgrade );
|
||||
}
|
||||
|
||||
public static boolean isBlockEnterable( World world, BlockPos pos, EntityPlayer player )
|
||||
{
|
||||
MinecraftServer server = player.getServer();
|
||||
if( server != null && !world.isRemote && server.isBlockProtected( world, pos, player ) )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
for( ITurtlePermissionProvider provider : providers )
|
||||
{
|
||||
if( !provider.isBlockEnterable( world, pos ) ) return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
public static boolean isBlockEditable( World world, BlockPos pos, EntityPlayer player )
|
||||
{
|
||||
MinecraftServer server = player.getServer();
|
||||
if( server != null && !world.isRemote && server.isBlockProtected( world, pos, player ) )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
for( ITurtlePermissionProvider provider : providers )
|
||||
{
|
||||
if( !provider.isBlockEditable( world, pos ) ) return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
}
|
132
src/main/java/dan200/computercraft/shared/TurtleUpgrades.java
Normal file
132
src/main/java/dan200/computercraft/shared/TurtleUpgrades.java
Normal file
@ -0,0 +1,132 @@
|
||||
/*
|
||||
* This file is part of ComputerCraft - http://www.computercraft.info
|
||||
* Copyright Daniel Ratcliffe, 2011-2018. Do not distribute without permission.
|
||||
* Send enquiries to dratcliffe@gmail.com
|
||||
*/
|
||||
|
||||
package dan200.computercraft.shared;
|
||||
|
||||
import com.google.common.base.Preconditions;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||
import dan200.computercraft.shared.util.InventoryUtil;
|
||||
import it.unimi.dsi.fastutil.ints.Int2ObjectMap;
|
||||
import it.unimi.dsi.fastutil.ints.Int2ObjectOpenHashMap;
|
||||
import net.minecraft.item.ItemStack;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
public final class TurtleUpgrades
|
||||
{
|
||||
private static final Map<String, ITurtleUpgrade> upgrades = new HashMap<>();
|
||||
private static final Int2ObjectMap<ITurtleUpgrade> legacyUpgrades = new Int2ObjectOpenHashMap<>();
|
||||
|
||||
public static void register( @Nonnull ITurtleUpgrade upgrade )
|
||||
{
|
||||
Preconditions.checkNotNull( upgrade, "upgrade cannot be null" );
|
||||
|
||||
int id = upgrade.getLegacyUpgradeID();
|
||||
if( id >= 0 && id < 64 )
|
||||
{
|
||||
String message = getMessage( upgrade, "Legacy UpgradeID '" + id + "' is reserved by ComputerCraft" );
|
||||
ComputerCraft.log.error( message );
|
||||
throw new RuntimeException( message );
|
||||
}
|
||||
|
||||
registerInternal( upgrade );
|
||||
}
|
||||
|
||||
public static void registerInternal( ITurtleUpgrade upgrade )
|
||||
{
|
||||
Preconditions.checkNotNull( upgrade, "upgrade cannot be null" );
|
||||
|
||||
// Check conditions
|
||||
int legacyId = upgrade.getLegacyUpgradeID();
|
||||
if( legacyId >= 0 )
|
||||
{
|
||||
if( legacyId >= Short.MAX_VALUE )
|
||||
{
|
||||
String message = getMessage( upgrade, "UpgradeID '" + legacyId + "' is out of range" );
|
||||
ComputerCraft.log.error( message );
|
||||
throw new RuntimeException( message );
|
||||
}
|
||||
|
||||
ITurtleUpgrade existing = legacyUpgrades.get( legacyId );
|
||||
if( existing != null )
|
||||
{
|
||||
String message = getMessage( upgrade, "UpgradeID '" + legacyId + "' is already registered by '" + existing.getUnlocalisedAdjective() + " Turtle'" );
|
||||
ComputerCraft.log.error( message );
|
||||
throw new RuntimeException( message );
|
||||
}
|
||||
}
|
||||
|
||||
String id = upgrade.getUpgradeID().toString();
|
||||
ITurtleUpgrade existing = upgrades.get( id );
|
||||
if( existing != null )
|
||||
{
|
||||
String message = getMessage( upgrade, "UpgradeID '" + id + "' is already registered by '" + existing.getUnlocalisedAdjective() + " Turtle'" );
|
||||
ComputerCraft.log.error( message );
|
||||
throw new RuntimeException( message );
|
||||
}
|
||||
|
||||
// Register
|
||||
if( legacyId >= 0 ) legacyUpgrades.put( legacyId, upgrade );
|
||||
upgrades.put( id, upgrade );
|
||||
}
|
||||
|
||||
private static String getMessage( ITurtleUpgrade upgrade, String rest )
|
||||
{
|
||||
return "Error registering '" + upgrade.getUnlocalisedAdjective() + " Turtle'. " + rest;
|
||||
}
|
||||
|
||||
public static ITurtleUpgrade get( String id )
|
||||
{
|
||||
return upgrades.get( id );
|
||||
}
|
||||
|
||||
public static ITurtleUpgrade get( int id )
|
||||
{
|
||||
return legacyUpgrades.get( id );
|
||||
}
|
||||
|
||||
public static ITurtleUpgrade get( @Nonnull ItemStack stack )
|
||||
{
|
||||
if( stack.isEmpty() ) return null;
|
||||
|
||||
for( ITurtleUpgrade upgrade : upgrades.values() )
|
||||
{
|
||||
ItemStack craftingStack = upgrade.getCraftingItem();
|
||||
if( !craftingStack.isEmpty() && InventoryUtil.areItemsStackable( stack, craftingStack ) )
|
||||
{
|
||||
return upgrade;
|
||||
}
|
||||
}
|
||||
|
||||
return null;
|
||||
}
|
||||
|
||||
public static Iterable<ITurtleUpgrade> getVanillaUpgrades()
|
||||
{
|
||||
List<ITurtleUpgrade> vanilla = new ArrayList<>();
|
||||
vanilla.add( ComputerCraft.Upgrades.diamondPickaxe );
|
||||
vanilla.add( ComputerCraft.Upgrades.diamondAxe );
|
||||
vanilla.add( ComputerCraft.Upgrades.diamondSword );
|
||||
vanilla.add( ComputerCraft.Upgrades.diamondShovel );
|
||||
vanilla.add( ComputerCraft.Upgrades.diamondHoe );
|
||||
vanilla.add( ComputerCraft.Upgrades.craftingTable );
|
||||
vanilla.add( ComputerCraft.Upgrades.wirelessModem );
|
||||
vanilla.add( ComputerCraft.Upgrades.advancedModem );
|
||||
vanilla.add( ComputerCraft.Upgrades.turtleSpeaker );
|
||||
return vanilla;
|
||||
}
|
||||
|
||||
public static boolean suitableForFamily( ComputerFamily family, ITurtleUpgrade upgrade )
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
@ -225,6 +225,7 @@ public abstract class BlockGeneric extends Block implements ITileEntityProvider
|
||||
}
|
||||
|
||||
@Override
|
||||
@Deprecated
|
||||
public boolean isSideSolid( IBlockState state, @Nonnull IBlockAccess world, @Nonnull BlockPos pos, EnumFacing side )
|
||||
{
|
||||
// We need to override this as the default implementation uses isNormalCube, which returns false if
|
||||
|
@ -7,6 +7,8 @@
|
||||
package dan200.computercraft.shared.computer.blocks;
|
||||
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.shared.BundledRedstone;
|
||||
import dan200.computercraft.shared.Peripherals;
|
||||
import dan200.computercraft.shared.common.IDirectionalTile;
|
||||
import dan200.computercraft.shared.common.ITerminal;
|
||||
import dan200.computercraft.shared.common.TileGeneric;
|
||||
@ -15,7 +17,6 @@ import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||
import dan200.computercraft.shared.computer.core.IComputer;
|
||||
import dan200.computercraft.shared.computer.core.ServerComputer;
|
||||
import dan200.computercraft.shared.util.DirectionUtil;
|
||||
import dan200.computercraft.shared.util.PeripheralUtil;
|
||||
import dan200.computercraft.shared.util.RedstoneUtil;
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.entity.player.EntityPlayer;
|
||||
@ -320,11 +321,11 @@ public abstract class TileComputerBase extends TileGeneric
|
||||
if( !isRedstoneBlockedOnSide( localDir ) )
|
||||
{
|
||||
computer.setRedstoneInput( localDir, getWorld().getRedstonePower( offset, offsetSide ) );
|
||||
computer.setBundledRedstoneInput( localDir, RedstoneUtil.getBundledRedstoneOutput( getWorld(), offset, offsetSide ) );
|
||||
computer.setBundledRedstoneInput( localDir, BundledRedstone.getOutput( getWorld(), offset, offsetSide ) );
|
||||
}
|
||||
if( !isPeripheralBlockedOnSide( localDir ) )
|
||||
{
|
||||
computer.setPeripheral( localDir, PeripheralUtil.getPeripheral( getWorld(), offset, offsetSide ) );
|
||||
computer.setPeripheral( localDir, Peripherals.getPeripheral( getWorld(), offset, offsetSide ) );
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -388,7 +388,7 @@ public class ServerComputer extends ServerTerminal
|
||||
@Override
|
||||
public int assignNewID()
|
||||
{
|
||||
return ComputerCraft.createUniqueNumberedSaveDir( m_world, "computer" );
|
||||
return ComputerCraftAPI.createUniqueNumberedSaveDir( m_world, "computer" );
|
||||
}
|
||||
|
||||
// Networking stuff
|
||||
|
@ -7,6 +7,7 @@
|
||||
package dan200.computercraft.shared.computer.items;
|
||||
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.ComputerCraftAPI;
|
||||
import dan200.computercraft.api.filesystem.IMount;
|
||||
import dan200.computercraft.api.media.IMedia;
|
||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||
@ -95,7 +96,7 @@ public abstract class ItemComputerBase extends ItemBlock implements IComputerIte
|
||||
int id = getComputerID( stack );
|
||||
if( id >= 0 )
|
||||
{
|
||||
return ComputerCraft.createSaveDirMount( world, "computer/" + id, ComputerCraft.computerSpaceLimit );
|
||||
return ComputerCraftAPI.createSaveDirMount( world, "computer/" + id, ComputerCraft.computerSpaceLimit );
|
||||
}
|
||||
}
|
||||
return null;
|
||||
|
@ -123,7 +123,7 @@ public class ItemDiskLegacy extends Item
|
||||
int diskID = getDiskID( stack );
|
||||
if( diskID < 0 )
|
||||
{
|
||||
diskID = ComputerCraft.createUniqueNumberedSaveDir( world, "computer/disk" );
|
||||
diskID = ComputerCraftAPI.createUniqueNumberedSaveDir( world, "computer/disk" );
|
||||
setDiskID( stack, diskID );
|
||||
}
|
||||
return ComputerCraftAPI.createSaveDirMount( world, "computer/disk/" + diskID, ComputerCraft.floppySpaceLimit );
|
||||
|
@ -12,6 +12,7 @@ import dan200.computercraft.api.filesystem.IWritableMount;
|
||||
import dan200.computercraft.api.media.IMedia;
|
||||
import dan200.computercraft.api.peripheral.IComputerAccess;
|
||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||
import dan200.computercraft.shared.MediaProviders;
|
||||
import dan200.computercraft.shared.peripheral.PeripheralType;
|
||||
import dan200.computercraft.shared.peripheral.common.BlockPeripheral;
|
||||
import dan200.computercraft.shared.peripheral.common.TilePeripheralBase;
|
||||
@ -97,7 +98,7 @@ public class TileDiskDrive extends TilePeripheralBase implements DefaultInventor
|
||||
ItemStack disk = player.getHeldItem( hand );
|
||||
if( !disk.isEmpty() && getStackInSlot( 0 ).isEmpty() )
|
||||
{
|
||||
if( ComputerCraft.getMedia( disk ) != null )
|
||||
if( MediaProviders.get( disk ) != null )
|
||||
{
|
||||
setInventorySlotContents( 0, disk );
|
||||
player.setHeldItem( hand, ItemStack.EMPTY );
|
||||
@ -387,7 +388,7 @@ public class TileDiskDrive extends TilePeripheralBase implements DefaultInventor
|
||||
|
||||
public IMedia getDiskMedia()
|
||||
{
|
||||
return ComputerCraft.getMedia( getDiskStack() );
|
||||
return MediaProviders.get( getDiskStack() );
|
||||
}
|
||||
|
||||
public String getDiskMountPath( IComputerAccess computer )
|
||||
|
@ -0,0 +1,19 @@
|
||||
/*
|
||||
* This file is part of ComputerCraft - http://www.computercraft.info
|
||||
* Copyright Daniel Ratcliffe, 2011-2018. Do not distribute without permission.
|
||||
* Send enquiries to dratcliffe@gmail.com
|
||||
*/
|
||||
|
||||
package dan200.computercraft.shared.peripheral.modem;
|
||||
|
||||
/**
|
||||
* This only exists for backwards compatiblity
|
||||
*/
|
||||
public abstract class WirelessModemPeripheral extends dan200.computercraft.shared.peripheral.modem.wireless.WirelessModemPeripheral
|
||||
{
|
||||
@Deprecated
|
||||
public WirelessModemPeripheral( boolean advanced )
|
||||
{
|
||||
super( new ModemState(), advanced );
|
||||
}
|
||||
}
|
@ -8,6 +8,7 @@ package dan200.computercraft.shared.peripheral.modem.wired;
|
||||
|
||||
import com.google.common.collect.ImmutableMap;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.ComputerCraftAPI;
|
||||
import dan200.computercraft.shared.peripheral.PeripheralType;
|
||||
import dan200.computercraft.shared.peripheral.common.BlockPeripheralBase;
|
||||
import dan200.computercraft.shared.peripheral.common.PeripheralItemFactory;
|
||||
@ -172,7 +173,7 @@ public class BlockCable extends BlockPeripheralBase
|
||||
{
|
||||
if( !state.getValue( Properties.CABLE ) ) return false;
|
||||
if( state.getValue( Properties.MODEM ).getFacing() == direction ) return true;
|
||||
return ComputerCraft.getWiredElementAt( world, pos.offset( direction ), direction.getOpposite() ) != null;
|
||||
return ComputerCraftAPI.getWiredElementAt( world, pos.offset( direction ), direction.getOpposite() ) != null;
|
||||
}
|
||||
|
||||
@Nonnull
|
||||
|
@ -8,6 +8,7 @@ package dan200.computercraft.shared.peripheral.modem.wired;
|
||||
|
||||
import com.google.common.base.Objects;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.ComputerCraftAPI;
|
||||
import dan200.computercraft.api.network.wired.IWiredElement;
|
||||
import dan200.computercraft.api.network.wired.IWiredNode;
|
||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||
@ -369,7 +370,7 @@ public class TileCable extends TileModemBase
|
||||
BlockPos offset = current.offset( facing );
|
||||
if( !world.isBlockLoaded( offset ) ) continue;
|
||||
|
||||
IWiredElement element = ComputerCraft.getWiredElementAt( world, offset, facing.getOpposite() );
|
||||
IWiredElement element = ComputerCraftAPI.getWiredElementAt( world, offset, facing.getOpposite() );
|
||||
if( element == null ) continue;
|
||||
|
||||
if( BlockCable.canConnectIn( state, facing ) )
|
||||
|
@ -7,7 +7,7 @@
|
||||
package dan200.computercraft.shared.peripheral.modem.wired;
|
||||
|
||||
import com.google.common.base.Objects;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.ComputerCraftAPI;
|
||||
import dan200.computercraft.api.network.wired.IWiredElement;
|
||||
import dan200.computercraft.api.network.wired.IWiredNode;
|
||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||
@ -283,7 +283,7 @@ public class TileWiredModemFull extends TilePeripheralBase
|
||||
BlockPos offset = current.offset( facing );
|
||||
if( !world.isBlockLoaded( offset ) ) continue;
|
||||
|
||||
IWiredElement element = ComputerCraft.getWiredElementAt( world, offset, facing.getOpposite() );
|
||||
IWiredElement element = ComputerCraftAPI.getWiredElementAt( world, offset, facing.getOpposite() );
|
||||
if( element == null ) continue;
|
||||
|
||||
// If we can connect to it then do so
|
||||
|
@ -8,8 +8,8 @@ package dan200.computercraft.shared.peripheral.modem.wired;
|
||||
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||
import dan200.computercraft.shared.Peripherals;
|
||||
import dan200.computercraft.shared.util.IDAssigner;
|
||||
import dan200.computercraft.shared.util.PeripheralUtil;
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.nbt.NBTTagCompound;
|
||||
import net.minecraft.util.EnumFacing;
|
||||
@ -139,7 +139,7 @@ public final class WiredModemLocalPeripheral
|
||||
Block block = world.getBlockState( offset ).getBlock();
|
||||
if( block == ComputerCraft.Blocks.wiredModemFull || block == ComputerCraft.Blocks.cable ) return null;
|
||||
|
||||
IPeripheral peripheral = PeripheralUtil.getPeripheral( world, offset, direction.getOpposite() );
|
||||
IPeripheral peripheral = Peripherals.getPeripheral( world, offset, direction.getOpposite() );
|
||||
return peripheral instanceof WiredModemPeripheral ? null : peripheral;
|
||||
}
|
||||
}
|
||||
|
@ -141,6 +141,7 @@ public class BlockAdvancedModem extends BlockPeripheralBase
|
||||
}
|
||||
|
||||
@Override
|
||||
@Deprecated
|
||||
public AxisAlignedBB getBoundingBox( IBlockState state, IBlockAccess source, BlockPos pos )
|
||||
{
|
||||
return ModemBounds.getBounds( state.getValue( Properties.FACING ) );
|
||||
|
@ -23,13 +23,6 @@ public abstract class WirelessModemPeripheral extends ModemPeripheral
|
||||
m_advanced = advanced;
|
||||
}
|
||||
|
||||
@Deprecated
|
||||
public WirelessModemPeripheral( boolean advanced )
|
||||
{
|
||||
// Only for backwards compatibiliy
|
||||
this( new ModemState(), advanced );
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isInterdimensional()
|
||||
{
|
||||
|
@ -11,6 +11,7 @@ import dan200.computercraft.api.lua.ILuaAPI;
|
||||
import dan200.computercraft.api.lua.ILuaContext;
|
||||
import dan200.computercraft.api.lua.LuaException;
|
||||
import dan200.computercraft.api.pocket.IPocketUpgrade;
|
||||
import dan200.computercraft.shared.PocketUpgrades;
|
||||
import dan200.computercraft.shared.pocket.core.PocketServerComputer;
|
||||
import dan200.computercraft.shared.util.InventoryUtil;
|
||||
import dan200.computercraft.shared.util.WorldUtil;
|
||||
@ -139,7 +140,7 @@ public class PocketAPI implements ILuaAPI
|
||||
ItemStack invStack = inv.get( (i + start) % inv.size() );
|
||||
if( !invStack.isEmpty() )
|
||||
{
|
||||
IPocketUpgrade newUpgrade = ComputerCraft.getPocketUpgrade( invStack );
|
||||
IPocketUpgrade newUpgrade = PocketUpgrades.get( invStack );
|
||||
|
||||
if( newUpgrade != null && newUpgrade != previous )
|
||||
{
|
||||
|
@ -8,9 +8,11 @@ package dan200.computercraft.shared.pocket.items;
|
||||
|
||||
import com.google.common.base.Objects;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.ComputerCraftAPI;
|
||||
import dan200.computercraft.api.filesystem.IMount;
|
||||
import dan200.computercraft.api.media.IMedia;
|
||||
import dan200.computercraft.api.pocket.IPocketUpgrade;
|
||||
import dan200.computercraft.shared.PocketUpgrades;
|
||||
import dan200.computercraft.shared.common.IColouredItem;
|
||||
import dan200.computercraft.shared.computer.blocks.ComputerState;
|
||||
import dan200.computercraft.shared.computer.core.ClientComputer;
|
||||
@ -100,7 +102,7 @@ public class ItemPocketComputer extends Item implements IComputerItem, IMedia, I
|
||||
private void getSubItems( NonNullList<ItemStack> list, ComputerFamily family )
|
||||
{
|
||||
list.add( PocketComputerItemFactory.create( -1, null, -1, family, null ) );
|
||||
for( IPocketUpgrade upgrade : ComputerCraft.getVanillaPocketUpgrades() )
|
||||
for( IPocketUpgrade upgrade : PocketUpgrades.getVanillaUpgrades() )
|
||||
{
|
||||
list.add( PocketComputerItemFactory.create( -1, null, -1, family, upgrade ) );
|
||||
}
|
||||
@ -268,7 +270,7 @@ public class ItemPocketComputer extends Item implements IComputerItem, IMedia, I
|
||||
int computerID = getComputerID( stack );
|
||||
if( computerID < 0 )
|
||||
{
|
||||
computerID = ComputerCraft.createUniqueNumberedSaveDir( world, "computer" );
|
||||
computerID = ComputerCraftAPI.createUniqueNumberedSaveDir( world, "computer" );
|
||||
setComputerID( stack, computerID );
|
||||
}
|
||||
computer = new PocketServerComputer(
|
||||
@ -405,7 +407,7 @@ public class ItemPocketComputer extends Item implements IComputerItem, IMedia, I
|
||||
int id = getComputerID( stack );
|
||||
if( id >= 0 )
|
||||
{
|
||||
return ComputerCraft.createSaveDirMount( world, "computer/" + id, ComputerCraft.computerSpaceLimit );
|
||||
return ComputerCraftAPI.createSaveDirMount( world, "computer/" + id, ComputerCraft.computerSpaceLimit );
|
||||
}
|
||||
return null;
|
||||
}
|
||||
@ -482,15 +484,12 @@ public class ItemPocketComputer extends Item implements IComputerItem, IMedia, I
|
||||
if( compound.hasKey( "upgrade", Constants.NBT.TAG_STRING ) )
|
||||
{
|
||||
String name = compound.getString( "upgrade" );
|
||||
return ComputerCraft.getPocketUpgrade( name );
|
||||
return PocketUpgrades.get( name );
|
||||
}
|
||||
else if( compound.hasKey( "upgrade", Constants.NBT.TAG_ANY_NUMERIC ) )
|
||||
{
|
||||
int id = compound.getInteger( "upgrade" );
|
||||
if( id == 1 )
|
||||
{
|
||||
return ComputerCraft.getPocketUpgrade( "computercraft:wireless_modem" );
|
||||
}
|
||||
if( id == 1 ) return ComputerCraft.PocketUpgrades.wirelessModem;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -9,6 +9,7 @@ package dan200.computercraft.shared.pocket.recipes;
|
||||
import com.google.gson.JsonObject;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.pocket.IPocketUpgrade;
|
||||
import dan200.computercraft.shared.PocketUpgrades;
|
||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||
import dan200.computercraft.shared.pocket.items.ItemPocketComputer;
|
||||
import dan200.computercraft.shared.pocket.items.PocketComputerItemFactory;
|
||||
@ -104,7 +105,7 @@ public class PocketComputerUpgradeRecipe extends IForgeRegistryEntry.Impl<IRecip
|
||||
}
|
||||
else if( x == computerX && y == computerY - 1 )
|
||||
{
|
||||
upgrade = ComputerCraft.getPocketUpgrade( item );
|
||||
upgrade = PocketUpgrades.get( item );
|
||||
if( upgrade == null ) return ItemStack.EMPTY;
|
||||
}
|
||||
else if( !item.isEmpty() )
|
||||
|
@ -9,6 +9,7 @@ package dan200.computercraft.shared.proxy;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
||||
import dan200.computercraft.api.turtle.event.TurtleActionEvent;
|
||||
import dan200.computercraft.shared.TurtleUpgrades;
|
||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||
import dan200.computercraft.shared.turtle.blocks.BlockTurtle;
|
||||
import dan200.computercraft.shared.turtle.blocks.TileTurtle;
|
||||
@ -19,10 +20,8 @@ import dan200.computercraft.shared.turtle.items.ItemTurtleAdvanced;
|
||||
import dan200.computercraft.shared.turtle.items.ItemTurtleLegacy;
|
||||
import dan200.computercraft.shared.turtle.items.ItemTurtleNormal;
|
||||
import dan200.computercraft.shared.turtle.items.TurtleItemFactory;
|
||||
import dan200.computercraft.shared.turtle.recipes.TurtleUpgradeRecipe;
|
||||
import dan200.computercraft.shared.turtle.upgrades.*;
|
||||
import dan200.computercraft.shared.util.ImpostorRecipe;
|
||||
import dan200.computercraft.shared.util.InventoryUtil;
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.entity.Entity;
|
||||
import net.minecraft.entity.item.EntityItem;
|
||||
@ -30,7 +29,6 @@ import net.minecraft.init.Items;
|
||||
import net.minecraft.item.Item;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.item.crafting.IRecipe;
|
||||
import net.minecraft.util.NonNullList;
|
||||
import net.minecraft.util.ResourceLocation;
|
||||
import net.minecraft.util.math.AxisAlignedBB;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
@ -46,19 +44,13 @@ import net.minecraftforge.fml.common.registry.EntityRegistry;
|
||||
import net.minecraftforge.fml.common.registry.GameRegistry;
|
||||
import net.minecraftforge.registries.IForgeRegistry;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import java.lang.ref.WeakReference;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.function.Function;
|
||||
|
||||
public abstract class CCTurtleProxyCommon implements ICCTurtleProxy
|
||||
{
|
||||
private Map<Integer, ITurtleUpgrade> m_legacyTurtleUpgrades;
|
||||
private Map<String, ITurtleUpgrade> m_turtleUpgrades;
|
||||
|
||||
private Function<ItemStack, ItemStack> dropConsumer;
|
||||
private List<ItemStack> remainingDrops;
|
||||
private WeakReference<World> dropWorld;
|
||||
@ -66,14 +58,6 @@ public abstract class CCTurtleProxyCommon implements ICCTurtleProxy
|
||||
private AxisAlignedBB dropBounds;
|
||||
private WeakReference<Entity> dropEntity;
|
||||
|
||||
public CCTurtleProxyCommon()
|
||||
{
|
||||
m_legacyTurtleUpgrades = new HashMap<>();
|
||||
m_turtleUpgrades = new HashMap<>();
|
||||
}
|
||||
|
||||
// ICCTurtleProxy implementation
|
||||
|
||||
@Override
|
||||
public void preInit()
|
||||
{
|
||||
@ -92,102 +76,6 @@ public abstract class CCTurtleProxyCommon implements ICCTurtleProxy
|
||||
registerTileEntities();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void registerTurtleUpgrade( ITurtleUpgrade upgrade )
|
||||
{
|
||||
// Check conditions
|
||||
int id = upgrade.getLegacyUpgradeID();
|
||||
if( id >= 0 && id < 64 )
|
||||
{
|
||||
String message = "Error registering '" + upgrade.getUnlocalisedAdjective() + " Turtle'. Legacy UpgradeID '" + id + "' is reserved by ComputerCraft";
|
||||
ComputerCraft.log.error( message );
|
||||
throw new RuntimeException( message );
|
||||
}
|
||||
|
||||
// Register
|
||||
registerTurtleUpgradeInternal( upgrade );
|
||||
}
|
||||
|
||||
@Override
|
||||
public ITurtleUpgrade getTurtleUpgrade( String id )
|
||||
{
|
||||
return m_turtleUpgrades.get( id );
|
||||
}
|
||||
|
||||
@Override
|
||||
public ITurtleUpgrade getTurtleUpgrade( int legacyId )
|
||||
{
|
||||
return m_legacyTurtleUpgrades.get( legacyId );
|
||||
}
|
||||
|
||||
@Override
|
||||
public ITurtleUpgrade getTurtleUpgrade( @Nonnull ItemStack stack )
|
||||
{
|
||||
for( ITurtleUpgrade upgrade : m_turtleUpgrades.values() )
|
||||
{
|
||||
try
|
||||
{
|
||||
ItemStack upgradeStack = upgrade.getCraftingItem();
|
||||
if( InventoryUtil.areItemsStackable( upgradeStack, stack ) )
|
||||
{
|
||||
return upgrade;
|
||||
}
|
||||
}
|
||||
catch( Exception e )
|
||||
{
|
||||
ComputerCraft.log.error( "Error getting computer upgrade item", e );
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public static boolean isUpgradeVanilla( ITurtleUpgrade upgrade )
|
||||
{
|
||||
return upgrade instanceof TurtleTool || upgrade instanceof TurtleModem || upgrade instanceof TurtleCraftingTable || upgrade instanceof TurtleSpeaker;
|
||||
}
|
||||
|
||||
public static boolean isUpgradeSuitableForFamily( ComputerFamily family, ITurtleUpgrade upgrade )
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
private void addAllUpgradedTurtles( ComputerFamily family, NonNullList<ItemStack> list )
|
||||
{
|
||||
ItemStack basicStack = TurtleItemFactory.create( -1, null, -1, family, null, null, 0, null );
|
||||
if( !basicStack.isEmpty() )
|
||||
{
|
||||
list.add( basicStack );
|
||||
}
|
||||
addUpgradedTurtle( family, ComputerCraft.Upgrades.diamondPickaxe, list );
|
||||
addUpgradedTurtle( family, ComputerCraft.Upgrades.diamondAxe, list );
|
||||
addUpgradedTurtle( family, ComputerCraft.Upgrades.diamondSword, list );
|
||||
addUpgradedTurtle( family, ComputerCraft.Upgrades.diamondShovel, list );
|
||||
addUpgradedTurtle( family, ComputerCraft.Upgrades.diamondHoe, list );
|
||||
addUpgradedTurtle( family, ComputerCraft.Upgrades.craftingTable, list );
|
||||
addUpgradedTurtle( family, ComputerCraft.Upgrades.wirelessModem, list );
|
||||
addUpgradedTurtle( family, ComputerCraft.Upgrades.advancedModem, list );
|
||||
addUpgradedTurtle( family, ComputerCraft.Upgrades.turtleSpeaker, list );
|
||||
}
|
||||
|
||||
private void addUpgradedTurtle( ComputerFamily family, ITurtleUpgrade upgrade, List<ItemStack> list )
|
||||
{
|
||||
if( isUpgradeSuitableForFamily( family, upgrade ) )
|
||||
{
|
||||
ItemStack stack = TurtleItemFactory.create( -1, null, -1, family, upgrade, null, 0, null );
|
||||
if( !stack.isEmpty() )
|
||||
{
|
||||
list.add( stack );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void addAllUpgradedTurtles( NonNullList<ItemStack> list )
|
||||
{
|
||||
addAllUpgradedTurtles( ComputerFamily.Normal, list );
|
||||
addAllUpgradedTurtles( ComputerFamily.Advanced, list );
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setDropConsumer( Entity entity, Function<ItemStack, ItemStack> consumer )
|
||||
{
|
||||
@ -241,45 +129,6 @@ public abstract class CCTurtleProxyCommon implements ICCTurtleProxy
|
||||
return remainingStacks;
|
||||
}
|
||||
|
||||
private void registerTurtleUpgradeInternal( ITurtleUpgrade upgrade )
|
||||
{
|
||||
// Check conditions
|
||||
int legacyID = upgrade.getLegacyUpgradeID();
|
||||
if( legacyID >= 0 )
|
||||
{
|
||||
if( legacyID >= Short.MAX_VALUE )
|
||||
{
|
||||
String message = "Error registering '" + upgrade.getUnlocalisedAdjective() + " Turtle'. UpgradeID '" + legacyID + "' is out of range";
|
||||
ComputerCraft.log.error( message );
|
||||
throw new RuntimeException( message );
|
||||
}
|
||||
|
||||
ITurtleUpgrade existing = m_legacyTurtleUpgrades.get( legacyID );
|
||||
if( existing != null )
|
||||
{
|
||||
String message = "Error registering '" + upgrade.getUnlocalisedAdjective() + " Turtle'. UpgradeID '" + legacyID + "' is already registered by '" + existing.getUnlocalisedAdjective() + " Turtle'";
|
||||
ComputerCraft.log.error( message );
|
||||
throw new RuntimeException( message );
|
||||
}
|
||||
}
|
||||
|
||||
String id = upgrade.getUpgradeID().toString();
|
||||
ITurtleUpgrade existing = m_turtleUpgrades.get( id );
|
||||
if( existing != null )
|
||||
{
|
||||
String message = "Error registering '" + upgrade.getUnlocalisedAdjective() + " Turtle'. UpgradeID '" + id + "' is already registered by '" + existing.getUnlocalisedAdjective() + " Turtle'";
|
||||
ComputerCraft.log.error( message );
|
||||
throw new RuntimeException( message );
|
||||
}
|
||||
|
||||
// Register
|
||||
if( legacyID >= 0 )
|
||||
{
|
||||
m_legacyTurtleUpgrades.put( legacyID, upgrade );
|
||||
}
|
||||
m_turtleUpgrades.put( id, upgrade );
|
||||
}
|
||||
|
||||
@SubscribeEvent
|
||||
public void registerBlocks( RegistryEvent.Register<Block> event )
|
||||
{
|
||||
@ -316,20 +165,15 @@ public abstract class CCTurtleProxyCommon implements ICCTurtleProxy
|
||||
|
||||
// Add a bunch of impostor recipes
|
||||
// TODO: Figure out a way to do this in a "nice" way.
|
||||
for( ITurtleUpgrade upgrade : m_turtleUpgrades.values() )
|
||||
for( ITurtleUpgrade upgrade : TurtleUpgrades.getVanillaUpgrades() )
|
||||
{
|
||||
if( !isUpgradeVanilla( upgrade ) ) continue;
|
||||
|
||||
// Add fake recipes to fool NEI
|
||||
ItemStack craftingItem = upgrade.getCraftingItem();
|
||||
|
||||
// A turtle just containing this upgrade
|
||||
for( ComputerFamily family : ComputerFamily.values() )
|
||||
{
|
||||
if( !isUpgradeSuitableForFamily( family, upgrade ) )
|
||||
{
|
||||
continue;
|
||||
}
|
||||
if( !TurtleUpgrades.suitableForFamily( family, upgrade ) ) continue;
|
||||
|
||||
ItemStack baseTurtle = TurtleItemFactory.create( -1, null, -1, family, null, null, 0, null );
|
||||
if( !baseTurtle.isEmpty() )
|
||||
@ -377,31 +221,31 @@ public abstract class CCTurtleProxyCommon implements ICCTurtleProxy
|
||||
{
|
||||
// Upgrades
|
||||
ComputerCraft.Upgrades.wirelessModem = new TurtleModem( false, new ResourceLocation( "computercraft", "wireless_modem" ), 1 );
|
||||
registerTurtleUpgradeInternal( ComputerCraft.Upgrades.wirelessModem );
|
||||
TurtleUpgrades.registerInternal( ComputerCraft.Upgrades.wirelessModem );
|
||||
|
||||
ComputerCraft.Upgrades.craftingTable = new TurtleCraftingTable( 2 );
|
||||
registerTurtleUpgradeInternal( ComputerCraft.Upgrades.craftingTable );
|
||||
TurtleUpgrades.registerInternal( ComputerCraft.Upgrades.craftingTable );
|
||||
|
||||
ComputerCraft.Upgrades.diamondSword = new TurtleSword( new ResourceLocation( "minecraft", "diamond_sword" ), 3, "upgrade.minecraft:diamond_sword.adjective", Items.DIAMOND_SWORD );
|
||||
registerTurtleUpgradeInternal( ComputerCraft.Upgrades.diamondSword );
|
||||
TurtleUpgrades.registerInternal( ComputerCraft.Upgrades.diamondSword );
|
||||
|
||||
ComputerCraft.Upgrades.diamondShovel = new TurtleShovel( new ResourceLocation( "minecraft", "diamond_shovel" ), 4, "upgrade.minecraft:diamond_shovel.adjective", Items.DIAMOND_SHOVEL );
|
||||
registerTurtleUpgradeInternal( ComputerCraft.Upgrades.diamondShovel );
|
||||
TurtleUpgrades.registerInternal( ComputerCraft.Upgrades.diamondShovel );
|
||||
|
||||
ComputerCraft.Upgrades.diamondPickaxe = new TurtleTool( new ResourceLocation( "minecraft", "diamond_pickaxe" ), 5, "upgrade.minecraft:diamond_pickaxe.adjective", Items.DIAMOND_PICKAXE );
|
||||
registerTurtleUpgradeInternal( ComputerCraft.Upgrades.diamondPickaxe );
|
||||
TurtleUpgrades.registerInternal( ComputerCraft.Upgrades.diamondPickaxe );
|
||||
|
||||
ComputerCraft.Upgrades.diamondAxe = new TurtleAxe( new ResourceLocation( "minecraft", "diamond_axe" ), 6, "upgrade.minecraft:diamond_axe.adjective", Items.DIAMOND_AXE );
|
||||
registerTurtleUpgradeInternal( ComputerCraft.Upgrades.diamondAxe );
|
||||
TurtleUpgrades.registerInternal( ComputerCraft.Upgrades.diamondAxe );
|
||||
|
||||
ComputerCraft.Upgrades.diamondHoe = new TurtleHoe( new ResourceLocation( "minecraft", "diamond_hoe" ), 7, "upgrade.minecraft:diamond_hoe.adjective", Items.DIAMOND_HOE );
|
||||
registerTurtleUpgradeInternal( ComputerCraft.Upgrades.diamondHoe );
|
||||
TurtleUpgrades.registerInternal( ComputerCraft.Upgrades.diamondHoe );
|
||||
|
||||
ComputerCraft.Upgrades.advancedModem = new TurtleModem( true, new ResourceLocation( "computercraft", "advanced_modem" ), -1 );
|
||||
registerTurtleUpgradeInternal( ComputerCraft.Upgrades.advancedModem );
|
||||
TurtleUpgrades.registerInternal( ComputerCraft.Upgrades.advancedModem );
|
||||
|
||||
ComputerCraft.Upgrades.turtleSpeaker = new TurtleSpeaker( new ResourceLocation( "computercraft", "speaker" ), 8 );
|
||||
registerTurtleUpgradeInternal( ComputerCraft.Upgrades.turtleSpeaker );
|
||||
TurtleUpgrades.registerInternal( ComputerCraft.Upgrades.turtleSpeaker );
|
||||
}
|
||||
|
||||
@SubscribeEvent
|
||||
|
@ -10,6 +10,7 @@ import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.ComputerCraftAPI;
|
||||
import dan200.computercraft.api.pocket.IPocketUpgrade;
|
||||
import dan200.computercraft.core.computer.MainThread;
|
||||
import dan200.computercraft.shared.PocketUpgrades;
|
||||
import dan200.computercraft.shared.command.CommandComputerCraft;
|
||||
import dan200.computercraft.shared.command.ContainerViewComputer;
|
||||
import dan200.computercraft.shared.common.DefaultBundledRedstoneProvider;
|
||||
@ -30,7 +31,6 @@ import dan200.computercraft.shared.media.items.ItemDiskExpanded;
|
||||
import dan200.computercraft.shared.media.items.ItemDiskLegacy;
|
||||
import dan200.computercraft.shared.media.items.ItemPrintout;
|
||||
import dan200.computercraft.shared.media.items.ItemTreasureDisk;
|
||||
import dan200.computercraft.shared.media.recipes.PrintoutRecipe;
|
||||
import dan200.computercraft.shared.network.ComputerCraftPacket;
|
||||
import dan200.computercraft.shared.peripheral.commandblock.CommandBlockPeripheralProvider;
|
||||
import dan200.computercraft.shared.peripheral.common.BlockPeripheral;
|
||||
@ -52,7 +52,6 @@ import dan200.computercraft.shared.pocket.items.ItemPocketComputer;
|
||||
import dan200.computercraft.shared.pocket.items.PocketComputerItemFactory;
|
||||
import dan200.computercraft.shared.pocket.peripherals.PocketModem;
|
||||
import dan200.computercraft.shared.pocket.peripherals.PocketSpeaker;
|
||||
import dan200.computercraft.shared.pocket.recipes.PocketComputerUpgradeRecipe;
|
||||
import dan200.computercraft.shared.turtle.blocks.TileTurtle;
|
||||
import dan200.computercraft.shared.turtle.inventory.ContainerTurtle;
|
||||
import dan200.computercraft.shared.util.Colour;
|
||||
@ -300,7 +299,7 @@ public abstract class ComputerCraftProxyCommon implements IComputerCraftProxy
|
||||
// Impostor Pocket Computer recipes (to fool NEI)
|
||||
ItemStack pocketComputer = PocketComputerItemFactory.create( -1, null, -1, ComputerFamily.Normal, null );
|
||||
ItemStack advancedPocketComputer = PocketComputerItemFactory.create( -1, null, -1, ComputerFamily.Advanced, null );
|
||||
for( IPocketUpgrade upgrade : ComputerCraft.getVanillaPocketUpgrades() )
|
||||
for( IPocketUpgrade upgrade : PocketUpgrades.getVanillaUpgrades() )
|
||||
{
|
||||
registry.register( new ImpostorRecipe(
|
||||
"computercraft:normal_pocket_upgrade",
|
||||
|
@ -6,14 +6,11 @@
|
||||
|
||||
package dan200.computercraft.shared.proxy;
|
||||
|
||||
import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
||||
import net.minecraft.entity.Entity;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.util.NonNullList;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.world.World;
|
||||
|
||||
import javax.annotation.Nonnull;
|
||||
import java.util.List;
|
||||
import java.util.function.Function;
|
||||
|
||||
@ -23,16 +20,6 @@ public interface ICCTurtleProxy
|
||||
|
||||
void init();
|
||||
|
||||
void registerTurtleUpgrade( ITurtleUpgrade upgrade );
|
||||
|
||||
ITurtleUpgrade getTurtleUpgrade( String id );
|
||||
|
||||
ITurtleUpgrade getTurtleUpgrade( int legacyId );
|
||||
|
||||
ITurtleUpgrade getTurtleUpgrade( @Nonnull ItemStack item );
|
||||
|
||||
void addAllUpgradedTurtles( NonNullList<ItemStack> list );
|
||||
|
||||
void setDropConsumer( Entity entity, Function<ItemStack, ItemStack> consumer );
|
||||
|
||||
void setDropConsumer( World world, BlockPos pos, Function<ItemStack, ItemStack> consumer );
|
||||
|
@ -13,6 +13,7 @@ import dan200.computercraft.api.lua.ILuaContext;
|
||||
import dan200.computercraft.api.lua.LuaException;
|
||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||
import dan200.computercraft.api.turtle.*;
|
||||
import dan200.computercraft.shared.TurtleUpgrades;
|
||||
import dan200.computercraft.shared.computer.blocks.ComputerProxy;
|
||||
import dan200.computercraft.shared.computer.blocks.TileComputerBase;
|
||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||
@ -132,14 +133,14 @@ public class TurtleBrain implements ITurtleAccess
|
||||
}
|
||||
}
|
||||
|
||||
public void readFromNBT( NBTTagCompound nbttagcompound )
|
||||
public void readFromNBT( NBTTagCompound tag )
|
||||
{
|
||||
// Read state
|
||||
m_direction = EnumFacing.byIndex( nbttagcompound.getInteger( "dir" ) );
|
||||
m_selectedSlot = nbttagcompound.getInteger( "selectedSlot" );
|
||||
if( nbttagcompound.hasKey( "fuelLevel" ) )
|
||||
m_direction = EnumFacing.byIndex( tag.getInteger( "dir" ) );
|
||||
m_selectedSlot = tag.getInteger( "selectedSlot" );
|
||||
if( tag.hasKey( "fuelLevel" ) )
|
||||
{
|
||||
m_fuelLevel = nbttagcompound.getInteger( "fuelLevel" );
|
||||
m_fuelLevel = tag.getInteger( "fuelLevel" );
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -147,9 +148,9 @@ public class TurtleBrain implements ITurtleAccess
|
||||
}
|
||||
|
||||
// Read owner
|
||||
if( nbttagcompound.hasKey( "owner", Constants.NBT.TAG_COMPOUND ) )
|
||||
if( tag.hasKey( "owner", Constants.NBT.TAG_COMPOUND ) )
|
||||
{
|
||||
NBTTagCompound owner = nbttagcompound.getCompoundTag( "owner" );
|
||||
NBTTagCompound owner = tag.getCompoundTag( "owner" );
|
||||
m_owningPlayer = new GameProfile(
|
||||
new UUID( owner.getLong( "upper_id" ), owner.getLong( "lower_id" ) ),
|
||||
owner.getString( "name" )
|
||||
@ -161,15 +162,15 @@ public class TurtleBrain implements ITurtleAccess
|
||||
}
|
||||
|
||||
// Read colour
|
||||
m_colourHex = ColourUtils.getHexColour( nbttagcompound );
|
||||
m_colourHex = ColourUtils.getHexColour( tag );
|
||||
|
||||
// Read overlay
|
||||
if( nbttagcompound.hasKey( "overlay_mod" ) )
|
||||
if( tag.hasKey( "overlay_mod" ) )
|
||||
{
|
||||
String overlay_mod = nbttagcompound.getString( "overlay_mod" );
|
||||
if( nbttagcompound.hasKey( "overlay_path" ) )
|
||||
String overlay_mod = tag.getString( "overlay_mod" );
|
||||
if( tag.hasKey( "overlay_path" ) )
|
||||
{
|
||||
String overlay_path = nbttagcompound.getString( "overlay_path" );
|
||||
String overlay_path = tag.getString( "overlay_path" );
|
||||
m_overlay = new ResourceLocation( overlay_mod, overlay_path );
|
||||
}
|
||||
else
|
||||
@ -186,10 +187,10 @@ public class TurtleBrain implements ITurtleAccess
|
||||
// (pre-1.4 turtles will have a "subType" variable, newer things will have "leftUpgrade" and "rightUpgrade")
|
||||
ITurtleUpgrade leftUpgrade = null;
|
||||
ITurtleUpgrade rightUpgrade = null;
|
||||
if( nbttagcompound.hasKey( "subType" ) )
|
||||
if( tag.hasKey( "subType" ) )
|
||||
{
|
||||
// Loading a pre-1.4 world
|
||||
int subType = nbttagcompound.getInteger( "subType" );
|
||||
int subType = tag.getInteger( "subType" );
|
||||
if( (subType & 0x1) > 0 )
|
||||
{
|
||||
leftUpgrade = ComputerCraft.Upgrades.diamondPickaxe;
|
||||
@ -202,26 +203,26 @@ public class TurtleBrain implements ITurtleAccess
|
||||
else
|
||||
{
|
||||
// Loading a post-1.4 world
|
||||
if( nbttagcompound.hasKey( "leftUpgrade" ) )
|
||||
if( tag.hasKey( "leftUpgrade" ) )
|
||||
{
|
||||
if( nbttagcompound.getTagId( "leftUpgrade" ) == Constants.NBT.TAG_STRING )
|
||||
if( tag.getTagId( "leftUpgrade" ) == Constants.NBT.TAG_STRING )
|
||||
{
|
||||
leftUpgrade = ComputerCraft.getTurtleUpgrade( nbttagcompound.getString( "leftUpgrade" ) );
|
||||
leftUpgrade = TurtleUpgrades.get( tag.getString( "leftUpgrade" ) );
|
||||
}
|
||||
else
|
||||
{
|
||||
leftUpgrade = ComputerCraft.getTurtleUpgrade( nbttagcompound.getShort( "leftUpgrade" ) );
|
||||
leftUpgrade = TurtleUpgrades.get( tag.getShort( "leftUpgrade" ) );
|
||||
}
|
||||
}
|
||||
if( nbttagcompound.hasKey( "rightUpgrade" ) )
|
||||
if( tag.hasKey( "rightUpgrade" ) )
|
||||
{
|
||||
if( nbttagcompound.getTagId( "rightUpgrade" ) == Constants.NBT.TAG_STRING )
|
||||
if( tag.getTagId( "rightUpgrade" ) == Constants.NBT.TAG_STRING )
|
||||
{
|
||||
rightUpgrade = ComputerCraft.getTurtleUpgrade( nbttagcompound.getString( "rightUpgrade" ) );
|
||||
rightUpgrade = TurtleUpgrades.get( tag.getString( "rightUpgrade" ) );
|
||||
}
|
||||
else
|
||||
{
|
||||
rightUpgrade = ComputerCraft.getTurtleUpgrade( nbttagcompound.getShort( "rightUpgrade" ) );
|
||||
rightUpgrade = TurtleUpgrades.get( tag.getShort( "rightUpgrade" ) );
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -230,13 +231,13 @@ public class TurtleBrain implements ITurtleAccess
|
||||
|
||||
// NBT
|
||||
m_upgradeNBTData.clear();
|
||||
if( nbttagcompound.hasKey( "leftUpgradeNBT" ) )
|
||||
if( tag.hasKey( "leftUpgradeNBT" ) )
|
||||
{
|
||||
m_upgradeNBTData.put( TurtleSide.Left, nbttagcompound.getCompoundTag( "leftUpgradeNBT" ).copy() );
|
||||
m_upgradeNBTData.put( TurtleSide.Left, tag.getCompoundTag( "leftUpgradeNBT" ).copy() );
|
||||
}
|
||||
if( nbttagcompound.hasKey( "rightUpgradeNBT" ) )
|
||||
if( tag.hasKey( "rightUpgradeNBT" ) )
|
||||
{
|
||||
m_upgradeNBTData.put( TurtleSide.Right, nbttagcompound.getCompoundTag( "rightUpgradeNBT" ).copy() );
|
||||
m_upgradeNBTData.put( TurtleSide.Right, tag.getCompoundTag( "rightUpgradeNBT" ).copy() );
|
||||
}
|
||||
}
|
||||
|
||||
@ -353,7 +354,7 @@ public class TurtleBrain implements ITurtleAccess
|
||||
// Upgrades
|
||||
if( nbttagcompound.hasKey( "leftUpgrade" ) )
|
||||
{
|
||||
setUpgrade( TurtleSide.Left, ComputerCraft.getTurtleUpgrade( nbttagcompound.getString( "leftUpgrade" ) ) );
|
||||
setUpgrade( TurtleSide.Left, TurtleUpgrades.get( nbttagcompound.getString( "leftUpgrade" ) ) );
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -361,7 +362,7 @@ public class TurtleBrain implements ITurtleAccess
|
||||
}
|
||||
if( nbttagcompound.hasKey( "rightUpgrade" ) )
|
||||
{
|
||||
setUpgrade( TurtleSide.Right, ComputerCraft.getTurtleUpgrade( nbttagcompound.getString( "rightUpgrade" ) ) );
|
||||
setUpgrade( TurtleSide.Right, TurtleUpgrades.get( nbttagcompound.getString( "rightUpgrade" ) ) );
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -6,11 +6,10 @@
|
||||
|
||||
package dan200.computercraft.shared.turtle.core;
|
||||
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.turtle.*;
|
||||
import dan200.computercraft.api.turtle.event.TurtleAction;
|
||||
import dan200.computercraft.api.turtle.event.TurtleActionEvent;
|
||||
import dan200.computercraft.shared.proxy.CCTurtleProxyCommon;
|
||||
import dan200.computercraft.shared.TurtleUpgrades;
|
||||
import dan200.computercraft.shared.util.InventoryUtil;
|
||||
import dan200.computercraft.shared.util.WorldUtil;
|
||||
import net.minecraft.item.ItemStack;
|
||||
@ -41,8 +40,8 @@ public class TurtleEquipCommand implements ITurtleCommand
|
||||
if( !selectedStack.isEmpty() )
|
||||
{
|
||||
newUpgradeStack = selectedStack.copy();
|
||||
newUpgrade = ComputerCraft.getTurtleUpgrade( newUpgradeStack );
|
||||
if( newUpgrade == null || !CCTurtleProxyCommon.isUpgradeSuitableForFamily( ((TurtleBrain) turtle).getFamily(), newUpgrade ) )
|
||||
newUpgrade = TurtleUpgrades.get( newUpgradeStack );
|
||||
if( newUpgrade == null || !TurtleUpgrades.suitableForFamily( ((TurtleBrain) turtle).getFamily(), newUpgrade ) )
|
||||
{
|
||||
return TurtleCommandResult.failure( "Not a valid upgrade" );
|
||||
}
|
||||
|
@ -12,6 +12,7 @@ import dan200.computercraft.api.turtle.ITurtleCommand;
|
||||
import dan200.computercraft.api.turtle.TurtleAnimation;
|
||||
import dan200.computercraft.api.turtle.TurtleCommandResult;
|
||||
import dan200.computercraft.api.turtle.event.TurtleBlockEvent;
|
||||
import dan200.computercraft.shared.TurtlePermissions;
|
||||
import dan200.computercraft.shared.util.WorldUtil;
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.block.state.IBlockState;
|
||||
@ -172,7 +173,7 @@ public class TurtleMoveCommand implements ITurtleCommand
|
||||
if( ComputerCraft.turtlesObeyBlockProtection )
|
||||
{
|
||||
// Check spawn protection
|
||||
if( !ComputerCraft.isBlockEnterable( world, position, turtlePlayer ) )
|
||||
if( !TurtlePermissions.isBlockEnterable( world, position, turtlePlayer ) )
|
||||
{
|
||||
return TurtleCommandResult.failure( "Cannot enter protected area" );
|
||||
}
|
||||
|
@ -12,6 +12,8 @@ import dan200.computercraft.api.turtle.ITurtleCommand;
|
||||
import dan200.computercraft.api.turtle.TurtleAnimation;
|
||||
import dan200.computercraft.api.turtle.TurtleCommandResult;
|
||||
import dan200.computercraft.api.turtle.event.TurtleBlockEvent;
|
||||
import dan200.computercraft.shared.TurtlePermissions;
|
||||
import dan200.computercraft.shared.TurtleUpgrades;
|
||||
import dan200.computercraft.shared.util.DirectionUtil;
|
||||
import dan200.computercraft.shared.util.InventoryUtil;
|
||||
import dan200.computercraft.shared.util.WorldUtil;
|
||||
@ -303,8 +305,8 @@ public class TurtlePlaceCommand implements ITurtleCommand
|
||||
{
|
||||
// Check spawn protection
|
||||
boolean editable = replaceable
|
||||
? ComputerCraft.isBlockEditable( world, position, player )
|
||||
: ComputerCraft.isBlockEditable( world, position.offset( side ), player );
|
||||
? TurtlePermissions.isBlockEditable( world, position, player )
|
||||
: TurtlePermissions.isBlockEditable( world, position.offset( side ), player );
|
||||
if( !editable )
|
||||
{
|
||||
if( o_errorMessage != null )
|
||||
|
@ -22,7 +22,7 @@ public class ItemTurtleAdvanced extends ItemTurtleNormal
|
||||
// IComputerItem implementation
|
||||
|
||||
@Override
|
||||
public ComputerFamily getFamily( int damage )
|
||||
public ComputerFamily getFamily()
|
||||
{
|
||||
return ComputerFamily.Advanced;
|
||||
}
|
||||
|
@ -6,9 +6,9 @@
|
||||
|
||||
package dan200.computercraft.shared.turtle.items;
|
||||
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
||||
import dan200.computercraft.api.turtle.TurtleSide;
|
||||
import dan200.computercraft.shared.TurtleUpgrades;
|
||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||
import dan200.computercraft.shared.computer.items.ItemComputerBase;
|
||||
import dan200.computercraft.shared.turtle.blocks.ITurtleTile;
|
||||
@ -40,18 +40,26 @@ public abstract class ItemTurtleBase extends ItemComputerBase implements ITurtle
|
||||
|
||||
public abstract ItemStack create( int id, String label, int colour, ITurtleUpgrade leftUpgrade, ITurtleUpgrade rightUpgrade, int fuelLevel, ResourceLocation overlay );
|
||||
|
||||
public abstract ComputerFamily getFamily();
|
||||
|
||||
@Override
|
||||
public ComputerFamily getFamily( int damage )
|
||||
{
|
||||
return getFamily();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void getSubItems( @Nullable CreativeTabs tabs, @Nonnull NonNullList<ItemStack> list )
|
||||
{
|
||||
if( !isInCreativeTab( tabs ) ) return;
|
||||
NonNullList<ItemStack> all = NonNullList.create();
|
||||
ComputerCraft.addAllUpgradedTurtles( all );
|
||||
for( ItemStack stack : all )
|
||||
|
||||
ComputerFamily family = getFamily();
|
||||
for( ITurtleUpgrade upgrade : TurtleUpgrades.getVanillaUpgrades() )
|
||||
{
|
||||
if( stack.getItem() == this )
|
||||
{
|
||||
list.add( stack );
|
||||
}
|
||||
if( !TurtleUpgrades.suitableForFamily( family, upgrade ) ) continue;
|
||||
|
||||
ItemStack stack = TurtleItemFactory.create( -1, null, -1, family, upgrade, null, 0, null );
|
||||
if( !stack.isEmpty() && stack.getItem() == this ) list.add( stack );
|
||||
}
|
||||
}
|
||||
|
||||
@ -61,7 +69,7 @@ public abstract class ItemTurtleBase extends ItemComputerBase implements ITurtle
|
||||
if( super.placeBlockAt( stack, player, world, pos, side, hitX, hitY, hitZ, newState ) )
|
||||
{
|
||||
TileEntity tile = world.getTileEntity( pos );
|
||||
if( tile != null && tile instanceof ITurtleTile )
|
||||
if( tile instanceof ITurtleTile )
|
||||
{
|
||||
ITurtleTile turtle = (ITurtleTile) tile;
|
||||
setupTurtleAfterPlacement( stack, turtle );
|
||||
|
@ -97,7 +97,7 @@ public class ItemTurtleLegacy extends ItemTurtleBase
|
||||
}
|
||||
|
||||
@Override
|
||||
public ComputerFamily getFamily( int damage )
|
||||
public ComputerFamily getFamily()
|
||||
{
|
||||
return ComputerFamily.Normal;
|
||||
}
|
||||
|
@ -9,6 +9,7 @@ package dan200.computercraft.shared.turtle.items;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
||||
import dan200.computercraft.api.turtle.TurtleSide;
|
||||
import dan200.computercraft.shared.TurtleUpgrades;
|
||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||
import dan200.computercraft.shared.util.ColourUtils;
|
||||
import net.minecraft.block.Block;
|
||||
@ -102,7 +103,7 @@ public class ItemTurtleNormal extends ItemTurtleBase
|
||||
}
|
||||
|
||||
@Override
|
||||
public ComputerFamily getFamily( int damage )
|
||||
public ComputerFamily getFamily()
|
||||
{
|
||||
return ComputerFamily.Normal;
|
||||
}
|
||||
@ -123,11 +124,11 @@ public class ItemTurtleNormal extends ItemTurtleBase
|
||||
{
|
||||
if( nbt.getTagId( "leftUpgrade" ) == Constants.NBT.TAG_STRING )
|
||||
{
|
||||
return ComputerCraft.getTurtleUpgrade( nbt.getString( "leftUpgrade" ) );
|
||||
return TurtleUpgrades.get( nbt.getString( "leftUpgrade" ) );
|
||||
}
|
||||
else
|
||||
{
|
||||
return ComputerCraft.getTurtleUpgrade( nbt.getShort( "leftUpgrade" ) );
|
||||
return TurtleUpgrades.get( nbt.getShort( "leftUpgrade" ) );
|
||||
}
|
||||
}
|
||||
break;
|
||||
@ -138,11 +139,11 @@ public class ItemTurtleNormal extends ItemTurtleBase
|
||||
{
|
||||
if( nbt.getTagId( "rightUpgrade" ) == Constants.NBT.TAG_STRING )
|
||||
{
|
||||
return ComputerCraft.getTurtleUpgrade( nbt.getString( "rightUpgrade" ) );
|
||||
return TurtleUpgrades.get( nbt.getString( "rightUpgrade" ) );
|
||||
}
|
||||
else
|
||||
{
|
||||
return ComputerCraft.getTurtleUpgrade( nbt.getShort( "rightUpgrade" ) );
|
||||
return TurtleUpgrades.get( nbt.getShort( "rightUpgrade" ) );
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
@ -7,11 +7,10 @@
|
||||
package dan200.computercraft.shared.turtle.recipes;
|
||||
|
||||
import com.google.gson.JsonObject;
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
||||
import dan200.computercraft.api.turtle.TurtleSide;
|
||||
import dan200.computercraft.shared.TurtleUpgrades;
|
||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||
import dan200.computercraft.shared.proxy.CCTurtleProxyCommon;
|
||||
import dan200.computercraft.shared.turtle.items.ITurtleItem;
|
||||
import dan200.computercraft.shared.turtle.items.TurtleItemFactory;
|
||||
import net.minecraft.inventory.InventoryCrafting;
|
||||
@ -157,7 +156,7 @@ public class TurtleUpgradeRecipe extends IForgeRegistryEntry.Impl<IRecipe> imple
|
||||
{
|
||||
if( !items[i].isEmpty() )
|
||||
{
|
||||
ITurtleUpgrade itemUpgrade = ComputerCraft.getTurtleUpgrade( items[i] );
|
||||
ITurtleUpgrade itemUpgrade = TurtleUpgrades.get( items[i] );
|
||||
if( itemUpgrade == null )
|
||||
{
|
||||
return ItemStack.EMPTY;
|
||||
@ -166,7 +165,7 @@ public class TurtleUpgradeRecipe extends IForgeRegistryEntry.Impl<IRecipe> imple
|
||||
{
|
||||
return ItemStack.EMPTY;
|
||||
}
|
||||
if( !CCTurtleProxyCommon.isUpgradeSuitableForFamily( family, itemUpgrade ) )
|
||||
if( !TurtleUpgrades.suitableForFamily( family, itemUpgrade ) )
|
||||
{
|
||||
return ItemStack.EMPTY;
|
||||
}
|
||||
|
@ -10,6 +10,7 @@ import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.turtle.*;
|
||||
import dan200.computercraft.api.turtle.event.TurtleAttackEvent;
|
||||
import dan200.computercraft.api.turtle.event.TurtleBlockEvent;
|
||||
import dan200.computercraft.shared.TurtlePermissions;
|
||||
import dan200.computercraft.shared.turtle.core.TurtlePlaceCommand;
|
||||
import dan200.computercraft.shared.turtle.core.TurtlePlayer;
|
||||
import dan200.computercraft.shared.util.InventoryUtil;
|
||||
@ -203,7 +204,7 @@ public class TurtleTool extends AbstractTurtleUpgrade
|
||||
return TurtleCommandResult.failure( "Cannot break protected block" );
|
||||
}
|
||||
|
||||
if( !ComputerCraft.isBlockEditable( world, blockPosition, turtlePlayer ) )
|
||||
if( !TurtlePermissions.isBlockEditable( world, blockPosition, turtlePlayer ) )
|
||||
{
|
||||
return TurtleCommandResult.failure( "Cannot break protected block" );
|
||||
}
|
||||
|
@ -1,15 +0,0 @@
|
||||
package dan200.computercraft.shared.util;
|
||||
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.api.peripheral.IPeripheral;
|
||||
import net.minecraft.util.EnumFacing;
|
||||
import net.minecraft.util.math.BlockPos;
|
||||
import net.minecraft.world.World;
|
||||
|
||||
public class PeripheralUtil
|
||||
{
|
||||
public static IPeripheral getPeripheral( World world, BlockPos pos, EnumFacing side )
|
||||
{
|
||||
return world.isValid( pos ) && !world.isRemote ? ComputerCraft.getPeripheralAt( world, pos, side ) : null;
|
||||
}
|
||||
}
|
@ -6,7 +6,7 @@
|
||||
|
||||
package dan200.computercraft.shared.util;
|
||||
|
||||
import dan200.computercraft.ComputerCraft;
|
||||
import dan200.computercraft.shared.BundledRedstone;
|
||||
import net.minecraft.block.state.IBlockState;
|
||||
import net.minecraft.init.Blocks;
|
||||
import net.minecraft.util.EnumFacing;
|
||||
@ -15,10 +15,10 @@ import net.minecraft.world.World;
|
||||
|
||||
public class RedstoneUtil
|
||||
{
|
||||
@Deprecated
|
||||
public static int getBundledRedstoneOutput( World world, BlockPos pos, EnumFacing side )
|
||||
{
|
||||
int signal = ComputerCraft.getBundledRedstoneOutput( world, pos, side );
|
||||
return signal >= 0 ? signal : 0;
|
||||
return BundledRedstone.getOutput( world, pos, side );
|
||||
}
|
||||
|
||||
public static void propagateRedstoneOutput( World world, BlockPos pos, EnumFacing side )
|
||||
|
Loading…
x
Reference in New Issue
Block a user