mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-24 23:23:44 +02:00 
			
		
		
		
	Compare commits
	
		
			43 Commits
		
	
	
		
			build/mast
			...
			feature/v6
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | a807b98f07 | ||
|   | 3dbbbc698e | ||
|   | a71af4e76f | ||
|   | 5c0e538231 | ||
|   | db963ffc61 | ||
|   | 7343319fe6 | ||
|   | dc6d0e089f | ||
|   | bbe31379e8 | ||
|   | 7c48fe198d | ||
|   | c5ff743c9e | ||
|   | fc93156362 | ||
|   | c875487173 | ||
|   | a100f497b5 | ||
|   | 99fa3f403e | ||
|   | be417ae954 | ||
|   | 0e4c87fb8f | ||
|   | a233bfe111 | ||
|   | 9328695c75 | ||
|   | 8e9a142be8 | ||
|   | 6cb88505a9 | ||
|   | ae3b86ed53 | ||
|   | 3d0ceb4eb9 | ||
|   | c8327bfa40 | ||
|   | c4db968830 | ||
|   | 852c180bbd | ||
|   | e45b2ba288 | ||
|   | f45fb8fd6f | ||
|   | b630baef55 | ||
|   | d6b2b41c89 | ||
|   | 10c9425826 | ||
|   | f369ccb30e | ||
|   | 026e3fc17e | ||
|   | b9f6f9b2b8 | ||
|   | a12fe280db | ||
|   | ff60ad1e24 | ||
|   | 7d15cc3ba3 | ||
|   | 4367be9ad0 | ||
|   | 9f4bdaef40 | ||
|   | 0d468505bb | ||
|   | fae95b758a | ||
|   | f7dd0c1d38 | ||
|   | 80c39ec79a | ||
|   | f1d9d4bdc7 | 
							
								
								
									
										1
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							| @@ -27,7 +27,6 @@ body: | ||||
|       description: Which server version version you using? If your server version is not listed, it is not supported. Update to a supported version first. | ||||
|       multiple: false | ||||
|       options: | ||||
|         - '1.18.2' | ||||
|         - '1.18.1' | ||||
|         - '1.18' | ||||
|         - '1.17.1' | ||||
|   | ||||
							
								
								
									
										6
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,11 +8,11 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v3 | ||||
|         uses: actions/checkout@v2.4.0 | ||||
|       - name: Validate Gradle Wrapper" | ||||
|         uses: gradle/wrapper-validation-action@v1 | ||||
|         uses: gradle/wrapper-validation-action@v1.0.4 | ||||
|       - name: Setup Java | ||||
|         uses: actions/setup-java@v3 | ||||
|         uses: actions/setup-java@v3.0.0 | ||||
|         with: | ||||
|           distribution: temurin | ||||
|           java-version: 17 | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -23,7 +23,7 @@ jobs: | ||||
|  | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v3 | ||||
|         uses: actions/checkout@v2 | ||||
|  | ||||
|       - name: Initialize CodeQL | ||||
|         uses: github/codeql-action/init@v1 | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							| @@ -14,6 +14,6 @@ jobs: | ||||
|     if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }} | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - uses: release-drafter/release-drafter@v5.19.0 | ||||
|       - uses: release-drafter/release-drafter@v5.18.1 | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|   | ||||
| @@ -76,6 +76,7 @@ import com.plotsquared.core.util.EventDispatcher; | ||||
| import com.plotsquared.core.util.MathMan; | ||||
| import com.plotsquared.core.util.Permissions; | ||||
| import com.plotsquared.core.util.PremiumVerification; | ||||
| import com.plotsquared.core.util.RegExUtil; | ||||
| import com.plotsquared.core.util.entity.EntityCategories; | ||||
| import com.plotsquared.core.util.task.TaskManager; | ||||
| import com.plotsquared.core.util.task.TaskTime; | ||||
| @@ -222,9 +223,10 @@ public class PlayerEventListener extends PlotListener implements Listener { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     @SuppressWarnings("StringSplitter") | ||||
|     @EventHandler(ignoreCancelled = true, priority = EventPriority.HIGHEST) | ||||
|     public void playerCommand(PlayerCommandPreprocessEvent event) { | ||||
|         String msg = event.getMessage().replace("/", "").toLowerCase(Locale.ROOT).trim(); | ||||
|         String msg = event.getMessage().toLowerCase().replaceAll("/", "").trim(); | ||||
|         if (msg.isEmpty()) { | ||||
|             return; | ||||
|         } | ||||
| @@ -238,9 +240,11 @@ public class PlayerEventListener extends PlotListener implements Listener { | ||||
|         String[] parts = msg.split(" "); | ||||
|         Plot plot = plotPlayer.getCurrentPlot(); | ||||
|         // Check WorldEdit | ||||
|         switch (parts[0]) { | ||||
|         switch (parts[0].toLowerCase()) { | ||||
|             case "up": | ||||
|             case "/up": | ||||
|             case "worldedit:up": | ||||
|             case "worldedit:/up": | ||||
|                 if (plot == null || (!plot.isAdded(plotPlayer.getUUID()) && !Permissions | ||||
|                         .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_OTHER, true))) { | ||||
|                     event.setCancelled(true); | ||||
| @@ -254,67 +258,63 @@ public class PlayerEventListener extends PlotListener implements Listener { | ||||
|         List<String> blockedCommands = plot != null ? | ||||
|                 plot.getFlag(BlockedCmdsFlag.class) : | ||||
|                 area.getFlag(BlockedCmdsFlag.class); | ||||
|         if (blockedCommands.isEmpty()) { | ||||
|             return; | ||||
|         } | ||||
|         if (Permissions.hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_BLOCKED_CMDS)) { | ||||
|             return; | ||||
|         } | ||||
|         // When using namespaced commands, we're not interested in the namespace | ||||
|         String part = parts[0]; | ||||
|         if (part.contains(":")) { | ||||
|             String[] namespaced = part.split(":"); | ||||
|             part = namespaced[1]; | ||||
|             msg = msg.substring(namespaced[0].length() + 1); | ||||
|         } | ||||
|         msg = replaceAliases(msg, part); | ||||
|         for (String blocked : blockedCommands) { | ||||
|             if (blocked.equalsIgnoreCase(msg)) { | ||||
|                 String perm; | ||||
|                 if (plot != null && plot.isAdded(plotPlayer.getUUID())) { | ||||
|                     perm = "plots.admin.command.blocked-cmds.shared"; | ||||
|         if (!blockedCommands.isEmpty() && !Permissions | ||||
|                 .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_INTERACT_BLOCKED_CMDS)) { | ||||
|             String part = parts[0]; | ||||
|             if (parts[0].contains(":")) { | ||||
|                 part = parts[0].split(":")[1]; | ||||
|                 msg = msg.replace(parts[0].split(":")[0] + ':', ""); | ||||
|             } | ||||
|             String s1 = part; | ||||
|             List<String> aliases = new ArrayList<>(); | ||||
|             for (HelpTopic cmdLabel : Bukkit.getServer().getHelpMap().getHelpTopics()) { | ||||
|                 if (part.equals(cmdLabel.getName())) { | ||||
|                     break; | ||||
|                 } | ||||
|                 String label = cmdLabel.getName().replaceFirst("/", ""); | ||||
|                 if (aliases.contains(label)) { | ||||
|                     continue; | ||||
|                 } | ||||
|                 PluginCommand p; | ||||
|                 if ((p = Bukkit.getPluginCommand(label)) != null) { | ||||
|                     for (String a : p.getAliases()) { | ||||
|                         if (aliases.contains(a)) { | ||||
|                             continue; | ||||
|                         } | ||||
|                         aliases.add(a); | ||||
|                         a = a.replaceFirst("/", ""); | ||||
|                         if (!a.equals(label) && a.equals(part)) { | ||||
|                             part = label; | ||||
|                             break; | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             if (!s1.equals(part)) { | ||||
|                 msg = msg.replace(s1, part); | ||||
|             } | ||||
|             for (String s : blockedCommands) { | ||||
|                 Pattern pattern; | ||||
|                 if (!RegExUtil.compiledPatterns.containsKey(s)) { | ||||
|                     RegExUtil.compiledPatterns.put(s, pattern = Pattern.compile(s)); | ||||
|                 } else { | ||||
|                     perm = "plots.admin.command.blocked-cmds.road"; | ||||
|                     pattern = RegExUtil.compiledPatterns.get(s); | ||||
|                 } | ||||
|                 if (!Permissions.hasPermission(plotPlayer, perm)) { | ||||
|                     plotPlayer.sendMessage(TranslatableCaption.of("blockedcmds.command_blocked")); | ||||
|                     event.setCancelled(true); | ||||
|                 } | ||||
|                 return; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private String replaceAliases(String msg, String part) { | ||||
|         String s1 = part; | ||||
|         Set<String> aliases = new HashSet<>(); | ||||
|         for (HelpTopic cmdLabel : Bukkit.getServer().getHelpMap().getHelpTopics()) { | ||||
|             if (part.equals(cmdLabel.getName())) { | ||||
|                 break; | ||||
|             } | ||||
|             String label = cmdLabel.getName().replaceFirst("/", ""); | ||||
|             if (aliases.contains(label)) { | ||||
|                 continue; | ||||
|             } | ||||
|             PluginCommand p = Bukkit.getPluginCommand(label); | ||||
|             if (p != null) { | ||||
|                 for (String a : p.getAliases()) { | ||||
|                     if (aliases.contains(a)) { | ||||
|                         continue; | ||||
|                 if (pattern.matcher(msg).matches()) { | ||||
|                     String perm; | ||||
|                     if (plot != null && plot.isAdded(plotPlayer.getUUID())) { | ||||
|                         perm = "plots.admin.command.blocked-cmds.shared"; | ||||
|                     } else { | ||||
|                         perm = "plots.admin.command.blocked-cmds.road"; | ||||
|                     } | ||||
|                     aliases.add(a); | ||||
|                     a = a.replaceFirst("/", ""); | ||||
|                     if (!a.equals(label) && a.equals(part)) { | ||||
|                         part = label; | ||||
|                         break; | ||||
|                     if (!Permissions.hasPermission(plotPlayer, perm)) { | ||||
|                         plotPlayer.sendMessage(TranslatableCaption.of("blockedcmds.command_blocked")); | ||||
|                         event.setCancelled(true); | ||||
|                     } | ||||
|                     return; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if (!s1.equals(part)) { | ||||
|             msg = msg.replace(s1, part); | ||||
|         } | ||||
|         return msg; | ||||
|     } | ||||
|  | ||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||
|   | ||||
| @@ -46,7 +46,7 @@ import static com.plotsquared.core.util.ReflectionUtils.getRefClass; | ||||
| public class SingleWorldListener implements Listener { | ||||
|  | ||||
|     private final Method methodGetHandleChunk; | ||||
|     private Field shouldSave = null; | ||||
|     private Field shouldSave; | ||||
|  | ||||
|     public SingleWorldListener() throws Exception { | ||||
|         ReflectionUtils.RefClass classCraftChunk = getRefClass("{cb}.CraftChunk"); | ||||
| @@ -59,12 +59,9 @@ public class SingleWorldListener implements Listener { | ||||
|                 } else { | ||||
|                     this.shouldSave = classChunk.getField("s").getRealField(); | ||||
|                 } | ||||
|             } else if (PlotSquared.platform().serverVersion()[1] == 17) { | ||||
|             } else { | ||||
|                 ReflectionUtils.RefClass classChunk = getRefClass("net.minecraft.world.level.chunk.Chunk"); | ||||
|                 this.shouldSave = classChunk.getField("r").getRealField(); | ||||
|             } else if (PlotSquared.platform().serverVersion()[1] == 18) { | ||||
|                 ReflectionUtils.RefClass classChunk = getRefClass("net.minecraft.world.level.chunk.IChunkAccess"); | ||||
|                 this.shouldSave = classChunk.getField("b").getRealField(); | ||||
|             } | ||||
|         } catch (NoSuchFieldException e) { | ||||
|             e.printStackTrace(); | ||||
|   | ||||
| @@ -67,7 +67,7 @@ public class GenChunk extends ScopedQueueCoordinator { | ||||
|      * @param minY minimum world Y, inclusive | ||||
|      * @param maxY maximum world Y, inclusive | ||||
|      * | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     public GenChunk(int minY, int maxY) { | ||||
|         super(null, Location.at("", 0, minY, 0), Location.at("", 15, maxY, 15)); | ||||
|   | ||||
| @@ -347,15 +347,13 @@ public class BukkitUtil extends WorldUtil { | ||||
|             final Block block = world.getBlockAt(location.getX(), location.getY(), location.getZ()); | ||||
|             final Material type = block.getType(); | ||||
|             if (type != Material.LEGACY_SIGN && type != Material.LEGACY_WALL_SIGN) { | ||||
|                 BlockFace facing = BlockFace.NORTH; | ||||
|                 if (!world.getBlockAt(location.getX(), location.getY(), location.getZ() + 1).getType().isSolid()) { | ||||
|                     if (world.getBlockAt(location.getX() - 1, location.getY(), location.getZ()).getType().isSolid()) { | ||||
|                         facing = BlockFace.EAST; | ||||
|                     } else if (world.getBlockAt(location.getX() + 1, location.getY(), location.getZ()).getType().isSolid()) { | ||||
|                         facing = BlockFace.WEST; | ||||
|                     } else if (world.getBlockAt(location.getX(), location.getY(), location.getZ() - 1).getType().isSolid()) { | ||||
|                         facing = BlockFace.SOUTH; | ||||
|                     } | ||||
|                 BlockFace facing = BlockFace.EAST; | ||||
|                 if (world.getBlockAt(location.getX(), location.getY(), location.getZ() + 1).getType().isSolid()) { | ||||
|                     facing = BlockFace.NORTH; | ||||
|                 } else if (world.getBlockAt(location.getX() + 1, location.getY(), location.getZ()).getType().isSolid()) { | ||||
|                     facing = BlockFace.WEST; | ||||
|                 } else if (world.getBlockAt(location.getX(), location.getY(), location.getZ() - 1).getType().isSolid()) { | ||||
|                     facing = BlockFace.SOUTH; | ||||
|                 } | ||||
|                 if (PlotSquared.platform().serverVersion()[1] == 13) { | ||||
|                     block.setType(Material.valueOf(area.legacySignMaterial()), false); | ||||
|   | ||||
| @@ -88,7 +88,7 @@ public class BukkitWorld implements World<org.bukkit.World> { | ||||
|     /** | ||||
|      * Get the min world height from a Bukkit {@link org.bukkit.World}. Inclusive | ||||
|      * | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     public static int getMinWorldHeight(org.bukkit.World world) { | ||||
|         return HAS_MIN_Y ? world.getMinHeight() : 0; | ||||
| @@ -97,7 +97,7 @@ public class BukkitWorld implements World<org.bukkit.World> { | ||||
|     /** | ||||
|      * Get the max world height from a Bukkit {@link org.bukkit.World}. Exclusive | ||||
|      * | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     public static int getMaxWorldHeight(org.bukkit.World world) { | ||||
|         return HAS_MIN_Y ? world.getMaxHeight() : 256; | ||||
| @@ -143,7 +143,7 @@ public class BukkitWorld implements World<org.bukkit.World> { | ||||
|     /** | ||||
|      * @deprecated This method is not meant to be invoked or overridden, with no replacement. | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.6.0") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     protected boolean canEqual(final Object other) { | ||||
|         return other instanceof BukkitWorld; | ||||
|     } | ||||
|   | ||||
| @@ -67,7 +67,7 @@ public class FaweSchematicHandler extends SchematicHandler { | ||||
|             final PlotPlayer<?> actor, | ||||
|             final RunnableVal<Boolean> whenDone | ||||
|     ) { | ||||
|         delegate.paste(schematic, plot, xOffset, yOffset, zOffset, autoHeight, actor, whenDone); | ||||
|         delegate.paste(schematic, plot, xOffset, yOffset, zOffset, autoHeight, whenDone); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|   | ||||
| @@ -102,7 +102,7 @@ public interface PlotPlatform<P> extends LocaleHolder { | ||||
|      * Gets the default minimum world height for the version of Minecraft that the server is running. | ||||
|      * | ||||
|      * @return minimum world height | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     int versionMinHeight(); | ||||
|  | ||||
| @@ -110,7 +110,7 @@ public interface PlotPlatform<P> extends LocaleHolder { | ||||
|      * Gets the default maximum world height for the version of Minecraft that the server is running. | ||||
|      * | ||||
|      * @return maximum world height (inclusive) | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     int versionMaxHeight(); | ||||
|  | ||||
|   | ||||
| @@ -48,7 +48,7 @@ public class Confirm extends SubCommand { | ||||
|             player.sendMessage(TranslatableCaption.of("confirm.expired_confirm")); | ||||
|             return false; | ||||
|         } | ||||
|         TaskManager.runTask(command.command); | ||||
|         TaskManager.runTaskAsync(command.command); | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -40,7 +40,6 @@ import com.plotsquared.core.plot.schematic.Schematic; | ||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | ||||
| import com.plotsquared.core.util.Permissions; | ||||
| import com.plotsquared.core.util.SchematicHandler; | ||||
| import com.plotsquared.core.util.TimeUtil; | ||||
| import com.plotsquared.core.util.task.RunnableVal; | ||||
| import com.plotsquared.core.util.task.TaskManager; | ||||
| import net.kyori.adventure.text.minimessage.Template; | ||||
| @@ -206,7 +205,7 @@ public class Load extends SubCommand { | ||||
|                     if (split.length < 5) { | ||||
|                         continue; | ||||
|                     } | ||||
|                     String time = TimeUtil.secToTime((System.currentTimeMillis() / 1000) - Long.parseLong(split[0])); | ||||
|                     String time = secToTime((System.currentTimeMillis() / 1000) - Long.parseLong(split[0])); | ||||
|                     String world = split[1]; | ||||
|                     PlotId id = PlotId.fromString(split[2] + ';' + split[3]); | ||||
|                     String size = split[4]; | ||||
| @@ -224,10 +223,6 @@ public class Load extends SubCommand { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @deprecated Use {@link TimeUtil#secToTime(long)} | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.6.2") | ||||
|     public String secToTime(long time) { | ||||
|         StringBuilder toreturn = new StringBuilder(); | ||||
|         if (time >= 33868800) { | ||||
|   | ||||
| @@ -389,7 +389,7 @@ public class ClassicPlotManager extends SquarePlotManager { | ||||
|         if (!plot.isMerged(Direction.NORTH)) { | ||||
|             int z = bot.getZ(); | ||||
|             for (int x = bot.getX(); x < top.getX(); x++) { | ||||
|                 for (int y = classicPlotWorld.getMinBuildHeight(); y <= classicPlotWorld.WALL_HEIGHT; y++) { | ||||
|                 for (int y = classicPlotWorld.getMaxBuildHeight(); y <= classicPlotWorld.WALL_HEIGHT; y++) { | ||||
|                     queue.setBlock(x, y, z, blocks); | ||||
|                 } | ||||
|             } | ||||
|   | ||||
| @@ -605,7 +605,7 @@ public class HybridUtils { | ||||
|      * @return if successful | ||||
|      * @deprecated use {@link HybridUtils#regenerateRoad(PlotArea, BlockVector2, int, QueueCoordinator)} | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.6.0") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     public boolean regenerateRoad(final PlotArea area, final BlockVector2 chunk, int extend) { | ||||
|         return regenerateRoad(area, chunk, extend, null); | ||||
|     } | ||||
| @@ -618,7 +618,7 @@ public class HybridUtils { | ||||
|      * @param extend           How far to extend setting air above the road | ||||
|      * @param queueCoordinator {@link QueueCoordinator} to use to set the blocks. Null if one should be created and enqueued | ||||
|      * @return if successful | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     public boolean regenerateRoad( | ||||
|             final PlotArea area, | ||||
|   | ||||
| @@ -309,7 +309,7 @@ public class PlotListener { | ||||
|                         } | ||||
|                         if ((lastPlot != null) && plot.getId().equals(lastPlot.getId()) && plot.hasOwner()) { | ||||
|                             final UUID plotOwner = plot.getOwnerAbs(); | ||||
|                             String owner = PlayerManager.resolveName(plotOwner, true).getComponent(player); | ||||
|                             String owner = PlayerManager.resolveName(plotOwner, false).getComponent(player); | ||||
|                             Caption header = fromFlag ? StaticCaption.of(title) : TranslatableCaption.of("titles" + | ||||
|                                     ".title_entered_plot"); | ||||
|                             Caption subHeader = fromFlag ? StaticCaption.of(subtitle) : TranslatableCaption.of("titles" + | ||||
|   | ||||
| @@ -35,7 +35,6 @@ import com.plotsquared.core.plot.world.PlotAreaManager; | ||||
| import com.plotsquared.core.util.Permissions; | ||||
| import com.plotsquared.core.util.WEManager; | ||||
| import com.plotsquared.core.util.WorldUtil; | ||||
| import com.sk89q.worldedit.EditSession; | ||||
| import com.sk89q.worldedit.WorldEdit; | ||||
| import com.sk89q.worldedit.entity.Player; | ||||
| import com.sk89q.worldedit.event.extent.EditSessionEvent; | ||||
| @@ -68,9 +67,6 @@ public class WESubscriber { | ||||
|             WorldEdit.getInstance().getEventBus().unregister(this); | ||||
|             return; | ||||
|         } | ||||
|         if (event.getStage() != EditSession.Stage.BEFORE_HISTORY) { | ||||
|             return; | ||||
|         } | ||||
|         World worldObj = event.getWorld(); | ||||
|         if (worldObj == null) { | ||||
|             return; | ||||
|   | ||||
| @@ -61,7 +61,7 @@ public interface World<T> { | ||||
|     /** | ||||
|      * Get the min world height. Inclusive. | ||||
|      * | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     int getMinHeight(); | ||||
|  | ||||
| @@ -69,7 +69,7 @@ public interface World<T> { | ||||
|     /** | ||||
|      * Get the max world height. Inclusive. | ||||
|      * | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     int getMaxHeight(); | ||||
|  | ||||
|   | ||||
| @@ -122,7 +122,7 @@ import static com.plotsquared.core.util.entity.EntityCategories.CAP_VEHICLE; | ||||
|  */ | ||||
| public class Plot { | ||||
|  | ||||
|     @Deprecated(forRemoval = true, since = "6.6.0") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     public static final int MAX_HEIGHT = 256; | ||||
|  | ||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + Plot.class.getSimpleName()); | ||||
|   | ||||
| @@ -1381,7 +1381,7 @@ public abstract class PlotArea { | ||||
|     /** | ||||
|      * Get the min height from which P2 will generate blocks. Inclusive. | ||||
|      * | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     public int getMinGenHeight() { | ||||
|         return this.minGenHeight; | ||||
| @@ -1390,7 +1390,7 @@ public abstract class PlotArea { | ||||
|     /** | ||||
|      * Get the max height to which P2 will generate blocks. Inclusive. | ||||
|      * | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     public int getMaxGenHeight() { | ||||
|         return this.maxGenHeight; | ||||
|   | ||||
| @@ -333,9 +333,10 @@ public final class PlotModificationManager { | ||||
|             ids.add(current.getId()); | ||||
|         } | ||||
|         this.plot.clearRatings(); | ||||
|         QueueCoordinator queue = this.plot.getArea().getQueue(); | ||||
|         QueueCoordinator queue = null; | ||||
|         if (createSign) { | ||||
|             this.removeSign(); | ||||
|             queue = this.plot.getArea().getQueue(); | ||||
|         } | ||||
|         PlotManager manager = this.plot.getArea().getPlotManager(); | ||||
|         if (createRoad) { | ||||
|   | ||||
| @@ -125,7 +125,7 @@ public abstract class PlotWorld { | ||||
|     /** | ||||
|      * @deprecated This method is not meant to be invoked or overridden, with no replacement. | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.6.0") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     protected boolean canEqual(final Object other) { | ||||
|         return other instanceof PlotWorld; | ||||
|     } | ||||
|   | ||||
| @@ -391,7 +391,7 @@ public class FlagContainer { | ||||
|     /** | ||||
|      * @deprecated This method is not meant to be invoked or overridden, with no replacement. | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.6.0") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     protected boolean canEqual(final Object other) { | ||||
|         return other instanceof FlagContainer; | ||||
|     } | ||||
|   | ||||
| @@ -221,7 +221,7 @@ public abstract class PlotFlag<T, F extends PlotFlag<T, F>> { | ||||
|     /** | ||||
|      * @deprecated This method is not meant to be invoked or overridden, with no replacement. | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.6.0") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     protected boolean canEqual(final Object other) { | ||||
|         return other instanceof PlotFlag; | ||||
|     } | ||||
|   | ||||
| @@ -74,7 +74,7 @@ public class LocalChunk { | ||||
|     /** | ||||
|      * Get the minimum layer position stored (usually -4 or 0). | ||||
|      * | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     public int getMinSection() { | ||||
|         return this.minSection; | ||||
|   | ||||
| @@ -77,7 +77,7 @@ public abstract class QueueCoordinator { | ||||
|      * @return a new {@link ScopedQueueCoordinator} | ||||
|      * @deprecated Use {@link ScopedQueueCoordinator#getForChunk(int, int, int, int)} | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.6.0") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     public ScopedQueueCoordinator getForChunk(int x, int z) { | ||||
|         if (getWorld() == null) { | ||||
|             return getForChunk(x, z, PlotSquared.platform().versionMinHeight(), PlotSquared.platform().versionMaxHeight()); | ||||
| @@ -91,7 +91,7 @@ public abstract class QueueCoordinator { | ||||
|      * @param x chunk x coordinate | ||||
|      * @param z chunk z coordinate | ||||
|      * @return a new {@link ScopedQueueCoordinator} | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     public ScopedQueueCoordinator getForChunk(int x, int z, int minY, int maxY) { | ||||
|         int bx = x << 4; | ||||
|   | ||||
| @@ -29,7 +29,6 @@ import java.util.HashMap; | ||||
| import java.util.Map; | ||||
| import java.util.regex.Pattern; | ||||
|  | ||||
| @Deprecated(since = "6.6.2", forRemoval = true) | ||||
| public class RegExUtil { | ||||
|  | ||||
|     public static Map<String, Pattern> compiledPatterns; | ||||
|   | ||||
| @@ -379,7 +379,7 @@ public abstract class RegionManager { | ||||
|         }); | ||||
|     } | ||||
|  | ||||
|     @Deprecated(forRemoval = true, since = "6.6.0") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     public void setBiome( | ||||
|             final CuboidRegion region, | ||||
|             final int extendBiome, | ||||
| @@ -398,7 +398,7 @@ public abstract class RegionManager { | ||||
|      * @param biome       biome to set | ||||
|      * @param area        {@link PlotArea} in which the biome is being set | ||||
|      * @param whenDone    task to run when complete | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     public void setBiome( | ||||
|             final CuboidRegion region, | ||||
|   | ||||
| @@ -76,7 +76,7 @@ public class RegionUtil { | ||||
|         return new CuboidRegion(min, max); | ||||
|     } | ||||
|  | ||||
|     @Deprecated(forRemoval = true, since = "6.6.0") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     public static CuboidRegion createRegion(int pos1x, int pos2x, int pos1z, int pos2z) { | ||||
|         return createRegion(pos1x, pos2x, 0, 255, pos1z, pos2z); | ||||
|     } | ||||
|   | ||||
| @@ -44,27 +44,27 @@ public final class TimeUtil { | ||||
|         StringBuilder toReturn = new StringBuilder(); | ||||
|         if (time >= 33868800) { | ||||
|             int years = (int) (time / 33868800); | ||||
|             time -= years * 33868800L; | ||||
|             time -= years * 33868800; | ||||
|             toReturn.append(years).append("y "); | ||||
|         } | ||||
|         if (time >= 604800) { | ||||
|             int weeks = (int) (time / 604800); | ||||
|             time -= weeks * 604800L; | ||||
|             time -= weeks * 604800; | ||||
|             toReturn.append(weeks).append("w "); | ||||
|         } | ||||
|         if (time >= 86400) { | ||||
|             int days = (int) (time / 86400); | ||||
|             time -= days * 86400L; | ||||
|             time -= days * 86400; | ||||
|             toReturn.append(days).append("d "); | ||||
|         } | ||||
|         if (time >= 3600) { | ||||
|             int hours = (int) (time / 3600); | ||||
|             time -= hours * 3600L; | ||||
|             time -= hours * 3600; | ||||
|             toReturn.append(hours).append("h "); | ||||
|         } | ||||
|         if (time >= 60) { | ||||
|             int minutes = (int) (time / 60); | ||||
|             time -= minutes * 60L; | ||||
|             time -= minutes * 60; | ||||
|             toReturn.append(minutes).append("m "); | ||||
|         } | ||||
|         if (toReturn.length() == 0 || time > 0) { | ||||
|   | ||||
| @@ -25,6 +25,7 @@ | ||||
|  */ | ||||
| package com.plotsquared.core.util; | ||||
|  | ||||
| import com.fastasyncworldedit.core.regions.RegionWrapper; | ||||
| import com.plotsquared.core.PlotSquared; | ||||
| import com.plotsquared.core.configuration.Settings; | ||||
| import com.plotsquared.core.location.Location; | ||||
| @@ -44,9 +45,6 @@ import java.util.UUID; | ||||
|  | ||||
| public class WEManager { | ||||
|  | ||||
|     private static final BlockVector3 MIN = BlockVector3.at(Integer.MIN_VALUE, Integer.MIN_VALUE, Integer.MIN_VALUE); | ||||
|     private static final BlockVector3 MAX = BlockVector3.at(Integer.MAX_VALUE, Integer.MAX_VALUE, Integer.MAX_VALUE); | ||||
|  | ||||
|     public static boolean maskContains(Set<CuboidRegion> mask, int x, int y, int z) { | ||||
|         for (CuboidRegion region : mask) { | ||||
|             if (RegionUtil.contains(region, x, y, z)) { | ||||
| @@ -94,7 +92,7 @@ public class WEManager { | ||||
|         Location location = player.getLocation(); | ||||
|         String world = location.getWorldName(); | ||||
|         if (!PlotSquared.get().getPlotAreaManager().hasPlotArea(world)) { | ||||
|             regions.add(new CuboidRegion(MIN, MAX)); | ||||
|             regions.add(RegionWrapper.GLOBAL()); | ||||
|             return regions; | ||||
|         } | ||||
|         PlotArea area = player.getApplicablePlotArea(); | ||||
|   | ||||
| @@ -96,7 +96,7 @@ public abstract class WorldUtil { | ||||
|      * @param world  World name | ||||
|      * @param region Region | ||||
|      * @param biome  Biome | ||||
|      * @since 6.6.0 | ||||
|      * @since TODO | ||||
|      */ | ||||
|     public static void setBiome(String world, final CuboidRegion region, BiomeType biome) { | ||||
|         PlotSquared.platform().worldUtil().setBiomes(world, region, biome); | ||||
|   | ||||
| @@ -71,7 +71,7 @@ public class UUIDMapping { | ||||
|     /** | ||||
|      * @deprecated This method is not meant to be invoked or overridden, with no replacement. | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.6.0") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     protected boolean canEqual(final Object other) { | ||||
|         return other instanceof UUIDMapping; | ||||
|     } | ||||
|   | ||||
| @@ -18,7 +18,7 @@ plugins { | ||||
|     idea | ||||
| } | ||||
|  | ||||
| version = "6.6.3-SNAPSHOT" | ||||
| version = "6.5.2-SNAPSHOT" | ||||
|  | ||||
| allprojects { | ||||
|     group = "com.plotsquared" | ||||
| @@ -40,9 +40,6 @@ allprojects { | ||||
|         maven { | ||||
|             name = "Jitpack" | ||||
|             url = uri("https://jitpack.io") | ||||
|             content { | ||||
|                 includeModule("com.github.MilkBowl", "VaultAPI") | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         maven { | ||||
|   | ||||
| @@ -6,7 +6,7 @@ guava = "31.0.1-jre" # Version set by Minecraft | ||||
|  | ||||
| # Platform expectations | ||||
| paper = "1.18.1-R0.1-SNAPSHOT" | ||||
| checker-qual = "3.21.4" | ||||
| checker-qual = "3.21.2" | ||||
| guice = "5.1.0" | ||||
| findbugs = "3.0.1" | ||||
| snakeyaml = "1.30" # Version set by Bukkit | ||||
| @@ -17,12 +17,12 @@ adventure-text-minimessage = "4.1.0-SNAPSHOT" | ||||
| adventure-platform-bukkit = "4.0.1" | ||||
|  | ||||
| # Plugins | ||||
| worldedit = "7.2.10" | ||||
| fawe = "2.1.1" | ||||
| worldedit = "7.2.9" | ||||
| fawe = "2.0.1" | ||||
| vault = "1.7.1" | ||||
| placeholderapi = "2.11.1" | ||||
| luckperms = "5.4" | ||||
| essentialsx = "2.19.4" | ||||
| essentialsx = "2.19.2" | ||||
| mvdwapi = "3.1.1" | ||||
|  | ||||
| # Third party | ||||
| @@ -33,7 +33,7 @@ arkitektonika = "2.1.1" | ||||
| paster = "1.1.4" | ||||
| bstats = "3.0.0" | ||||
| paperlib = "1.0.7" | ||||
| squirrelid = "0.3.1" | ||||
| squirrelid = "0.3.0" | ||||
| serverlib = "2.3.1" | ||||
| http4j = "1.3" | ||||
|  | ||||
| @@ -78,7 +78,7 @@ prtree = { group = "com.intellectualsites.prtree", name = "PRTree", version.ref | ||||
| aopalliance = { group = "aopalliance", name = "aopalliance", version.ref = "aopalliance" } | ||||
| cloudServices = { group = "cloud.commandframework", name = "cloud-services", version.ref = "cloud-services" } | ||||
| mvdwapi = { group = "com.intellectualsites.mvdwplaceholderapi", name = "MVdWPlaceholderAPI", version.ref = "mvdwapi" } | ||||
| squirrelid = { group = "org.enginehub", name = "squirrelid", version.ref = "squirrelid" } | ||||
| squirrelid = { group = "com.github.EngineHub", name = "SquirrelID", version.ref = "squirrelid" } | ||||
| serverlib = { group = "dev.notmyfault.serverlib", name = "ServerLib", version.ref = "serverlib" } | ||||
| bstats = { group = "org.bstats", name = "bstats-bukkit", version.ref = "bstats" } | ||||
| paperlib = { group = "io.papermc", name = "paperlib", version.ref = "paperlib" } | ||||
|   | ||||
							
								
								
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
| distributionBase=GRADLE_USER_HOME | ||||
| distributionPath=wrapper/dists | ||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-7.4.2-bin.zip | ||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-7.4-all.zip | ||||
| zipStoreBase=GRADLE_USER_HOME | ||||
| zipStorePath=wrapper/dists | ||||
|   | ||||
| @@ -8,8 +8,7 @@ | ||||
|     "com.google.guava:guava", | ||||
|     "com.google.code.gson:gson", | ||||
|     "gson", | ||||
|     "snakeyaml", | ||||
|     "net.kyori" | ||||
|     "snakeyaml" | ||||
|   ], | ||||
|   "timezone": "Europe/Berlin", | ||||
|   "schedule": [ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user