Fixed NPE regression in non loaded chunks access
Improved blockstate updater logic
This commit is contained in:
parent
a6c8068d72
commit
c0c8a6b23b
4 changed files with 20 additions and 20 deletions
|
@ -465,7 +465,9 @@ public class Commons {
|
||||||
while(!toIterate.isEmpty() && range < maxRange) {
|
while(!toIterate.isEmpty() && range < maxRange) {
|
||||||
toIterateNext = new HashSet<>();
|
toIterateNext = new HashSet<>();
|
||||||
for (final BlockPos current : toIterate) {
|
for (final BlockPos current : toIterate) {
|
||||||
if (whitelist.contains(new VectorI(current).getBlockState_noChunkLoading(world).getBlock())) {
|
final IBlockState blockStateCurrent = VectorI.getBlockState_noChunkLoading(world, current);
|
||||||
|
if ( blockStateCurrent != null
|
||||||
|
&& whitelist.contains(blockStateCurrent.getBlock()) ) {
|
||||||
iterated.add(current);
|
iterated.add(current);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -474,7 +476,9 @@ public class Commons {
|
||||||
current.getY() + direction.y,
|
current.getY() + direction.y,
|
||||||
current.getZ() + direction.z );
|
current.getZ() + direction.z );
|
||||||
if (!iterated.contains(next) && !toIgnore.contains(next) && !toIterate.contains(next) && !toIterateNext.contains(next)) {
|
if (!iterated.contains(next) && !toIgnore.contains(next) && !toIterate.contains(next) && !toIterateNext.contains(next)) {
|
||||||
if (whitelist.contains(new VectorI(next).getBlockState_noChunkLoading(world).getBlock())) {
|
final IBlockState blockStateNext = VectorI.getBlockState_noChunkLoading(world, next);
|
||||||
|
if ( blockStateNext != null
|
||||||
|
&& whitelist.contains(blockStateNext.getBlock())) {
|
||||||
toIterateNext.add(next);
|
toIterateNext.add(next);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -127,6 +127,9 @@ public abstract class TileEntityAbstractBase extends TileEntity implements IBloc
|
||||||
blockState.getBlock(), this, blockState_in, property, value));
|
blockState.getBlock(), this, blockState_in, property, value));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (blockState.getValue(property) == value) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
blockState = blockState.withProperty(property, value);
|
blockState = blockState.withProperty(property, value);
|
||||||
}
|
}
|
||||||
if (getBlockMetadata() != blockState.getBlock().getMetaFromState(blockState)) {
|
if (getBlockMetadata() != blockState.getBlock().getMetaFromState(blockState)) {
|
||||||
|
|
|
@ -25,6 +25,7 @@ import java.util.Set;
|
||||||
import java.util.TreeMap;
|
import java.util.TreeMap;
|
||||||
|
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
|
import net.minecraft.block.state.IBlockState;
|
||||||
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;
|
||||||
|
@ -202,8 +203,12 @@ public class AcceleratorSetup extends GlobalPosition {
|
||||||
WarpDrive.blockVoidShellGlass);
|
WarpDrive.blockVoidShellGlass);
|
||||||
TrajectoryPoint trajectoryPoint = null;
|
TrajectoryPoint trajectoryPoint = null;
|
||||||
for (final EnumFacing direction : EnumFacing.HORIZONTALS) {
|
for (final EnumFacing direction : EnumFacing.HORIZONTALS) {
|
||||||
final VectorI next = firstVoidShell.clone(direction);
|
final BlockPos next = new BlockPos(firstVoidShell.x + direction.getXOffset(),
|
||||||
if (whitelist.contains(next.getBlockState_noChunkLoading(world).getBlock())) {
|
firstVoidShell.y + direction.getYOffset(),
|
||||||
|
firstVoidShell.z + direction.getZOffset() );
|
||||||
|
final IBlockState blockStateNext = VectorI.getBlockState_noChunkLoading(world, next);
|
||||||
|
if ( blockStateNext != null
|
||||||
|
&& whitelist.contains(blockStateNext.getBlock()) ) {
|
||||||
trajectoryPoint = new TrajectoryPoint(world, firstVoidShell.translate(direction), direction);
|
trajectoryPoint = new TrajectoryPoint(world, firstVoidShell.translate(direction), direction);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -93,14 +93,10 @@ public class VectorI implements Cloneable {
|
||||||
return blockAccess.getBlockState(new BlockPos(x, y, z)).getBlock();
|
return blockAccess.getBlockState(new BlockPos(x, y, z)).getBlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
public IBlockState getBlockState(IBlockAccess blockAccess) {
|
public IBlockState getBlockState(final IBlockAccess blockAccess) {
|
||||||
return blockAccess.getBlockState(new BlockPos(x, y, z));
|
return blockAccess.getBlockState(new BlockPos(x, y, z));
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isChunkLoaded(final IBlockAccess blockAccess) {
|
|
||||||
return isChunkLoaded(blockAccess, x, z);
|
|
||||||
}
|
|
||||||
|
|
||||||
static public boolean isChunkLoaded(final IBlockAccess blockAccess, final int x, final int z) {
|
static public boolean isChunkLoaded(final IBlockAccess blockAccess, final int x, final int z) {
|
||||||
if (blockAccess instanceof WorldServer) {
|
if (blockAccess instanceof WorldServer) {
|
||||||
return ChunkHandler.isLoaded((WorldServer) blockAccess, x, 64, z);
|
return ChunkHandler.isLoaded((WorldServer) blockAccess, x, 64, z);
|
||||||
|
@ -121,24 +117,16 @@ public class VectorI implements Cloneable {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public IBlockState getBlockState_noChunkLoading(final IBlockAccess blockAccess, final EnumFacing side) {
|
static public IBlockState getBlockState_noChunkLoading(final IBlockAccess blockAccess, final BlockPos blockPos) {
|
||||||
return getBlockState_noChunkLoading(blockAccess, x + side.getXOffset(), y + side.getYOffset(), z + side.getZOffset());
|
|
||||||
}
|
|
||||||
|
|
||||||
public IBlockState getBlockState_noChunkLoading(final IBlockAccess blockAccess) {
|
|
||||||
return getBlockState_noChunkLoading(blockAccess, x, y, z);
|
|
||||||
}
|
|
||||||
|
|
||||||
static public IBlockState getBlockState_noChunkLoading(final IBlockAccess blockAccess, final int x, final int y, final int z) {
|
|
||||||
// skip unloaded worlds
|
// skip unloaded worlds
|
||||||
if (blockAccess == null) {
|
if (blockAccess == null) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
// skip unloaded chunks
|
// skip unloaded chunks
|
||||||
if (!isChunkLoaded(blockAccess, x, z)) {
|
if (!isChunkLoaded(blockAccess, blockPos.getX(), blockPos.getZ())) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return blockAccess.getBlockState(new BlockPos(x, y, z));
|
return blockAccess.getBlockState(blockPos);
|
||||||
}
|
}
|
||||||
|
|
||||||
public TileEntity getTileEntity(final IBlockAccess blockAccess) {
|
public TileEntity getTileEntity(final IBlockAccess blockAccess) {
|
||||||
|
|
Loading…
Reference in a new issue