2020-05-17 04:05:14 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Spottedleaf <spottedleaf@spottedleaf.dev>
|
|
|
|
Date: Mon, 27 Apr 2020 02:48:06 -0700
|
|
|
|
Subject: [PATCH] Reduce MutableInt allocations from light engine
|
|
|
|
|
2020-06-05 07:25:11 +02:00
|
|
|
We can abuse the fact light is single threaded and share an instance
|
|
|
|
per light engine instance
|
2020-05-17 04:05:14 +02:00
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/LightEngineBlock.java b/src/main/java/net/minecraft/server/LightEngineBlock.java
|
2020-06-05 07:25:11 +02:00
|
|
|
index 93a972605c26aa757b9c915876f847da04fcb496..07fadc21ee12138b52cc77c50da536fec5b032f5 100644
|
2020-05-17 04:05:14 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/LightEngineBlock.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/LightEngineBlock.java
|
2020-06-05 07:25:11 +02:00
|
|
|
@@ -6,6 +6,7 @@ public final class LightEngineBlock extends LightEngineLayer<LightEngineStorageB
|
|
|
|
|
|
|
|
private static final EnumDirection[] e = EnumDirection.values();
|
|
|
|
private final BlockPosition.MutableBlockPosition f = new BlockPosition.MutableBlockPosition();
|
|
|
|
+ private final MutableInt mutableint = new MutableInt(); // Paper
|
|
|
|
|
|
|
|
public LightEngineBlock(ILightAccess ilightaccess) {
|
|
|
|
super(ilightaccess, EnumSkyBlock.BLOCK, new LightEngineStorageBlock(ilightaccess));
|
|
|
|
@@ -37,7 +38,7 @@ public final class LightEngineBlock extends LightEngineLayer<LightEngineStorageB
|
2020-05-17 04:05:14 +02:00
|
|
|
if (enumdirection == null) {
|
|
|
|
return 15;
|
|
|
|
} else {
|
|
|
|
- MutableInt mutableint = new MutableInt();
|
2020-06-05 07:25:11 +02:00
|
|
|
+ //MutableInt mutableint = new MutableInt(); // Paper - share mutableint, single threaded
|
2020-05-17 04:05:14 +02:00
|
|
|
IBlockData iblockdata = this.a(j, mutableint);
|
|
|
|
|
|
|
|
if (mutableint.getValue() >= 15) {
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/LightEngineSky.java b/src/main/java/net/minecraft/server/LightEngineSky.java
|
2020-06-05 07:25:11 +02:00
|
|
|
index 2301a982e17ab9568e3da9ca84c4a024c7c1b214..f0b57784006752e031800a12a1a3c1a5945c636b 100644
|
2020-05-17 04:05:14 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/LightEngineSky.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/LightEngineSky.java
|
2020-06-05 07:25:11 +02:00
|
|
|
@@ -6,6 +6,7 @@ public final class LightEngineSky extends LightEngineLayer<LightEngineStorageSky
|
|
|
|
|
|
|
|
private static final EnumDirection[] e = EnumDirection.values();
|
|
|
|
private static final EnumDirection[] f = new EnumDirection[]{EnumDirection.NORTH, EnumDirection.SOUTH, EnumDirection.WEST, EnumDirection.EAST};
|
|
|
|
+ private final MutableInt mutableint = new MutableInt(); // Paper
|
|
|
|
|
|
|
|
public LightEngineSky(ILightAccess ilightaccess) {
|
|
|
|
super(ilightaccess, EnumSkyBlock.SKY, new LightEngineStorageSky(ilightaccess));
|
|
|
|
@@ -27,7 +28,7 @@ public final class LightEngineSky extends LightEngineLayer<LightEngineStorageSky
|
2020-05-17 04:05:14 +02:00
|
|
|
if (k >= 15) {
|
|
|
|
return k;
|
|
|
|
} else {
|
|
|
|
- MutableInt mutableint = new MutableInt();
|
2020-06-05 07:25:11 +02:00
|
|
|
+ //MutableInt mutableint = new MutableInt(); // Paper - share mutableint, single threaded
|
2020-05-17 04:05:14 +02:00
|
|
|
IBlockData iblockdata = this.a(j, mutableint);
|
|
|
|
|
|
|
|
if (mutableint.getValue() >= 15) {
|