Fix whack diff from last commit

This commit is contained in:
Nassim Jahnke 2024-12-27 13:47:25 +01:00
parent 2b73d1957c
commit 326c687047
No known key found for this signature in database
GPG key ID: EF6771C01F6EF02F
2 changed files with 14 additions and 22 deletions

View file

@ -25,7 +25,7 @@
FluidState getFluidState(BlockPos pos); FluidState getFluidState(BlockPos pos);
default int getLightEmission(BlockPos pos) { default int getLightEmission(BlockPos pos) {
@@ -66,19 +_,46 @@ @@ -66,10 +_,25 @@
); );
} }
@ -33,39 +33,31 @@
- return traverseBlocks(context.getFrom(), context.getTo(), context, (traverseContext, traversePos) -> { - return traverseBlocks(context.getFrom(), context.getTo(), context, (traverseContext, traversePos) -> {
- BlockState blockState = this.getBlockState(traversePos); - BlockState blockState = this.getBlockState(traversePos);
- FluidState fluidState = this.getFluidState(traversePos); - FluidState fluidState = this.getFluidState(traversePos);
- Vec3 from = traverseContext.getFrom();
- Vec3 to = traverseContext.getTo();
- VoxelShape blockShape = traverseContext.getBlockShape(blockState, this, traversePos);
+ // CraftBukkit start - moved block handling into separate method for use by Block#rayTrace + // CraftBukkit start - moved block handling into separate method for use by Block#rayTrace
+ default BlockHitResult clip(ClipContext context, BlockPos traversePos) { + default BlockHitResult clip(ClipContext traverseContext, BlockPos traversePos) {
+ // Paper start - Add predicate for blocks when raytracing + // Paper start - Add predicate for blocks when raytracing
+ return clip(context, traversePos, null); + return clip(traverseContext, traversePos, null);
+ } + }
+ +
+ default BlockHitResult clip(ClipContext context, BlockPos traversePos, java.util.function.Predicate<? super org.bukkit.block.Block> canCollide) { + default BlockHitResult clip(ClipContext traverseContext, BlockPos traversePos, java.util.function.Predicate<? super org.bukkit.block.Block> canCollide) {
+ // Paper end - Add predicate for blocks when raytracing + // Paper end - Add predicate for blocks when raytracing
+ // Paper start - Prevent raytrace from loading chunks + // Paper start - Prevent raytrace from loading chunks
+ BlockState blockState = this.getBlockStateIfLoaded(traversePos); + BlockState blockState = this.getBlockStateIfLoaded(traversePos);
+ if (blockState == null) { + if (blockState == null) {
+ // copied the last function parameter (listed below) + // copied the last function parameter (listed below)
+ Vec3 vec3d = context.getFrom().subtract(context.getTo()); + Vec3 vec3d = traverseContext.getFrom().subtract(traverseContext.getTo());
+ +
+ return BlockHitResult.miss(context.getTo(), Direction.getApproximateNearest(vec3d.x, vec3d.y, vec3d.z), BlockPos.containing(context.getTo())); + return BlockHitResult.miss(traverseContext.getTo(), Direction.getApproximateNearest(vec3d.x, vec3d.y, vec3d.z), BlockPos.containing(traverseContext.getTo()));
+ } + }
+ // Paper end - Prevent raytrace from loading chunks + // Paper end - Prevent raytrace from loading chunks
+ if (blockState.isAir() || (canCollide != null && this instanceof LevelAccessor levelAccessor && !canCollide.test(org.bukkit.craftbukkit.block.CraftBlock.at(levelAccessor, traversePos)))) return null; // Paper - Perf: optimise air cases & check canCollide predicate + if (blockState.isAir() || (canCollide != null && this instanceof LevelAccessor levelAccessor && !canCollide.test(org.bukkit.craftbukkit.block.CraftBlock.at(levelAccessor, traversePos)))) return null; // Paper - Perf: optimise air cases & check canCollide predicate
+ FluidState fluidState = blockState.getFluidState(); // Paper - Perf: don't need to go to world state again + FluidState fluidState = blockState.getFluidState(); // Paper - Perf: don't need to go to world state again
+ Vec3 from = context.getFrom(); Vec3 from = traverseContext.getFrom();
+ Vec3 to = context.getTo(); Vec3 to = traverseContext.getTo();
+ VoxelShape blockShape = context.getBlockShape(blockState, this, traversePos); VoxelShape blockShape = traverseContext.getBlockShape(blockState, this, traversePos);
BlockHitResult blockHitResult = this.clipWithInteractionOverride(from, to, traversePos, blockShape, blockState); @@ -79,6 +_,18 @@
- VoxelShape fluidShape = traverseContext.getFluidShape(fluidState, this, traversePos); double d = blockHitResult == null ? Double.MAX_VALUE : traverseContext.getFrom().distanceToSqr(blockHitResult.getLocation());
+ VoxelShape fluidShape = context.getFluidShape(fluidState, this, traversePos); double d1 = blockHitResult1 == null ? Double.MAX_VALUE : traverseContext.getFrom().distanceToSqr(blockHitResult1.getLocation());
BlockHitResult blockHitResult1 = fluidShape.clip(from, to, traversePos);
- double d = blockHitResult == null ? Double.MAX_VALUE : traverseContext.getFrom().distanceToSqr(blockHitResult.getLocation());
- double d1 = blockHitResult1 == null ? Double.MAX_VALUE : traverseContext.getFrom().distanceToSqr(blockHitResult1.getLocation());
+ double d = blockHitResult == null ? Double.MAX_VALUE : context.getFrom().distanceToSqr(blockHitResult.getLocation());
+ double d1 = blockHitResult1 == null ? Double.MAX_VALUE : context.getFrom().distanceToSqr(blockHitResult1.getLocation());
return d <= d1 ? blockHitResult : blockHitResult1; return d <= d1 ? blockHitResult : blockHitResult1;
+ } + }
+ // CraftBukkit end + // CraftBukkit end

View file

@ -613,8 +613,8 @@ public abstract class DelegatedGeneratorAccess implements WorldGenLevel {
} }
@Override @Override
public BlockHitResult clip(ClipContext context, BlockPos traversePos) { public BlockHitResult clip(ClipContext traverseContext, BlockPos traversePos) {
return this.handle.clip(context, traversePos); return this.handle.clip(traverseContext, traversePos);
} }
@Override @Override