aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/api/0431-Add-Structure-check-API.patch
blob: e2d19afb3258ed71ca36704413ab309f9672c339 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Jake Potrebic <jake.m.potrebic@gmail.com>
Date: Mon, 27 Mar 2023 10:20:06 -0700
Subject: [PATCH] Add Structure check API


diff --git a/src/main/java/org/bukkit/World.java b/src/main/java/org/bukkit/World.java
index 02184b68cc126b278985fd966e3c8e4ade18c464..ecc2d486cfec79cce27a947dfeed4853575a594d 100644
--- a/src/main/java/org/bukkit/World.java
+++ b/src/main/java/org/bukkit/World.java
@@ -78,6 +78,30 @@ public interface World extends RegionAccessor, WorldInfo, PluginMessageRecipient
      */
     int getPlayerCount();
     // Paper end
+    // Paper start - structure check API
+    /**
+     * Check if the naturally-generated structure exists at the position.
+     * <p>
+     * Note that if the position is not loaded, this may cause chunk loads/generation
+     * to check if a structure is at that position. Use {@link #isPositionLoaded(io.papermc.paper.math.Position)}
+     * to check if a position is loaded
+     *
+     * @param position the position to check at
+     * @param structure the structure to check for
+     * @return true if that structure exists at the position
+     */
+    boolean hasStructureAt(io.papermc.paper.math.@NotNull Position position, @NotNull Structure structure);
+
+    /**
+     * Checks if this position is loaded.
+     *
+     * @param position position to check
+     * @return true if loaded
+     */
+    default boolean isPositionLoaded(io.papermc.paper.math.@NotNull Position position) {
+        return this.isChunkLoaded(position.blockX() >> 4, position.blockZ() >> 4);
+    }
+    // Paper end
 
     /**
      * Gets the {@link Block} at the given coordinates