Implement asynchronous NBT saving
This commit is contained in:
@@ -0,0 +1,32 @@
|
|||||||
|
package net.gensokyoreimagined.nitori.core;
|
||||||
|
|
||||||
|
import net.minecraft.Util;
|
||||||
|
import net.minecraft.world.entity.player.Player;
|
||||||
|
import net.minecraft.world.level.storage.PlayerDataStorage;
|
||||||
|
import org.bukkit.craftbukkit.CraftServer;
|
||||||
|
import org.bukkit.craftbukkit.entity.CraftPlayer;
|
||||||
|
import org.spongepowered.asm.mixin.Mixin;
|
||||||
|
import org.spongepowered.asm.mixin.injection.At;
|
||||||
|
import org.spongepowered.asm.mixin.injection.Redirect;
|
||||||
|
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
|
||||||
|
@Mixin(CraftPlayer.class)
|
||||||
|
public class MixinCraftPlayer {
|
||||||
|
@Redirect(method = "saveData", at = @At(value = "INVOKE", target = "Lnet/minecraft/world/level/storage/PlayerDataStorage;save(Lnet/minecraft/world/entity/player/Player;)V"))
|
||||||
|
private void gensouHacks$savePlayerData(PlayerDataStorage instance, Player path) {
|
||||||
|
Runnable writeRunnable = () -> {
|
||||||
|
var craftPlayer = (CraftPlayer) (Object) this;
|
||||||
|
var server = craftPlayer.getServer();
|
||||||
|
|
||||||
|
if (server instanceof CraftServer craftServer) {
|
||||||
|
var handle = craftPlayer.getHandle();
|
||||||
|
var playerIo = craftServer.getHandle().playerIo;
|
||||||
|
playerIo.save(handle);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
var ioExecutor = Util.backgroundExecutor();
|
||||||
|
CompletableFuture.runAsync(writeRunnable, ioExecutor);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,32 @@
|
|||||||
|
package net.gensokyoreimagined.nitori.core;
|
||||||
|
|
||||||
|
import net.minecraft.Util;
|
||||||
|
import net.minecraft.nbt.CompoundTag;
|
||||||
|
import net.minecraft.world.level.storage.LevelStorageSource;
|
||||||
|
import org.spongepowered.asm.mixin.Mixin;
|
||||||
|
import org.spongepowered.asm.mixin.Shadow;
|
||||||
|
import org.spongepowered.asm.mixin.injection.At;
|
||||||
|
import org.spongepowered.asm.mixin.injection.Redirect;
|
||||||
|
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
|
||||||
|
@Mixin(LevelStorageSource.LevelStorageAccess.class)
|
||||||
|
public abstract class MixinLevelStorageAccess {
|
||||||
|
@Shadow protected abstract void saveLevelData(CompoundTag nbt);
|
||||||
|
|
||||||
|
@Redirect(method = "modifyLevelDataWithoutDatafix", at = @At(value = "INVOKE", target = "Lnet/minecraft/world/level/storage/LevelStorageSource$LevelStorageAccess;saveLevelData(Lnet/minecraft/nbt/CompoundTag;)V"))
|
||||||
|
private void gensouHacks$saveLevelData(LevelStorageSource.LevelStorageAccess levelStorageAccess, CompoundTag compoundTag) {
|
||||||
|
Runnable writeRunnable = () -> saveLevelData(compoundTag);
|
||||||
|
|
||||||
|
var ioExecutor = Util.backgroundExecutor();
|
||||||
|
CompletableFuture.runAsync(writeRunnable, ioExecutor);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Redirect(method = "saveDataTag(Lnet/minecraft/core/RegistryAccess;Lnet/minecraft/world/level/storage/WorldData;Lnet/minecraft/nbt/CompoundTag;)V", at = @At(value = "INVOKE", target = "Lnet/minecraft/world/level/storage/LevelStorageSource$LevelStorageAccess;saveLevelData(Lnet/minecraft/nbt/CompoundTag;)V"))
|
||||||
|
private void gensouHacks$saveLevelData2(LevelStorageSource.LevelStorageAccess levelStorageAccess, CompoundTag compoundTag) {
|
||||||
|
Runnable writeRunnable = () -> saveLevelData(compoundTag);
|
||||||
|
|
||||||
|
var ioExecutor = Util.backgroundExecutor();
|
||||||
|
CompletableFuture.runAsync(writeRunnable, ioExecutor);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,28 @@
|
|||||||
|
package net.gensokyoreimagined.nitori.core;
|
||||||
|
|
||||||
|
import net.minecraft.Util;
|
||||||
|
import net.minecraft.server.players.PlayerList;
|
||||||
|
import net.minecraft.world.entity.player.Player;
|
||||||
|
import net.minecraft.world.level.storage.PlayerDataStorage;
|
||||||
|
import org.spongepowered.asm.mixin.Final;
|
||||||
|
import org.spongepowered.asm.mixin.Mixin;
|
||||||
|
import org.spongepowered.asm.mixin.Shadow;
|
||||||
|
import org.spongepowered.asm.mixin.injection.At;
|
||||||
|
import org.spongepowered.asm.mixin.injection.Redirect;
|
||||||
|
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
|
||||||
|
@Mixin(PlayerList.class)
|
||||||
|
public class MixinPlayerList {
|
||||||
|
@Final
|
||||||
|
@Shadow
|
||||||
|
public PlayerDataStorage playerIo;
|
||||||
|
|
||||||
|
@Redirect(method = "save", at = @At(value = "INVOKE", target = "Lnet/minecraft/world/level/storage/PlayerDataStorage;save(Lnet/minecraft/world/entity/player/Player;)V"))
|
||||||
|
private void gensouHacks$savePlayerData(PlayerDataStorage instance, Player player) {
|
||||||
|
Runnable writeRunnable = () -> playerIo.save(player);
|
||||||
|
|
||||||
|
var ioExecutor = Util.backgroundExecutor();
|
||||||
|
CompletableFuture.runAsync(writeRunnable, ioExecutor);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -26,6 +26,9 @@
|
|||||||
"MixinWorldGenRegion",
|
"MixinWorldGenRegion",
|
||||||
"ChunkMapMixin",
|
"ChunkMapMixin",
|
||||||
"ChunkMapMixin$TrackedEntity",
|
"ChunkMapMixin$TrackedEntity",
|
||||||
"MixinReobfServer"
|
"MixinReobfServer",
|
||||||
|
"MixinLevelStorageAccess",
|
||||||
|
"MixinPlayerList",
|
||||||
|
"MixinCraftPlayer"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user