mirror of
https://github.com/Samsuik/Sakura.git
synced 2025-12-19 14:59:30 +00:00
165 lines
9.7 KiB
Diff
165 lines
9.7 KiB
Diff
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
From: Samsuik <kfian294ma4@gmail.com>
|
|
Date: Mon, 22 Apr 2024 23:01:26 +0100
|
|
Subject: [PATCH] Replace explosion density cache
|
|
|
|
|
|
diff --git a/net/minecraft/server/level/ServerLevel.java b/net/minecraft/server/level/ServerLevel.java
|
|
index 8fec4a46a9cf13d832306bd87a4fe17be79bef86..dce3331c7dbbf9bb6c6342d0a760c040342a2d0c 100644
|
|
--- a/net/minecraft/server/level/ServerLevel.java
|
|
+++ b/net/minecraft/server/level/ServerLevel.java
|
|
@@ -698,6 +698,7 @@ public class ServerLevel extends Level implements ServerEntityGetter, WorldGenLe
|
|
this.getCraftServer().addWorld(this.getWorld()); // CraftBukkit
|
|
this.levelTickScheduler.registerNewTask(this.explosionPositions::clear, 0); // Sakura - client visibility settings
|
|
this.levelTickScheduler.registerNewTask(this.mergeHandler::expire, 200); // Sakura - merge cannon entities
|
|
+ this.levelTickScheduler.registerNewTask(this.densityCache::invalidate, 0); // Sakura - explosion density cache
|
|
}
|
|
|
|
// Paper start
|
|
diff --git a/net/minecraft/world/level/Level.java b/net/minecraft/world/level/Level.java
|
|
index 5c4c2823ec6b5e2d9293b9130ddf2bc1c3c12048..125f61e6560790bed25e2f7aedaa189caf31a8aa 100644
|
|
--- a/net/minecraft/world/level/Level.java
|
|
+++ b/net/minecraft/world/level/Level.java
|
|
@@ -842,6 +842,7 @@ public abstract class Level implements LevelAccessor, AutoCloseable, ca.spottedl
|
|
public final me.samsuik.sakura.listener.BlockChangeTracker blockChangeTracker = new me.samsuik.sakura.listener.BlockChangeTracker(this);
|
|
// Sakura end - track block changes and tick scheduler
|
|
public final me.samsuik.sakura.entity.merge.EntityMergeHandler mergeHandler = new me.samsuik.sakura.entity.merge.EntityMergeHandler(); // Sakura - merge cannon entities
|
|
+ public final me.samsuik.sakura.explosion.density.BlockDensityCache densityCache = new me.samsuik.sakura.explosion.density.BlockDensityCache(); // Sakura - explosion density cache
|
|
|
|
protected Level(
|
|
WritableLevelData levelData,
|
|
diff --git a/net/minecraft/world/level/ServerExplosion.java b/net/minecraft/world/level/ServerExplosion.java
|
|
index 9f06e32101f494d94d9210210255d5d72ca4ff36..6d3e03b3c9fed817808de6ee08b531069d342dd5 100644
|
|
--- a/net/minecraft/world/level/ServerExplosion.java
|
|
+++ b/net/minecraft/world/level/ServerExplosion.java
|
|
@@ -296,7 +296,12 @@ public class ServerExplosion implements Explosion {
|
|
Math.fma(dz, diffZ, offZ)
|
|
);
|
|
|
|
- if (!this.clipsAnything(from, source, context, blockCache, blockPos)) {
|
|
+ // Sakura start - replace density cache
|
|
+ final float density = this.level.densityCache.getKnownDensity(from);
|
|
+ if (density != me.samsuik.sakura.explosion.density.BlockDensityCache.UNKNOWN_DENSITY) {
|
|
+ missedRays += (int) density;
|
|
+ } else if (!this.clipsAnything(from, source, context, blockCache, blockPos)) {
|
|
+ // Sakura end - replace density cache
|
|
++missedRays;
|
|
}
|
|
}
|
|
@@ -385,8 +390,16 @@ public class ServerExplosion implements Explosion {
|
|
double d9 = Mth.lerp(d6, boundingBox.minY, boundingBox.maxY);
|
|
double d10 = Mth.lerp(d7, boundingBox.minZ, boundingBox.maxZ);
|
|
Vec3 vec3 = new Vec3(d8 + d3, d9, d10 + d4);
|
|
- if (entity.level().clip(new ClipContext(vec3, explosionVector, ClipContext.Block.COLLIDER, ClipContext.Fluid.NONE, entity)).getType()
|
|
- == HitResult.Type.MISS) {
|
|
+ // Sakura start - replace density cache
|
|
+ final net.minecraft.world.phys.HitResult.Type hitResult;
|
|
+ final float density = entity.level().densityCache.getKnownDensity(vec3);
|
|
+ if (density != me.samsuik.sakura.explosion.density.BlockDensityCache.UNKNOWN_DENSITY) {
|
|
+ hitResult = density != 0.0f ? net.minecraft.world.phys.HitResult.Type.MISS : net.minecraft.world.phys.HitResult.Type.BLOCK;
|
|
+ } else {
|
|
+ hitResult = entity.level().clip(new ClipContext(vec3, explosionVector, ClipContext.Block.COLLIDER, ClipContext.Fluid.NONE, entity)).getType();
|
|
+ }
|
|
+ if (hitResult == HitResult.Type.MISS) {
|
|
+ // Sakura end - replace density cache
|
|
i++;
|
|
}
|
|
|
|
@@ -691,6 +704,11 @@ public class ServerExplosion implements Explosion {
|
|
return;
|
|
}
|
|
// CraftBukkit end
|
|
+ // Sakura start - explosion density cache
|
|
+ if (!blocks.isEmpty() && !this.level.paperConfig().environment.optimizeExplosions) {
|
|
+ this.level.densityCache.invalidate();
|
|
+ }
|
|
+ // Sakura end - explosion density cache
|
|
|
|
for (BlockPos blockPos : blocks) {
|
|
// CraftBukkit start - TNTPrimeEvent
|
|
@@ -857,14 +875,12 @@ public class ServerExplosion implements Explosion {
|
|
|
|
// Paper start - Optimize explosions
|
|
protected float getBlockDensity(Vec3 vec3d, Entity entity) {
|
|
- if (!this.level.paperConfig().environment.optimizeExplosions) {
|
|
- return this.getSeenFraction(vec3d, entity, this.directMappedBlockCache, this.mutablePos); // Paper - collision optimisations
|
|
- }
|
|
- CacheKey key = new CacheKey(this, entity.getBoundingBox());
|
|
- Float blockDensity = this.level.explosionDensityCache.get(key);
|
|
- if (blockDensity == null) {
|
|
+ // Sakura start - replace density cache
|
|
+ float blockDensity = this.level.densityCache.getDensity(vec3d, entity);
|
|
+ if (blockDensity == me.samsuik.sakura.explosion.density.BlockDensityCache.UNKNOWN_DENSITY) {
|
|
blockDensity = this.getSeenFraction(vec3d, entity, this.directMappedBlockCache, this.mutablePos); // Paper - collision optimisations
|
|
- this.level.explosionDensityCache.put(key, blockDensity);
|
|
+ this.level.densityCache.putDensity(vec3d, entity, blockDensity);
|
|
+ // Sakura end - replace density cache
|
|
}
|
|
|
|
return blockDensity;
|
|
diff --git a/net/minecraft/world/level/block/BasePressurePlateBlock.java b/net/minecraft/world/level/block/BasePressurePlateBlock.java
|
|
index 69d490c79e30fb42da69bbd804ecaea7b88fe7b0..497409e04dc4b9366da1fbe0641b8424c727a176 100644
|
|
--- a/net/minecraft/world/level/block/BasePressurePlateBlock.java
|
|
+++ b/net/minecraft/world/level/block/BasePressurePlateBlock.java
|
|
@@ -109,6 +109,11 @@ public abstract class BasePressurePlateBlock extends Block {
|
|
// CraftBukkit end
|
|
if (currentSignal != signalStrength) {
|
|
BlockState blockState = this.setSignalForState(state, signalStrength);
|
|
+ // Sakura start - explosion density cache
|
|
+ if (!level.paperConfig().environment.optimizeExplosions) {
|
|
+ level.densityCache.invalidate();
|
|
+ }
|
|
+ // Sakura end - explosion density cache
|
|
level.setBlock(pos, blockState, 2);
|
|
this.updateNeighbours(level, pos);
|
|
level.setBlocksDirty(pos, state, blockState);
|
|
diff --git a/net/minecraft/world/level/block/TripWireHookBlock.java b/net/minecraft/world/level/block/TripWireHookBlock.java
|
|
index 30b97cdcd495490ef65c2ab9dfc39a39c93002ca..e57cc9f0987d9d4cda888bc633e5f24e510ec709 100644
|
|
--- a/net/minecraft/world/level/block/TripWireHookBlock.java
|
|
+++ b/net/minecraft/world/level/block/TripWireHookBlock.java
|
|
@@ -182,6 +182,11 @@ public class TripWireHookBlock extends Block {
|
|
if (!cancelledReceiverHook) { // always trigger two events even when the first hook current change is cancelled
|
|
// Paper end - Call BlockRedstoneEvent
|
|
Direction opposite = direction.getOpposite();
|
|
+ // Sakura start - explosion density cache
|
|
+ if (!level.paperConfig().environment.optimizeExplosions) {
|
|
+ level.densityCache.invalidate();
|
|
+ }
|
|
+ // Sakura end - explosion density cache
|
|
level.setBlock(blockPosx, blockState1.setValue(FACING, opposite), 3);
|
|
notifyNeighbors(block, level, blockPosx, opposite);
|
|
emitState(level, blockPosx, flag2, flag3, flag, flag1);
|
|
diff --git a/net/minecraft/world/phys/AABB.java b/net/minecraft/world/phys/AABB.java
|
|
index 85148858db1fd5e9da8bbdde4b0d84110d80e373..23d5a2726f6113eaa79196ac6f6b8db85e386f97 100644
|
|
--- a/net/minecraft/world/phys/AABB.java
|
|
+++ b/net/minecraft/world/phys/AABB.java
|
|
@@ -442,4 +442,28 @@ public class AABB {
|
|
center.x - xSize / 2.0, center.y - ySize / 2.0, center.z - zSize / 2.0, center.x + xSize / 2.0, center.y + ySize / 2.0, center.z + zSize / 2.0
|
|
);
|
|
}
|
|
+
|
|
+ // Sakura start - explosion density cache
|
|
+ public final boolean isAABBInBounds(AABB bb) {
|
|
+ return this.minX <= bb.minX && this.maxX >= bb.maxX
|
|
+ && this.minY <= bb.minY && this.maxY >= bb.maxY
|
|
+ && this.minZ <= bb.minZ && this.maxZ >= bb.maxZ;
|
|
+ }
|
|
+
|
|
+ public final boolean isVec3InBounds(Vec3 p) {
|
|
+ return this.minX <= p.x && this.maxX >= p.x
|
|
+ && this.minY <= p.y && this.maxY >= p.y
|
|
+ && this.minZ <= p.z && this.maxZ >= p.z;
|
|
+ }
|
|
+
|
|
+ public final AABB expand(Vec3 pos) {
|
|
+ double minX = Math.min(this.minX, pos.x);
|
|
+ double minY = Math.min(this.minY, pos.y);
|
|
+ double minZ = Math.min(this.minZ, pos.z);
|
|
+ double maxX = Math.max(this.maxX, pos.x);
|
|
+ double maxY = Math.max(this.maxY, pos.y);
|
|
+ double maxZ = Math.max(this.maxZ, pos.z);
|
|
+ return new AABB(minX, minY, minZ, maxX, maxY, maxZ);
|
|
+ }
|
|
+ // Sakura end - explosion density cache
|
|
}
|