From 6a4ab717220a83974374212bd1c3e75e12b7c429 Mon Sep 17 00:00:00 2001 From: Paul19988 Date: Sat, 16 Jan 2021 00:51:00 +0000 Subject: [PATCH] Fixed head texture load issue --- .../grinderwolf/swm/nms/CraftSlimeWorld.java | 3 ++ .../swm/nms/v1_16_R3/Converter.java | 1 - .../swm/nms/v1_16_R3/CustomWorldServer.java | 29 ++++++++++++++++--- 3 files changed, 28 insertions(+), 5 deletions(-) diff --git a/slimeworldmanager-nms-common/src/main/java/com/grinderwolf/swm/nms/CraftSlimeWorld.java b/slimeworldmanager-nms-common/src/main/java/com/grinderwolf/swm/nms/CraftSlimeWorld.java index df3c73f0..95f8372f 100644 --- a/slimeworldmanager-nms-common/src/main/java/com/grinderwolf/swm/nms/CraftSlimeWorld.java +++ b/slimeworldmanager-nms-common/src/main/java/com/grinderwolf/swm/nms/CraftSlimeWorld.java @@ -185,6 +185,9 @@ public byte[] serialize() { outStream.writeInt(tileEntitiesData.length); outStream.write(compressedTileEntitiesData); +// System.out.println("HEADS: "); +// System.out.println("TILES: " + tileEntitiesList.toString()); + // Entities List entitiesList = sortedChunks.stream().flatMap(chunk -> chunk.getEntities().stream()).collect(Collectors.toList()); diff --git a/slimeworldmanager-nms-v1_16_R3/src/main/java/com/grinderwolf/swm/nms/v1_16_R3/Converter.java b/slimeworldmanager-nms-v1_16_R3/src/main/java/com/grinderwolf/swm/nms/v1_16_R3/Converter.java index 27a6c7cb..353f6165 100644 --- a/slimeworldmanager-nms-v1_16_R3/src/main/java/com/grinderwolf/swm/nms/v1_16_R3/Converter.java +++ b/slimeworldmanager-nms-v1_16_R3/src/main/java/com/grinderwolf/swm/nms/v1_16_R3/Converter.java @@ -79,7 +79,6 @@ static NBTBase convertTag(Tag tag) { NBTTagCompound compound = new NBTTagCompound(); ((CompoundTag) tag).getValue().forEach((key, value) -> compound.set(key, convertTag(value))); - return compound; case TAG_INT_ARRAY: return new NBTTagIntArray(((IntArrayTag) tag).getValue()); diff --git a/slimeworldmanager-nms-v1_16_R3/src/main/java/com/grinderwolf/swm/nms/v1_16_R3/CustomWorldServer.java b/slimeworldmanager-nms-v1_16_R3/src/main/java/com/grinderwolf/swm/nms/v1_16_R3/CustomWorldServer.java index 06064f07..0e3df67d 100644 --- a/slimeworldmanager-nms-v1_16_R3/src/main/java/com/grinderwolf/swm/nms/v1_16_R3/CustomWorldServer.java +++ b/slimeworldmanager-nms-v1_16_R3/src/main/java/com/grinderwolf/swm/nms/v1_16_R3/CustomWorldServer.java @@ -11,6 +11,8 @@ import com.grinderwolf.swm.api.world.properties.SlimePropertyMap; import com.grinderwolf.swm.nms.CraftSlimeChunk; import com.grinderwolf.swm.nms.CraftSlimeWorld; +import com.mojang.authlib.GameProfile; +import com.mojang.authlib.properties.Property; import lombok.Getter; import lombok.Setter; import net.minecraft.server.v1_16_R3.*; @@ -25,6 +27,7 @@ import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.function.Consumer; +import java.util.logging.Level; public class CustomWorldServer extends WorldServer { @@ -106,11 +109,11 @@ public void save(IProgressUpdate progressUpdate, boolean forceSave, boolean flag private void save() { synchronized (saveLock) { // Don't want to save the SlimeWorld from multiple threads simultaneously try { -// LOGGER.info("Saving world " + slimeWorld.getName() + "..."); + Bukkit.getLogger().log(Level.INFO, "Saving world " + slimeWorld.getName() + "..."); long start = System.currentTimeMillis(); byte[] serializedWorld = slimeWorld.serialize(); slimeWorld.getLoader().saveWorld(slimeWorld.getName(), serializedWorld, false); -// LOGGER.info("World " + slimeWorld.getName() + " saved in " + (System.currentTimeMillis() - start) + "ms."); + Bukkit.getLogger().log(Level.INFO, "World " + slimeWorld.getName() + " saved in " + (System.currentTimeMillis() - start) + "ms."); } catch (IOException ex) { ex.printStackTrace(); } @@ -229,10 +232,28 @@ private Chunk createChunk(SlimeChunk chunk) { // Sometimes null tile entities are saved if (type.isPresent()) { - IBlockData blockData = nmsChunk.getType(new BlockPosition(tag.getIntValue("x").get(), tag.getIntValue("y").get(), tag.getIntValue("z").get())); + BlockPosition blockPosition = new BlockPosition(tag.getIntValue("x").get(), tag.getIntValue("y").get(), tag.getIntValue("z").get()); + IBlockData blockData = nmsChunk.getType(blockPosition); TileEntity entity = TileEntity.create(blockData, (NBTTagCompound) Converter.convertTag(tag)); - if (entity != null) { + if(type.get().toLowerCase().contains("skull") || type.get().toLowerCase().contains("head")) { + NBTTagCompound nbtTagCompound = (NBTTagCompound) Converter.convertTag(tag); + if(tag.getAsCompoundTag("SkullOwner").isPresent()) { + if(tag.getAsCompoundTag("SkullOwner").get().getAsCompoundTag("Properties").isPresent()) { + TileEntitySkull entitySkull = (TileEntitySkull) entity; + String texture = nbtTagCompound.getCompound("SkullOwner").getCompound("Properties").get("textures").toString().split(":")[1].replace("\"", ""); + texture = texture.replace("}", ""); + texture = texture.replace("]", ""); + + GameProfile gameProfile = new GameProfile(UUID.randomUUID(), UUID.randomUUID().toString()); + Property property = new Property("textures", texture); + gameProfile.getProperties().put("textures", property); + entitySkull.setGameProfile(gameProfile); + + entitySkull.update(); + } + } + } nmsChunk.a(entity); loadedEntities++; }