 01a13871de
			
		
	
	
	
	
	01a13871dePatch documentation to come Issues with the old system that are fixed now: - World generation does not scale with cpu cores effectively. - Relies on the main thread for scheduling and maintaining chunk state, dropping chunk load/generate rates at lower tps. - Unreliable prioritisation of chunk gen/load calls that block the main thread. - Shutdown logic is utterly unreliable, as it has to wait for all chunks to unload - is it guaranteed that the chunk system is in a state on shutdown that it can reliably do this? Watchdog shutdown also typically failed due to thread checks, which is now resolved. - Saving of data is not unified (i.e can save chunk data without saving entity data, poses problems for desync if shutdown is really abnormal. - Entities are not loaded with chunks. This caused quite a bit of headache for Chunk#getEntities API, but now the new chunk system loads entities with chunks so that they are ready whenever the chunk loads in. Effectively brings the behavior back to 1.16 era, but still storing entities in their own separate regionfiles. The above list is not complete. The patch documentation will complete it. New chunk system hard relies on starlight and dataconverter, and most importantly the new concurrent utilities in ConcurrentUtil. Some of the old async chunk i/o interface (i.e the old file io thread reroutes _some_ calls to the new file io thread) is kept for plugin compat reasons. It will be removed in the next major version of minecraft. The old legacy chunk system patches have been moved to the removed folder in case we need them again.
		
			
				
	
	
		
			63 lines
		
	
	
	
		
			2.6 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
	
		
			2.6 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
 | |
| From: Aikar <aikar@aikar.co>
 | |
| Date: Mon, 29 Jun 2020 03:26:17 -0400
 | |
| Subject: [PATCH] Support old UUID format for NBT
 | |
| 
 | |
| We have stored UUID in plenty of places that did not get DFU'd
 | |
| 
 | |
| So just look for old format and load it if it exists.
 | |
| 
 | |
| diff --git a/src/main/java/net/minecraft/nbt/CompoundTag.java b/src/main/java/net/minecraft/nbt/CompoundTag.java
 | |
| index 0778fdd4f47015787f7ffbfb39c31ec0e1c039bd..912fd5135e89348bdd3c0a8b6c07860ebc106df3 100644
 | |
| --- a/src/main/java/net/minecraft/nbt/CompoundTag.java
 | |
| +++ b/src/main/java/net/minecraft/nbt/CompoundTag.java
 | |
| @@ -181,6 +181,12 @@ public class CompoundTag implements Tag {
 | |
|      }
 | |
|  
 | |
|      public void putUUID(String key, UUID value) {
 | |
| +        // Paper start - support old format
 | |
| +        if (this.contains(key + "Most", 99) && this.contains(key + "Least", 99)) {
 | |
| +            this.tags.remove(key + "Most");
 | |
| +            this.tags.remove(key + "Least");
 | |
| +        }
 | |
| +        // Paper end
 | |
|          this.tags.put(key, NbtUtils.createUUID(value));
 | |
|      }
 | |
|  
 | |
| @@ -189,10 +195,20 @@ public class CompoundTag implements Tag {
 | |
|       * You must use {@link #hasUUID(String)} before or else it <b>will</b> throw an NPE.
 | |
|       */
 | |
|      public UUID getUUID(String key) {
 | |
| +        // Paper start - support old format
 | |
| +        if (!contains(key, 11) && this.contains(key + "Most", 99) && this.contains(key + "Least", 99)) {
 | |
| +            return new UUID(this.getLong(key + "Most"), this.getLong(key + "Least"));
 | |
| +        }
 | |
| +        // Paper end
 | |
|          return NbtUtils.loadUUID(this.get(key));
 | |
|      }
 | |
|  
 | |
|      public boolean hasUUID(String key) {
 | |
| +        // Paper start - support old format
 | |
| +        if (this.contains(key + "Most", 99) && this.contains(key + "Least", 99)) {
 | |
| +            return true;
 | |
| +        }
 | |
| +        // Paper end
 | |
|          Tag tag = this.get(key);
 | |
|          return tag != null && tag.getType() == IntArrayTag.TYPE && ((IntArrayTag)tag).getAsIntArray().length == 4;
 | |
|      }
 | |
| diff --git a/src/main/java/net/minecraft/nbt/NbtUtils.java b/src/main/java/net/minecraft/nbt/NbtUtils.java
 | |
| index d6d8adf1e49cdb74dc5d8e2e60bcaca7c5e1c16d..b31741a9c3363e4288636ceff9b38c598a84aa43 100644
 | |
| --- a/src/main/java/net/minecraft/nbt/NbtUtils.java
 | |
| +++ b/src/main/java/net/minecraft/nbt/NbtUtils.java
 | |
| @@ -75,6 +75,11 @@ public final class NbtUtils {
 | |
|          if (nbt.contains("Name", 8)) {
 | |
|              string = nbt.getString("Name");
 | |
|          }
 | |
| +        // Paper start - support string UUID's
 | |
| +        if (nbt.contains("Id", 8)) {
 | |
| +            uUID = UUID.fromString(nbt.getString("Id"));
 | |
| +        }
 | |
| +        // Paper end
 | |
|  
 | |
|          if (nbt.hasUUID("Id")) {
 | |
|              uUID = nbt.getUUID("Id");
 |