mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-25 07:33:44 +02:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			7.5.5
			...
			fix/ci/pub
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | bc35324842 | 
| @@ -837,8 +837,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | ||||
|                         case "HOPPER_MINECART": | ||||
|                         case "MINECART_MOB_SPAWNER": | ||||
|                         case "SPAWNER_MINECART": | ||||
|                         case "END_CRYSTAL": | ||||
|                         case "ENDER_CRYSTAL": // Backwards compatibility for 1.20.4 | ||||
|                         case "ENDER_CRYSTAL": | ||||
|                         case "MINECART_TNT": | ||||
|                         case "TNT_MINECART": | ||||
|                         case "CHEST_BOAT": | ||||
| @@ -956,8 +955,6 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | ||||
|                         case "ENDERMITE": | ||||
|                         case "ENDER_DRAGON": | ||||
|                         case "GHAST": | ||||
|                         case "HAPPY_GHAST": // 1.21.6+ | ||||
|                         case "GHASTLING": // 1.21.6+ | ||||
|                         case "GIANT": | ||||
|                         case "GUARDIAN": | ||||
|                         case "HORSE": | ||||
|   | ||||
| @@ -115,7 +115,7 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | ||||
|                 this.dataByte = getOrdinal(Boat.Type.values(), boat.getBoatType()); | ||||
|                 storeInventory(boat); | ||||
|             } | ||||
|             case "ARROW", "EGG", "END_CRYSTAL", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "EXPERIENCE_ORB", "FALLING_BLOCK", "FIREBALL", | ||||
|             case "ARROW", "EGG", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "EXPERIENCE_ORB", "FALLING_BLOCK", "FIREBALL", | ||||
|                     "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", "MINECART_MOB_SPAWNER", | ||||
|                     "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SLIME", "SMALL_FIREBALL", "SNOWBALL", "MINECART_FURNACE", "SPLASH_POTION", | ||||
|                     "THROWN_EXP_BOTTLE", "WITHER_SKULL", "UNKNOWN", "SPECTRAL_ARROW", "SHULKER_BULLET", "DRAGON_FIREBALL", "AREA_EFFECT_CLOUD", | ||||
| @@ -272,7 +272,7 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | ||||
|                 this.dataByte = (byte) entity1.getPhase().ordinal(); | ||||
|                 return; | ||||
|             } | ||||
|             case "SKELETON", "WITHER_SKELETON", "GUARDIAN", "ELDER_GUARDIAN", "GHAST", "HAPPY_GHAST", "GHASTLING", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", | ||||
|             case "SKELETON", "WITHER_SKELETON", "GUARDIAN", "ELDER_GUARDIAN", "GHAST", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", | ||||
|                     "ZOMBIFIED_PIGLIN", "PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", | ||||
|                     "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SHULKER", "SNOWMAN", "SNOW_GOLEM" -> { | ||||
|                 storeLiving((LivingEntity) entity); | ||||
| @@ -511,7 +511,7 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | ||||
|                 ((Slime) entity).setSize(this.dataByte); | ||||
|                 return entity; | ||||
|             } */ | ||||
|             case "ARROW", "EGG", "END_CRYSTAL", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "DROPPED_ITEM", "EXPERIENCE_ORB", "FALLING_BLOCK", | ||||
|             case "ARROW", "EGG", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "DROPPED_ITEM", "EXPERIENCE_ORB", "FALLING_BLOCK", | ||||
|                     "FIREBALL", "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", | ||||
|                     "MINECART_MOB_SPAWNER", "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SMALL_FIREBALL", "SNOWBALL", | ||||
|                     "SPLASH_POTION", "THROWN_EXP_BOTTLE", "SPECTRAL_ARROW", "SHULKER_BULLET", "AREA_EFFECT_CLOUD", | ||||
| @@ -676,7 +676,7 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | ||||
|                 restoreLiving((LivingEntity) entity); | ||||
|                 return entity; | ||||
|             } | ||||
|             case "ENDERMITE", "GHAST", "HAPPY_GHAST", "GHASTLING", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", "PIGLIN", "ZOMBIFIED_PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SNOWMAN", "SHULKER", "GUARDIAN", "ELDER_GUARDIAN", "SKELETON", "WITHER_SKELETON" -> { | ||||
|             case "ENDERMITE", "GHAST", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", "PIGLIN", "ZOMBIFIED_PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SNOWMAN", "SHULKER", "GUARDIAN", "ELDER_GUARDIAN", "SKELETON", "WITHER_SKELETON" -> { | ||||
|                 restoreLiving((LivingEntity) entity); | ||||
|                 return entity; | ||||
|             } | ||||
|   | ||||
| @@ -79,7 +79,6 @@ import com.plotsquared.core.util.task.TaskManager; | ||||
| import com.plotsquared.core.util.task.TaskTime; | ||||
| import com.sk89q.worldedit.WorldEdit; | ||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||
| import com.sk89q.worldedit.util.Enums; | ||||
| import com.sk89q.worldedit.world.block.BlockType; | ||||
| import com.sk89q.worldedit.world.block.BlockTypes; | ||||
| import io.papermc.lib.PaperLib; | ||||
| @@ -160,7 +159,6 @@ import java.util.Collections; | ||||
| import java.util.HashSet; | ||||
| import java.util.List; | ||||
| import java.util.Locale; | ||||
| import java.util.Objects; | ||||
| import java.util.Optional; | ||||
| import java.util.Set; | ||||
| import java.util.UUID; | ||||
| @@ -185,15 +183,6 @@ public class PlayerEventListener implements Listener { | ||||
|             Material.WRITABLE_BOOK, | ||||
|             Material.WRITTEN_BOOK | ||||
|     ); | ||||
|  | ||||
|     /** | ||||
|      * The correct EntityType for End Crystal, determined once at class loading time. | ||||
|      * Tries END_CRYSTAL first (1.21+), falls back to ENDER_CRYSTAL (1.20.4 and older). | ||||
|      */ | ||||
|     private static final EntityType END_CRYSTAL_ENTITY_TYPE = Objects.requireNonNull( | ||||
|             Enums.findByValue(EntityType.class, "END_CRYSTAL", "ENDER_CRYSTAL") | ||||
|     ); | ||||
|  | ||||
|     private static final Set<String> DYES; | ||||
|  | ||||
|     static { | ||||
| @@ -1328,8 +1317,8 @@ public class PlayerEventListener implements Listener { | ||||
|                 // reset the player's hand item if spawning needs to be cancelled. | ||||
|                 if (type == Material.ARMOR_STAND || type == Material.END_CRYSTAL) { | ||||
|                     Plot plot = location.getOwnedPlotAbs(); | ||||
|                     EntityType entityType = type == Material.ARMOR_STAND ? EntityType.ARMOR_STAND : END_CRYSTAL_ENTITY_TYPE; | ||||
|                     if (BukkitEntityUtil.checkEntity(entityType, plot)) { | ||||
|                     if (BukkitEntityUtil.checkEntity(type == Material.ARMOR_STAND ? EntityType.ARMOR_STAND : EntityType.ENDER_CRYSTAL, | ||||
|                             plot)) { | ||||
|                         event.setCancelled(true); | ||||
|                         break; | ||||
|                     } | ||||
|   | ||||
| @@ -101,10 +101,6 @@ public class Grant extends Command { | ||||
|                                     ); | ||||
|                                 } else { | ||||
|                                     access.set(access.get().orElse(0) + 1); | ||||
|                                     player.sendMessage( | ||||
|                                             TranslatableCaption.of("grants.added"), | ||||
|                                             TagResolver.resolver("grants", Tag.inserting(Component.text(access.get().orElse(0)))) | ||||
|                                     ); | ||||
|                                 } | ||||
|                             } | ||||
|                         } else { | ||||
|   | ||||
| @@ -275,7 +275,7 @@ public class MainCommand extends Command { | ||||
|     private CompletableFuture<Optional<CommandExecutionData>> prepareArguments(CommandExecutionData data) { | ||||
|         if (data.args().length >= 2) { | ||||
|             PlotArea area = data.player().getApplicablePlotArea(); | ||||
|             Plot newPlot = Plot.fromString(area, data.args()[0], data.player()); | ||||
|             Plot newPlot = Plot.fromString(area, data.args()[0]); | ||||
|             return preparePlotArgument(newPlot, data, area) | ||||
|                     .thenApply(d -> d.flatMap(x -> prepareFlagArgument(x, area))); | ||||
|         } else { | ||||
|   | ||||
| @@ -321,8 +321,7 @@ public class Plot { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get the plot from a string. Performs a check to ensure Plot#getBottomAbs is not outside world bounds | ||||
|      * (x/z +/- 30,000,000) to prevent crashes | ||||
|      * Get the plot from a string. | ||||
|      * | ||||
|      * @param player  Provides a context for what world to search in. Prefixing the term with 'world_name;' will override this context. | ||||
|      * @param arg     The search term | ||||
| @@ -333,31 +332,6 @@ public class Plot { | ||||
|             final @Nullable PlotPlayer<?> player, | ||||
|             final @Nullable String arg, | ||||
|             final boolean message | ||||
|     ) { | ||||
|         Plot plot = getPlotFromStringUnchecked(player, arg, message); | ||||
|         if (plot != null && !WorldUtil.isValidLocation(plot.getBottomAbs())) { | ||||
|             if (message) { | ||||
|                 (player == null ? ConsolePlayer.getConsole() : player).sendMessage(TranslatableCaption.of( | ||||
|                         "invalid.world_location_plot")); | ||||
|             } | ||||
|             return null; | ||||
|         } | ||||
|         return plot; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get the plot from a string. Does not perform a check on world bounds. | ||||
|      * | ||||
|      * @param player  Provides a context for what world to search in. Prefixing the term with 'world_name;' will override this context. | ||||
|      * @param arg     The search term | ||||
|      * @param message If a message should be sent to the player if a plot cannot be found | ||||
|      * @return The plot if only 1 result is found, or null | ||||
|      * @since 7.5.5 | ||||
|      */ | ||||
|     public static @Nullable Plot getPlotFromStringUnchecked( | ||||
|             final @Nullable PlotPlayer<?> player, | ||||
|             final @Nullable String arg, | ||||
|             final boolean message | ||||
|     ) { | ||||
|         if (arg == null) { | ||||
|             if (player == null) { | ||||
| @@ -415,51 +389,13 @@ public class Plot { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a plot from a string e.g. [area];[id]. Performs a check to ensure Plot#getBottomAbs is not outside world bounds | ||||
|      * (x/z +/- 30,000,000) to prevent crashes | ||||
|      * Gets a plot from a string e.g. [area];[id] | ||||
|      * | ||||
|      * @param defaultArea if no area is specified | ||||
|      * @param string      plot id/area + id | ||||
|      * @return New or existing plot object | ||||
|      */ | ||||
|     public static @Nullable Plot fromString(final @Nullable PlotArea defaultArea, final @NonNull String string) { | ||||
|         return fromString(defaultArea, string, null); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a plot from a string e.g. [area];[id]. Performs a check to ensure Plot#getBottomAbs is not outside world bounds | ||||
|      * (x/z +/- 30,000,000) to prevent crashes | ||||
|      * | ||||
|      * @param defaultArea if no area is specified | ||||
|      * @param string      plot id/area + id | ||||
|      * @param player      {@link PlotPlayer} player to notify if plot is invalid (outside bounds) | ||||
|      * @return New or existing plot object | ||||
|      * @since 7.5.5 | ||||
|      */ | ||||
|     public static @Nullable Plot fromString( | ||||
|             final @Nullable PlotArea defaultArea, | ||||
|             final @NonNull String string, | ||||
|             final @Nullable PlotPlayer<?> player | ||||
|     ) { | ||||
|         Plot plot = fromStringUnchecked(defaultArea, string); | ||||
|         if (plot != null && !WorldUtil.isValidLocation(plot.getBottomAbs())) { | ||||
|             if (player != null) { | ||||
|                 player.sendMessage(TranslatableCaption.of("invalid.world_location_plot")); | ||||
|             } | ||||
|             return null; | ||||
|         } | ||||
|         return plot; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets a plot from a string e.g. [area];[id]. Does not perform a check on world bounds. | ||||
|      * | ||||
|      * @param defaultArea if no area is specified | ||||
|      * @param string      plot id/area + id | ||||
|      * @return New or existing plot object | ||||
|      * @since 7.5.5 | ||||
|      */ | ||||
|     public static @Nullable Plot fromStringUnchecked(final @Nullable PlotArea defaultArea, final @NonNull String string) { | ||||
|         final String[] split = string.split("[;,]"); | ||||
|         if (split.length == 2) { | ||||
|             if (defaultArea != null) { | ||||
| @@ -483,8 +419,7 @@ public class Plot { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Return a new/cached plot object at a given location. Does not check world bounds for potential crashes, these should be | ||||
|      * performed before (or after) this method is used. | ||||
|      * Return a new/cached plot object at a given location. | ||||
|      * | ||||
|      * <p> | ||||
|      * Use {@link PlotPlayer#getCurrentPlot()} if a player is expected here. | ||||
|   | ||||
| @@ -371,7 +371,8 @@ public final class PlotModificationManager { | ||||
|                             manager.createRoadSouthEast(current, queue); | ||||
|                         } | ||||
|                     } | ||||
|                 } else if (current.isMerged(Direction.SOUTH)) { | ||||
|                 } | ||||
|                 if (current.isMerged(Direction.SOUTH)) { | ||||
|                     manager.createRoadSouth(current, queue); | ||||
|                 } | ||||
|             } | ||||
|   | ||||
| @@ -63,18 +63,4 @@ public class PlotTitle { | ||||
|         return subtitle; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Provides a string representation of this plot title value (used in placeholders). | ||||
|      * | ||||
|      * @return the plot title representation in the format {@code "<title>" "<subtitle>"} | ||||
|      * @since 7.5.5 | ||||
|      */ | ||||
|     @Override | ||||
|     public String toString() { | ||||
|         return "\"%s\" \"%s\"".formatted( | ||||
|                 this.title != null ? this.title : "", | ||||
|                 this.subtitle != null ? this.subtitle : "" | ||||
|         ); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -234,7 +234,6 @@ | ||||
|   "invalid.not_valid_number": "<prefix><red>That's not a valid number within the range: </red><gray><value></gray>", | ||||
|   "invalid.not_valid_plot_id": "<prefix><red>That's not a valid plot ID.</red>", | ||||
|   "invalid.origin_cant_be_target": "<prefix><red>The origin and target location cannot be the same.</red>", | ||||
|   "invalid.world_location_plot": "<prefix><red>The target plot is invalid.</red>", | ||||
|   "invalid.found_no_plots": "<prefix><red>Found no plots with your search query.</red>", | ||||
|   "invalid.number_not_in_range": "<prefix><red>That's not a valid number within the range: <gray>(<min>, <max>)</gray></red>", | ||||
|   "invalid.number_not_positive": "<red>That's not a positive number: <gray><value></gray></red>", | ||||
| @@ -457,7 +456,7 @@ | ||||
|   "category.command_category_debug": "<gray>Debug</gray>", | ||||
|   "category.command_category_administration": "<gray>Admin</gray>", | ||||
|   "grants.granted_plots": "<prefix><gold>Result: <gray><amount> </gray>grants left.</gold>", | ||||
|   "grants.added": "<prefix><gold>1</gold> <gray>grant has been added. (<grants> total grants)</gray>", | ||||
|   "grants.added": "<prefix><gold><grants></gold> <gray>grant(s) have been added.</gray>", | ||||
|   "events.event_denied": "<prefix><gold><value> </gold><gray>Cancelled by external plugin.</gray>", | ||||
|   "backups.backup_impossible": "<prefix><red>Backups are not enabled for this plot: <plot>.</red>", | ||||
|   "backups.backup_save_success": "<prefix><gold>The backup was created successfully.</gold>", | ||||
|   | ||||
| @@ -20,7 +20,7 @@ plugins { | ||||
| } | ||||
|  | ||||
| group = "com.intellectualsites.plotsquared" | ||||
| version = "7.5.5" | ||||
| version = "7.5.5-SNAPSHOT" | ||||
|  | ||||
| if (!File("$rootDir/.git").exists()) { | ||||
|     logger.lifecycle(""" | ||||
| @@ -67,8 +67,8 @@ subprojects { | ||||
|  | ||||
|     dependencies { | ||||
|         // Tests | ||||
|         testImplementation("org.junit.jupiter:junit-jupiter:5.13.4") | ||||
|         testRuntimeOnly("org.junit.platform:junit-platform-launcher:1.13.4") | ||||
|         testImplementation("org.junit.jupiter:junit-jupiter:5.13.3") | ||||
|         testRuntimeOnly("org.junit.platform:junit-platform-launcher:1.13.3") | ||||
|     } | ||||
|  | ||||
|     plugins.withId("java") { | ||||
| @@ -204,7 +204,7 @@ tasks.getByName<Jar>("jar") { | ||||
|     enabled = false | ||||
| } | ||||
|  | ||||
| val supportedVersions = listOf("1.19.4", "1.20.6", "1.21.1", "1.21.3", "1.21.4", "1.21.5", "1.21.6", "1.21.7", "1.21.8") | ||||
| val supportedVersions = listOf("1.19.4", "1.20.6", "1.21.1", "1.21.3", "1.21.4", "1.21.5") | ||||
| tasks { | ||||
|     register("cacheLatestFaweArtifact") { | ||||
|         val lastSuccessfulBuildUrl = uri("https://ci.athion.net/job/FastAsyncWorldEdit/lastSuccessfulBuild/api/json").toURL() | ||||
|   | ||||
| @@ -35,7 +35,7 @@ serverlib = "2.3.7" | ||||
| # Gradle plugins | ||||
| shadow = "8.3.8" | ||||
| grgit = "4.1.1" | ||||
| spotless = "7.2.1" | ||||
| spotless = "7.2.0" | ||||
| publish = "0.34.0" | ||||
| runPaper = "2.3.1" | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user