Stop builder in favor of wither

Signed-off-by: TheMode <themode@outlook.fr>
This commit is contained in:
TheMode 2022-10-29 12:45:26 +02:00
parent 3155c99e2b
commit dae6da3824
3 changed files with 35 additions and 57 deletions

View File

@ -2,7 +2,6 @@ package net.minestom.server.instance.batch;
import net.minestom.server.instance.block.Block;
import org.jetbrains.annotations.ApiStatus;
import org.jetbrains.annotations.Contract;
import org.jetbrains.annotations.NotNull;
@ApiStatus.Experimental
@ -14,13 +13,13 @@ public sealed interface BatchQuery
return BatchQueryImpl.fallback(getter, x, y, z, condition, query);
}
static @NotNull Builder builder(int radius) {
return new BatchQueryImpl.Builder(radius);
static @NotNull BatchQuery radius(int radius) {
return BatchQueryImpl.radius(radius);
}
static @NotNull BatchQuery radius(int radius) {
return builder(radius).build();
}
@NotNull BatchQuery withType(@NotNull Block @NotNull ... blocks);
@NotNull BatchQuery withExact(@NotNull Block @NotNull ... blocks);
interface Result extends Block.Getter {
/**
@ -30,15 +29,4 @@ public sealed interface BatchQuery
*/
int count();
}
sealed interface Builder
permits BatchQueryImpl.Builder {
@Contract("_ -> this")
@NotNull Builder type(@NotNull Block @NotNull ... blocks);
@Contract("_ -> this")
@NotNull Builder exact(@NotNull Block @NotNull ... blocks);
@NotNull BatchQuery build();
}
}

View File

@ -4,17 +4,43 @@ import net.minestom.server.coordinate.Point;
import net.minestom.server.coordinate.Vec;
import net.minestom.server.instance.block.Block;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import org.jetbrains.annotations.UnknownNullability;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import java.util.function.Predicate;
import java.util.stream.Collectors;
record BatchQueryImpl(int radius,
@NotNull Predicate<Block> predicate) implements BatchQuery {
@Nullable Set<Integer> type,
@Nullable Set<Block> exact) implements BatchQuery {
public BatchQueryImpl {
type = type != null ? Set.copyOf(type) : null;
exact = exact != null ? Set.copyOf(exact) : null;
}
static BatchQuery radius(int radius) {
return new BatchQueryImpl(radius, null, null);
}
@Override
public @NotNull BatchQuery withType(@NotNull Block @NotNull ... blocks) {
var updatedType = Arrays.stream(blocks).map(Block::id).collect(Collectors.toUnmodifiableSet());
return new BatchQueryImpl(radius, updatedType, exact);
}
@Override
public @NotNull BatchQuery withExact(@NotNull Block @NotNull ... blocks) {
return new BatchQueryImpl(radius, type, Set.of(blocks));
}
private boolean valid(Block block) {
if (type != null && !type.contains(block.id()))
return false;
return exact == null || exact.contains(block);
}
static Result fallback(Block.Getter getter, int x, int y, int z,
Block.Getter.Condition condition, BatchQuery query) {
@ -29,7 +55,7 @@ record BatchQueryImpl(int radius,
final int blockY = y + j;
final int blockZ = z + k;
final Block block = getter.getBlock(blockX, blockY, blockZ);
if (!queryImpl.predicate.test(block)) {
if (!queryImpl.valid(block)) {
continue;
}
blocks.put(new Vec(blockX, blockY, blockZ), block);
@ -55,40 +81,4 @@ record BatchQueryImpl(int radius,
return blocks.size();
}
}
static final class Builder implements BatchQuery.Builder {
private final int radius;
private Set<Integer> type;
private Set<Block> exact;
Builder(Integer radius) {
this.radius = radius;
}
@Override
public BatchQuery.@NotNull Builder type(@NotNull Block @NotNull ... blocks) {
this.type = Arrays.stream(blocks).map(Block::id).collect(Collectors.toUnmodifiableSet());
return this;
}
@Override
public BatchQuery.@NotNull Builder exact(@NotNull Block @NotNull ... blocks) {
this.exact = Set.of(blocks);
return this;
}
@Override
public @NotNull BatchQuery build() {
var type = this.type != null ? Set.copyOf(this.type) : null;
var exact = this.exact != null ? Set.copyOf(this.exact) : null;
return new BatchQueryImpl(radius,
block -> {
if (type != null && !type.contains(block.id()))
return false;
if (exact != null && !exact.contains(block))
return false;
return true;
});
}
}
}

View File

@ -42,7 +42,7 @@ public class BatchQueryIntegrationTest {
@Test
public void type(Env env) {
var instance = env.process().instance().createInstanceContainer();
var batch = BatchQuery.builder(3).type(Block.STONE).build();
var batch = BatchQuery.radius(3).withType(Block.STONE);
instance.loadChunk(0, 0).join();