mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-25 01:31:29 +01:00
#987: Add generateTree method with a predicate
By: DerFrZocker <derrieple@gmail.com>
This commit is contained in:
parent
9b581cce11
commit
db38e9a8f5
@ -7,6 +7,7 @@ import java.util.Iterator;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
|
import java.util.function.Predicate;
|
||||||
import net.minecraft.core.BlockPosition;
|
import net.minecraft.core.BlockPosition;
|
||||||
import net.minecraft.core.EnumDirection;
|
import net.minecraft.core.EnumDirection;
|
||||||
import net.minecraft.core.IRegistry;
|
import net.minecraft.core.IRegistry;
|
||||||
@ -297,17 +298,24 @@ public abstract class CraftRegionAccessor implements RegionAccessor {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean generateTree(Location location, Random random, TreeType treeType, Consumer<BlockState> consumer) {
|
public boolean generateTree(Location location, Random random, TreeType treeType, Consumer<BlockState> consumer) {
|
||||||
|
return generateTree(location, random, treeType, (consumer == null) ? null : (block) -> {
|
||||||
|
consumer.accept(block);
|
||||||
|
return true;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean generateTree(Location location, Random random, TreeType treeType, Predicate<BlockState> predicate) {
|
||||||
BlockPosition pos = new BlockPosition(location.getBlockX(), location.getBlockY(), location.getBlockZ());
|
BlockPosition pos = new BlockPosition(location.getBlockX(), location.getBlockY(), location.getBlockZ());
|
||||||
BlockStateListPopulator populator = new BlockStateListPopulator(getHandle());
|
BlockStateListPopulator populator = new BlockStateListPopulator(getHandle());
|
||||||
boolean result = generateTree(populator, getHandle().getMinecraftWorld().getChunkSource().getGenerator(), pos, random, treeType);
|
boolean result = generateTree(populator, getHandle().getMinecraftWorld().getChunkSource().getGenerator(), pos, random, treeType);
|
||||||
populator.refreshTiles();
|
populator.refreshTiles();
|
||||||
|
|
||||||
for (BlockState blockState : populator.getList()) {
|
for (BlockState blockState : populator.getList()) {
|
||||||
if (consumer != null) {
|
if (predicate == null || predicate.test(blockState)) {
|
||||||
consumer.accept(blockState);
|
|
||||||
}
|
|
||||||
blockState.update(true, true);
|
blockState.update(true, true);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user