| 
									
										
										
										
											2021-06-11 14:02:28 +02:00
										 |  |  | From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 | 
					
						
							|  |  |  | From: Aikar <aikar@aikar.co> | 
					
						
							|  |  |  | Date: Fri, 18 Mar 2016 20:16:03 -0400 | 
					
						
							|  |  |  | Subject: [PATCH] Add World Util Methods | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Methods that can be used for other patches to help improve logic. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | diff --git a/src/main/java/net/minecraft/server/level/ServerLevel.java b/src/main/java/net/minecraft/server/level/ServerLevel.java
 | 
					
						
							|  |  |  | index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
 | 
					
						
							|  |  |  | --- a/src/main/java/net/minecraft/server/level/ServerLevel.java
 | 
					
						
							|  |  |  | +++ b/src/main/java/net/minecraft/server/level/ServerLevel.java
 | 
					
						
							| 
									
										
										
										
											2021-07-11 00:01:29 -07:00
										 |  |  | @@ -0,0 +0,0 @@ public class ServerLevel extends Level implements WorldGenLevel {
 | 
					
						
							| 
									
										
										
										
											2021-06-11 14:02:28 +02:00
										 |  |  |      public final LevelStorageSource.LevelStorageAccess convertable; | 
					
						
							|  |  |  |      public final UUID uuid; | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | -    public LevelChunk getChunkIfLoaded(int x, int z) {
 | 
					
						
							|  |  |  | +    @Override public LevelChunk getChunkIfLoaded(int x, int z) { // Paper - this was added in world too but keeping here for NMS ABI
 | 
					
						
							|  |  |  |          return this.chunkSource.getChunk(x, z, false); | 
					
						
							|  |  |  |      } | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | diff --git a/src/main/java/net/minecraft/world/level/Level.java b/src/main/java/net/minecraft/world/level/Level.java
 | 
					
						
							|  |  |  | index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
 | 
					
						
							|  |  |  | --- a/src/main/java/net/minecraft/world/level/Level.java
 | 
					
						
							|  |  |  | +++ b/src/main/java/net/minecraft/world/level/Level.java
 | 
					
						
							|  |  |  | @@ -0,0 +0,0 @@ public abstract class Level implements LevelAccessor, AutoCloseable {
 | 
					
						
							|  |  |  |          return chunk == null ? null : chunk.getFluidState(blockposition); | 
					
						
							|  |  |  |      } | 
					
						
							| 
									
										
										
										
											2021-12-05 15:32:02 -08:00
										 |  |  |   | 
					
						
							| 
									
										
										
										
											2021-06-11 14:02:28 +02:00
										 |  |  | +    public final boolean isLoadedAndInBounds(BlockPos blockposition) { // Paper - final for inline
 | 
					
						
							| 
									
										
										
										
											2021-06-17 14:39:36 -07:00
										 |  |  | +        return getWorldBorder().isWithinBounds(blockposition) && getChunkIfLoadedImmediately(blockposition.getX() >> 4, blockposition.getZ() >> 4) != null;
 | 
					
						
							| 
									
										
										
										
											2021-06-11 14:02:28 +02:00
										 |  |  | +    }
 | 
					
						
							|  |  |  | +
 | 
					
						
							| 
									
										
										
										
											2021-12-05 15:32:02 -08:00
										 |  |  | +    public @Nullable LevelChunk getChunkIfLoaded(int x, int z) { // Overridden in WorldServer for ABI compat which has final
 | 
					
						
							| 
									
										
										
										
											2021-06-11 14:02:28 +02:00
										 |  |  | +        return ((ServerLevel) this).getChunkSource().getChunkAtIfLoadedImmediately(x, z);
 | 
					
						
							|  |  |  | +    }
 | 
					
						
							| 
									
										
										
										
											2021-12-05 15:32:02 -08:00
										 |  |  | +    public final @Nullable LevelChunk getChunkIfLoaded(BlockPos blockposition) {
 | 
					
						
							| 
									
										
										
										
											2021-06-11 14:02:28 +02:00
										 |  |  | +        return ((ServerLevel) this).getChunkSource().getChunkAtIfLoadedImmediately(blockposition.getX() >> 4, blockposition.getZ() >> 4);
 | 
					
						
							|  |  |  | +    }
 | 
					
						
							|  |  |  | +
 | 
					
						
							|  |  |  | +    //  reduces need to do isLoaded before getType
 | 
					
						
							| 
									
										
										
										
											2021-12-05 15:32:02 -08:00
										 |  |  | +    public final @Nullable BlockState getBlockStateIfLoadedAndInBounds(BlockPos blockposition) {
 | 
					
						
							|  |  |  | +        return getWorldBorder().isWithinBounds(blockposition) ? getBlockStateIfLoaded(blockposition) : null;
 | 
					
						
							| 
									
										
										
										
											2021-06-11 14:02:28 +02:00
										 |  |  | +    }
 | 
					
						
							| 
									
										
										
										
											2021-12-05 15:32:02 -08:00
										 |  |  | +
 | 
					
						
							| 
									
										
										
										
											2021-06-11 14:02:28 +02:00
										 |  |  |      @Override | 
					
						
							| 
									
										
										
										
											2021-12-05 15:32:02 -08:00
										 |  |  |      public final ChunkAccess getChunk(int chunkX, int chunkZ, ChunkStatus leastStatus, boolean create) { // Paper - final for inline | 
					
						
							|  |  |  |          // Paper end |