SPIGOT-2385: RegionFileCache synchronization issues
By: md_5 <git@md-5.net>
This commit is contained in:
parent
f5e45ed35f
commit
c93d857872
2 changed files with 69 additions and 7 deletions
32
paper-server/nms-patches/RegionFileCache.patch
Normal file
32
paper-server/nms-patches/RegionFileCache.patch
Normal file
|
@ -0,0 +1,32 @@
|
|||
--- a/net/minecraft/server/RegionFileCache.java
|
||||
+++ b/net/minecraft/server/RegionFileCache.java
|
||||
@@ -53,15 +53,25 @@
|
||||
RegionFileCache.a.clear();
|
||||
}
|
||||
|
||||
- public static DataInputStream c(File file, int i, int j) {
|
||||
+ // CraftBukkit start - call sites hoisted for synchronization
|
||||
+ public static synchronized NBTTagCompound c(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);
|
||||
}
|
||||
|
||||
- public static DataOutputStream d(File file, int i, int j) {
|
||||
+ public static synchronized void d(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
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue