public class BlockChangeLimiter extends AbstractDelegateExtent
MaxChangedBlocksException
is thrown.Constructor and Description |
---|
BlockChangeLimiter(Extent extent,
int limit)
Create a new instance.
|
Modifier and Type | Method and Description |
---|---|
int |
getCount()
Get the number of blocks that have been counted so far.
|
int |
getLimit()
Get the limit.
|
<B extends BlockStateHolder<B>> |
setBlock(BlockVector3 location,
B block)
Change the block at the given location to the given block.
|
void |
setLimit(int limit)
Set the limit.
|
commit, commitBefore, createEntity, fullySupports3DBiomes, getBiome, getBlock, getEntities, getEntities, getExtent, getFullBlock, getMaximumPoint, getMinimumPoint, setBiome
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
getBiome
setBiome
public BlockChangeLimiter(Extent extent, int limit)
extent
- the extentlimit
- the limit (>= 0) or -1 for no limitpublic int getLimit()
public void setLimit(int limit)
limit
- the limit (>= 0) or -1 for no limitpublic int getCount()
public <B extends BlockStateHolder<B>> boolean setBlock(BlockVector3 location, B 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 error