mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-01-07 16:00:31 +00:00
Simplify placement logic of various blocks
- For those where placement is stored in the metadata (computers), don't also set it in onBlockPlacedBy. - Remove .getDefaultState(int, EnumFacing) override, as this means we have more control over what is passed to us (namely, placer's direction too).
This commit is contained in:
parent
7fd19c43e9
commit
61daab910e
@ -10,7 +10,6 @@ import net.minecraft.block.Block;
|
|||||||
import net.minecraft.block.ITileEntityProvider;
|
import net.minecraft.block.ITileEntityProvider;
|
||||||
import net.minecraft.block.material.Material;
|
import net.minecraft.block.material.Material;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.entity.EntityLivingBase;
|
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
@ -31,8 +30,6 @@ public abstract class BlockGeneric extends Block implements ITileEntityProvider
|
|||||||
this.hasTileEntity = true;
|
this.hasTileEntity = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected abstract IBlockState getDefaultBlockState( int damage, EnumFacing placedSide );
|
|
||||||
|
|
||||||
protected abstract TileGeneric createTile( IBlockState state );
|
protected abstract TileGeneric createTile( IBlockState state );
|
||||||
|
|
||||||
protected abstract TileGeneric createTile( int damage );
|
protected abstract TileGeneric createTile( int damage );
|
||||||
@ -53,14 +50,6 @@ public abstract class BlockGeneric extends Block implements ITileEntityProvider
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nonnull
|
|
||||||
@Override
|
|
||||||
@Deprecated
|
|
||||||
public final IBlockState getStateForPlacement( World world, BlockPos pos, EnumFacing side, float hitX, float hitY, float hitZ, int damage, EntityLivingBase placer )
|
|
||||||
{
|
|
||||||
return getDefaultBlockState( damage, side );
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean removedByPlayer( @Nonnull IBlockState state, World world, @Nonnull BlockPos pos, @Nonnull EntityPlayer player, boolean willHarvest )
|
public boolean removedByPlayer( @Nonnull IBlockState state, World world, @Nonnull BlockPos pos, @Nonnull EntityPlayer player, boolean willHarvest )
|
||||||
{
|
{
|
||||||
|
@ -86,16 +86,9 @@ public class BlockCommandComputer extends BlockComputerBase
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected IBlockState getDefaultBlockState( ComputerFamily family, EnumFacing placedSide )
|
protected IBlockState getDefaultBlockState( ComputerFamily family, EnumFacing placedSide )
|
||||||
{
|
|
||||||
if( placedSide.getAxis() != EnumFacing.Axis.Y )
|
|
||||||
{
|
{
|
||||||
return getDefaultState().withProperty( Properties.FACING, placedSide );
|
return getDefaultState().withProperty( Properties.FACING, placedSide );
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
return getDefaultState();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ComputerFamily getFamily( int damage )
|
public ComputerFamily getFamily( int damage )
|
||||||
@ -114,20 +107,4 @@ public class BlockCommandComputer extends BlockComputerBase
|
|||||||
{
|
{
|
||||||
return new TileCommandComputer();
|
return new TileCommandComputer();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onBlockPlacedBy( World world, BlockPos pos, IBlockState state, EntityLivingBase player, @Nonnull ItemStack itemstack )
|
|
||||||
{
|
|
||||||
// Not sure why this is necessary
|
|
||||||
TileEntity tile = world.getTileEntity( pos );
|
|
||||||
if( tile instanceof TileCommandComputer )
|
|
||||||
{
|
|
||||||
tile.setWorld( world ); // Not sure why this is necessary
|
|
||||||
tile.setPos( pos ); // Not sure why this is necessary
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set direction
|
|
||||||
EnumFacing dir = DirectionUtil.fromEntityRot( player );
|
|
||||||
setDirection( world, pos, dir );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -9,14 +9,12 @@ 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.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;
|
||||||
import net.minecraft.block.properties.PropertyDirection;
|
import net.minecraft.block.properties.PropertyDirection;
|
||||||
import net.minecraft.block.properties.PropertyEnum;
|
import net.minecraft.block.properties.PropertyEnum;
|
||||||
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.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
@ -97,24 +95,9 @@ public class BlockComputer extends BlockComputerBase
|
|||||||
@Override
|
@Override
|
||||||
protected IBlockState getDefaultBlockState( ComputerFamily family, EnumFacing placedSide )
|
protected IBlockState getDefaultBlockState( ComputerFamily family, EnumFacing placedSide )
|
||||||
{
|
{
|
||||||
IBlockState state = getDefaultState();
|
return getDefaultState()
|
||||||
if( placedSide.getAxis() != EnumFacing.Axis.Y )
|
.withProperty( Properties.FACING, placedSide )
|
||||||
{
|
.withProperty( Properties.ADVANCED, family == ComputerFamily.Advanced );
|
||||||
state = state.withProperty( Properties.FACING, placedSide );
|
|
||||||
}
|
|
||||||
|
|
||||||
switch( family )
|
|
||||||
{
|
|
||||||
case Normal:
|
|
||||||
default:
|
|
||||||
{
|
|
||||||
return state.withProperty( Properties.ADVANCED, false );
|
|
||||||
}
|
|
||||||
case Advanced:
|
|
||||||
{
|
|
||||||
return state.withProperty( Properties.ADVANCED, true );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
@ -151,22 +134,6 @@ public class BlockComputer extends BlockComputerBase
|
|||||||
return new TileComputer();
|
return new TileComputer();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onBlockPlacedBy( World world, BlockPos pos, IBlockState state, EntityLivingBase player, @Nonnull ItemStack stack )
|
|
||||||
{
|
|
||||||
// Not sure why this is necessary
|
|
||||||
TileEntity tile = world.getTileEntity( pos );
|
|
||||||
if( tile instanceof TileComputer )
|
|
||||||
{
|
|
||||||
tile.setWorld( world ); // Not sure why this is necessary
|
|
||||||
tile.setPos( pos ); // Not sure why this is necessary
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set direction
|
|
||||||
EnumFacing dir = DirectionUtil.fromEntityRot( player );
|
|
||||||
setDirection( world, pos, dir );
|
|
||||||
}
|
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
@Override
|
@Override
|
||||||
public ItemStack getPickBlock( @Nonnull IBlockState state, RayTraceResult target, @Nonnull World world, @Nonnull BlockPos pos, EntityPlayer player )
|
public ItemStack getPickBlock( @Nonnull IBlockState state, RayTraceResult target, @Nonnull World world, @Nonnull BlockPos pos, EntityPlayer player )
|
||||||
|
@ -8,16 +8,18 @@ package dan200.computercraft.shared.computer.blocks;
|
|||||||
|
|
||||||
import dan200.computercraft.shared.common.BlockDirectional;
|
import dan200.computercraft.shared.common.BlockDirectional;
|
||||||
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
import dan200.computercraft.shared.computer.core.ComputerFamily;
|
||||||
import dan200.computercraft.shared.computer.items.ItemComputerBase;
|
import dan200.computercraft.shared.util.DirectionUtil;
|
||||||
import net.minecraft.block.material.Material;
|
import net.minecraft.block.material.Material;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.entity.EntityLivingBase;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.world.IBlockAccess;
|
import net.minecraft.world.IBlockAccess;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
|
import javax.annotation.Nonnull;
|
||||||
|
|
||||||
public abstract class BlockComputerBase extends BlockDirectional
|
public abstract class BlockComputerBase extends BlockDirectional
|
||||||
{
|
{
|
||||||
public BlockComputerBase( Material material )
|
public BlockComputerBase( Material material )
|
||||||
@ -47,11 +49,12 @@ public abstract class BlockComputerBase extends BlockDirectional
|
|||||||
|
|
||||||
protected abstract TileComputerBase createTile( ComputerFamily family );
|
protected abstract TileComputerBase createTile( ComputerFamily family );
|
||||||
|
|
||||||
|
@Nonnull
|
||||||
@Override
|
@Override
|
||||||
protected final IBlockState getDefaultBlockState( int damage, EnumFacing placedSide )
|
@Deprecated
|
||||||
|
public final IBlockState getStateForPlacement( World world, BlockPos pos, EnumFacing side, float hitX, float hitY, float hitZ, int damage, EntityLivingBase placer )
|
||||||
{
|
{
|
||||||
ItemComputerBase item = (ItemComputerBase) Item.getItemFromBlock( this );
|
return getDefaultBlockState( getFamily( damage ), DirectionUtil.fromEntityRot( placer ) );
|
||||||
return getDefaultBlockState( item.getFamily( damage ), placedSide );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -560,14 +560,7 @@ public class BlockPeripheral extends BlockPeripheralBase
|
|||||||
@Override
|
@Override
|
||||||
public void onBlockPlacedBy( World world, BlockPos pos, IBlockState state, EntityLivingBase player, @Nonnull ItemStack stack )
|
public void onBlockPlacedBy( World world, BlockPos pos, IBlockState state, EntityLivingBase player, @Nonnull ItemStack stack )
|
||||||
{
|
{
|
||||||
// Not sure why this is necessary
|
|
||||||
TileEntity tile = world.getTileEntity( pos );
|
TileEntity tile = world.getTileEntity( pos );
|
||||||
if( tile instanceof TilePeripheralBase )
|
|
||||||
{
|
|
||||||
tile.setWorld( world ); // Not sure why this is necessary
|
|
||||||
tile.setPos( pos ); // Not sure why this is necessary
|
|
||||||
}
|
|
||||||
|
|
||||||
switch( getPeripheralType( state ) )
|
switch( getPeripheralType( state ) )
|
||||||
{
|
{
|
||||||
case Speaker:
|
case Speaker:
|
||||||
|
@ -11,8 +11,8 @@ import dan200.computercraft.shared.common.TileGeneric;
|
|||||||
import dan200.computercraft.shared.peripheral.PeripheralType;
|
import dan200.computercraft.shared.peripheral.PeripheralType;
|
||||||
import net.minecraft.block.material.Material;
|
import net.minecraft.block.material.Material;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
|
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;
|
||||||
@ -44,11 +44,12 @@ public abstract class BlockPeripheralBase extends BlockDirectional
|
|||||||
return true; // ItemPeripheralBase handles this
|
return true; // ItemPeripheralBase handles this
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nonnull
|
||||||
@Override
|
@Override
|
||||||
protected final IBlockState getDefaultBlockState( int damage, EnumFacing placedSide )
|
@Deprecated
|
||||||
|
public final IBlockState getStateForPlacement( World world, BlockPos pos, EnumFacing side, float hitX, float hitY, float hitZ, int damage, EntityLivingBase placer )
|
||||||
{
|
{
|
||||||
ItemPeripheralBase item = (ItemPeripheralBase) Item.getItemFromBlock( this );
|
return getDefaultBlockState( getPeripheralType( damage ), side );
|
||||||
return getDefaultBlockState( item.getPeripheralType( damage ), placedSide );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -177,17 +177,11 @@ public class BlockTurtle extends BlockComputerBase
|
|||||||
@Override
|
@Override
|
||||||
public void onBlockPlacedBy( World world, BlockPos pos, IBlockState state, EntityLivingBase player, @Nonnull ItemStack itemstack )
|
public void onBlockPlacedBy( World world, BlockPos pos, IBlockState state, EntityLivingBase player, @Nonnull ItemStack itemstack )
|
||||||
{
|
{
|
||||||
// Not sure why this is necessary
|
|
||||||
TileEntity tile = world.getTileEntity( pos );
|
TileEntity tile = world.getTileEntity( pos );
|
||||||
if( tile instanceof TileTurtle )
|
if( tile instanceof TileTurtle && player instanceof EntityPlayer )
|
||||||
{
|
|
||||||
tile.setWorld( world ); // Not sure why this is necessary
|
|
||||||
tile.setPos( pos ); // Not sure why this is necessary
|
|
||||||
if( player instanceof EntityPlayer )
|
|
||||||
{
|
{
|
||||||
((TileTurtle) tile).setOwningPlayer( ((EntityPlayer) player).getGameProfile() );
|
((TileTurtle) tile).setOwningPlayer( ((EntityPlayer) player).getGameProfile() );
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// Set direction
|
// Set direction
|
||||||
EnumFacing dir = DirectionUtil.fromEntityRot( player );
|
EnumFacing dir = DirectionUtil.fromEntityRot( player );
|
||||||
|
Loading…
Reference in New Issue
Block a user