public abstract class AbstractBufferingExtent extends AbstractDelegateExtent
setBlock(BlockVector3, BlockStateHolder)
and the delegate extent. This class ensures that getBlock(BlockVector3)
is properly
handled, by returning buffered blocks.Modifier | Constructor and Description |
---|---|
protected |
AbstractBufferingExtent(Extent extent)
Create a new instance.
|
Modifier and Type | Method and Description |
---|---|
BlockState |
getBlock(BlockVector3 position)
Get a snapshot of the block at the given location.
|
protected java.util.Optional<BaseBlock> |
getBufferedBlock(BlockVector3 position)
Deprecated.
New subclasses should override
getBufferedFullBlock(BlockVector3)
instead |
protected BaseBlock |
getBufferedFullBlock(BlockVector3 position)
Gets a block from the buffer, or null if not buffered.
|
BaseBlock |
getFullBlock(BlockVector3 position)
Get a immutable snapshot of the block at the given location.
|
abstract <T extends BlockStateHolder<T>> |
setBlock(BlockVector3 location,
T block)
Change the block at the given location to the given block.
|
protected <T extends BlockStateHolder<T>> |
setDelegateBlock(BlockVector3 location,
T block) |
commit, commitBefore, createEntity, fullySupports3DBiomes, getBiome, getEntities, getEntities, getExtent, getMaximumPoint, getMinimumPoint, setBiome
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
getBiome
setBiome
protected AbstractBufferingExtent(Extent extent)
extent
- the extentpublic abstract <T extends BlockStateHolder<T>> boolean setBlock(BlockVector3 location, T block) throws WorldEditException
OutputExtent
BlockStateHolder
to the world, so future changes to the
BlockStateHolder
do not affect the world until this method is called again.
The return value of this method indicates whether the change was probably successful. It may not be successful if, for example, the location is out of the bounds of the extent. It may be unsuccessful if the block passed is the same as the one in the world. However, the return value is only an estimation and it may be incorrect, but it could be used to count, for example, the approximate number of changes.
setBlock
in interface OutputExtent
setBlock
in class AbstractDelegateExtent
location
- position of the blockblock
- block to setWorldEditException
- thrown on an errorprotected final <T extends BlockStateHolder<T>> boolean setDelegateBlock(BlockVector3 location, T block) throws WorldEditException
WorldEditException
public BlockState getBlock(BlockVector3 position)
InputExtent
If the given position is out of the bounds of the extent, then the behavior
is undefined (an air block could be returned). However, null
should not be returned.
The returned block is immutable and is a snapshot of the block at the time
of call. It has no position attached to it, so it could be reused in
Pattern
s and so on.
getBlock
in interface InputExtent
getBlock
in class AbstractDelegateExtent
position
- position of the blockpublic BaseBlock getFullBlock(BlockVector3 position)
InputExtent
getFullBlock
in interface InputExtent
getFullBlock
in class AbstractDelegateExtent
position
- position of the block@Deprecated protected java.util.Optional<BaseBlock> getBufferedBlock(BlockVector3 position)
getBufferedFullBlock(BlockVector3)
instead@NonAbstractForCompatibility(delegateName="getBufferedBlock", delegateParams=BlockVector3.class) @Nullable protected BaseBlock getBufferedFullBlock(BlockVector3 position)
position
- The positionNonAbstractForCompatibility
for details