2021-06-11 12:02:28 +00:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Spottedleaf <Spottedleaf@users.noreply.github.com>
Date: Tue, 14 Jan 2020 14:59:08 -0800
Subject: [PATCH] Optimise Chunk#getFluid
Removing the try catch and generally reducing ops should make it
faster on its own, however removing the try catch makes it
easier to inline due to code size
diff --git a/src/main/java/net/minecraft/world/level/chunk/LevelChunk.java b/src/main/java/net/minecraft/world/level/chunk/LevelChunk.java
2022-09-26 08:02:51 +00:00
index bc573695ace324c7cd536bc24fbfc66a53ef9fa0..bd1c957a9405ccf18f110c7976cf8e0af922cf78 100644
2021-06-11 12:02:28 +00:00
--- a/src/main/java/net/minecraft/world/level/chunk/LevelChunk.java
+++ b/src/main/java/net/minecraft/world/level/chunk/LevelChunk.java
2022-09-26 08:02:51 +00:00
@@ -427,18 +427,20 @@ public class LevelChunk extends ChunkAccess {
2021-06-11 12:02:28 +00:00
}
public FluidState getFluidState(int x, int y, int z) {
- try {
2021-06-13 22:05:18 +00:00
- int l = this.getSectionIndex(y);
-
- if (l >= 0 && l < this.sections.length) {
- LevelChunkSection chunksection = this.sections[l];
+ // try { // Paper - remove try catch
2021-06-11 12:02:28 +00:00
+ // Paper start - reduce the number of ops in this call
2021-06-13 22:05:18 +00:00
+ int index = this.getSectionIndex(y);
2021-06-11 12:02:28 +00:00
+ if (index >= 0 && index < this.sections.length) {
+ LevelChunkSection chunksection = this.sections[index];
2021-11-24 09:01:27 +00:00
if (!chunksection.hasOnlyAir()) {
- return chunksection.getFluidState(x & 15, y & 15, z & 15);
2021-06-11 12:02:28 +00:00
+ return chunksection.states.get((y & 15) << 8 | (z & 15) << 4 | x & 15).getFluidState();
2021-11-24 09:01:27 +00:00
+ // Paper end
2021-06-11 12:02:28 +00:00
}
}
return Fluids.EMPTY.defaultFluidState();
2021-06-13 22:05:18 +00:00
+ /* // Paper - remove try catch
} catch (Throwable throwable) {
CrashReport crashreport = CrashReport.forThrowable(throwable, "Getting fluid state");
CrashReportCategory crashreportsystemdetails = crashreport.addCategory("Block being got");
2022-09-26 08:02:51 +00:00
@@ -448,6 +450,7 @@ public class LevelChunk extends ChunkAccess {
2021-06-11 12:02:28 +00:00
});
throw new ReportedException(crashreport);
}
+ */ // Paper - remove try catch
}
// CraftBukkit start
diff --git a/src/main/java/net/minecraft/world/level/chunk/LevelChunkSection.java b/src/main/java/net/minecraft/world/level/chunk/LevelChunkSection.java
2022-07-21 19:53:04 +00:00
index 785fbcf9bafcdec1c5be213de3d8512690023415..066874d27495dcaa3dea254b7328257e46920357 100644
2021-06-11 12:02:28 +00:00
--- a/src/main/java/net/minecraft/world/level/chunk/LevelChunkSection.java
+++ b/src/main/java/net/minecraft/world/level/chunk/LevelChunkSection.java
2022-06-08 04:06:41 +00:00
@@ -54,7 +54,7 @@ public class LevelChunkSection {
2021-06-11 12:02:28 +00:00
}
public FluidState getFluidState(int x, int y, int z) {
2021-11-24 09:01:27 +00:00
- return ((BlockState) this.states.get(x, y, z)).getFluidState();
2021-06-13 22:05:18 +00:00
+ return this.states.get(x, y, z).getFluidState(); // Paper - diff on change - we expect this to be effectively just getType(x, y, z).getFluid(). If this changes we need to check other patches that use IBlockData#getFluid.
2021-06-11 12:02:28 +00:00
}
public void acquire() {