mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-26 23:23:45 +01:00 
			
		
		
		
	Compare commits
	
		
			7 Commits
		
	
	
		
			fix/v6/dis
			...
			dont-fire-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | dbd900f8c3 | ||
|   | 0dd8b1053c | ||
|   | 0558fcf5d5 | ||
|   | c45bbe3ec5 | ||
|   | 07e598e48f | ||
|   | f6f00dfcda | ||
|   | 63a6bdc1d6 | 
| @@ -56,6 +56,7 @@ import com.plotsquared.core.util.TabCompletions; | ||||
| import com.plotsquared.core.util.WorldUtil; | ||||
| import com.plotsquared.core.util.task.RunnableVal3; | ||||
| import com.sk89q.worldedit.EditSession; | ||||
| import com.sk89q.worldedit.EditSessionBuilder; | ||||
| import com.sk89q.worldedit.LocalSession; | ||||
| import com.sk89q.worldedit.WorldEdit; | ||||
| import com.sk89q.worldedit.entity.Player; | ||||
| @@ -228,12 +229,14 @@ public class Area extends SubCommand { | ||||
|                 try (final ClipboardWriter clipboardWriter = BuiltInClipboardFormat.SPONGE_SCHEMATIC.getWriter(new FileOutputStream( | ||||
|                         file))) { | ||||
|                     final BlockArrayClipboard clipboard = new BlockArrayClipboard(selectedRegion); | ||||
|                     final EditSession editSession = WorldEdit | ||||
|                             .getInstance() | ||||
|                             .getEditSessionFactory() | ||||
|                             .getEditSession(selectedRegion.getWorld(), -1); | ||||
|  | ||||
|                     EditSessionBuilder editSessionBuilder = WorldEdit.getInstance().newEditSessionBuilder(); | ||||
|                     editSessionBuilder.world(selectedRegion.getWorld()); | ||||
|                     final EditSession editSession = editSessionBuilder.build(); | ||||
|  | ||||
|                     final ForwardExtentCopy forwardExtentCopy = | ||||
|                             new ForwardExtentCopy(editSession, selectedRegion, clipboard, selectedRegion.getMinimumPoint()); | ||||
|  | ||||
|                     forwardExtentCopy.setCopyingBiomes(true); | ||||
|                     forwardExtentCopy.setCopyingEntities(true); | ||||
|                     Operations.complete(forwardExtentCopy); | ||||
|   | ||||
| @@ -106,7 +106,6 @@ public class Clear extends Command { | ||||
|             BackupManager.backup(player, plot, () -> { | ||||
|                 final long start = System.currentTimeMillis(); | ||||
|                 boolean result = plot.getPlotModificationManager().clear(true, false, player, () -> { | ||||
|                     plot.getPlotModificationManager().unlink(); | ||||
|                     TaskManager.runTask(() -> { | ||||
|                         plot.removeRunning(); | ||||
|                         // If the state changes, then mark it as no longer done | ||||
|   | ||||
| @@ -62,7 +62,7 @@ public class ComponentPreset implements ConfigurationSerializable { | ||||
|     public static ComponentPreset deserialize(final @NonNull Map<String, Object> map) { | ||||
|         final ClassicPlotManagerComponent classicPlotManagerComponent = ClassicPlotManagerComponent | ||||
|                 .fromString(map.getOrDefault("component", "").toString()).orElseThrow(() -> | ||||
|                         new IllegalArgumentException("The preset needs a valid target component")); | ||||
|                         new IllegalArgumentException("The preset in components.yml needs a valid target component, got: " + map.get("component"))); | ||||
|         final String pattern = map.getOrDefault("pattern", "").toString(); | ||||
|         final double cost = Double.parseDouble(map.getOrDefault("cost", "0.0").toString()); | ||||
|         final String permission = map.getOrDefault("permission", "").toString(); | ||||
|   | ||||
| @@ -144,7 +144,7 @@ public class ClassicPlotManager extends SquarePlotManager { | ||||
|                     plot.getRegions(), | ||||
|                     blocks, | ||||
|                     classicPlotWorld.getMinBuildHeight(), | ||||
|                     classicPlotWorld.getMaxBuildHeight(), | ||||
|                     classicPlotWorld.getMaxBuildHeight() - 1, | ||||
|                     actor, | ||||
|                     queue | ||||
|             ); | ||||
| @@ -175,7 +175,7 @@ public class ClassicPlotManager extends SquarePlotManager { | ||||
|                             plot.getRegions(), | ||||
|                             blocks, | ||||
|                             classicPlotWorld.PLOT_HEIGHT + 1, | ||||
|                             classicPlotWorld.getMaxBuildHeight(), | ||||
|                             classicPlotWorld.getMaxBuildHeight() - 1, | ||||
|                             actor, | ||||
|                             queue | ||||
|                     ); | ||||
| @@ -281,7 +281,7 @@ public class ClassicPlotManager extends SquarePlotManager { | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         int maxY = classicPlotWorld.getMaxBuildHeight(); | ||||
|         int maxY = classicPlotWorld.getMaxBuildHeight() - 1; | ||||
|         if (!plot.isMerged(Direction.NORTH)) { | ||||
|             int z = bottom.getZ(); | ||||
|             for (int x = bottom.getX(); x <= top.getX(); x++) { | ||||
|   | ||||
| @@ -204,7 +204,7 @@ public class HybridPlotWorld extends ClassicPlotWorld { | ||||
|                 } | ||||
|                 Object value; | ||||
|                 try { | ||||
|                     final boolean accessible = field.isAccessible(); | ||||
|                     final boolean accessible = field.canAccess(field); | ||||
|                     field.setAccessible(true); | ||||
|                     value = field.get(this); | ||||
|                     field.setAccessible(accessible); | ||||
|   | ||||
| @@ -2506,7 +2506,7 @@ public class Plot { | ||||
|                 } | ||||
|             } | ||||
|             int minHeight = getArea().getMinBuildHeight(); | ||||
|             int maxHeight = getArea().getMaxBuildHeight(); | ||||
|             int maxHeight = getArea().getMaxBuildHeight() - 1; | ||||
|             Location gtopabs = this.area.getPlotAbs(top).getTopAbs(); | ||||
|             Location gbotabs = this.area.getPlotAbs(bot).getBottomAbs(); | ||||
|             visited.addAll(Lists.newArrayList((Iterable<? extends PlotId>) PlotId.PlotRangeIterator.range(bot, top))); | ||||
|   | ||||
| @@ -220,17 +220,6 @@ public final class PlotModificationManager { | ||||
|         if (isDelete) { | ||||
|             this.removeSign(); | ||||
|         } | ||||
|         PlotUnlinkEvent event = PlotSquared.get().getEventDispatcher() | ||||
|                 .callUnlink( | ||||
|                         this.plot.getArea(), | ||||
|                         this.plot, | ||||
|                         true, | ||||
|                         !isDelete, | ||||
|                         isDelete ? PlotUnlinkEvent.REASON.DELETE : PlotUnlinkEvent.REASON.CLEAR | ||||
|                 ); | ||||
|         if (event.getEventResult() != Result.DENY && this.unlinkPlot(event.isCreateRoad(), event.isCreateSign())) { | ||||
|             PlotSquared.get().getEventDispatcher().callPostUnlink(plot, event.getReason()); | ||||
|         } | ||||
|         final PlotManager manager = this.plot.getArea().getPlotManager(); | ||||
|         Runnable run = new Runnable() { | ||||
|             @Override | ||||
| @@ -281,7 +270,21 @@ public final class PlotModificationManager { | ||||
|                 manager.clearPlot(current, this, actor, null); | ||||
|             } | ||||
|         }; | ||||
|         run.run(); | ||||
|         PlotUnlinkEvent event = PlotSquared.get().getEventDispatcher() | ||||
|                 .callUnlink( | ||||
|                         this.plot.getArea(), | ||||
|                         this.plot, | ||||
|                         true, | ||||
|                         !isDelete, | ||||
|                         isDelete ? PlotUnlinkEvent.REASON.DELETE : PlotUnlinkEvent.REASON.CLEAR | ||||
|                 ); | ||||
|         if (event.getEventResult() != Result.DENY) { | ||||
|             if (this.unlinkPlot(event.isCreateRoad(), event.isCreateSign(), run)) { | ||||
|                 PlotSquared.get().getEventDispatcher().callPostUnlink(plot, event.getReason()); | ||||
|             } | ||||
|         } else { | ||||
|             run.run(); | ||||
|         } | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
| @@ -321,7 +324,23 @@ public final class PlotModificationManager { | ||||
|      * @return success/!cancelled | ||||
|      */ | ||||
|     public boolean unlinkPlot(final boolean createRoad, final boolean createSign) { | ||||
|         return unlinkPlot(createRoad, createSign, null); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Unlink the plot and all connected plots. | ||||
|      * | ||||
|      * @param createRoad whether to recreate road | ||||
|      * @param createSign whether to recreate signs | ||||
|      * @param whenDone   Task to run when unlink is complete | ||||
|      * @return success/!cancelled | ||||
|      * @since TODO | ||||
|      */ | ||||
|     public boolean unlinkPlot(final boolean createRoad, final boolean createSign, final Runnable whenDone) { | ||||
|         if (!this.plot.isMerged()) { | ||||
|             if (whenDone != null) { | ||||
|                 whenDone.run(); | ||||
|             } | ||||
|             return false; | ||||
|         } | ||||
|         final Set<Plot> plots = this.plot.getConnectedPlots(); | ||||
| @@ -366,14 +385,17 @@ public final class PlotModificationManager { | ||||
|                     current.getPlotModificationManager().setSign(PlayerManager.resolveName(current.getOwnerAbs()).getComponent( | ||||
|                             LocaleHolder.console())); | ||||
|                 } | ||||
|                 if (whenDone != null) { | ||||
|                     TaskManager.runTask(whenDone); | ||||
|                 } | ||||
|             })); | ||||
|         } else if (whenDone != null) { | ||||
|             queue.setCompleteTask(whenDone); | ||||
|         } | ||||
|         if (createRoad) { | ||||
|             manager.finishPlotUnlink(ids, queue); | ||||
|         } | ||||
|         if (queue != null) { | ||||
|             queue.enqueue(); | ||||
|         } | ||||
|         queue.enqueue(); | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -106,7 +106,7 @@ public class WEManager { | ||||
|                             .getTrusted().contains(uuid))) && !plot.getFlag(NoWorldeditFlag.class)) { | ||||
|                 for (CuboidRegion region : plot.getRegions()) { | ||||
|                     BlockVector3 pos1 = region.getMinimumPoint().withY(area.getMinBuildHeight()); | ||||
|                     BlockVector3 pos2 = region.getMaximumPoint().withY(area.getMaxBuildHeight()); | ||||
|                     BlockVector3 pos2 = region.getMaximumPoint().withY(area.getMaxBuildHeight() - 1); | ||||
|                     CuboidRegion copy = new CuboidRegion(pos1, pos2); | ||||
|                     regions.add(copy); | ||||
|                 } | ||||
|   | ||||
| @@ -20,6 +20,16 @@ plugins { | ||||
| group = "com.plotsquared" | ||||
| version = "6.10.9-SNAPSHOT" | ||||
|  | ||||
| if (!File("$rootDir/.git").exists()) { | ||||
|     logger.lifecycle(""" | ||||
|     ************************************************************************************** | ||||
|     You need to fork and clone this repository! Don't download a .zip file. | ||||
|     If you need assistance, consult the GitHub docs: https://docs.github.com/get-started/quickstart/fork-a-repo | ||||
|     ************************************************************************************** | ||||
|     """.trimIndent() | ||||
|     ).also { kotlin.system.exitProcess(1) } | ||||
| } | ||||
|  | ||||
| subprojects { | ||||
|     group = rootProject.group | ||||
|     version = rootProject.version | ||||
|   | ||||
		Reference in New Issue
	
	Block a user