Paper/nms-patches/RegionFileCache.patch

35 Zeilen
1.3 KiB
Diff

--- a/net/minecraft/server/RegionFileCache.java
+++ b/net/minecraft/server/RegionFileCache.java
2017-05-14 04:00:00 +02:00
@@ -74,17 +74,27 @@
RegionFileCache.a.clear();
}
2016-11-17 02:41:03 +01:00
- public static DataInputStream d(File file, int i, int j) {
+ // CraftBukkit start - call sites hoisted for synchronization
2016-11-17 02:41:03 +01:00
+ public static synchronized NBTTagCompound d(File file, int i, int j) throws IOException {
RegionFile regionfile = a(file, i, j);
- return regionfile.a(i & 31, j & 31);
+ DataInputStream datainputstream = regionfile.a(i & 31, j & 31);
+
+ if (datainputstream == null) {
+ return null;
+ }
+
+ return NBTCompressedStreamTools.a(datainputstream);
}
2016-11-17 02:41:03 +01:00
- public static DataOutputStream e(File file, int i, int j) {
+ public static synchronized void e(File file, int i, int j, NBTTagCompound nbttagcompound) throws IOException {
RegionFile regionfile = a(file, i, j);
- return regionfile.b(i & 31, j & 31);
+ DataOutputStream dataoutputstream = regionfile.b(i & 31, j & 31);
+ NBTCompressedStreamTools.a(nbttagcompound, (java.io.DataOutput) dataoutputstream);
+ dataoutputstream.close();
}
+ // CraftBukkit end
2016-11-17 02:41:03 +01:00
2017-05-14 04:00:00 +02:00
public static synchronized boolean chunkExists(File file, int i, int j) {
2016-11-17 02:41:03 +01:00
RegionFile regionfile = b(file, i, j);