2019-12-12 17:20:43 +01:00
|
|
|
From 9d1b272b4ccf35d5f84c79ca400de67e0a6b3d3b Mon Sep 17 00:00:00 2001
|
2018-12-12 04:32:39 +01:00
|
|
|
From: Zach Brown <zach@zachbr.io>
|
|
|
|
Date: Tue, 11 Dec 2018 22:25:07 -0500
|
|
|
|
Subject: [PATCH] Lazy init world storage in CraftOfflinePlayer
|
|
|
|
|
|
|
|
Allows access to some offline player properties even when there are no
|
|
|
|
worlds loaded. This is typically a rare occurrence but probably one that
|
|
|
|
should be covered as best we can.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftOfflinePlayer.java b/src/main/java/org/bukkit/craftbukkit/CraftOfflinePlayer.java
|
2019-12-12 17:20:43 +01:00
|
|
|
index 6a448c02e..c1ef1c950 100644
|
2018-12-12 04:32:39 +01:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftOfflinePlayer.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftOfflinePlayer.java
|
2019-05-05 19:19:34 +02:00
|
|
|
@@ -25,12 +25,12 @@ import org.bukkit.plugin.Plugin;
|
2018-12-12 04:32:39 +01:00
|
|
|
public class CraftOfflinePlayer implements OfflinePlayer, ConfigurationSerializable {
|
|
|
|
private final GameProfile profile;
|
|
|
|
private final CraftServer server;
|
|
|
|
- private final WorldNBTStorage storage;
|
|
|
|
+ private WorldNBTStorage storage; // Paper - lazy init
|
|
|
|
|
|
|
|
protected CraftOfflinePlayer(CraftServer server, GameProfile profile) {
|
|
|
|
this.server = server;
|
|
|
|
this.profile = profile;
|
|
|
|
- this.storage = (WorldNBTStorage) (server.console.getWorldServer(DimensionManager.OVERWORLD).getDataManager());
|
|
|
|
+ //this.storage = (WorldNBTStorage) (server.console.getWorldServer(DimensionManager.OVERWORLD).getDataManager()); // Paper - lazy init
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2019-05-06 04:58:04 +02:00
|
|
|
@@ -177,8 +177,23 @@ public class CraftOfflinePlayer implements OfflinePlayer, ConfigurationSerializa
|
2018-12-12 04:32:39 +01:00
|
|
|
return hash;
|
|
|
|
}
|
|
|
|
|
|
|
|
+ // Paper - lazy
|
|
|
|
+ private WorldNBTStorage getStorageLazy() {
|
|
|
|
+ if (this.storage == null) {
|
|
|
|
+ net.minecraft.server.WorldServer worldServer = server.console.getWorldServer(DimensionManager.OVERWORLD);
|
|
|
|
+ if (worldServer == null) {
|
|
|
|
+ throw new IllegalStateException("Cannot get world storage when there are no worlds loaded!");
|
|
|
|
+ } else {
|
|
|
|
+ this.storage = (WorldNBTStorage) worldServer.getDataManager();
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ return this.storage;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
+
|
|
|
|
private NBTTagCompound getData() {
|
|
|
|
- return storage.getPlayerData(getUniqueId().toString());
|
|
|
|
+ return getStorageLazy().getPlayerData(getUniqueId().toString());
|
|
|
|
}
|
|
|
|
|
|
|
|
private NBTTagCompound getBukkitData() {
|
2019-05-06 04:58:04 +02:00
|
|
|
@@ -195,7 +210,7 @@ public class CraftOfflinePlayer implements OfflinePlayer, ConfigurationSerializa
|
2018-12-12 04:32:39 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
private File getDataFile() {
|
|
|
|
- return new File(storage.getPlayerDir(), getUniqueId() + ".dat");
|
|
|
|
+ return new File(getStorageLazy().getPlayerDir(), getUniqueId() + ".dat");
|
|
|
|
}
|
|
|
|
|
2019-05-06 04:58:04 +02:00
|
|
|
@Override
|
2018-12-12 04:32:39 +01:00
|
|
|
--
|
2019-12-12 17:20:43 +01:00
|
|
|
2.17.1
|
2018-12-12 04:32:39 +01:00
|
|
|
|