mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2024-12-14 12:10:30 +00:00
Store references to the registered items
This means we can avoid several rather ugly instances of getItemBlock and a cast. We also derive the ItemBlock's registered name from the block's name, which makes the register a little less ugly.
This commit is contained in:
parent
227d5e9e69
commit
e33f852baa
@ -37,15 +37,20 @@ import dan200.computercraft.shared.computer.core.ClientComputerRegistry;
|
|||||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||||
import dan200.computercraft.shared.computer.core.ServerComputer;
|
import dan200.computercraft.shared.computer.core.ServerComputer;
|
||||||
import dan200.computercraft.shared.computer.core.ServerComputerRegistry;
|
import dan200.computercraft.shared.computer.core.ServerComputerRegistry;
|
||||||
|
import dan200.computercraft.shared.computer.items.ItemCommandComputer;
|
||||||
|
import dan200.computercraft.shared.computer.items.ItemComputer;
|
||||||
import dan200.computercraft.shared.media.items.ItemDiskExpanded;
|
import dan200.computercraft.shared.media.items.ItemDiskExpanded;
|
||||||
import dan200.computercraft.shared.media.items.ItemDiskLegacy;
|
import dan200.computercraft.shared.media.items.ItemDiskLegacy;
|
||||||
import dan200.computercraft.shared.media.items.ItemPrintout;
|
import dan200.computercraft.shared.media.items.ItemPrintout;
|
||||||
import dan200.computercraft.shared.media.items.ItemTreasureDisk;
|
import dan200.computercraft.shared.media.items.ItemTreasureDisk;
|
||||||
import dan200.computercraft.shared.peripheral.common.BlockPeripheral;
|
import dan200.computercraft.shared.peripheral.common.BlockPeripheral;
|
||||||
|
import dan200.computercraft.shared.peripheral.common.ItemPeripheral;
|
||||||
import dan200.computercraft.shared.peripheral.diskdrive.TileDiskDrive;
|
import dan200.computercraft.shared.peripheral.diskdrive.TileDiskDrive;
|
||||||
import dan200.computercraft.shared.peripheral.modem.wired.BlockCable;
|
import dan200.computercraft.shared.peripheral.modem.wired.BlockCable;
|
||||||
import dan200.computercraft.shared.peripheral.modem.wired.BlockWiredModemFull;
|
import dan200.computercraft.shared.peripheral.modem.wired.BlockWiredModemFull;
|
||||||
|
import dan200.computercraft.shared.peripheral.modem.wired.ItemCable;
|
||||||
import dan200.computercraft.shared.peripheral.modem.wireless.BlockAdvancedModem;
|
import dan200.computercraft.shared.peripheral.modem.wireless.BlockAdvancedModem;
|
||||||
|
import dan200.computercraft.shared.peripheral.modem.wireless.ItemAdvancedModem;
|
||||||
import dan200.computercraft.shared.peripheral.modem.wireless.WirelessNetwork;
|
import dan200.computercraft.shared.peripheral.modem.wireless.WirelessNetwork;
|
||||||
import dan200.computercraft.shared.peripheral.printer.TilePrinter;
|
import dan200.computercraft.shared.peripheral.printer.TilePrinter;
|
||||||
import dan200.computercraft.shared.pocket.items.ItemPocketComputer;
|
import dan200.computercraft.shared.pocket.items.ItemPocketComputer;
|
||||||
@ -55,6 +60,9 @@ import dan200.computercraft.shared.proxy.ICCTurtleProxy;
|
|||||||
import dan200.computercraft.shared.proxy.IComputerCraftProxy;
|
import dan200.computercraft.shared.proxy.IComputerCraftProxy;
|
||||||
import dan200.computercraft.shared.turtle.blocks.BlockTurtle;
|
import dan200.computercraft.shared.turtle.blocks.BlockTurtle;
|
||||||
import dan200.computercraft.shared.turtle.blocks.TileTurtle;
|
import dan200.computercraft.shared.turtle.blocks.TileTurtle;
|
||||||
|
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.upgrades.*;
|
import dan200.computercraft.shared.turtle.upgrades.*;
|
||||||
import dan200.computercraft.shared.util.CreativeTabMain;
|
import dan200.computercraft.shared.util.CreativeTabMain;
|
||||||
import dan200.computercraft.shared.util.IDAssigner;
|
import dan200.computercraft.shared.util.IDAssigner;
|
||||||
@ -63,6 +71,7 @@ import dan200.computercraft.shared.wired.CapabilityWiredElement;
|
|||||||
import dan200.computercraft.shared.wired.WiredNode;
|
import dan200.computercraft.shared.wired.WiredNode;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.entity.player.EntityPlayerMP;
|
import net.minecraft.entity.player.EntityPlayerMP;
|
||||||
|
import net.minecraft.item.ItemBlock;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.server.MinecraftServer;
|
import net.minecraft.server.MinecraftServer;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
@ -187,6 +196,13 @@ public class ComputerCraft
|
|||||||
|
|
||||||
public static class Items
|
public static class Items
|
||||||
{
|
{
|
||||||
|
public static ItemComputer computer;
|
||||||
|
public static ItemCommandComputer commandComputer;
|
||||||
|
|
||||||
|
public static ItemTurtleLegacy turtle;
|
||||||
|
public static ItemTurtleNormal turtleExpanded;
|
||||||
|
public static ItemTurtleAdvanced turtleAdvanced;
|
||||||
|
|
||||||
public static ItemPocketComputer pocketComputer;
|
public static ItemPocketComputer pocketComputer;
|
||||||
|
|
||||||
public static ItemDiskLegacy disk;
|
public static ItemDiskLegacy disk;
|
||||||
@ -194,6 +210,11 @@ public class ComputerCraft
|
|||||||
public static ItemTreasureDisk treasureDisk;
|
public static ItemTreasureDisk treasureDisk;
|
||||||
|
|
||||||
public static ItemPrintout printout;
|
public static ItemPrintout printout;
|
||||||
|
|
||||||
|
public static ItemPeripheral peripheral;
|
||||||
|
public static ItemAdvancedModem advancedModem;
|
||||||
|
public static ItemCable cable;
|
||||||
|
public static ItemBlock wiredModemFull;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class TurtleUpgrades
|
public static class TurtleUpgrades
|
||||||
|
@ -7,7 +7,6 @@
|
|||||||
package dan200.computercraft.client;
|
package dan200.computercraft.client;
|
||||||
|
|
||||||
import dan200.computercraft.ComputerCraft;
|
import dan200.computercraft.ComputerCraft;
|
||||||
import net.minecraft.block.Block;
|
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
import net.minecraft.client.renderer.ItemMeshDefinition;
|
import net.minecraft.client.renderer.ItemMeshDefinition;
|
||||||
import net.minecraft.client.renderer.block.model.IBakedModel;
|
import net.minecraft.client.renderer.block.model.IBakedModel;
|
||||||
@ -55,22 +54,22 @@ public class ClientRegistry
|
|||||||
public static void registerModels( ModelRegistryEvent event )
|
public static void registerModels( ModelRegistryEvent event )
|
||||||
{
|
{
|
||||||
// Register item models
|
// Register item models
|
||||||
registerUniversalItemModel( ComputerCraft.Blocks.computer, "computer" );
|
registerUniversalItemModel( ComputerCraft.Items.computer, "computer" );
|
||||||
registerItemModel( ComputerCraft.Blocks.commandComputer, 0, "command_computer" );
|
registerItemModel( ComputerCraft.Items.commandComputer, 0, "command_computer" );
|
||||||
|
|
||||||
registerItemModel( ComputerCraft.Items.pocketComputer, 0, "pocket_computer" );
|
registerItemModel( ComputerCraft.Items.pocketComputer, 0, "pocket_computer" );
|
||||||
registerItemModel( ComputerCraft.Items.pocketComputer, 1, "advanced_pocket_computer" );
|
registerItemModel( ComputerCraft.Items.pocketComputer, 1, "advanced_pocket_computer" );
|
||||||
|
|
||||||
registerItemModel( ComputerCraft.Blocks.peripheral, 0, "peripheral" );
|
registerItemModel( ComputerCraft.Items.peripheral, 0, "peripheral" );
|
||||||
registerItemModel( ComputerCraft.Blocks.peripheral, 1, "wireless_modem" );
|
registerItemModel( ComputerCraft.Items.peripheral, 1, "wireless_modem" );
|
||||||
registerItemModel( ComputerCraft.Blocks.peripheral, 2, "monitor" );
|
registerItemModel( ComputerCraft.Items.peripheral, 2, "monitor" );
|
||||||
registerItemModel( ComputerCraft.Blocks.peripheral, 3, "printer" );
|
registerItemModel( ComputerCraft.Items.peripheral, 3, "printer" );
|
||||||
registerItemModel( ComputerCraft.Blocks.peripheral, 4, "advanced_monitor" );
|
registerItemModel( ComputerCraft.Items.peripheral, 4, "advanced_monitor" );
|
||||||
registerItemModel( ComputerCraft.Blocks.cable, 0, "cable" );
|
registerItemModel( ComputerCraft.Items.cable, 0, "cable" );
|
||||||
registerItemModel( ComputerCraft.Blocks.cable, 1, "wired_modem" );
|
registerItemModel( ComputerCraft.Items.cable, 1, "wired_modem" );
|
||||||
registerItemModel( ComputerCraft.Blocks.advancedModem, 0, "advanced_modem" );
|
registerItemModel( ComputerCraft.Items.advancedModem, 0, "advanced_modem" );
|
||||||
registerItemModel( ComputerCraft.Blocks.peripheral, 5, "speaker" );
|
registerItemModel( ComputerCraft.Items.peripheral, 5, "speaker" );
|
||||||
registerItemModel( ComputerCraft.Blocks.wiredModemFull, 0, "wired_modem_full" );
|
registerItemModel( ComputerCraft.Items.wiredModemFull, 0, "wired_modem_full" );
|
||||||
|
|
||||||
registerUniversalItemModel( ComputerCraft.Items.disk, "disk" );
|
registerUniversalItemModel( ComputerCraft.Items.disk, "disk" );
|
||||||
registerItemModel( ComputerCraft.Items.diskExpanded, 0, "disk_expanded" );
|
registerItemModel( ComputerCraft.Items.diskExpanded, 0, "disk_expanded" );
|
||||||
@ -80,26 +79,10 @@ public class ClientRegistry
|
|||||||
registerItemModel( ComputerCraft.Items.printout, 1, "pages" );
|
registerItemModel( ComputerCraft.Items.printout, 1, "pages" );
|
||||||
registerItemModel( ComputerCraft.Items.printout, 2, "book" );
|
registerItemModel( ComputerCraft.Items.printout, 2, "book" );
|
||||||
|
|
||||||
ItemMeshDefinition turtleMeshDefinition = new ItemMeshDefinition()
|
String[] extraTurtleModels = new String[] { "turtle", "turtle_advanced", "turtle_white", "turtle_elf_overlay" };
|
||||||
{
|
registerUniversalItemModel( ComputerCraft.Items.turtle, "turtle_dynamic", extraTurtleModels );
|
||||||
private ModelResourceLocation turtle_dynamic = new ModelResourceLocation( "computercraft:turtle_dynamic", "inventory" );
|
registerUniversalItemModel( ComputerCraft.Items.turtleExpanded, "turtle_dynamic", extraTurtleModels );
|
||||||
|
registerUniversalItemModel( ComputerCraft.Items.turtleAdvanced, "turtle_dynamic", extraTurtleModels );
|
||||||
@Nonnull
|
|
||||||
@Override
|
|
||||||
public ModelResourceLocation getModelLocation( @Nonnull ItemStack stack )
|
|
||||||
{
|
|
||||||
return turtle_dynamic;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
String[] turtleModelNames = new String[] {
|
|
||||||
"turtle_dynamic",
|
|
||||||
"turtle", "turtle_advanced", "turtle_white",
|
|
||||||
"turtle_elf_overlay"
|
|
||||||
};
|
|
||||||
|
|
||||||
registerUniversalItemModel( ComputerCraft.Blocks.turtle, turtleMeshDefinition, turtleModelNames );
|
|
||||||
registerUniversalItemModel( ComputerCraft.Blocks.turtleExpanded, turtleMeshDefinition, turtleModelNames );
|
|
||||||
registerUniversalItemModel( ComputerCraft.Blocks.turtleAdvanced, turtleMeshDefinition, turtleModelNames );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@SubscribeEvent
|
@SubscribeEvent
|
||||||
@ -127,11 +110,6 @@ public class ClientRegistry
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void registerItemModel( Block block, int damage, String name )
|
|
||||||
{
|
|
||||||
registerItemModel( Item.getItemFromBlock( block ), damage, name );
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void registerItemModel( Item item, int damage, String name )
|
private static void registerItemModel( Item item, int damage, String name )
|
||||||
{
|
{
|
||||||
ResourceLocation location = new ResourceLocation( ComputerCraft.MOD_ID, name );
|
ResourceLocation location = new ResourceLocation( ComputerCraft.MOD_ID, name );
|
||||||
@ -140,39 +118,27 @@ public class ClientRegistry
|
|||||||
ModelLoader.setCustomModelResourceLocation( item, damage, res );
|
ModelLoader.setCustomModelResourceLocation( item, damage, res );
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void registerUniversalItemModel( Block block, ItemMeshDefinition definition, String[] names )
|
private static void registerUniversalItemModel( Item item, String mainModel, String... extraModels )
|
||||||
{
|
{
|
||||||
registerUniversalItemModel( Item.getItemFromBlock( block ), definition, names );
|
ResourceLocation mainLocation = new ResourceLocation( ComputerCraft.MOD_ID, mainModel );
|
||||||
}
|
|
||||||
|
|
||||||
private static void registerUniversalItemModel( Item item, ItemMeshDefinition definition, String[] names )
|
ResourceLocation[] modelLocations = new ResourceLocation[extraModels.length + 1];
|
||||||
{
|
modelLocations[0] = mainLocation;
|
||||||
ResourceLocation[] resources = new ResourceLocation[names.length];
|
for( int i = 0; i < extraModels.length; i++ )
|
||||||
for( int i = 0; i < names.length; i++ )
|
|
||||||
{
|
{
|
||||||
resources[i] = new ResourceLocation( ComputerCraft.MOD_ID, names[i] );
|
modelLocations[i + 1] = new ResourceLocation( ComputerCraft.MOD_ID, extraModels[i] );
|
||||||
}
|
}
|
||||||
ModelBakery.registerItemVariants( item, resources );
|
|
||||||
ModelLoader.setCustomMeshDefinition( item, definition );
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void registerUniversalItemModel( Block block, String name )
|
ModelBakery.registerItemVariants( item, modelLocations );
|
||||||
{
|
|
||||||
registerUniversalItemModel( Item.getItemFromBlock( block ), name );
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void registerUniversalItemModel( Item item, String name )
|
final ModelResourceLocation mainModelLocation = new ModelResourceLocation( mainLocation, "inventory" );
|
||||||
{
|
|
||||||
ResourceLocation location = new ResourceLocation( ComputerCraft.MOD_ID, name );
|
|
||||||
final ModelResourceLocation res = new ModelResourceLocation( location, "inventory" );
|
|
||||||
ModelBakery.registerItemVariants( item, location );
|
|
||||||
ModelLoader.setCustomMeshDefinition( item, new ItemMeshDefinition()
|
ModelLoader.setCustomMeshDefinition( item, new ItemMeshDefinition()
|
||||||
{
|
{
|
||||||
@Nonnull
|
@Nonnull
|
||||||
@Override
|
@Override
|
||||||
public ModelResourceLocation getModelLocation( @Nonnull ItemStack stack )
|
public ModelResourceLocation getModelLocation( @Nonnull ItemStack stack )
|
||||||
{
|
{
|
||||||
return res;
|
return mainModelLocation;
|
||||||
}
|
}
|
||||||
} );
|
} );
|
||||||
}
|
}
|
||||||
|
@ -51,6 +51,7 @@ import dan200.computercraft.shared.util.ImpostorShapelessRecipe;
|
|||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.init.Items;
|
import net.minecraft.init.Items;
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
|
import net.minecraft.item.ItemBlock;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.item.crafting.IRecipe;
|
import net.minecraft.item.crafting.IRecipe;
|
||||||
import net.minecraft.item.crafting.Ingredient;
|
import net.minecraft.item.crafting.Ingredient;
|
||||||
@ -74,9 +75,25 @@ public final class Registry
|
|||||||
{
|
{
|
||||||
IForgeRegistry<Block> registry = event.getRegistry();
|
IForgeRegistry<Block> registry = event.getRegistry();
|
||||||
|
|
||||||
// Computer
|
// Computers
|
||||||
ComputerCraft.Blocks.computer = new BlockComputer();
|
ComputerCraft.Blocks.computer = new BlockComputer();
|
||||||
registry.register( ComputerCraft.Blocks.computer.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "computer" ) ) );
|
ComputerCraft.Blocks.commandComputer = new BlockCommandComputer();
|
||||||
|
|
||||||
|
registry.registerAll(
|
||||||
|
ComputerCraft.Blocks.computer.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "computer" ) ),
|
||||||
|
ComputerCraft.Blocks.commandComputer.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "command_computer" ) )
|
||||||
|
);
|
||||||
|
|
||||||
|
// Turtle
|
||||||
|
ComputerCraft.Blocks.turtle = new BlockTurtle();
|
||||||
|
ComputerCraft.Blocks.turtleExpanded = new BlockTurtle();
|
||||||
|
ComputerCraft.Blocks.turtleAdvanced = new BlockTurtle();
|
||||||
|
|
||||||
|
registry.registerAll(
|
||||||
|
ComputerCraft.Blocks.turtle.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "turtle" ) ),
|
||||||
|
ComputerCraft.Blocks.turtleExpanded.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "turtle_expanded" ) ),
|
||||||
|
ComputerCraft.Blocks.turtleAdvanced.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "turtle_advanced" ) )
|
||||||
|
);
|
||||||
|
|
||||||
// Peripheral
|
// Peripheral
|
||||||
ComputerCraft.Blocks.peripheral = new BlockPeripheral();
|
ComputerCraft.Blocks.peripheral = new BlockPeripheral();
|
||||||
@ -86,11 +103,7 @@ public final class Registry
|
|||||||
ComputerCraft.Blocks.cable = new BlockCable();
|
ComputerCraft.Blocks.cable = new BlockCable();
|
||||||
registry.register( ComputerCraft.Blocks.cable.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "cable" ) ) );
|
registry.register( ComputerCraft.Blocks.cable.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "cable" ) ) );
|
||||||
|
|
||||||
// Command Computer
|
// Advanced modem
|
||||||
ComputerCraft.Blocks.commandComputer = new BlockCommandComputer();
|
|
||||||
registry.register( ComputerCraft.Blocks.commandComputer.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "command_computer" ) ) );
|
|
||||||
|
|
||||||
// Command Computer
|
|
||||||
ComputerCraft.Blocks.advancedModem = new BlockAdvancedModem();
|
ComputerCraft.Blocks.advancedModem = new BlockAdvancedModem();
|
||||||
registry.register( ComputerCraft.Blocks.advancedModem.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "advanced_modem" ) ) );
|
registry.register( ComputerCraft.Blocks.advancedModem.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "advanced_modem" ) ) );
|
||||||
|
|
||||||
@ -98,17 +111,6 @@ public final class Registry
|
|||||||
ComputerCraft.Blocks.wiredModemFull = new BlockWiredModemFull();
|
ComputerCraft.Blocks.wiredModemFull = new BlockWiredModemFull();
|
||||||
registry.register( ComputerCraft.Blocks.wiredModemFull.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "wired_modem_full" ) ) );
|
registry.register( ComputerCraft.Blocks.wiredModemFull.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "wired_modem_full" ) ) );
|
||||||
|
|
||||||
// Turtle
|
|
||||||
ComputerCraft.Blocks.turtle = BlockTurtle.createTurtleBlock();
|
|
||||||
registry.register( ComputerCraft.Blocks.turtle.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "turtle" ) ) );
|
|
||||||
|
|
||||||
ComputerCraft.Blocks.turtleExpanded = BlockTurtle.createTurtleBlock();
|
|
||||||
registry.register( ComputerCraft.Blocks.turtleExpanded.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "turtle_expanded" ) ) );
|
|
||||||
|
|
||||||
// Advanced Turtle
|
|
||||||
ComputerCraft.Blocks.turtleAdvanced = BlockTurtle.createTurtleBlock();
|
|
||||||
registry.register( ComputerCraft.Blocks.turtleAdvanced.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "turtle_advanced" ) ) );
|
|
||||||
|
|
||||||
registerTileEntities();
|
registerTileEntities();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -131,52 +133,70 @@ public final class Registry
|
|||||||
GameRegistry.registerTileEntity( TileWiredModemFull.class, new ResourceLocation( ComputerCraft.MOD_ID, "wired_modem_full" ) );
|
GameRegistry.registerTileEntity( TileWiredModemFull.class, new ResourceLocation( ComputerCraft.MOD_ID, "wired_modem_full" ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static <T extends ItemBlock> T setupItemBlock( T item )
|
||||||
|
{
|
||||||
|
item.setRegistryName( item.getBlock().getRegistryName() );
|
||||||
|
return item;
|
||||||
|
}
|
||||||
|
|
||||||
@SubscribeEvent
|
@SubscribeEvent
|
||||||
public static void registerItems( RegistryEvent.Register<Item> event )
|
public static void registerItems( RegistryEvent.Register<Item> event )
|
||||||
{
|
{
|
||||||
IForgeRegistry<Item> registry = event.getRegistry();
|
IForgeRegistry<Item> registry = event.getRegistry();
|
||||||
|
|
||||||
registry.register( new ItemTurtleLegacy( ComputerCraft.Blocks.turtle ).setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "turtle" ) ) );
|
// Computers
|
||||||
registry.register( new ItemTurtleNormal( ComputerCraft.Blocks.turtleExpanded ).setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "turtle_expanded" ) ) );
|
ComputerCraft.Items.computer = new ItemComputer( ComputerCraft.Blocks.computer );
|
||||||
registry.register( new ItemTurtleAdvanced( ComputerCraft.Blocks.turtleAdvanced ).setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "turtle_advanced" ) ) );
|
ComputerCraft.Items.commandComputer = new ItemCommandComputer( ComputerCraft.Blocks.commandComputer );
|
||||||
|
|
||||||
// Computer
|
registry.registerAll(
|
||||||
registry.register( new ItemComputer( ComputerCraft.Blocks.computer ).setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "computer" ) ) );
|
setupItemBlock( ComputerCraft.Items.computer ),
|
||||||
|
setupItemBlock( ComputerCraft.Items.commandComputer )
|
||||||
// Peripheral
|
);
|
||||||
registry.register( new ItemPeripheral( ComputerCraft.Blocks.peripheral ).setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "peripheral" ) ) );
|
|
||||||
|
|
||||||
// Cable
|
|
||||||
registry.register( new ItemCable( ComputerCraft.Blocks.cable ).setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "cable" ) ) );
|
|
||||||
|
|
||||||
// Command Computer
|
|
||||||
registry.register( new ItemCommandComputer( ComputerCraft.Blocks.commandComputer ).setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "command_computer" ) ) );
|
|
||||||
|
|
||||||
// Advanced modem
|
|
||||||
registry.register( new ItemAdvancedModem( ComputerCraft.Blocks.advancedModem ).setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "advanced_modem" ) ) );
|
|
||||||
|
|
||||||
// Full block modem
|
|
||||||
registry.register( new ItemWiredModemFull( ComputerCraft.Blocks.wiredModemFull ).setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "wired_modem_full" ) ) );
|
|
||||||
|
|
||||||
// Items
|
|
||||||
// Floppy Disk
|
|
||||||
ComputerCraft.Items.disk = new ItemDiskLegacy();
|
|
||||||
registry.register( ComputerCraft.Items.disk.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "disk" ) ) );
|
|
||||||
|
|
||||||
ComputerCraft.Items.diskExpanded = new ItemDiskExpanded();
|
|
||||||
registry.register( ComputerCraft.Items.diskExpanded.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "disk_expanded" ) ) );
|
|
||||||
|
|
||||||
// Treasure Disk
|
|
||||||
ComputerCraft.Items.treasureDisk = new ItemTreasureDisk();
|
|
||||||
registry.register( ComputerCraft.Items.treasureDisk.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "treasure_disk" ) ) );
|
|
||||||
|
|
||||||
// Printout
|
|
||||||
ComputerCraft.Items.printout = new ItemPrintout();
|
|
||||||
registry.register( ComputerCraft.Items.printout.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "printout" ) ) );
|
|
||||||
|
|
||||||
// Pocket computer
|
// Pocket computer
|
||||||
ComputerCraft.Items.pocketComputer = new ItemPocketComputer();
|
ComputerCraft.Items.pocketComputer = new ItemPocketComputer();
|
||||||
registry.register( ComputerCraft.Items.pocketComputer.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "pocket_computer" ) ) );
|
registry.register(
|
||||||
|
ComputerCraft.Items.pocketComputer.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "pocket_computer" ) )
|
||||||
|
);
|
||||||
|
|
||||||
|
// Turtle
|
||||||
|
ComputerCraft.Items.turtle = new ItemTurtleLegacy( ComputerCraft.Blocks.turtle );
|
||||||
|
ComputerCraft.Items.turtleExpanded = new ItemTurtleNormal( ComputerCraft.Blocks.turtleExpanded );
|
||||||
|
ComputerCraft.Items.turtleAdvanced = new ItemTurtleAdvanced( ComputerCraft.Blocks.turtleAdvanced );
|
||||||
|
|
||||||
|
registry.registerAll(
|
||||||
|
setupItemBlock( ComputerCraft.Items.turtle ),
|
||||||
|
setupItemBlock( ComputerCraft.Items.turtleExpanded ),
|
||||||
|
setupItemBlock( ComputerCraft.Items.turtleAdvanced )
|
||||||
|
);
|
||||||
|
|
||||||
|
// Printouts
|
||||||
|
ComputerCraft.Items.printout = new ItemPrintout();
|
||||||
|
registry.register( ComputerCraft.Items.printout.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "printout" ) ) );
|
||||||
|
|
||||||
|
// Disks
|
||||||
|
ComputerCraft.Items.disk = new ItemDiskLegacy();
|
||||||
|
ComputerCraft.Items.diskExpanded = new ItemDiskExpanded();
|
||||||
|
ComputerCraft.Items.treasureDisk = new ItemTreasureDisk();
|
||||||
|
|
||||||
|
registry.registerAll(
|
||||||
|
ComputerCraft.Items.disk.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "disk" ) ),
|
||||||
|
ComputerCraft.Items.diskExpanded.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "disk_expanded" ) ),
|
||||||
|
ComputerCraft.Items.treasureDisk.setRegistryName( new ResourceLocation( ComputerCraft.MOD_ID, "treasure_disk" ) )
|
||||||
|
);
|
||||||
|
|
||||||
|
// Peripherals
|
||||||
|
ComputerCraft.Items.peripheral = new ItemPeripheral( ComputerCraft.Blocks.peripheral );
|
||||||
|
ComputerCraft.Items.advancedModem = new ItemAdvancedModem( ComputerCraft.Blocks.advancedModem );
|
||||||
|
ComputerCraft.Items.cable = new ItemCable( ComputerCraft.Blocks.cable );
|
||||||
|
ComputerCraft.Items.wiredModemFull = new ItemWiredModemFull( ComputerCraft.Blocks.wiredModemFull );
|
||||||
|
|
||||||
|
registry.registerAll(
|
||||||
|
setupItemBlock( ComputerCraft.Items.peripheral ),
|
||||||
|
setupItemBlock( ComputerCraft.Items.advancedModem ),
|
||||||
|
setupItemBlock( ComputerCraft.Items.cable ),
|
||||||
|
setupItemBlock( ComputerCraft.Items.wiredModemFull )
|
||||||
|
);
|
||||||
|
|
||||||
registerTurtleUpgrades();
|
registerTurtleUpgrades();
|
||||||
registerPocketUpgrades();
|
registerPocketUpgrades();
|
||||||
@ -192,14 +212,14 @@ public final class Registry
|
|||||||
|
|
||||||
// Turtle upgrades
|
// Turtle upgrades
|
||||||
// TODO: Figure out a way to do this in a "nice" way.
|
// TODO: Figure out a way to do this in a "nice" way.
|
||||||
for( ITurtleUpgrade upgrade : dan200.computercraft.shared.TurtleUpgrades.getVanillaUpgrades() )
|
for( ITurtleUpgrade upgrade : TurtleUpgrades.getVanillaUpgrades() )
|
||||||
{
|
{
|
||||||
ItemStack craftingItem = upgrade.getCraftingItem();
|
ItemStack craftingItem = upgrade.getCraftingItem();
|
||||||
|
|
||||||
// A turtle just containing this upgrade
|
// A turtle just containing this upgrade
|
||||||
for( ComputerFamily family : ComputerFamily.values() )
|
for( ComputerFamily family : ComputerFamily.values() )
|
||||||
{
|
{
|
||||||
if( !dan200.computercraft.shared.TurtleUpgrades.suitableForFamily( family, upgrade ) ) continue;
|
if( !TurtleUpgrades.suitableForFamily( family, upgrade ) ) continue;
|
||||||
|
|
||||||
ItemStack baseTurtle = TurtleItemFactory.create( -1, null, -1, family, null, null, 0, null );
|
ItemStack baseTurtle = TurtleItemFactory.create( -1, null, -1, family, null, null, 0, null );
|
||||||
if( !baseTurtle.isEmpty() )
|
if( !baseTurtle.isEmpty() )
|
||||||
@ -277,31 +297,31 @@ public final class Registry
|
|||||||
{
|
{
|
||||||
// Upgrades
|
// Upgrades
|
||||||
ComputerCraft.TurtleUpgrades.wirelessModem = new TurtleModem( false, new ResourceLocation( "computercraft", "wireless_modem" ), 1 );
|
ComputerCraft.TurtleUpgrades.wirelessModem = new TurtleModem( false, new ResourceLocation( "computercraft", "wireless_modem" ), 1 );
|
||||||
dan200.computercraft.shared.TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.wirelessModem );
|
TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.wirelessModem );
|
||||||
|
|
||||||
ComputerCraft.TurtleUpgrades.craftingTable = new TurtleCraftingTable( 2 );
|
ComputerCraft.TurtleUpgrades.craftingTable = new TurtleCraftingTable( 2 );
|
||||||
dan200.computercraft.shared.TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.craftingTable );
|
TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.craftingTable );
|
||||||
|
|
||||||
ComputerCraft.TurtleUpgrades.diamondSword = new TurtleSword( new ResourceLocation( "minecraft", "diamond_sword" ), 3, "upgrade.minecraft:diamond_sword.adjective", Items.DIAMOND_SWORD );
|
ComputerCraft.TurtleUpgrades.diamondSword = new TurtleSword( new ResourceLocation( "minecraft", "diamond_sword" ), 3, "upgrade.minecraft:diamond_sword.adjective", Items.DIAMOND_SWORD );
|
||||||
dan200.computercraft.shared.TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.diamondSword );
|
TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.diamondSword );
|
||||||
|
|
||||||
ComputerCraft.TurtleUpgrades.diamondShovel = new TurtleShovel( new ResourceLocation( "minecraft", "diamond_shovel" ), 4, "upgrade.minecraft:diamond_shovel.adjective", Items.DIAMOND_SHOVEL );
|
ComputerCraft.TurtleUpgrades.diamondShovel = new TurtleShovel( new ResourceLocation( "minecraft", "diamond_shovel" ), 4, "upgrade.minecraft:diamond_shovel.adjective", Items.DIAMOND_SHOVEL );
|
||||||
dan200.computercraft.shared.TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.diamondShovel );
|
TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.diamondShovel );
|
||||||
|
|
||||||
ComputerCraft.TurtleUpgrades.diamondPickaxe = new TurtleTool( new ResourceLocation( "minecraft", "diamond_pickaxe" ), 5, "upgrade.minecraft:diamond_pickaxe.adjective", Items.DIAMOND_PICKAXE );
|
ComputerCraft.TurtleUpgrades.diamondPickaxe = new TurtleTool( new ResourceLocation( "minecraft", "diamond_pickaxe" ), 5, "upgrade.minecraft:diamond_pickaxe.adjective", Items.DIAMOND_PICKAXE );
|
||||||
dan200.computercraft.shared.TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.diamondPickaxe );
|
TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.diamondPickaxe );
|
||||||
|
|
||||||
ComputerCraft.TurtleUpgrades.diamondAxe = new TurtleAxe( new ResourceLocation( "minecraft", "diamond_axe" ), 6, "upgrade.minecraft:diamond_axe.adjective", Items.DIAMOND_AXE );
|
ComputerCraft.TurtleUpgrades.diamondAxe = new TurtleAxe( new ResourceLocation( "minecraft", "diamond_axe" ), 6, "upgrade.minecraft:diamond_axe.adjective", Items.DIAMOND_AXE );
|
||||||
dan200.computercraft.shared.TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.diamondAxe );
|
TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.diamondAxe );
|
||||||
|
|
||||||
ComputerCraft.TurtleUpgrades.diamondHoe = new TurtleHoe( new ResourceLocation( "minecraft", "diamond_hoe" ), 7, "upgrade.minecraft:diamond_hoe.adjective", Items.DIAMOND_HOE );
|
ComputerCraft.TurtleUpgrades.diamondHoe = new TurtleHoe( new ResourceLocation( "minecraft", "diamond_hoe" ), 7, "upgrade.minecraft:diamond_hoe.adjective", Items.DIAMOND_HOE );
|
||||||
dan200.computercraft.shared.TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.diamondHoe );
|
TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.diamondHoe );
|
||||||
|
|
||||||
ComputerCraft.TurtleUpgrades.advancedModem = new TurtleModem( true, new ResourceLocation( "computercraft", "advanced_modem" ), -1 );
|
ComputerCraft.TurtleUpgrades.advancedModem = new TurtleModem( true, new ResourceLocation( "computercraft", "advanced_modem" ), -1 );
|
||||||
dan200.computercraft.shared.TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.advancedModem );
|
TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.advancedModem );
|
||||||
|
|
||||||
ComputerCraft.TurtleUpgrades.speaker = new TurtleSpeaker( new ResourceLocation( "computercraft", "speaker" ), 8 );
|
ComputerCraft.TurtleUpgrades.speaker = new TurtleSpeaker( new ResourceLocation( "computercraft", "speaker" ), 8 );
|
||||||
dan200.computercraft.shared.TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.speaker );
|
TurtleUpgrades.registerInternal( ComputerCraft.TurtleUpgrades.speaker );
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void registerPocketUpgrades()
|
public static void registerPocketUpgrades()
|
||||||
@ -328,15 +348,15 @@ public final class Registry
|
|||||||
String key = mapping.key.getPath();
|
String key = mapping.key.getPath();
|
||||||
if( key.equalsIgnoreCase( "CC-Computer" ) )
|
if( key.equalsIgnoreCase( "CC-Computer" ) )
|
||||||
{
|
{
|
||||||
mapping.remap( Item.getItemFromBlock( ComputerCraft.Blocks.computer ) );
|
mapping.remap( ComputerCraft.Items.computer );
|
||||||
}
|
}
|
||||||
else if( key.equalsIgnoreCase( "CC-Peripheral" ) )
|
else if( key.equalsIgnoreCase( "CC-Peripheral" ) )
|
||||||
{
|
{
|
||||||
mapping.remap( Item.getItemFromBlock( ComputerCraft.Blocks.peripheral ) );
|
mapping.remap( ComputerCraft.Items.peripheral );
|
||||||
}
|
}
|
||||||
else if( key.equalsIgnoreCase( "CC-Cable" ) )
|
else if( key.equalsIgnoreCase( "CC-Cable" ) )
|
||||||
{
|
{
|
||||||
mapping.remap( Item.getItemFromBlock( ComputerCraft.Blocks.cable ) );
|
mapping.remap( ComputerCraft.Items.cable );
|
||||||
}
|
}
|
||||||
else if( key.equalsIgnoreCase( "diskExpanded" ) )
|
else if( key.equalsIgnoreCase( "diskExpanded" ) )
|
||||||
{
|
{
|
||||||
@ -352,15 +372,15 @@ public final class Registry
|
|||||||
}
|
}
|
||||||
else if( key.equalsIgnoreCase( "CC-Turtle" ) )
|
else if( key.equalsIgnoreCase( "CC-Turtle" ) )
|
||||||
{
|
{
|
||||||
mapping.remap( Item.getItemFromBlock( ComputerCraft.Blocks.turtle ) );
|
mapping.remap( ComputerCraft.Items.turtle );
|
||||||
}
|
}
|
||||||
else if( key.equalsIgnoreCase( "CC-TurtleExpanded" ) )
|
else if( key.equalsIgnoreCase( "CC-TurtleExpanded" ) )
|
||||||
{
|
{
|
||||||
mapping.remap( Item.getItemFromBlock( ComputerCraft.Blocks.turtleExpanded ) );
|
mapping.remap( ComputerCraft.Items.turtleExpanded );
|
||||||
}
|
}
|
||||||
else if( key.equalsIgnoreCase( "CC-TurtleAdvanced" ) )
|
else if( key.equalsIgnoreCase( "CC-TurtleAdvanced" ) )
|
||||||
{
|
{
|
||||||
mapping.remap( Item.getItemFromBlock( ComputerCraft.Blocks.turtleAdvanced ) );
|
mapping.remap( ComputerCraft.Items.turtleAdvanced );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,6 @@ package dan200.computercraft.shared.computer.blocks;
|
|||||||
import dan200.computercraft.ComputerCraft;
|
import dan200.computercraft.ComputerCraft;
|
||||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||||
import dan200.computercraft.shared.computer.items.ComputerItemFactory;
|
import dan200.computercraft.shared.computer.items.ComputerItemFactory;
|
||||||
import dan200.computercraft.shared.computer.items.ItemComputer;
|
|
||||||
import dan200.computercraft.shared.util.DirectionUtil;
|
import dan200.computercraft.shared.util.DirectionUtil;
|
||||||
import net.minecraft.block.material.Material;
|
import net.minecraft.block.material.Material;
|
||||||
import net.minecraft.block.properties.PropertyBool;
|
import net.minecraft.block.properties.PropertyBool;
|
||||||
@ -19,7 +18,6 @@ import net.minecraft.block.state.BlockStateContainer;
|
|||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.entity.EntityLivingBase;
|
import net.minecraft.entity.EntityLivingBase;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.Item;
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
@ -131,7 +129,7 @@ public class BlockComputer extends BlockComputerBase
|
|||||||
@Override
|
@Override
|
||||||
public ComputerFamily getFamily( int damage )
|
public ComputerFamily getFamily( int damage )
|
||||||
{
|
{
|
||||||
return ((ItemComputer) Item.getItemFromBlock( this )).getFamily( damage );
|
return ComputerCraft.Items.computer.getFamily( damage );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -9,7 +9,6 @@ package dan200.computercraft.shared.computer.items;
|
|||||||
import dan200.computercraft.ComputerCraft;
|
import dan200.computercraft.ComputerCraft;
|
||||||
import dan200.computercraft.shared.computer.blocks.TileComputer;
|
import dan200.computercraft.shared.computer.blocks.TileComputer;
|
||||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||||
import net.minecraft.item.Item;
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
@ -31,15 +30,9 @@ public class ComputerItemFactory
|
|||||||
{
|
{
|
||||||
case Normal:
|
case Normal:
|
||||||
case Advanced:
|
case Advanced:
|
||||||
{
|
return ComputerCraft.Items.computer.create( id, label, family );
|
||||||
ItemComputer computer = ((ItemComputer) Item.getItemFromBlock( ComputerCraft.Blocks.computer ));
|
|
||||||
return computer.create( id, label, family );
|
|
||||||
}
|
|
||||||
case Command:
|
case Command:
|
||||||
{
|
return ComputerCraft.Items.commandComputer.create( id, label, family );
|
||||||
ItemCommandComputer commandComputer = ((ItemCommandComputer) Item.getItemFromBlock( ComputerCraft.Blocks.commandComputer ));
|
|
||||||
return commandComputer.create( id, label, family );
|
|
||||||
}
|
|
||||||
default:
|
default:
|
||||||
return ItemStack.EMPTY;
|
return ItemStack.EMPTY;
|
||||||
}
|
}
|
||||||
|
@ -22,9 +22,9 @@ public class JEIComputerCraft implements IModPlugin
|
|||||||
@Override
|
@Override
|
||||||
public void registerItemSubtypes( ISubtypeRegistry subtypeRegistry )
|
public void registerItemSubtypes( ISubtypeRegistry subtypeRegistry )
|
||||||
{
|
{
|
||||||
subtypeRegistry.registerSubtypeInterpreter( Item.getItemFromBlock( ComputerCraft.Blocks.turtle ), turtleSubtype );
|
subtypeRegistry.registerSubtypeInterpreter( ComputerCraft.Items.turtle, turtleSubtype );
|
||||||
subtypeRegistry.registerSubtypeInterpreter( Item.getItemFromBlock( ComputerCraft.Blocks.turtleExpanded ), turtleSubtype );
|
subtypeRegistry.registerSubtypeInterpreter( ComputerCraft.Items.turtleExpanded, turtleSubtype );
|
||||||
subtypeRegistry.registerSubtypeInterpreter( Item.getItemFromBlock( ComputerCraft.Blocks.turtleAdvanced ), turtleSubtype );
|
subtypeRegistry.registerSubtypeInterpreter( ComputerCraft.Items.turtleAdvanced, turtleSubtype );
|
||||||
|
|
||||||
subtypeRegistry.registerSubtypeInterpreter( ComputerCraft.Items.pocketComputer, pocketSubtype );
|
subtypeRegistry.registerSubtypeInterpreter( ComputerCraft.Items.pocketComputer, pocketSubtype );
|
||||||
|
|
||||||
|
@ -21,7 +21,6 @@ import net.minecraft.block.state.BlockFaceShape;
|
|||||||
import net.minecraft.block.state.BlockStateContainer;
|
import net.minecraft.block.state.BlockStateContainer;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.entity.EntityLivingBase;
|
import net.minecraft.entity.EntityLivingBase;
|
||||||
import net.minecraft.item.Item;
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.BlockRenderLayer;
|
import net.minecraft.util.BlockRenderLayer;
|
||||||
@ -519,7 +518,7 @@ public class BlockPeripheral extends BlockPeripheralBase
|
|||||||
@Override
|
@Override
|
||||||
public PeripheralType getPeripheralType( int damage )
|
public PeripheralType getPeripheralType( int damage )
|
||||||
{
|
{
|
||||||
return ((ItemPeripheral) Item.getItemFromBlock( this )).getPeripheralType( damage );
|
return ComputerCraft.Items.peripheral.getPeripheralType( damage );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -8,9 +8,6 @@ package dan200.computercraft.shared.peripheral.common;
|
|||||||
|
|
||||||
import dan200.computercraft.ComputerCraft;
|
import dan200.computercraft.ComputerCraft;
|
||||||
import dan200.computercraft.shared.peripheral.PeripheralType;
|
import dan200.computercraft.shared.peripheral.PeripheralType;
|
||||||
import dan200.computercraft.shared.peripheral.modem.wired.ItemCable;
|
|
||||||
import dan200.computercraft.shared.peripheral.modem.wireless.ItemAdvancedModem;
|
|
||||||
import net.minecraft.item.Item;
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
@ -26,9 +23,6 @@ public class PeripheralItemFactory
|
|||||||
@Nonnull
|
@Nonnull
|
||||||
public static ItemStack create( PeripheralType type, String label, int quantity )
|
public static ItemStack create( PeripheralType type, String label, int quantity )
|
||||||
{
|
{
|
||||||
ItemPeripheral peripheral = ((ItemPeripheral) Item.getItemFromBlock( ComputerCraft.Blocks.peripheral ));
|
|
||||||
ItemCable cable = ((ItemCable) Item.getItemFromBlock( ComputerCraft.Blocks.cable ));
|
|
||||||
ItemAdvancedModem advancedModem = ((ItemAdvancedModem) Item.getItemFromBlock( ComputerCraft.Blocks.advancedModem ));
|
|
||||||
switch( type )
|
switch( type )
|
||||||
{
|
{
|
||||||
case Speaker:
|
case Speaker:
|
||||||
@ -37,18 +31,12 @@ public class PeripheralItemFactory
|
|||||||
case Monitor:
|
case Monitor:
|
||||||
case AdvancedMonitor:
|
case AdvancedMonitor:
|
||||||
case WirelessModem:
|
case WirelessModem:
|
||||||
{
|
return ComputerCraft.Items.peripheral.create( type, label, quantity );
|
||||||
return peripheral.create( type, label, quantity );
|
|
||||||
}
|
|
||||||
case WiredModem:
|
case WiredModem:
|
||||||
case Cable:
|
case Cable:
|
||||||
{
|
return ComputerCraft.Items.cable.create( type, label, quantity );
|
||||||
return cable.create( type, label, quantity );
|
|
||||||
}
|
|
||||||
case AdvancedModem:
|
case AdvancedModem:
|
||||||
{
|
return new ItemStack( ComputerCraft.Blocks.advancedModem, quantity );
|
||||||
return advancedModem.create( type, label, quantity );
|
|
||||||
}
|
|
||||||
case WiredModemFull:
|
case WiredModemFull:
|
||||||
return new ItemStack( ComputerCraft.Blocks.wiredModemFull, quantity );
|
return new ItemStack( ComputerCraft.Blocks.wiredModemFull, quantity );
|
||||||
}
|
}
|
||||||
|
@ -22,7 +22,6 @@ import net.minecraft.block.state.IBlockState;
|
|||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
import net.minecraft.entity.EntityLivingBase;
|
import net.minecraft.entity.EntityLivingBase;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.Item;
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
@ -212,7 +211,7 @@ public class BlockCable extends BlockPeripheralBase
|
|||||||
@Override
|
@Override
|
||||||
public PeripheralType getPeripheralType( int damage )
|
public PeripheralType getPeripheralType( int damage )
|
||||||
{
|
{
|
||||||
return ((ItemCable) Item.getItemFromBlock( this )).getPeripheralType( damage );
|
return ComputerCraft.Items.cable.getPeripheralType( damage );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -27,30 +27,6 @@ public class ItemAdvancedModem extends ItemPeripheralBase
|
|||||||
setCreativeTab( ComputerCraft.mainCreativeTab );
|
setCreativeTab( ComputerCraft.mainCreativeTab );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nonnull
|
|
||||||
public ItemStack create( PeripheralType type, String label, int quantity )
|
|
||||||
{
|
|
||||||
ItemStack stack;
|
|
||||||
switch( type )
|
|
||||||
{
|
|
||||||
case AdvancedModem:
|
|
||||||
{
|
|
||||||
stack = new ItemStack( this, quantity, 0 );
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
{
|
|
||||||
// Ignore types we can't handle
|
|
||||||
return ItemStack.EMPTY;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if( label != null )
|
|
||||||
{
|
|
||||||
stack.setStackDisplayName( label );
|
|
||||||
}
|
|
||||||
return stack;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void getSubItems( @Nullable CreativeTabs tabs, @Nonnull NonNullList<ItemStack> list )
|
public void getSubItems( @Nullable CreativeTabs tabs, @Nonnull NonNullList<ItemStack> list )
|
||||||
{
|
{
|
||||||
|
@ -43,11 +43,6 @@ public class BlockTurtle extends BlockComputerBase
|
|||||||
public static final PropertyDirection FACING = PropertyDirection.create( "facing", EnumFacing.Plane.HORIZONTAL );
|
public static final PropertyDirection FACING = PropertyDirection.create( "facing", EnumFacing.Plane.HORIZONTAL );
|
||||||
}
|
}
|
||||||
|
|
||||||
public static BlockTurtle createTurtleBlock()
|
|
||||||
{
|
|
||||||
return new BlockTurtle();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Members
|
// Members
|
||||||
|
|
||||||
public BlockTurtle()
|
public BlockTurtle()
|
||||||
|
@ -11,7 +11,6 @@ import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
|||||||
import dan200.computercraft.api.turtle.TurtleSide;
|
import dan200.computercraft.api.turtle.TurtleSide;
|
||||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||||
import dan200.computercraft.shared.turtle.blocks.ITurtleTile;
|
import dan200.computercraft.shared.turtle.blocks.ITurtleTile;
|
||||||
import net.minecraft.item.Item;
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.util.ResourceLocation;
|
import net.minecraft.util.ResourceLocation;
|
||||||
|
|
||||||
@ -43,14 +42,14 @@ public class TurtleItemFactory
|
|||||||
{
|
{
|
||||||
case Normal:
|
case Normal:
|
||||||
{
|
{
|
||||||
ItemTurtleBase legacy = ((ItemTurtleBase) Item.getItemFromBlock( ComputerCraft.Blocks.turtle ));
|
ItemTurtleBase legacy = ComputerCraft.Items.turtle;
|
||||||
ItemTurtleBase normal = ((ItemTurtleBase) Item.getItemFromBlock( ComputerCraft.Blocks.turtleExpanded ));
|
ItemTurtleBase normal = ComputerCraft.Items.turtleExpanded;
|
||||||
ItemStack legacyStack = legacy.create( id, label, colour, leftUpgrade, rightUpgrade, fuelLevel, overlay );
|
ItemStack legacyStack = legacy.create( id, label, colour, leftUpgrade, rightUpgrade, fuelLevel, overlay );
|
||||||
return (legacyStack != null) ? legacyStack : normal.create( id, label, colour, leftUpgrade, rightUpgrade, fuelLevel, overlay );
|
return legacyStack != null ? legacyStack : normal.create( id, label, colour, leftUpgrade, rightUpgrade, fuelLevel, overlay );
|
||||||
}
|
}
|
||||||
case Advanced:
|
case Advanced:
|
||||||
{
|
{
|
||||||
ItemTurtleBase advanced = ((ItemTurtleBase) Item.getItemFromBlock( ComputerCraft.Blocks.turtleAdvanced ));
|
ItemTurtleBase advanced = ComputerCraft.Items.turtleAdvanced;
|
||||||
return advanced.create( id, label, colour, leftUpgrade, rightUpgrade, fuelLevel, overlay );
|
return advanced.create( id, label, colour, leftUpgrade, rightUpgrade, fuelLevel, overlay );
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
Loading…
Reference in New Issue
Block a user