mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-24 23:23:44 +02:00 
			
		
		
		
	Compare commits
	
		
			5 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | a791f99a13 | ||
|   | f10d0b8fbb | ||
|   | 3fc380545f | ||
|   | c22307bf47 | ||
|   | 20bac8bc9d | 
							
								
								
									
										4
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitattributes
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +0,0 @@ | ||||
| * text=auto | ||||
|  | ||||
| *.java text | ||||
| *.jar binary | ||||
| @@ -2,6 +2,7 @@ name: Announce release on discord | ||||
| on: | ||||
|   release: | ||||
|     types: [published] | ||||
|  | ||||
| jobs: | ||||
|   send_announcement: | ||||
|     runs-on: ubuntu-latest | ||||
| @@ -11,7 +12,7 @@ jobs: | ||||
|           DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} | ||||
|           DISCORD_USERNAME: PlotSquared Release | ||||
|           DISCORD_AVATAR: https://raw.githubusercontent.com/IntellectualSites/Assets/main/plugins/PlotSquared/PlotSquared.png | ||||
|         uses: Ilshidur/action-discord@08d9328877d6954120eef2b07abbc79249bb6210 # ratchet:Ilshidur/action-discord@0.3.2 | ||||
|         uses: Ilshidur/action-discord@0.3.2 | ||||
|         with: | ||||
|           args: | | ||||
|             "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>" | ||||
|   | ||||
							
								
								
									
										10
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,21 +1,23 @@ | ||||
| name: Build PR | ||||
| on: [pull_request] | ||||
|  | ||||
| on: [ pull_request ] | ||||
|  | ||||
| jobs: | ||||
|   build_pr: | ||||
|     if: github.repository_owner == 'IntellectualSites' | ||||
|     runs-on: ${{ matrix.os }} | ||||
|     strategy: | ||||
|       matrix: | ||||
|         os: [ubuntu-latest, windows-latest, macos-latest] | ||||
|         os: [ ubuntu-latest, windows-latest, macos-latest ] | ||||
|     steps: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v3 | ||||
|       - name: Validate Gradle Wrapper | ||||
|         uses: gradle/wrapper-validation-action@55e685c48d84285a5b0418cd094606e199cca3b6 # v1 | ||||
|         uses: gradle/wrapper-validation-action@v1 | ||||
|       - name: Setup Java | ||||
|         uses: actions/setup-java@v3 | ||||
|         with: | ||||
|           distribution: temurin | ||||
|           java-version: 17 | ||||
|       - name: Clean Build | ||||
|         run: ./gradlew clean build | ||||
|         run: ./gradlew clean build --warning-mode all | ||||
|   | ||||
							
								
								
									
										8
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,8 +1,10 @@ | ||||
| name: build | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - v6 | ||||
|  | ||||
| jobs: | ||||
|   build: | ||||
|     if: github.repository_owner == 'IntellectualSites' | ||||
| @@ -11,7 +13,7 @@ jobs: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v3 | ||||
|       - name: Validate Gradle Wrapper | ||||
|         uses: gradle/wrapper-validation-action@55e685c48d84285a5b0418cd094606e199cca3b6 # v1 | ||||
|         uses: gradle/wrapper-validation-action@v1 | ||||
|       - name: Setup Java | ||||
|         uses: actions/setup-java@v3 | ||||
|         with: | ||||
| @@ -43,7 +45,7 @@ jobs: | ||||
|           ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} | ||||
|       - name: Publish core javadoc | ||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} | ||||
|         uses: cpina/github-action-push-to-another-repository@0a14457bb28b04dfa1652e0ffdfda866d2845c73 # main | ||||
|         uses: cpina/github-action-push-to-another-repository@main | ||||
|         env: | ||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||
|         with: | ||||
| @@ -55,7 +57,7 @@ jobs: | ||||
|           target-directory: core | ||||
|       - name: Publish bukkit javadoc | ||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} | ||||
|         uses: cpina/github-action-push-to-another-repository@0a14457bb28b04dfa1652e0ffdfda866d2845c73 # main | ||||
|         uses: cpina/github-action-push-to-another-repository@main | ||||
|         env: | ||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||
|         with: | ||||
|   | ||||
							
								
								
									
										17
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,8 +1,10 @@ | ||||
| name: "CodeQL" | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     # The branches below must be a subset of the branches above | ||||
|     branches: [v6] | ||||
|     branches: [ v6 ] | ||||
|  | ||||
| jobs: | ||||
|   analyze: | ||||
|     name: Analyze | ||||
| @@ -11,18 +13,23 @@ jobs: | ||||
|       actions: read | ||||
|       contents: read | ||||
|       security-events: write | ||||
|  | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         language: ['java'] | ||||
|         language: [ 'java' ] | ||||
|  | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v3 | ||||
|  | ||||
|       - name: Initialize CodeQL | ||||
|         uses: github/codeql-action/init@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2 | ||||
|         uses: github/codeql-action/init@v2 | ||||
|         with: | ||||
|           languages: ${{ matrix.language }} | ||||
|  | ||||
|       - name: Autobuild | ||||
|         uses: github/codeql-action/autobuild@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2 | ||||
|         uses: github/codeql-action/autobuild@v2 | ||||
|  | ||||
|       - name: Perform CodeQL Analysis | ||||
|         uses: github/codeql-action/analyze@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2 | ||||
|         uses: github/codeql-action/analyze@v2 | ||||
|   | ||||
							
								
								
									
										6
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,12 +1,14 @@ | ||||
| name: draft release | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - v6 | ||||
|   pull_request: | ||||
|     types: [opened, reopened, synchronize] | ||||
|     types: [ opened, reopened, synchronize ] | ||||
|   pull_request_target: | ||||
|     types: [opened, reopened, synchronize] | ||||
|     types: [ opened, reopened, synchronize ] | ||||
|  | ||||
| jobs: | ||||
|   update_release_draft: | ||||
|     if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }} | ||||
|   | ||||
| @@ -71,8 +71,6 @@ import com.plotsquared.core.configuration.Storage; | ||||
| import com.plotsquared.core.configuration.caption.ChatFormatter; | ||||
| import com.plotsquared.core.configuration.file.YamlConfiguration; | ||||
| import com.plotsquared.core.database.DBFunc; | ||||
| import com.plotsquared.core.events.RemoveRoadEntityEvent; | ||||
| import com.plotsquared.core.events.Result; | ||||
| import com.plotsquared.core.generator.GeneratorWrapper; | ||||
| import com.plotsquared.core.generator.IndependentPlotGenerator; | ||||
| import com.plotsquared.core.generator.SingleWorldGenerator; | ||||
| @@ -111,7 +109,6 @@ import com.plotsquared.core.uuid.CacheUUIDService; | ||||
| import com.plotsquared.core.uuid.UUIDPipeline; | ||||
| import com.plotsquared.core.uuid.offline.OfflineModeUUIDService; | ||||
| import com.sk89q.worldedit.WorldEdit; | ||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||
| import io.papermc.lib.PaperLib; | ||||
| import net.kyori.adventure.audience.Audience; | ||||
| import net.kyori.adventure.text.Component; | ||||
| @@ -813,7 +810,8 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | ||||
|                                         if (entity.hasMetadata("ps-tmp-teleport")) { | ||||
|                                             continue; | ||||
|                                         } | ||||
|                                         this.removeRoadEntity(entity, iterator); | ||||
|                                         iterator.remove(); | ||||
|                                         entity.remove(); | ||||
|                                     } | ||||
|                                     continue; | ||||
|                                 } | ||||
| @@ -826,7 +824,8 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | ||||
|                                     if (entity.hasMetadata("ps-tmp-teleport")) { | ||||
|                                         continue; | ||||
|                                     } | ||||
|                                     this.removeRoadEntity(entity, iterator); | ||||
|                                     iterator.remove(); | ||||
|                                     entity.remove(); | ||||
|                                 } | ||||
|                             } | ||||
|                             continue; | ||||
| @@ -836,7 +835,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | ||||
|                         case "DROPPED_ITEM": | ||||
|                             if (Settings.Enabled_Components.KILL_ROAD_ITEMS | ||||
|                                     && plotArea.getOwnedPlotAbs(BukkitUtil.adapt(entity.getLocation())) == null) { | ||||
|                                 this.removeRoadEntity(entity, iterator); | ||||
|                                 entity.remove(); | ||||
|                             } | ||||
|                             // dropped item | ||||
|                             continue; | ||||
| @@ -867,7 +866,8 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | ||||
|                                                 if (entity.hasMetadata("ps-tmp-teleport")) { | ||||
|                                                     continue; | ||||
|                                                 } | ||||
|                                                 this.removeRoadEntity(entity, iterator); | ||||
|                                                 iterator.remove(); | ||||
|                                                 entity.remove(); | ||||
|                                             } | ||||
|                                         } | ||||
|                                     } | ||||
| @@ -972,7 +972,8 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | ||||
|                                                 if (entity.hasMetadata("ps-tmp-teleport")) { | ||||
|                                                     continue; | ||||
|                                                 } | ||||
|                                                 this.removeRoadEntity(entity, iterator); | ||||
|                                                 iterator.remove(); | ||||
|                                                 entity.remove(); | ||||
|                                             } | ||||
|                                         } | ||||
|                                     } else { | ||||
| @@ -983,7 +984,8 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | ||||
|                                             if (entity.hasMetadata("ps-tmp-teleport")) { | ||||
|                                                 continue; | ||||
|                                             } | ||||
|                                             this.removeRoadEntity(entity, iterator); | ||||
|                                             iterator.remove(); | ||||
|                                             entity.remove(); | ||||
|                                         } | ||||
|                                     } | ||||
|                                 } | ||||
| @@ -997,17 +999,6 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | ||||
|         }), TaskTime.seconds(1L)); | ||||
|     } | ||||
|  | ||||
|     private void removeRoadEntity(Entity entity, Iterator<Entity> entityIterator) { | ||||
|         RemoveRoadEntityEvent event = eventDispatcher.callRemoveRoadEntity(BukkitAdapter.adapt(entity)); | ||||
|  | ||||
|         if (event.getEventResult() == Result.DENY) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         entityIterator.remove(); | ||||
|         entity.remove(); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public @Nullable | ||||
|     final ChunkGenerator getDefaultWorldGenerator( | ||||
|   | ||||
| @@ -161,12 +161,6 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | ||||
|         world.setWaterAnimalSpawnLimit(limit); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * The entire method is deprecated, but kept for compatibility with versions lower than or equal to 1.16.2. | ||||
|      * The method will be removed in future versions, because WorldEdit and FastAsyncWorldEdit only support the latest point | ||||
|      * release. | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.11.0") | ||||
|     @Override | ||||
|     public @NonNull ChunkData generateChunkData( | ||||
|             @NonNull World world, @NonNull Random random, int x, int z, | ||||
|   | ||||
| @@ -71,7 +71,6 @@ import org.bukkit.block.BlockFace; | ||||
| import org.bukkit.block.BlockState; | ||||
| import org.bukkit.block.data.BlockData; | ||||
| import org.bukkit.block.data.type.Dispenser; | ||||
| import org.bukkit.block.data.type.Farmland; | ||||
| import org.bukkit.entity.Entity; | ||||
| import org.bukkit.entity.Fireball; | ||||
| import org.bukkit.entity.Player; | ||||
| @@ -99,7 +98,6 @@ import org.bukkit.event.block.BlockSpreadEvent; | ||||
| import org.bukkit.event.block.CauldronLevelChangeEvent; | ||||
| import org.bukkit.event.block.EntityBlockFormEvent; | ||||
| import org.bukkit.event.block.LeavesDecayEvent; | ||||
| import org.bukkit.event.block.MoistureChangeEvent; | ||||
| import org.bukkit.event.block.SpongeAbsorbEvent; | ||||
| import org.bukkit.event.world.StructureGrowEvent; | ||||
| import org.bukkit.projectiles.BlockProjectileSource; | ||||
| @@ -705,41 +703,6 @@ public class BlockEventListener implements Listener { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||
|     public void onMoistureChange(MoistureChangeEvent event) { | ||||
|         Block block = event.getBlock(); | ||||
|         Location location = BukkitUtil.adapt(block.getLocation()); | ||||
|         PlotArea area = location.getPlotArea(); | ||||
|  | ||||
|         if (area == null) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         Plot plot = area.getOwnedPlot(location); | ||||
|  | ||||
|         if (plot == null) { | ||||
|             event.setCancelled(true); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         if (block.getBlockData() instanceof Farmland farmland && event.getNewState().getBlockData() instanceof Farmland newFarmland) { | ||||
|             int currentMoisture = farmland.getMoisture(); | ||||
|             int newMoisture = newFarmland.getMoisture(); | ||||
|  | ||||
|             // farmland gets moisturizes | ||||
|             if (newMoisture > currentMoisture) { | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             if (plot.getFlag(SoilDryFlag.class)) { | ||||
|                 return; | ||||
|             } | ||||
|  | ||||
|             plot.debug("Soil could not dry because soil-dry = false"); | ||||
|             event.setCancelled(true); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||
|     public void onChange(BlockFromToEvent event) { | ||||
|         Block fromBlock = event.getBlock(); | ||||
|   | ||||
| @@ -75,7 +75,7 @@ public class BukkitPlayer extends PlotPlayer<Player> { | ||||
|      * @deprecated Please do not use this method. Instead use {@link BukkitUtil#adapt(Player)}, as it caches player objects. | ||||
|      * This method will be made private in a future release. | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.10.9") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     public BukkitPlayer( | ||||
|             final @NonNull PlotAreaManager plotAreaManager, final @NonNull EventDispatcher eventDispatcher, | ||||
|             final @NonNull Player player, final @NonNull PermissionHandler permissionHandler | ||||
| @@ -92,7 +92,7 @@ public class BukkitPlayer extends PlotPlayer<Player> { | ||||
|      * @deprecated Please do not use this method. Instead use {@link BukkitUtil#adapt(Player)}, as it caches player objects. | ||||
|      * This method will be made private in a future release. | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.10.9") | ||||
|     @Deprecated(forRemoval = true, since = "TODO") | ||||
|     public BukkitPlayer( | ||||
|             final @NonNull PlotAreaManager plotAreaManager, final @NonNull | ||||
|             EventDispatcher eventDispatcher, final @NonNull Player player, | ||||
|   | ||||
| @@ -239,11 +239,9 @@ public final class BukkitChunkCoordinator extends ChunkCoordinator { | ||||
|      * server's main thread. | ||||
|      */ | ||||
|     private void processChunk(final @NonNull Chunk chunk) { | ||||
|         /* Chunk#isLoaded does not necessarily return true shortly after PaperLib#getChunkAtAsync completes, but the chunk is | ||||
|         still loaded. | ||||
|         if (!chunk.isLoaded()) { | ||||
|             throw new IllegalArgumentException(String.format("Chunk %d;%d is is not loaded", chunk.getX(), chunk.getZ()); | ||||
|         }*/ | ||||
|             throw new IllegalArgumentException(String.format("Chunk %d;%d is is not loaded", chunk.getX(), chunk.getZ())); | ||||
|         } | ||||
|         if (finished) { | ||||
|             return; | ||||
|         } | ||||
|   | ||||
| @@ -24,6 +24,7 @@ import org.bukkit.Bukkit; | ||||
| import org.checkerframework.checker.nullness.qual.NonNull; | ||||
|  | ||||
| import java.util.Map; | ||||
| import java.util.Objects; | ||||
|  | ||||
| public class BukkitWorld implements World<org.bukkit.World> { | ||||
|  | ||||
|   | ||||
| @@ -80,3 +80,4 @@ public class FaweSchematicHandler extends SchematicHandler { | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -55,7 +55,7 @@ further defined and clarified by project maintainers. | ||||
| ## Enforcement | ||||
|  | ||||
| Instances of abusive, harassing, or otherwise unacceptable behavior may be | ||||
| reported by contacting the project team at contact<at>intellectualsites.com. All | ||||
| reported by contacting the project team at contact@intellectualsites.com. All | ||||
| complaints will be reviewed and investigated and will result in a response that | ||||
| is deemed necessary and appropriate to the circumstances. The project team is | ||||
| obligated to maintain confidentiality with regard to the reporter of an incident. | ||||
|   | ||||
| @@ -56,7 +56,6 @@ 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; | ||||
| @@ -229,9 +228,10 @@ public class Area extends SubCommand { | ||||
|                 try (final ClipboardWriter clipboardWriter = BuiltInClipboardFormat.SPONGE_SCHEMATIC.getWriter(new FileOutputStream( | ||||
|                         file))) { | ||||
|                     final BlockArrayClipboard clipboard = new BlockArrayClipboard(selectedRegion); | ||||
|                     EditSessionBuilder editSessionBuilder = WorldEdit.getInstance().newEditSessionBuilder(); | ||||
|                     editSessionBuilder.world(selectedRegion.getWorld()); | ||||
|                     final EditSession editSession = editSessionBuilder.build(); | ||||
|                     final EditSession editSession = WorldEdit | ||||
|                             .getInstance() | ||||
|                             .getEditSessionFactory() | ||||
|                             .getEditSession(selectedRegion.getWorld(), -1); | ||||
|                     final ForwardExtentCopy forwardExtentCopy = | ||||
|                             new ForwardExtentCopy(editSession, selectedRegion, clipboard, selectedRegion.getMinimumPoint()); | ||||
|                     forwardExtentCopy.setCopyingBiomes(true); | ||||
|   | ||||
| @@ -106,6 +106,7 @@ 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 | ||||
|   | ||||
| @@ -28,6 +28,7 @@ import com.plotsquared.core.generator.HybridUtils; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| import com.plotsquared.core.plot.PlotArea; | ||||
| import com.plotsquared.core.plot.expiration.ExpireManager; | ||||
| import com.plotsquared.core.plot.expiration.PlotAnalysis; | ||||
| import com.plotsquared.core.plot.flag.GlobalFlagContainer; | ||||
| import com.plotsquared.core.plot.flag.PlotFlag; | ||||
| @@ -41,6 +42,7 @@ import org.checkerframework.checker.nullness.qual.NonNull; | ||||
|  | ||||
| import java.util.Arrays; | ||||
| import java.util.Collection; | ||||
| import java.util.HashSet; | ||||
| import java.util.LinkedHashSet; | ||||
| import java.util.List; | ||||
| import java.util.Locale; | ||||
|   | ||||
| @@ -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 in components.yml needs a valid target component, got: " + map.get("component"))); | ||||
|                         new IllegalArgumentException("The preset needs a valid target 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(); | ||||
|   | ||||
| @@ -1,63 +0,0 @@ | ||||
| /* | ||||
|  * PlotSquared, a land and world management plugin for Minecraft. | ||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||
|  * Copyright (C) IntellectualSites team and contributors | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| package com.plotsquared.core.events; | ||||
|  | ||||
| import com.sk89q.worldedit.entity.Entity; | ||||
| import org.checkerframework.checker.nullness.qual.NonNull; | ||||
|  | ||||
| /** | ||||
|  * @since TODO | ||||
|  */ | ||||
| public abstract class EntityEvent { | ||||
|  | ||||
|     private final Entity entity; | ||||
|  | ||||
|     private String name; | ||||
|  | ||||
|     /** | ||||
|      * @since 6.11.0 | ||||
|      */ | ||||
|     public EntityEvent(Entity entity) { | ||||
|         this.entity = entity; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Obtain the entity involved in the event | ||||
|      * | ||||
|      * @return Entity | ||||
|      * @since 6.11.0 | ||||
|      */ | ||||
|     public Entity getEntity() { | ||||
|         return this.entity; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Obtain the event's class name | ||||
|      * | ||||
|      * @return the event class name | ||||
|      * @since 6.11.0 | ||||
|      */ | ||||
|     @NonNull public String getEventName() { | ||||
|         if (this.name == null) { | ||||
|             this.name = this.getClass().getSimpleName(); | ||||
|         } | ||||
|         return this.name; | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -1,50 +0,0 @@ | ||||
| /* | ||||
|  * PlotSquared, a land and world management plugin for Minecraft. | ||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> | ||||
|  * Copyright (C) IntellectualSites team and contributors | ||||
|  * | ||||
|  * This program is free software: you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
|  * the Free Software Foundation, either version 3 of the License, or | ||||
|  * (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
|  * GNU General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||
|  */ | ||||
| package com.plotsquared.core.events; | ||||
|  | ||||
| import com.sk89q.worldedit.entity.Entity; | ||||
|  | ||||
| /** | ||||
|  * @since 6.11.0 | ||||
|  */ | ||||
| public class RemoveRoadEntityEvent extends EntityEvent implements CancellablePlotEvent { | ||||
|  | ||||
|     private Result eventResult; | ||||
|  | ||||
|     /** | ||||
|      * RemoveRoadEntityEvent: Called when an entity on road is removed. | ||||
|      * | ||||
|      * @param entity The entity to remove | ||||
|      * @since 6.11.0 | ||||
|      */ | ||||
|     public RemoveRoadEntityEvent(Entity entity) { | ||||
|         super(entity); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public Result getEventResult() { | ||||
|         return this.eventResult; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void setEventResult(Result eventResult) { | ||||
|         this.eventResult = eventResult; | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -144,7 +144,7 @@ public class ClassicPlotManager extends SquarePlotManager { | ||||
|                     plot.getRegions(), | ||||
|                     blocks, | ||||
|                     classicPlotWorld.getMinBuildHeight(), | ||||
|                     classicPlotWorld.getMaxBuildHeight() - 1, | ||||
|                     classicPlotWorld.getMaxBuildHeight(), | ||||
|                     actor, | ||||
|                     queue | ||||
|             ); | ||||
| @@ -175,7 +175,7 @@ public class ClassicPlotManager extends SquarePlotManager { | ||||
|                             plot.getRegions(), | ||||
|                             blocks, | ||||
|                             classicPlotWorld.PLOT_HEIGHT + 1, | ||||
|                             classicPlotWorld.getMaxBuildHeight() - 1, | ||||
|                             classicPlotWorld.getMaxBuildHeight(), | ||||
|                             actor, | ||||
|                             queue | ||||
|                     ); | ||||
| @@ -281,7 +281,7 @@ public class ClassicPlotManager extends SquarePlotManager { | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         int maxY = classicPlotWorld.getMaxBuildHeight() - 1; | ||||
|         int maxY = classicPlotWorld.getMaxBuildHeight(); | ||||
|         if (!plot.isMerged(Direction.NORTH)) { | ||||
|             int z = bottom.getZ(); | ||||
|             for (int x = bottom.getX(); x <= top.getX(); x++) { | ||||
|   | ||||
| @@ -2506,7 +2506,7 @@ public class Plot { | ||||
|                 } | ||||
|             } | ||||
|             int minHeight = getArea().getMinBuildHeight(); | ||||
|             int maxHeight = getArea().getMaxBuildHeight() - 1; | ||||
|             int maxHeight = getArea().getMaxBuildHeight(); | ||||
|             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,6 +220,17 @@ 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 | ||||
| @@ -270,21 +281,7 @@ public final class PlotModificationManager { | ||||
|                 manager.clearPlot(current, this, actor, null); | ||||
|             } | ||||
|         }; | ||||
|         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(); | ||||
|         } | ||||
|         run.run(); | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
| @@ -324,23 +321,7 @@ 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 6.10.9 | ||||
|      */ | ||||
|     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(); | ||||
| @@ -385,17 +366,14 @@ 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); | ||||
|         } | ||||
|         queue.enqueue(); | ||||
|         if (queue != null) { | ||||
|             queue.enqueue(); | ||||
|         } | ||||
|         return true; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -24,6 +24,7 @@ import org.checkerframework.checker.nullness.qual.NonNull; | ||||
| import org.checkerframework.checker.nullness.qual.Nullable; | ||||
|  | ||||
| import java.util.Collection; | ||||
| import java.util.Objects; | ||||
|  | ||||
| /** | ||||
|  * A world that contains plots | ||||
|   | ||||
| @@ -24,6 +24,7 @@ import org.checkerframework.checker.nullness.qual.NonNull; | ||||
|  | ||||
| import java.util.Collection; | ||||
| import java.util.Collections; | ||||
| import java.util.Objects; | ||||
|  | ||||
| /** | ||||
|  * A plot flag is any property that can be assigned | ||||
|   | ||||
| @@ -221,7 +221,7 @@ public abstract class QueueCoordinator { | ||||
|      * @return success or not | ||||
|      * @deprecated Biomes now take XYZ, see {@link #setBiome(int, int, int, BiomeType)} | ||||
|      *         <br> | ||||
|      *         Scheduled for removal once we drop the support for versions not supporting 3D biomes, 1.18 and earlier. | ||||
|      *         Scheduled for removal once we drop the support for versions not supporting 3D biomes. | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.0.0") | ||||
|     public abstract boolean setBiome(int x, int z, @NonNull BiomeType biome); | ||||
|   | ||||
| @@ -45,7 +45,6 @@ import com.plotsquared.core.events.PlotFlagRemoveEvent; | ||||
| import com.plotsquared.core.events.PlotMergeEvent; | ||||
| import com.plotsquared.core.events.PlotRateEvent; | ||||
| import com.plotsquared.core.events.PlotUnlinkEvent; | ||||
| import com.plotsquared.core.events.RemoveRoadEntityEvent; | ||||
| import com.plotsquared.core.events.TeleportCause; | ||||
| import com.plotsquared.core.events.post.PostPlayerAutoPlotEvent; | ||||
| import com.plotsquared.core.events.post.PostPlotChangeOwnerEvent; | ||||
| @@ -72,7 +71,6 @@ import com.plotsquared.core.plot.flag.types.BlockTypeWrapper; | ||||
| import com.plotsquared.core.plot.world.SinglePlotArea; | ||||
| import com.plotsquared.core.util.task.TaskManager; | ||||
| import com.sk89q.worldedit.WorldEdit; | ||||
| import com.sk89q.worldedit.entity.Entity; | ||||
| import com.sk89q.worldedit.function.pattern.Pattern; | ||||
| import com.sk89q.worldedit.world.block.BlockType; | ||||
| import com.sk89q.worldedit.world.block.BlockTypes; | ||||
| @@ -298,12 +296,6 @@ public class EventDispatcher { | ||||
|         return event; | ||||
|     } | ||||
|  | ||||
|     public RemoveRoadEntityEvent callRemoveRoadEntity(Entity entity) { | ||||
|         RemoveRoadEntityEvent event = new RemoveRoadEntityEvent(entity); | ||||
|         eventBus.post(event); | ||||
|         return event; | ||||
|     } | ||||
|  | ||||
|     public void doJoinTask(final PlotPlayer<?> player) { | ||||
|         if (player == null) { | ||||
|             return; //possible future warning message to figure out where we are retrieving null | ||||
|   | ||||
| @@ -19,6 +19,7 @@ | ||||
| package com.plotsquared.core.util; | ||||
|  | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| import com.sk89q.worldedit.math.BlockVector2; | ||||
| import com.sk89q.worldedit.math.BlockVector3; | ||||
| import com.sk89q.worldedit.regions.CuboidRegion; | ||||
|   | ||||
| @@ -491,10 +491,6 @@ public abstract class SchematicHandler { | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * The legacy web interface is deprecated for removal in favor of Arkitektonika. | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.11.0") | ||||
|     public List<String> getSaves(UUID uuid) { | ||||
|         String rawJSON; | ||||
|         try { | ||||
|   | ||||
| @@ -31,6 +31,7 @@ import com.plotsquared.core.plot.Plot; | ||||
| import com.plotsquared.core.plot.PlotArea; | ||||
| import com.plotsquared.core.uuid.UUIDMapping; | ||||
| import org.checkerframework.checker.nullness.qual.NonNull; | ||||
| import org.checkerframework.checker.nullness.qual.Nullable; | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| import java.util.Arrays; | ||||
|   | ||||
| @@ -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() - 1); | ||||
|                     BlockVector3 pos2 = region.getMaximumPoint().withY(area.getMaxBuildHeight()); | ||||
|                     CuboidRegion copy = new CuboidRegion(pos1, pos2); | ||||
|                     regions.add(copy); | ||||
|                 } | ||||
|   | ||||
| @@ -252,10 +252,6 @@ public abstract class WorldUtil { | ||||
|      */ | ||||
|     public abstract void refreshChunk(int x, int z, String world); | ||||
|  | ||||
|     /** | ||||
|      * The legacy web interface is deprecated for removal in favor of Arkitektonika. | ||||
|      */ | ||||
|     @Deprecated(forRemoval = true, since = "6.11.0") | ||||
|     public void upload( | ||||
|             final @NonNull Plot plot, | ||||
|             final @Nullable UUID uuid, | ||||
|   | ||||
| @@ -55,3 +55,4 @@ public class AbstractDelegateOutputStream extends OutputStream { | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -21,6 +21,7 @@ package com.plotsquared.core.util.query; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| import org.checkerframework.checker.nullness.qual.NonNull; | ||||
|  | ||||
| import java.util.Objects; | ||||
| import java.util.UUID; | ||||
|  | ||||
| class OwnersIncludeFilter implements PlotFilter { | ||||
|   | ||||
| @@ -83,3 +83,4 @@ public interface PlotSquaredTask extends Runnable { | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -276,3 +276,4 @@ public class AbstractDBTest implements AbstractDB { | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| <p align="center"> | ||||
|     <img src="https://raw.githubusercontent.com/IntellectualSites/Assets/main/plugins/PlotSquared/PlotSquared.svg" width="250"> | ||||
| </p> | ||||
|  | ||||
|    | ||||
| --- | ||||
|  | ||||
| PlotSquared is a land and world management plugin for Minecraft.  | ||||
|   | ||||
| @@ -18,17 +18,7 @@ plugins { | ||||
| } | ||||
|  | ||||
| group = "com.plotsquared" | ||||
| version = "6.11.1-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) } | ||||
| } | ||||
| version = "6.10.9-SNAPSHOT" | ||||
|  | ||||
| subprojects { | ||||
|     group = rootProject.group | ||||
| @@ -74,7 +64,7 @@ subprojects { | ||||
|     } | ||||
|  | ||||
|     dependencies { | ||||
|         implementation(platform("com.intellectualsites.bom:bom-1.18.x:1.24")) | ||||
|         implementation(platform("com.intellectualsites.bom:bom-1.18.x:1.22")) | ||||
|     } | ||||
|  | ||||
|     dependencies { | ||||
| @@ -100,9 +90,6 @@ subprojects { | ||||
|         java { | ||||
|             licenseHeaderFile(rootProject.file("HEADER.txt")) | ||||
|             target("**/*.java") | ||||
|             endWithNewline() | ||||
|             trimTrailingWhitespace() | ||||
|             removeUnusedImports() | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -155,7 +142,7 @@ subprojects { | ||||
|                             id.set("NotMyFault") | ||||
|                             name.set("Alexander Brandes") | ||||
|                             organization.set("IntellectualSites") | ||||
|                             email.set("contact(at)notmyfault.dev") | ||||
|                             email.set("contact@notmyfault.dev") | ||||
|                         } | ||||
|                         developer { | ||||
|                             id.set("SirYwell") | ||||
|   | ||||
| @@ -11,18 +11,18 @@ essentialsx = "2.19.7" | ||||
| mvdwapi = "3.1.1" | ||||
|  | ||||
| # Third party | ||||
| prtree = "2.0.1" | ||||
| prtree = "2.0.0" | ||||
| aopalliance = "1.0" | ||||
| cloud-services = "1.8.2" | ||||
| arkitektonika = "2.1.2" | ||||
| cloud-services = "1.8.0" | ||||
| arkitektonika = "2.1.1" | ||||
| squirrelid = "0.3.1" | ||||
| http4j = "1.3" | ||||
|  | ||||
| # Gradle plugins | ||||
| shadow = "7.1.2" | ||||
| grgit = "4.1.1" | ||||
| spotless = "6.16.0" | ||||
| nexus = "1.2.0" | ||||
| spotless = "6.13.0" | ||||
| nexus = "1.1.0" | ||||
|  | ||||
| [libraries] | ||||
| # Platform expectations | ||||
|   | ||||
							
								
								
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| distributionBase=GRADLE_USER_HOME | ||||
| distributionPath=wrapper/dists | ||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-7.6.1-bin.zip | ||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-7.6-bin.zip | ||||
| networkTimeout=10000 | ||||
| zipStoreBase=GRADLE_USER_HOME | ||||
| zipStorePath=wrapper/dists | ||||
|   | ||||
| @@ -4,7 +4,6 @@ | ||||
|     "config:base", | ||||
|     ":semanticCommitsDisabled" | ||||
|   ], | ||||
|   "labels": ["dependencies"], | ||||
|   "rebaseWhen": "conflicted", | ||||
|   "schedule": ["on the first day of the week"] | ||||
|   "labels": ["Renovate"], | ||||
|   "rebaseWhen": "conflicted" | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user