mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-26 07:03:45 +01:00 
			
		
		
		
	Compare commits
	
		
			61 Commits
		
	
	
		
			chore/v7/d
			...
			fix/plot-c
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | cc1e209ea4 | ||
|   | 745b06a008 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 77b2bd166a | ||
|   | 8e02336c44 | ||
|   | 3adfbde45a | ||
|   | e6db8e2750 | ||
|   | 9cd0ee9b49 | ||
|   | d455d1fcd7 | ||
|   | ea19ff783f | ||
|   | 447e4c7d58 | ||
|   | 89031447f2 | ||
|   | 4210a3a555 | ||
|   | 42e146b8c7 | ||
|   | a5fdcda673 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 52823f5024 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 1326c257a0 | ||
|   | fc3137cd96 | ||
|   | a5c53a96d1 | ||
|   | c46cc73f52 | ||
|   | 276e619caa | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f11acacedd | ||
|   | f636a5ec63 | ||
|   | d1bac90745 | ||
|   | 785362c576 | ||
|   | e98f628d34 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b2ab61559c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | dd6eb8e74f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 97cdd03ea4 | ||
|   | f5118e6802 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 94ca5cf679 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 5a55a1f602 | ||
|   | 1e7ba7d173 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ed33635a15 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 888682e5d0 | ||
|   | 72bb5f00b0 | ||
|   | 773fd6f59f | ||
|   | aa784e98f8 | ||
|   | 5cce86d924 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 84567bcb00 | ||
|   | d7c2ab1d16 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0d359ade0c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | ffbec24290 | ||
|   | 586474c8e6 | ||
|   | 70b6636f50 | ||
|   | ab357deb48 | ||
|   | bd62d1a1c7 | ||
|   | 6130c3dfa5 | ||
|   | 26692d6633 | ||
|   | bb0f200429 | ||
|   | 5787588500 | ||
|   | bed62edc02 | ||
|   | ee0f389c78 | ||
|   | b40383b5a4 | ||
|   | be8903128d | ||
|   | 08800ec16d | ||
|   | 83e274ff9f | ||
|   | 0dd8b1053c | ||
|   | 0558fcf5d5 | ||
|   | 5af8be4293 | ||
|   | cbacdd67eb | ||
|   | c45bbe3ec5 | 
| @@ -1,8 +1,7 @@ | |||||||
| name: Announce release on discord | name: Announce release on discord | ||||||
| on: | on: | ||||||
|   release: |   release: | ||||||
|     types: [published] |     types: [ published ] | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   send_announcement: |   send_announcement: | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
| @@ -12,7 +11,7 @@ jobs: | |||||||
|           DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} |           DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} | ||||||
|           DISCORD_USERNAME: PlotSquared Release |           DISCORD_USERNAME: PlotSquared Release | ||||||
|           DISCORD_AVATAR: https://raw.githubusercontent.com/IntellectualSites/Assets/main/plugins/PlotSquared/PlotSquared.png |           DISCORD_AVATAR: https://raw.githubusercontent.com/IntellectualSites/Assets/main/plugins/PlotSquared/PlotSquared.png | ||||||
|         uses: Ilshidur/action-discord@0.3.2 |         uses: Ilshidur/action-discord@08d9328877d6954120eef2b07abbc79249bb6210 # ratchet:Ilshidur/action-discord@0.3.2 | ||||||
|         with: |         with: | ||||||
|           args: | |           args: | | ||||||
|             "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>" |             "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>" | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,7 +1,5 @@ | |||||||
| name: Build PR | name: Build PR | ||||||
|  |  | ||||||
| on: [ pull_request ] | on: [ pull_request ] | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   build_pr: |   build_pr: | ||||||
|     if: github.repository_owner == 'IntellectualSites' |     if: github.repository_owner == 'IntellectualSites' | ||||||
| @@ -13,7 +11,7 @@ jobs: | |||||||
|       - name: Checkout Repository |       - name: Checkout Repository | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
|       - name: Validate Gradle Wrapper |       - name: Validate Gradle Wrapper | ||||||
|         uses: gradle/wrapper-validation-action@v1 |         uses: gradle/wrapper-validation-action@55e685c48d84285a5b0418cd094606e199cca3b6 # v1 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v3 |         uses: actions/setup-java@v3 | ||||||
|         with: |         with: | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										20
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,10 +1,8 @@ | |||||||
| name: build | name: build | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - v7 |       - main | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   build: |   build: | ||||||
|     if: github.repository_owner == 'IntellectualSites' |     if: github.repository_owner == 'IntellectualSites' | ||||||
| @@ -13,7 +11,7 @@ jobs: | |||||||
|       - name: Checkout Repository |       - name: Checkout Repository | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
|       - name: Validate Gradle Wrapper |       - name: Validate Gradle Wrapper | ||||||
|         uses: gradle/wrapper-validation-action@v1 |         uses: gradle/wrapper-validation-action@55e685c48d84285a5b0418cd094606e199cca3b6 # v1 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v3 |         uses: actions/setup-java@v3 | ||||||
|         with: |         with: | ||||||
| @@ -30,7 +28,7 @@ jobs: | |||||||
|             echo "STATUS=release" >> $GITHUB_ENV |             echo "STATUS=release" >> $GITHUB_ENV | ||||||
|           fi |           fi | ||||||
|       - name: Publish Release |       - name: Publish Release | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}} | ||||||
|         run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository |         run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository | ||||||
|         env: |         env: | ||||||
|           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} |           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} | ||||||
| @@ -38,15 +36,14 @@ jobs: | |||||||
|           ORG_GRADLE_PROJECT_signingKey: ${{ secrets.SIGNING_KEY }} |           ORG_GRADLE_PROJECT_signingKey: ${{ secrets.SIGNING_KEY }} | ||||||
|           ORG_GRADLE_PROJECT_signingPassword: ${{ secrets.SIGNING_PASSWORD }} |           ORG_GRADLE_PROJECT_signingPassword: ${{ secrets.SIGNING_PASSWORD }} | ||||||
|       - name: Publish Snapshot |       - name: Publish Snapshot | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS != 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7' }} |         if: ${{ runner.os == 'Linux' && env.STATUS != 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main' }} | ||||||
|         run: ./gradlew publishToSonatype |         run: ./gradlew publishToSonatype | ||||||
|         env: |         env: | ||||||
|           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} |           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} | ||||||
|           ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} |           ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} | ||||||
|       - name: Publish core javadoc |       - name: Publish core javadoc | ||||||
|        # if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}} | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'snapshot' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} |         uses: cpina/github-action-push-to-another-repository@0a14457bb28b04dfa1652e0ffdfda866d2845c73 | ||||||
|         uses: cpina/github-action-push-to-another-repository@main |  | ||||||
|         env: |         env: | ||||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} |           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||||
|         with: |         with: | ||||||
| @@ -57,9 +54,8 @@ jobs: | |||||||
|           target-branch: main |           target-branch: main | ||||||
|           target-directory: v7/core |           target-directory: v7/core | ||||||
|       - name: Publish bukkit javadoc |       - name: Publish bukkit javadoc | ||||||
|        # if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}} | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'snapshot' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} |         uses: cpina/github-action-push-to-another-repository@0a14457bb28b04dfa1652e0ffdfda866d2845c73 # main | ||||||
|         uses: cpina/github-action-push-to-another-repository@main |  | ||||||
|         env: |         env: | ||||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} |           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||||
|         with: |         with: | ||||||
|   | |||||||
							
								
								
									
										16
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,11 +1,10 @@ | |||||||
| name: "CodeQL" | name: "CodeQL" | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: [ v7 ] |     branches: [ main ] | ||||||
|   pull_request: |   pull_request: | ||||||
|     # The branches below must be a subset of the branches above |     # The branches below must be a subset of the branches above | ||||||
|     branches: [ v7 ] |     branches: [ main ] | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   analyze: |   analyze: | ||||||
| @@ -15,23 +14,18 @@ jobs: | |||||||
|       actions: read |       actions: read | ||||||
|       contents: read |       contents: read | ||||||
|       security-events: write |       security-events: write | ||||||
|  |  | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         language: [ 'java' ] |         language: [ 'java' ] | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout repository |       - name: Checkout repository | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|       - name: Initialize CodeQL |       - name: Initialize CodeQL | ||||||
|         uses: github/codeql-action/init@v2 |         uses: github/codeql-action/init@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2 | ||||||
|         with: |         with: | ||||||
|           languages: ${{ matrix.language }} |           languages: ${{ matrix.language }} | ||||||
|  |  | ||||||
|       - name: Autobuild |       - name: Autobuild | ||||||
|         uses: github/codeql-action/autobuild@v2 |         uses: github/codeql-action/autobuild@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2 | ||||||
|  |  | ||||||
|       - name: Perform CodeQL Analysis |       - name: Perform CodeQL Analysis | ||||||
|         uses: github/codeql-action/analyze@v2 |         uses: github/codeql-action/analyze@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2 | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,14 +1,12 @@ | |||||||
| name: draft release | name: draft release | ||||||
|  |  | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - v6 |       - main | ||||||
|   pull_request: |   pull_request: | ||||||
|     types: [ opened, reopened, synchronize ] |     types: [ opened, reopened, synchronize ] | ||||||
|   pull_request_target: |   pull_request_target: | ||||||
|     types: [ opened, reopened, synchronize ] |     types: [ opened, reopened, synchronize ] | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   update_release_draft: |   update_release_draft: | ||||||
|     if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }} |     if: ${{ github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name }} | ||||||
|   | |||||||
| @@ -102,7 +102,7 @@ tasks { | |||||||
|         opt.links("https://jd.papermc.io/paper/1.19/") |         opt.links("https://jd.papermc.io/paper/1.19/") | ||||||
|         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-bukkit/" + libs.worldeditBukkit.get().versionConstraint.toString()) |         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-bukkit/" + libs.worldeditBukkit.get().versionConstraint.toString()) | ||||||
|         opt.links("https://intellectualsites.github.io/plotsquared-javadocs/core/") |         opt.links("https://intellectualsites.github.io/plotsquared-javadocs/core/") | ||||||
|         opt.links("https://jd.adventure.kyori.net/api/4.12.0/") |         opt.links("https://jd.advntr.dev/api/4.12.0/") | ||||||
|         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") |         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") | ||||||
|         opt.links("https://checkerframework.org/api/") |         opt.links("https://checkerframework.org/api/") | ||||||
|         opt.isLinkSource = true |         opt.isLinkSource = true | ||||||
|   | |||||||
| @@ -49,8 +49,8 @@ import com.plotsquared.bukkit.player.BukkitPlayerManager; | |||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.plotsquared.bukkit.util.BukkitWorld; | import com.plotsquared.bukkit.util.BukkitWorld; | ||||||
| import com.plotsquared.bukkit.util.SetGenCB; | import com.plotsquared.bukkit.util.SetGenCB; | ||||||
| import com.plotsquared.bukkit.util.UpdateUtility; |  | ||||||
| import com.plotsquared.bukkit.util.TranslationUpdateManager; | import com.plotsquared.bukkit.util.TranslationUpdateManager; | ||||||
|  | import com.plotsquared.bukkit.util.UpdateUtility; | ||||||
| import com.plotsquared.bukkit.util.task.BukkitTaskManager; | import com.plotsquared.bukkit.util.task.BukkitTaskManager; | ||||||
| import com.plotsquared.bukkit.util.task.PaperTimeConverter; | import com.plotsquared.bukkit.util.task.PaperTimeConverter; | ||||||
| import com.plotsquared.bukkit.util.task.SpigotTimeConverter; | import com.plotsquared.bukkit.util.task.SpigotTimeConverter; | ||||||
| @@ -72,6 +72,8 @@ import com.plotsquared.core.configuration.Storage; | |||||||
| import com.plotsquared.core.configuration.caption.ChatFormatter; | import com.plotsquared.core.configuration.caption.ChatFormatter; | ||||||
| import com.plotsquared.core.configuration.file.YamlConfiguration; | import com.plotsquared.core.configuration.file.YamlConfiguration; | ||||||
| import com.plotsquared.core.database.DBFunc; | 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.GeneratorWrapper; | ||||||
| import com.plotsquared.core.generator.IndependentPlotGenerator; | import com.plotsquared.core.generator.IndependentPlotGenerator; | ||||||
| import com.plotsquared.core.generator.SingleWorldGenerator; | import com.plotsquared.core.generator.SingleWorldGenerator; | ||||||
| @@ -110,6 +112,7 @@ import com.plotsquared.core.uuid.CacheUUIDService; | |||||||
| import com.plotsquared.core.uuid.UUIDPipeline; | import com.plotsquared.core.uuid.UUIDPipeline; | ||||||
| import com.plotsquared.core.uuid.offline.OfflineModeUUIDService; | import com.plotsquared.core.uuid.offline.OfflineModeUUIDService; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
|  | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import io.papermc.lib.PaperLib; | import io.papermc.lib.PaperLib; | ||||||
| import net.kyori.adventure.audience.Audience; | import net.kyori.adventure.audience.Audience; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| @@ -818,8 +821,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                         if (entity.hasMetadata("ps-tmp-teleport")) { |                                         if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                             continue; |                                             continue; | ||||||
|                                         } |                                         } | ||||||
|                                         iterator.remove(); |                                         this.removeRoadEntity(entity, iterator); | ||||||
|                                         entity.remove(); |  | ||||||
|                                     } |                                     } | ||||||
|                                     continue; |                                     continue; | ||||||
|                                 } |                                 } | ||||||
| @@ -832,8 +834,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                     if (entity.hasMetadata("ps-tmp-teleport")) { |                                     if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                         continue; |                                         continue; | ||||||
|                                     } |                                     } | ||||||
|                                     iterator.remove(); |                                     this.removeRoadEntity(entity, iterator); | ||||||
|                                     entity.remove(); |  | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
|                             continue; |                             continue; | ||||||
| @@ -843,7 +844,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                         case "DROPPED_ITEM": |                         case "DROPPED_ITEM": | ||||||
|                             if (Settings.Enabled_Components.KILL_ROAD_ITEMS |                             if (Settings.Enabled_Components.KILL_ROAD_ITEMS | ||||||
|                                     && plotArea.getOwnedPlotAbs(BukkitUtil.adapt(entity.getLocation())) == null) { |                                     && plotArea.getOwnedPlotAbs(BukkitUtil.adapt(entity.getLocation())) == null) { | ||||||
|                                 entity.remove(); |                                 this.removeRoadEntity(entity, iterator); | ||||||
|                             } |                             } | ||||||
|                             // dropped item |                             // dropped item | ||||||
|                             continue; |                             continue; | ||||||
| @@ -874,8 +875,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                                 if (entity.hasMetadata("ps-tmp-teleport")) { |                                                 if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                                     continue; |                                                     continue; | ||||||
|                                                 } |                                                 } | ||||||
|                                                 iterator.remove(); |                                                 this.removeRoadEntity(entity, iterator); | ||||||
|                                                 entity.remove(); |  | ||||||
|                                             } |                                             } | ||||||
|                                         } |                                         } | ||||||
|                                     } |                                     } | ||||||
| @@ -980,8 +980,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                                 if (entity.hasMetadata("ps-tmp-teleport")) { |                                                 if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                                     continue; |                                                     continue; | ||||||
|                                                 } |                                                 } | ||||||
|                                                 iterator.remove(); |                                                 this.removeRoadEntity(entity, iterator); | ||||||
|                                                 entity.remove(); |  | ||||||
|                                             } |                                             } | ||||||
|                                         } |                                         } | ||||||
|                                     } else { |                                     } else { | ||||||
| @@ -992,8 +991,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                                             if (entity.hasMetadata("ps-tmp-teleport")) { |                                             if (entity.hasMetadata("ps-tmp-teleport")) { | ||||||
|                                                 continue; |                                                 continue; | ||||||
|                                             } |                                             } | ||||||
|                                             iterator.remove(); |                                             this.removeRoadEntity(entity, iterator); | ||||||
|                                             entity.remove(); |  | ||||||
|                                         } |                                         } | ||||||
|                                     } |                                     } | ||||||
|                                 } |                                 } | ||||||
| @@ -1007,6 +1005,17 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|         }), TaskTime.seconds(1L)); |         }), 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 |     @Override | ||||||
|     public @Nullable |     public @Nullable | ||||||
|     final ChunkGenerator getDefaultWorldGenerator( |     final ChunkGenerator getDefaultWorldGenerator( | ||||||
| @@ -1176,9 +1185,17 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|     public @NonNull String worldEditImplementations() { |     public @NonNull String worldEditImplementations() { | ||||||
|         StringBuilder msg = new StringBuilder(); |         StringBuilder msg = new StringBuilder(); | ||||||
|         if (Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit") != null) { |         if (Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit") != null) { | ||||||
|             msg.append("FastAsyncWorldEdit: ").append(Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit").getDescription().getVersion()); |             msg.append("FastAsyncWorldEdit: ").append(Bukkit | ||||||
|  |                     .getPluginManager() | ||||||
|  |                     .getPlugin("FastAsyncWorldEdit") | ||||||
|  |                     .getDescription() | ||||||
|  |                     .getVersion()); | ||||||
|         } else if (Bukkit.getPluginManager().getPlugin("AsyncWorldEdit") != null) { |         } else if (Bukkit.getPluginManager().getPlugin("AsyncWorldEdit") != null) { | ||||||
|             msg.append("AsyncWorldEdit: ").append(Bukkit.getPluginManager().getPlugin("AsyncWorldEdit").getDescription().getVersion()).append("\n"); |             msg.append("AsyncWorldEdit: ").append(Bukkit | ||||||
|  |                     .getPluginManager() | ||||||
|  |                     .getPlugin("AsyncWorldEdit") | ||||||
|  |                     .getDescription() | ||||||
|  |                     .getVersion()).append("\n"); | ||||||
|             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); |             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); | ||||||
|         } else { |         } else { | ||||||
|             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); |             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); | ||||||
|   | |||||||
| @@ -101,50 +101,26 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|             this.noGravity = true; |             this.noGravity = true; | ||||||
|         } |         } | ||||||
|         switch (entity.getType().toString()) { |         switch (entity.getType().toString()) { | ||||||
|             case "BOAT": |             case "BOAT" -> { | ||||||
|                 Boat boat = (Boat) entity; |                 Boat boat = (Boat) entity; | ||||||
|                 this.dataByte = getOrdinal(TreeSpecies.values(), boat.getWoodType()); |                 this.dataByte = getOrdinal(TreeSpecies.values(), boat.getWoodType()); | ||||||
|                 return; |                 return; | ||||||
|             case "ARROW": |             } | ||||||
|             case "EGG": |             case "ARROW", "EGG", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "EXPERIENCE_ORB", "FALLING_BLOCK", "FIREBALL", | ||||||
|             case "ENDER_CRYSTAL": |                     "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", "MINECART_MOB_SPAWNER", | ||||||
|             case "ENDER_PEARL": |                     "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SLIME", "SMALL_FIREBALL", "SNOWBALL", "MINECART_FURNACE", "SPLASH_POTION", | ||||||
|             case "ENDER_SIGNAL": |                     "THROWN_EXP_BOTTLE", "WITHER_SKULL", "UNKNOWN", "SPECTRAL_ARROW", "SHULKER_BULLET", "DRAGON_FIREBALL", "AREA_EFFECT_CLOUD", | ||||||
|             case "EXPERIENCE_ORB": |                     "TRIDENT", "LLAMA_SPIT" -> { | ||||||
|             case "FALLING_BLOCK": |  | ||||||
|             case "FIREBALL": |  | ||||||
|             case "FIREWORK": |  | ||||||
|             case "FISHING_HOOK": |  | ||||||
|             case "LEASH_HITCH": |  | ||||||
|             case "LIGHTNING": |  | ||||||
|             case "MINECART": |  | ||||||
|             case "MINECART_COMMAND": |  | ||||||
|             case "MINECART_MOB_SPAWNER": |  | ||||||
|             case "MINECART_TNT": |  | ||||||
|             case "PLAYER": |  | ||||||
|             case "PRIMED_TNT": |  | ||||||
|             case "SLIME": |  | ||||||
|             case "SMALL_FIREBALL": |  | ||||||
|             case "SNOWBALL": |  | ||||||
|             case "MINECART_FURNACE": |  | ||||||
|             case "SPLASH_POTION": |  | ||||||
|             case "THROWN_EXP_BOTTLE": |  | ||||||
|             case "WITHER_SKULL": |  | ||||||
|             case "UNKNOWN": |  | ||||||
|             case "SPECTRAL_ARROW": |  | ||||||
|             case "SHULKER_BULLET": |  | ||||||
|             case "DRAGON_FIREBALL": |  | ||||||
|             case "AREA_EFFECT_CLOUD": |  | ||||||
|             case "TRIDENT": |  | ||||||
|             case "LLAMA_SPIT": |  | ||||||
|                 // Do this stuff later |                 // Do this stuff later | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // MISC // |             // MISC // | ||||||
|             case "DROPPED_ITEM": |             case "DROPPED_ITEM" -> { | ||||||
|                 Item item = (Item) entity; |                 Item item = (Item) entity; | ||||||
|                 this.stack = item.getItemStack(); |                 this.stack = item.getItemStack(); | ||||||
|                 return; |                 return; | ||||||
|             case "ITEM_FRAME": |             } | ||||||
|  |             case "ITEM_FRAME" -> { | ||||||
|                 this.x = Math.floor(this.getX()); |                 this.x = Math.floor(this.getX()); | ||||||
|                 this.y = Math.floor(this.getY()); |                 this.y = Math.floor(this.getY()); | ||||||
|                 this.z = Math.floor(this.getZ()); |                 this.z = Math.floor(this.getZ()); | ||||||
| @@ -152,7 +128,8 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 this.dataByte = getOrdinal(Rotation.values(), itemFrame.getRotation()); |                 this.dataByte = getOrdinal(Rotation.values(), itemFrame.getRotation()); | ||||||
|                 this.stack = itemFrame.getItem().clone(); |                 this.stack = itemFrame.getItem().clone(); | ||||||
|                 return; |                 return; | ||||||
|             case "PAINTING": |             } | ||||||
|  |             case "PAINTING" -> { | ||||||
|                 this.x = Math.floor(this.getX()); |                 this.x = Math.floor(this.getX()); | ||||||
|                 this.y = Math.floor(this.getY()); |                 this.y = Math.floor(this.getY()); | ||||||
|                 this.z = Math.floor(this.getZ()); |                 this.z = Math.floor(this.getZ()); | ||||||
| @@ -165,20 +142,17 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 } |                 } | ||||||
|                 this.dataString = art.name(); |                 this.dataString = art.name(); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END MISC // |             // END MISC // | ||||||
|             // INVENTORY HOLDER // |             // INVENTORY HOLDER // | ||||||
|             case "MINECART_CHEST": |             case "MINECART_CHEST", "MINECART_HOPPER" -> { | ||||||
|             case "MINECART_HOPPER": |  | ||||||
|                 storeInventory((InventoryHolder) entity); |                 storeInventory((InventoryHolder) entity); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // START LIVING ENTITY // |             // START LIVING ENTITY // | ||||||
|             // START AGEABLE // |             // START AGEABLE // | ||||||
|             // START TAMEABLE // |             // START TAMEABLE // | ||||||
|             case "HORSE": |             case "HORSE", "DONKEY", "LLAMA", "MULE", "SKELETON_HORSE" -> { | ||||||
|             case "DONKEY": |  | ||||||
|             case "LLAMA": |  | ||||||
|             case "MULE": |  | ||||||
|             case "SKELETON_HORSE": |  | ||||||
|                 AbstractHorse horse = (AbstractHorse) entity; |                 AbstractHorse horse = (AbstractHorse) entity; | ||||||
|                 this.horse = new HorseStats(); |                 this.horse = new HorseStats(); | ||||||
|                 this.horse.jump = horse.getJumpStrength(); |                 this.horse.jump = horse.getJumpStrength(); | ||||||
| @@ -194,16 +168,17 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 storeLiving(horse); |                 storeLiving(horse); | ||||||
|                 storeInventory(horse); |                 storeInventory(horse); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END INVENTORY HOLDER // |             // END INVENTORY HOLDER // | ||||||
|             case "WOLF": |             case "WOLF", "OCELOT" -> { | ||||||
|             case "OCELOT": |  | ||||||
|                 storeTameable((Tameable) entity); |                 storeTameable((Tameable) entity); | ||||||
|                 storeAgeable((Ageable) entity); |                 storeAgeable((Ageable) entity); | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END TAMEABLE // |             // END TAMEABLE // | ||||||
|             //todo fix sheep |             //todo fix sheep | ||||||
|             case "SHEEP": |             case "SHEEP" -> { | ||||||
|                 Sheep sheep = (Sheep) entity; |                 Sheep sheep = (Sheep) entity; | ||||||
|                 if (sheep.isSheared()) { |                 if (sheep.isSheared()) { | ||||||
|                     this.dataByte = (byte) 1; |                     this.dataByte = (byte) 1; | ||||||
| @@ -214,23 +189,20 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 storeAgeable(sheep); |                 storeAgeable(sheep); | ||||||
|                 storeLiving(sheep); |                 storeLiving(sheep); | ||||||
|                 return; |                 return; | ||||||
|             case "VILLAGER": |             } | ||||||
|             case "CHICKEN": |             case "VILLAGER", "CHICKEN", "COW", "MUSHROOM_COW", "PIG", "TURTLE", "POLAR_BEAR" -> { | ||||||
|             case "COW": |  | ||||||
|             case "MUSHROOM_COW": |  | ||||||
|             case "PIG": |  | ||||||
|             case "TURTLE": |  | ||||||
|             case "POLAR_BEAR": |  | ||||||
|                 storeAgeable((Ageable) entity); |                 storeAgeable((Ageable) entity); | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|             case "RABBIT": |             } | ||||||
|  |             case "RABBIT" -> { | ||||||
|                 this.dataByte = getOrdinal(Rabbit.Type.values(), ((Rabbit) entity).getRabbitType()); |                 this.dataByte = getOrdinal(Rabbit.Type.values(), ((Rabbit) entity).getRabbitType()); | ||||||
|                 storeAgeable((Ageable) entity); |                 storeAgeable((Ageable) entity); | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|  |             } | ||||||
|             // END AGEABLE // |             // END AGEABLE // | ||||||
|             case "ARMOR_STAND": |             case "ARMOR_STAND" -> { | ||||||
|                 ArmorStand stand = (ArmorStand) entity; |                 ArmorStand stand = (ArmorStand) entity; | ||||||
|                 this.inventory = |                 this.inventory = | ||||||
|                         new ItemStack[]{stand.getItemInHand().clone(), stand.getHelmet().clone(), |                         new ItemStack[]{stand.getItemInHand().clone(), stand.getHelmet().clone(), | ||||||
| @@ -238,37 +210,30 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                                 stand.getBoots().clone()}; |                                 stand.getBoots().clone()}; | ||||||
|                 storeLiving(stand); |                 storeLiving(stand); | ||||||
|                 this.stand = new ArmorStandStats(); |                 this.stand = new ArmorStandStats(); | ||||||
|  |  | ||||||
|                 EulerAngle head = stand.getHeadPose(); |                 EulerAngle head = stand.getHeadPose(); | ||||||
|                 this.stand.head[0] = (float) head.getX(); |                 this.stand.head[0] = (float) head.getX(); | ||||||
|                 this.stand.head[1] = (float) head.getY(); |                 this.stand.head[1] = (float) head.getY(); | ||||||
|                 this.stand.head[2] = (float) head.getZ(); |                 this.stand.head[2] = (float) head.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle body = stand.getBodyPose(); |                 EulerAngle body = stand.getBodyPose(); | ||||||
|                 this.stand.body[0] = (float) body.getX(); |                 this.stand.body[0] = (float) body.getX(); | ||||||
|                 this.stand.body[1] = (float) body.getY(); |                 this.stand.body[1] = (float) body.getY(); | ||||||
|                 this.stand.body[2] = (float) body.getZ(); |                 this.stand.body[2] = (float) body.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle leftLeg = stand.getLeftLegPose(); |                 EulerAngle leftLeg = stand.getLeftLegPose(); | ||||||
|                 this.stand.leftLeg[0] = (float) leftLeg.getX(); |                 this.stand.leftLeg[0] = (float) leftLeg.getX(); | ||||||
|                 this.stand.leftLeg[1] = (float) leftLeg.getY(); |                 this.stand.leftLeg[1] = (float) leftLeg.getY(); | ||||||
|                 this.stand.leftLeg[2] = (float) leftLeg.getZ(); |                 this.stand.leftLeg[2] = (float) leftLeg.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle rightLeg = stand.getRightLegPose(); |                 EulerAngle rightLeg = stand.getRightLegPose(); | ||||||
|                 this.stand.rightLeg[0] = (float) rightLeg.getX(); |                 this.stand.rightLeg[0] = (float) rightLeg.getX(); | ||||||
|                 this.stand.rightLeg[1] = (float) rightLeg.getY(); |                 this.stand.rightLeg[1] = (float) rightLeg.getY(); | ||||||
|                 this.stand.rightLeg[2] = (float) rightLeg.getZ(); |                 this.stand.rightLeg[2] = (float) rightLeg.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle leftArm = stand.getLeftArmPose(); |                 EulerAngle leftArm = stand.getLeftArmPose(); | ||||||
|                 this.stand.leftArm[0] = (float) leftArm.getX(); |                 this.stand.leftArm[0] = (float) leftArm.getX(); | ||||||
|                 this.stand.leftArm[1] = (float) leftArm.getY(); |                 this.stand.leftArm[1] = (float) leftArm.getY(); | ||||||
|                 this.stand.leftArm[2] = (float) leftArm.getZ(); |                 this.stand.leftArm[2] = (float) leftArm.getZ(); | ||||||
|  |  | ||||||
|                 EulerAngle rightArm = stand.getRightArmPose(); |                 EulerAngle rightArm = stand.getRightArmPose(); | ||||||
|                 this.stand.rightArm[0] = (float) rightArm.getX(); |                 this.stand.rightArm[0] = (float) rightArm.getX(); | ||||||
|                 this.stand.rightArm[1] = (float) rightArm.getY(); |                 this.stand.rightArm[1] = (float) rightArm.getY(); | ||||||
|                 this.stand.rightArm[2] = (float) rightArm.getZ(); |                 this.stand.rightArm[2] = (float) rightArm.getZ(); | ||||||
|  |  | ||||||
|                 if (stand.hasArms()) { |                 if (stand.hasArms()) { | ||||||
|                     this.stand.arms = true; |                     this.stand.arms = true; | ||||||
|                 } |                 } | ||||||
| @@ -282,52 +247,37 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                     this.stand.small = true; |                     this.stand.small = true; | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             case "ENDERMITE": |             } | ||||||
|  |             case "ENDERMITE" -> { | ||||||
|                 return; |                 return; | ||||||
|             case "BAT": |             } | ||||||
|  |             case "BAT" -> { | ||||||
|                 if (((Bat) entity).isAwake()) { |                 if (((Bat) entity).isAwake()) { | ||||||
|                     this.dataByte = (byte) 1; |                     this.dataByte = (byte) 1; | ||||||
|                 } else { |                 } else { | ||||||
|                     this.dataByte = (byte) 0; |                     this.dataByte = (byte) 0; | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             case "ENDER_DRAGON": |             } | ||||||
|  |             case "ENDER_DRAGON" -> { | ||||||
|                 EnderDragon entity1 = (EnderDragon) entity; |                 EnderDragon entity1 = (EnderDragon) entity; | ||||||
|                 this.dataByte = (byte) entity1.getPhase().ordinal(); |                 this.dataByte = (byte) entity1.getPhase().ordinal(); | ||||||
|                 return; |                 return; | ||||||
|             case "SKELETON": |             } | ||||||
|             case "WITHER_SKELETON": |             case "SKELETON", "WITHER_SKELETON", "GUARDIAN", "ELDER_GUARDIAN", "GHAST", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", | ||||||
|             case "GUARDIAN": |                     "ZOMBIFIED_PIGLIN", "PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", | ||||||
|             case "ELDER_GUARDIAN": |                     "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SHULKER", "SNOWMAN" -> { | ||||||
|             case "GHAST": |  | ||||||
|             case "MAGMA_CUBE": |  | ||||||
|             case "SQUID": |  | ||||||
|             case "PIG_ZOMBIE": |  | ||||||
|             case "HOGLIN": |  | ||||||
|             case "ZOMBIFIED_PIGLIN": |  | ||||||
|             case "PIGLIN": |  | ||||||
|             case "PIGLIN_BRUTE": |  | ||||||
|             case "ZOMBIE": |  | ||||||
|             case "WITHER": |  | ||||||
|             case "WITCH": |  | ||||||
|             case "SPIDER": |  | ||||||
|             case "CAVE_SPIDER": |  | ||||||
|             case "SILVERFISH": |  | ||||||
|             case "GIANT": |  | ||||||
|             case "ENDERMAN": |  | ||||||
|             case "CREEPER": |  | ||||||
|             case "BLAZE": |  | ||||||
|             case "SHULKER": |  | ||||||
|             case "SNOWMAN": |  | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|                 return; |                 return; | ||||||
|             case "IRON_GOLEM": |             } | ||||||
|  |             case "IRON_GOLEM" -> { | ||||||
|                 if (((IronGolem) entity).isPlayerCreated()) { |                 if (((IronGolem) entity).isPlayerCreated()) { | ||||||
|                     this.dataByte = (byte) 1; |                     this.dataByte = (byte) 1; | ||||||
|                 } else { |                 } else { | ||||||
|                     this.dataByte = (byte) 0; |                     this.dataByte = (byte) 0; | ||||||
|                 } |                 } | ||||||
|                 storeLiving((LivingEntity) entity); |                 storeLiving((LivingEntity) entity); | ||||||
|  |             } | ||||||
|             // END LIVING // |             // END LIVING // | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -465,20 +415,15 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|         } |         } | ||||||
|         Entity entity; |         Entity entity; | ||||||
|         switch (this.getType().toString()) { |         switch (this.getType().toString()) { | ||||||
|             case "DROPPED_ITEM": |             case "DROPPED_ITEM" -> { | ||||||
|                 return world.dropItem(location, this.stack); |                 return world.dropItem(location, this.stack); | ||||||
|             case "PLAYER": |             } | ||||||
|             case "LEASH_HITCH": |             case "PLAYER", "LEASH_HITCH" -> { | ||||||
|                 return null; |                 return null; | ||||||
|             case "ITEM_FRAME": |             } | ||||||
|                 entity = world.spawn(location, ItemFrame.class); |             case "ITEM_FRAME" -> entity = world.spawn(location, ItemFrame.class); | ||||||
|                 break; |             case "PAINTING" -> entity = world.spawn(location, Painting.class); | ||||||
|             case "PAINTING": |             default -> entity = world.spawnEntity(location, this.getType()); | ||||||
|                 entity = world.spawn(location, Painting.class); |  | ||||||
|                 break; |  | ||||||
|             default: |  | ||||||
|                 entity = world.spawnEntity(location, this.getType()); |  | ||||||
|                 break; |  | ||||||
|         } |         } | ||||||
|         if (this.depth == 0) { |         if (this.depth == 0) { | ||||||
|             return entity; |             return entity; | ||||||
| @@ -506,72 +451,46 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|             entity.setGravity(false); |             entity.setGravity(false); | ||||||
|         } |         } | ||||||
|         switch (entity.getType().toString()) { |         switch (entity.getType().toString()) { | ||||||
|             case "BOAT": |             case "BOAT" -> { | ||||||
|                 Boat boat = (Boat) entity; |                 Boat boat = (Boat) entity; | ||||||
|                 boat.setWoodType(TreeSpecies.values()[dataByte]); |                 boat.setWoodType(TreeSpecies.values()[dataByte]); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "SLIME": |             } | ||||||
|  |             case "SLIME" -> { | ||||||
|                 ((Slime) entity).setSize(this.dataByte); |                 ((Slime) entity).setSize(this.dataByte); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ARROW": |             } | ||||||
|             case "EGG": |             case "ARROW", "EGG", "ENDER_CRYSTAL", "ENDER_PEARL", "ENDER_SIGNAL", "DROPPED_ITEM", "EXPERIENCE_ORB", "FALLING_BLOCK", | ||||||
|             case "ENDER_CRYSTAL": |                     "FIREBALL", "FIREWORK", "FISHING_HOOK", "LEASH_HITCH", "LIGHTNING", "MINECART", "MINECART_COMMAND", | ||||||
|             case "ENDER_PEARL": |                     "MINECART_MOB_SPAWNER", "MINECART_TNT", "PLAYER", "PRIMED_TNT", "SMALL_FIREBALL", "SNOWBALL", | ||||||
|             case "ENDER_SIGNAL": |                     "SPLASH_POTION", "THROWN_EXP_BOTTLE", "SPECTRAL_ARROW", "SHULKER_BULLET", "AREA_EFFECT_CLOUD", | ||||||
|             case "DROPPED_ITEM": |                     "DRAGON_FIREBALL", "WITHER_SKULL", "MINECART_FURNACE", "LLAMA_SPIT", "TRIDENT", "UNKNOWN" -> { | ||||||
|             case "EXPERIENCE_ORB": |  | ||||||
|             case "FALLING_BLOCK": |  | ||||||
|             case "FIREBALL": |  | ||||||
|             case "FIREWORK": |  | ||||||
|             case "FISHING_HOOK": |  | ||||||
|             case "LEASH_HITCH": |  | ||||||
|             case "LIGHTNING": |  | ||||||
|             case "MINECART": |  | ||||||
|             case "MINECART_COMMAND": |  | ||||||
|             case "MINECART_MOB_SPAWNER": |  | ||||||
|             case "MINECART_TNT": |  | ||||||
|             case "PLAYER": |  | ||||||
|             case "PRIMED_TNT": |  | ||||||
|             case "SMALL_FIREBALL": |  | ||||||
|             case "SNOWBALL": |  | ||||||
|             case "SPLASH_POTION": |  | ||||||
|             case "THROWN_EXP_BOTTLE": |  | ||||||
|             case "SPECTRAL_ARROW": |  | ||||||
|             case "SHULKER_BULLET": |  | ||||||
|             case "AREA_EFFECT_CLOUD": |  | ||||||
|             case "DRAGON_FIREBALL": |  | ||||||
|             case "WITHER_SKULL": |  | ||||||
|             case "MINECART_FURNACE": |  | ||||||
|             case "LLAMA_SPIT": |  | ||||||
|             case "TRIDENT": |  | ||||||
|             case "UNKNOWN": |  | ||||||
|                 // Do this stuff later |                 // Do this stuff later | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // MISC // |             // MISC // | ||||||
|             case "ITEM_FRAME": |             case "ITEM_FRAME" -> { | ||||||
|                 ItemFrame itemframe = (ItemFrame) entity; |                 ItemFrame itemframe = (ItemFrame) entity; | ||||||
|                 itemframe.setRotation(Rotation.values()[this.dataByte]); |                 itemframe.setRotation(Rotation.values()[this.dataByte]); | ||||||
|                 itemframe.setItem(this.stack); |                 itemframe.setItem(this.stack); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "PAINTING": |             } | ||||||
|  |             case "PAINTING" -> { | ||||||
|                 Painting painting = (Painting) entity; |                 Painting painting = (Painting) entity; | ||||||
|                 painting.setFacingDirection(BlockFace.values()[this.dataByte], true); |                 painting.setFacingDirection(BlockFace.values()[this.dataByte], true); | ||||||
|                 painting.setArt(Art.getByName(this.dataString), true); |                 painting.setArt(Art.getByName(this.dataString), true); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END MISC // |             // END MISC // | ||||||
|             // INVENTORY HOLDER // |             // INVENTORY HOLDER // | ||||||
|             case "MINECART_CHEST": |             case "MINECART_CHEST", "MINECART_HOPPER" -> { | ||||||
|             case "MINECART_HOPPER": |  | ||||||
|                 restoreInventory((InventoryHolder) entity); |                 restoreInventory((InventoryHolder) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // START LIVING ENTITY // |             // START LIVING ENTITY // | ||||||
|             // START AGEABLE // |             // START AGEABLE // | ||||||
|             // START TAMEABLE // |             // START TAMEABLE // | ||||||
|             case "HORSE": |             case "HORSE", "LLAMA", "SKELETON_HORSE", "DONKEY", "MULE" -> { | ||||||
|             case "LLAMA": |  | ||||||
|             case "SKELETON_HORSE": |  | ||||||
|             case "DONKEY": |  | ||||||
|             case "MULE": |  | ||||||
|                 AbstractHorse horse = (AbstractHorse) entity; |                 AbstractHorse horse = (AbstractHorse) entity; | ||||||
|                 horse.setJumpStrength(this.horse.jump); |                 horse.setJumpStrength(this.horse.jump); | ||||||
|                 if (horse instanceof ChestedHorse) { |                 if (horse instanceof ChestedHorse) { | ||||||
| @@ -586,15 +505,16 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 restoreLiving(horse); |                 restoreLiving(horse); | ||||||
|                 restoreInventory(horse); |                 restoreInventory(horse); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END INVENTORY HOLDER // |             // END INVENTORY HOLDER // | ||||||
|             case "WOLF": |             case "WOLF", "OCELOT" -> { | ||||||
|             case "OCELOT": |  | ||||||
|                 restoreTameable((Tameable) entity); |                 restoreTameable((Tameable) entity); | ||||||
|                 restoreAgeable((Ageable) entity); |                 restoreAgeable((Ageable) entity); | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END AGEABLE // |             // END AGEABLE // | ||||||
|             case "SHEEP": |             case "SHEEP" -> { | ||||||
|                 Sheep sheep = (Sheep) entity; |                 Sheep sheep = (Sheep) entity; | ||||||
|                 if (this.dataByte == 1) { |                 if (this.dataByte == 1) { | ||||||
|                     sheep.setSheared(true); |                     sheep.setSheared(true); | ||||||
| @@ -605,25 +525,22 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 restoreAgeable(sheep); |                 restoreAgeable(sheep); | ||||||
|                 restoreLiving(sheep); |                 restoreLiving(sheep); | ||||||
|                 return sheep; |                 return sheep; | ||||||
|             case "VILLAGER": |             } | ||||||
|             case "CHICKEN": |             case "VILLAGER", "CHICKEN", "COW", "TURTLE", "POLAR_BEAR", "MUSHROOM_COW", "PIG" -> { | ||||||
|             case "COW": |  | ||||||
|             case "TURTLE": |  | ||||||
|             case "POLAR_BEAR": |  | ||||||
|             case "MUSHROOM_COW": |  | ||||||
|             case "PIG": |  | ||||||
|                 restoreAgeable((Ageable) entity); |                 restoreAgeable((Ageable) entity); | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END AGEABLE // |             // END AGEABLE // | ||||||
|             case "RABBIT": |             case "RABBIT" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((Rabbit) entity).setRabbitType(Rabbit.Type.values()[this.dataByte]); |                     ((Rabbit) entity).setRabbitType(Rabbit.Type.values()[this.dataByte]); | ||||||
|                 } |                 } | ||||||
|                 restoreAgeable((Ageable) entity); |                 restoreAgeable((Ageable) entity); | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ARMOR_STAND": |             } | ||||||
|  |             case "ARMOR_STAND" -> { | ||||||
|                 // CHECK positions |                 // CHECK positions | ||||||
|                 ArmorStand stand = (ArmorStand) entity; |                 ArmorStand stand = (ArmorStand) entity; | ||||||
|                 if (this.inventory[0] != null) { |                 if (this.inventory[0] != null) { | ||||||
| @@ -693,56 +610,38 @@ public final class ReplicatingEntityWrapper extends EntityWrapper { | |||||||
|                 } |                 } | ||||||
|                 restoreLiving(stand); |                 restoreLiving(stand); | ||||||
|                 return stand; |                 return stand; | ||||||
|             case "BAT": |             } | ||||||
|  |             case "BAT" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((Bat) entity).setAwake(true); |                     ((Bat) entity).setAwake(true); | ||||||
|                 } |                 } | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ENDER_DRAGON": |             } | ||||||
|  |             case "ENDER_DRAGON" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((EnderDragon) entity).setPhase(EnderDragon.Phase.values()[this.dataByte]); |                     ((EnderDragon) entity).setPhase(EnderDragon.Phase.values()[this.dataByte]); | ||||||
|                 } |                 } | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "ENDERMITE": |             } | ||||||
|             case "GHAST": |             case "ENDERMITE", "GHAST", "MAGMA_CUBE", "SQUID", "PIG_ZOMBIE", "HOGLIN", "PIGLIN", "ZOMBIFIED_PIGLIN", "PIGLIN_BRUTE", "ZOMBIE", "WITHER", "WITCH", "SPIDER", "CAVE_SPIDER", "SILVERFISH", "GIANT", "ENDERMAN", "CREEPER", "BLAZE", "SNOWMAN", "SHULKER", "GUARDIAN", "ELDER_GUARDIAN", "SKELETON", "WITHER_SKELETON" -> { | ||||||
|             case "MAGMA_CUBE": |  | ||||||
|             case "SQUID": |  | ||||||
|             case "PIG_ZOMBIE": |  | ||||||
|             case "HOGLIN": |  | ||||||
|             case "PIGLIN": |  | ||||||
|             case "ZOMBIFIED_PIGLIN": |  | ||||||
|             case "PIGLIN_BRUTE": |  | ||||||
|             case "ZOMBIE": |  | ||||||
|             case "WITHER": |  | ||||||
|             case "WITCH": |  | ||||||
|             case "SPIDER": |  | ||||||
|             case "CAVE_SPIDER": |  | ||||||
|             case "SILVERFISH": |  | ||||||
|             case "GIANT": |  | ||||||
|             case "ENDERMAN": |  | ||||||
|             case "CREEPER": |  | ||||||
|             case "BLAZE": |  | ||||||
|             case "SNOWMAN": |  | ||||||
|             case "SHULKER": |  | ||||||
|             case "GUARDIAN": |  | ||||||
|             case "ELDER_GUARDIAN": |  | ||||||
|             case "SKELETON": |  | ||||||
|             case "WITHER_SKELETON": |  | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             case "IRON_GOLEM": |             } | ||||||
|  |             case "IRON_GOLEM" -> { | ||||||
|                 if (this.dataByte != 0) { |                 if (this.dataByte != 0) { | ||||||
|                     ((IronGolem) entity).setPlayerCreated(true); |                     ((IronGolem) entity).setPlayerCreated(true); | ||||||
|                 } |                 } | ||||||
|                 restoreLiving((LivingEntity) entity); |                 restoreLiving((LivingEntity) entity); | ||||||
|                 return entity; |                 return entity; | ||||||
|             default: |             } | ||||||
|  |             default -> { | ||||||
|                 if (Settings.DEBUG) { |                 if (Settings.DEBUG) { | ||||||
|                     LOGGER.info("Could not identify entity: {}", entity.getType()); |                     LOGGER.info("Could not identify entity: {}", entity.getType()); | ||||||
|                 } |                 } | ||||||
|                 return entity; |                 return entity; | ||||||
|  |             } | ||||||
|             // END LIVING |             // END LIVING | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -277,6 +277,11 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         return super.getBaseHeight(worldInfo, random, x, z, heightMap); |         return super.getBaseHeight(worldInfo, random, x, z, heightMap); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 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. | ||||||
|  |      */ | ||||||
|     @SuppressWarnings("deprecation") // The entire method is deprecated, but kept for compatibility with <=1.16.2 |     @SuppressWarnings("deprecation") // The entire method is deprecated, but kept for compatibility with <=1.16.2 | ||||||
|     @Override |     @Override | ||||||
|     @Deprecated(since = "TODO") |     @Deprecated(since = "TODO") | ||||||
| @@ -287,8 +292,8 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|             if (this.platformGenerator != this) { |             if (this.platformGenerator != this) { | ||||||
|                 return this.platformGenerator.generateChunkData(world, random, x, z, biome); |                 return this.platformGenerator.generateChunkData(world, random, x, z, biome); | ||||||
|             } else { |             } else { | ||||||
|                 // Return super as it will throw an exception caught by the server that will mean this method is no longer used. |                 // Throw exception to be caught by the server that indicates the new generation API is being used. | ||||||
|                 return super.generateChunkData(world, random, x, z, biome); |                 throw new UnsupportedOperationException("Using new generation methods. This method is unsupported."); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -411,7 +416,8 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         } |         } | ||||||
|         PlotArea area = UncheckedWorldLocation.at(name, chunkX << 4, 0, chunkZ << 4).getPlotArea(); |         PlotArea area = UncheckedWorldLocation.at(name, chunkX << 4, 0, chunkZ << 4).getPlotArea(); | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             throw new IllegalStateException(String.format("Cannot generate chunk that does not belong to a plot area. World: %s", |             throw new IllegalStateException(String.format( | ||||||
|  |                     "Cannot generate chunk that does not belong to a plot area. World: %s", | ||||||
|                     name |                     name | ||||||
|             )); |             )); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -72,6 +72,7 @@ import org.bukkit.block.BlockFace; | |||||||
| import org.bukkit.block.BlockState; | import org.bukkit.block.BlockState; | ||||||
| import org.bukkit.block.data.BlockData; | import org.bukkit.block.data.BlockData; | ||||||
| import org.bukkit.block.data.type.Dispenser; | import org.bukkit.block.data.type.Dispenser; | ||||||
|  | import org.bukkit.block.data.type.Farmland; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.Fireball; | import org.bukkit.entity.Fireball; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
| @@ -99,6 +100,7 @@ import org.bukkit.event.block.BlockSpreadEvent; | |||||||
| import org.bukkit.event.block.CauldronLevelChangeEvent; | import org.bukkit.event.block.CauldronLevelChangeEvent; | ||||||
| import org.bukkit.event.block.EntityBlockFormEvent; | import org.bukkit.event.block.EntityBlockFormEvent; | ||||||
| import org.bukkit.event.block.LeavesDecayEvent; | import org.bukkit.event.block.LeavesDecayEvent; | ||||||
|  | import org.bukkit.event.block.MoistureChangeEvent; | ||||||
| import org.bukkit.event.block.SpongeAbsorbEvent; | import org.bukkit.event.block.SpongeAbsorbEvent; | ||||||
| import org.bukkit.event.world.StructureGrowEvent; | import org.bukkit.event.world.StructureGrowEvent; | ||||||
| import org.bukkit.projectiles.BlockProjectileSource; | import org.bukkit.projectiles.BlockProjectileSource; | ||||||
| @@ -740,6 +742,43 @@ 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) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onChange(BlockFromToEvent event) { |     public void onChange(BlockFromToEvent event) { | ||||||
|         Block fromBlock = event.getBlock(); |         Block fromBlock = event.getBlock(); | ||||||
|   | |||||||
| @@ -92,7 +92,11 @@ public class BlockEventListener117 implements Listener { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null && !PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, MiscInteractFlag.class, true) || plot != null && !plot.getFlag( |         if (plot == null && !PlotFlagUtil.isAreaRoadFlagsAndFlagEquals( | ||||||
|  |                 area, | ||||||
|  |                 MiscInteractFlag.class, | ||||||
|  |                 true | ||||||
|  |         ) || plot != null && !plot.getFlag( | ||||||
|                 MiscInteractFlag.class)) { |                 MiscInteractFlag.class)) { | ||||||
|             if (plotPlayer != null) { |             if (plotPlayer != null) { | ||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|   | |||||||
| @@ -234,7 +234,8 @@ public class ChunkListener implements Listener { | |||||||
|         Chunk chunk = event.getChunk(); |         Chunk chunk = event.getChunk(); | ||||||
|         if (Settings.Chunk_Processor.AUTO_TRIM) { |         if (Settings.Chunk_Processor.AUTO_TRIM) { | ||||||
|             String world = chunk.getWorld().getName(); |             String world = chunk.getWorld().getName(); | ||||||
|             if ((!Settings.Enabled_Components.WORLDS || !SinglePlotArea.isSinglePlotWorld(world)) && this.plotAreaManager.hasPlotArea(world)) { |             if ((!Settings.Enabled_Components.WORLDS || !SinglePlotArea.isSinglePlotWorld(world)) && this.plotAreaManager.hasPlotArea( | ||||||
|  |                     world)) { | ||||||
|                 if (unloadChunk(world, chunk, true)) { |                 if (unloadChunk(world, chunk, true)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -145,54 +145,37 @@ public class EntityEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         CreatureSpawnEvent.SpawnReason reason = event.getSpawnReason(); |         CreatureSpawnEvent.SpawnReason reason = event.getSpawnReason(); | ||||||
|         switch (reason.toString()) { |         switch (reason.toString()) { | ||||||
|             case "DISPENSE_EGG": |             case "DISPENSE_EGG", "EGG", "OCELOT_BABY", "SPAWNER_EGG" -> { | ||||||
|             case "EGG": |  | ||||||
|             case "OCELOT_BABY": |  | ||||||
|             case "SPAWNER_EGG": |  | ||||||
|                 if (!area.isSpawnEggs()) { |                 if (!area.isSpawnEggs()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "REINFORCEMENTS": |             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL", | ||||||
|             case "NATURAL": |                     "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN" -> { | ||||||
|             case "MOUNT": |  | ||||||
|             case "PATROL": |  | ||||||
|             case "RAID": |  | ||||||
|             case "SHEARED": |  | ||||||
|             case "SILVERFISH_BLOCK": |  | ||||||
|             case "ENDER_PEARL": |  | ||||||
|             case "TRAP": |  | ||||||
|             case "VILLAGE_DEFENSE": |  | ||||||
|             case "VILLAGE_INVASION": |  | ||||||
|             case "BEEHIVE": |  | ||||||
|             case "CHUNK_GEN": |  | ||||||
|                 if (!area.isMobSpawning()) { |                 if (!area.isMobSpawning()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BREEDING": |             case "BREEDING" -> { | ||||||
|                 if (!area.isSpawnBreeding()) { |                 if (!area.isSpawnBreeding()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BUILD_IRONGOLEM": |             case "BUILD_IRONGOLEM", "BUILD_SNOWMAN", "BUILD_WITHER", "CUSTOM" -> { | ||||||
|             case "BUILD_SNOWMAN": |  | ||||||
|             case "BUILD_WITHER": |  | ||||||
|             case "CUSTOM": |  | ||||||
|                 if (!area.isSpawnCustom() && entity.getType() != EntityType.ARMOR_STAND) { |                 if (!area.isSpawnCustom() && entity.getType() != EntityType.ARMOR_STAND) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "SPAWNER": |             case "SPAWNER" -> { | ||||||
|                 if (!area.isMobSpawnerSpawning()) { |                 if (!area.isMobSpawnerSpawning()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|         } |         } | ||||||
|         Plot plot = area.getOwnedPlotAbs(location); |         Plot plot = area.getOwnedPlotAbs(location); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|   | |||||||
| @@ -43,10 +43,10 @@ import com.plotsquared.core.plot.flag.implementations.DoneFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | ||||||
| import com.plotsquared.core.plot.flag.types.BooleanFlag; | import com.plotsquared.core.plot.flag.types.BooleanFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; |  | ||||||
| import org.bukkit.Chunk; | import org.bukkit.Chunk; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.TileState; | import org.bukkit.block.TileState; | ||||||
| @@ -178,59 +178,41 @@ public class PaperListener implements Listener { | |||||||
|         } |         } | ||||||
|         CreatureSpawnEvent.SpawnReason reason = event.getReason(); |         CreatureSpawnEvent.SpawnReason reason = event.getReason(); | ||||||
|         switch (reason.toString()) { |         switch (reason.toString()) { | ||||||
|             case "DISPENSE_EGG": |             case "DISPENSE_EGG", "EGG", "OCELOT_BABY", "SPAWNER_EGG" -> { | ||||||
|             case "EGG": |  | ||||||
|             case "OCELOT_BABY": |  | ||||||
|             case "SPAWNER_EGG": |  | ||||||
|                 if (!area.isSpawnEggs()) { |                 if (!area.isSpawnEggs()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "REINFORCEMENTS": |             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL", "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN" -> { | ||||||
|             case "NATURAL": |  | ||||||
|             case "MOUNT": |  | ||||||
|             case "PATROL": |  | ||||||
|             case "RAID": |  | ||||||
|             case "SHEARED": |  | ||||||
|             case "SILVERFISH_BLOCK": |  | ||||||
|             case "ENDER_PEARL": |  | ||||||
|             case "TRAP": |  | ||||||
|             case "VILLAGE_DEFENSE": |  | ||||||
|             case "VILLAGE_INVASION": |  | ||||||
|             case "BEEHIVE": |  | ||||||
|             case "CHUNK_GEN": |  | ||||||
|                 if (!area.isMobSpawning()) { |                 if (!area.isMobSpawning()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BREEDING": |             case "BREEDING" -> { | ||||||
|                 if (!area.isSpawnBreeding()) { |                 if (!area.isSpawnBreeding()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "BUILD_IRONGOLEM": |             case "BUILD_IRONGOLEM", "BUILD_SNOWMAN", "BUILD_WITHER", "CUSTOM" -> { | ||||||
|             case "BUILD_SNOWMAN": |  | ||||||
|             case "BUILD_WITHER": |  | ||||||
|             case "CUSTOM": |  | ||||||
|                 if (!area.isSpawnCustom() && event.getType() != EntityType.ARMOR_STAND) { |                 if (!area.isSpawnCustom() && event.getType() != EntityType.ARMOR_STAND) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|             case "SPAWNER": |             case "SPAWNER" -> { | ||||||
|                 if (!area.isMobSpawnerSpawning()) { |                 if (!area.isMobSpawnerSpawning()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 break; |             } | ||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlotAbs(); |         Plot plot = location.getOwnedPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
| @@ -457,9 +439,11 @@ public class PaperListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private boolean getBooleanFlagValue(@NonNull FlagContainer container, |     private boolean getBooleanFlagValue( | ||||||
|  |             @NonNull FlagContainer container, | ||||||
|             @NonNull Class<? extends BooleanFlag<?>> flagClass, |             @NonNull Class<? extends BooleanFlag<?>> flagClass, | ||||||
|                                         boolean defaultValue) { |             boolean defaultValue | ||||||
|  |     ) { | ||||||
|         BooleanFlag<?> flag = container.getFlag(flagClass); |         BooleanFlag<?> flag = container.getFlag(flagClass); | ||||||
|         return flag == null ? defaultValue : flag.getValue(); |         return flag == null ? defaultValue : flag.getValue(); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -273,8 +273,7 @@ public class PlayerEventListener implements Listener { | |||||||
|         Plot plot = plotPlayer.getCurrentPlot(); |         Plot plot = plotPlayer.getCurrentPlot(); | ||||||
|         // Check WorldEdit |         // Check WorldEdit | ||||||
|         switch (parts[0]) { |         switch (parts[0]) { | ||||||
|             case "up": |             case "up", "worldedit:up" -> { | ||||||
|             case "worldedit:up": |  | ||||||
|                 if (plot == null || (!plot.isAdded(plotPlayer.getUUID()) && !plotPlayer.hasPermission( |                 if (plot == null || (!plot.isAdded(plotPlayer.getUUID()) && !plotPlayer.hasPermission( | ||||||
|                         Permission.PERMISSION_ADMIN_BUILD_OTHER, |                         Permission.PERMISSION_ADMIN_BUILD_OTHER, | ||||||
|                         true |                         true | ||||||
| @@ -283,6 +282,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|         if (plot == null && !area.isRoadFlags()) { |         if (plot == null && !area.isRoadFlags()) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -572,7 +572,8 @@ public class PlayerEventListener implements Listener { | |||||||
|             if (now == null) { |             if (now == null) { | ||||||
|                 try (final MetaDataAccess<Boolean> kickAccess = |                 try (final MetaDataAccess<Boolean> kickAccess = | ||||||
|                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { |                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { | ||||||
|                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { |                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse( | ||||||
|  |                             false)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -665,7 +666,8 @@ public class PlayerEventListener implements Listener { | |||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 try (final MetaDataAccess<Boolean> kickAccess = |                 try (final MetaDataAccess<Boolean> kickAccess = | ||||||
|                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { |                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { | ||||||
|                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { |                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse( | ||||||
|  |                             false)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -1114,13 +1116,13 @@ public class PlayerEventListener implements Listener { | |||||||
|         Location location = BukkitUtil.adapt(block.getLocation()); |         Location location = BukkitUtil.adapt(block.getLocation()); | ||||||
|         Action action = event.getAction(); |         Action action = event.getAction(); | ||||||
|         switch (action) { |         switch (action) { | ||||||
|             case PHYSICAL: { |             case PHYSICAL -> { | ||||||
|                 eventType = PlayerBlockEventType.TRIGGER_PHYSICAL; |                 eventType = PlayerBlockEventType.TRIGGER_PHYSICAL; | ||||||
|                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); |                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); | ||||||
|                 break; |  | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             //todo rearrange the right click code. it is all over the place. |             //todo rearrange the right click code. it is all over the place. | ||||||
|             case RIGHT_CLICK_BLOCK: { |             case RIGHT_CLICK_BLOCK -> { | ||||||
|                 Material blockType = block.getType(); |                 Material blockType = block.getType(); | ||||||
|                 eventType = PlayerBlockEventType.INTERACT_BLOCK; |                 eventType = PlayerBlockEventType.INTERACT_BLOCK; | ||||||
|                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); |                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); | ||||||
| @@ -1142,22 +1144,17 @@ public class PlayerEventListener implements Listener { | |||||||
|  |  | ||||||
|                 // in the following, lb needs to have the material of the item in hand i.e. type |                 // in the following, lb needs to have the material of the item in hand i.e. type | ||||||
|                 switch (type.toString()) { |                 switch (type.toString()) { | ||||||
|                     case "REDSTONE": |                     case "REDSTONE", "STRING", "PUMPKIN_SEEDS", "MELON_SEEDS", "COCOA_BEANS", "WHEAT_SEEDS", "BEETROOT_SEEDS", | ||||||
|                     case "STRING": |                             "SWEET_BERRIES", "GLOW_BERRIES" -> { | ||||||
|                     case "PUMPKIN_SEEDS": |  | ||||||
|                     case "MELON_SEEDS": |  | ||||||
|                     case "COCOA_BEANS": |  | ||||||
|                     case "WHEAT_SEEDS": |  | ||||||
|                     case "BEETROOT_SEEDS": |  | ||||||
|                     case "SWEET_BERRIES": |  | ||||||
|                     case "GLOW_BERRIES": |  | ||||||
|                         return; |                         return; | ||||||
|                     default: |                     } | ||||||
|  |                     default -> { | ||||||
|                         //eventType = PlayerBlockEventType.PLACE_BLOCK; |                         //eventType = PlayerBlockEventType.PLACE_BLOCK; | ||||||
|                         if (type.isBlock()) { |                         if (type.isBlock()) { | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|  |                 } | ||||||
|                 if (PaperLib.isPaper()) { |                 if (PaperLib.isPaper()) { | ||||||
|                     if (MaterialTags.SPAWN_EGGS.isTagged(type) || Material.EGG.equals(type)) { |                     if (MaterialTags.SPAWN_EGGS.isTagged(type) || Material.EGG.equals(type)) { | ||||||
|                         eventType = PlayerBlockEventType.SPAWN_MOB; |                         eventType = PlayerBlockEventType.SPAWN_MOB; | ||||||
| @@ -1189,9 +1186,8 @@ public class PlayerEventListener implements Listener { | |||||||
|                     eventType = PlayerBlockEventType.READ; |                     eventType = PlayerBlockEventType.READ; | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|                 break; |  | ||||||
|             } |             } | ||||||
|             case LEFT_CLICK_BLOCK: { |             case LEFT_CLICK_BLOCK -> { | ||||||
|                 Material blockType = block.getType(); |                 Material blockType = block.getType(); | ||||||
|  |  | ||||||
|                 // todo: when the code above is rearranged, it would be great to beautify this as well. |                 // todo: when the code above is rearranged, it would be great to beautify this as well. | ||||||
| @@ -1202,11 +1198,11 @@ public class PlayerEventListener implements Listener { | |||||||
|  |  | ||||||
|                 eventType = PlayerBlockEventType.INTERACT_BLOCK; |                 eventType = PlayerBlockEventType.INTERACT_BLOCK; | ||||||
|                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); |                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); | ||||||
|                 break; |  | ||||||
|             } |             } | ||||||
|             default: |             default -> { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|         if (this.worldEdit != null && pp.getAttribute("worldedit")) { |         if (this.worldEdit != null && pp.getAttribute("worldedit")) { | ||||||
|             if (event.getMaterial() == Material.getMaterial(this.worldEdit.getConfiguration().wandItem)) { |             if (event.getMaterial() == Material.getMaterial(this.worldEdit.getConfiguration().wandItem)) { | ||||||
|                 return; |                 return; | ||||||
|   | |||||||
| @@ -30,9 +30,9 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.PlotHandler; | import com.plotsquared.core.plot.PlotHandler; | ||||||
| import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; |  | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.LivingEntity; | import org.bukkit.entity.LivingEntity; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
|   | |||||||
| @@ -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.bukkit.managers; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
| import com.google.inject.Singleton; |  | ||||||
| import org.bukkit.World; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; |  | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; |  | ||||||
| import se.hyperver.hyperverse.Hyperverse; |  | ||||||
| import se.hyperver.hyperverse.world.WorldConfiguration; |  | ||||||
| import se.hyperver.hyperverse.world.WorldConfigurationBuilder; |  | ||||||
| import se.hyperver.hyperverse.world.WorldFeatures; |  | ||||||
| import se.hyperver.hyperverse.world.WorldType; |  | ||||||
|  |  | ||||||
| Hyperverse implementation is currently put on ice until Hyperverse is released on a stable line and deployed to the central |  | ||||||
| repository. |  | ||||||
|  |  | ||||||
| @Singleton |  | ||||||
| public class HyperverseWorldManager extends BukkitWorldManager { |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public @Nullable World handleWorldCreation(@NonNull String worldName, @Nullable String generator) { |  | ||||||
|         // First let Bukkit register the world |  | ||||||
|         this.setGenerator(worldName, generator); |  | ||||||
|         // Create the world |  | ||||||
|         final WorldConfigurationBuilder worldConfigurationBuilder = WorldConfiguration.builder() |  | ||||||
|                 .setName(worldName).setType(WorldType.OVER_WORLD); |  | ||||||
|         if (generator != null) { |  | ||||||
|             worldConfigurationBuilder.setGenerator(generator).setWorldFeatures(WorldFeatures.FLATLAND); |  | ||||||
|         } |  | ||||||
|         try { |  | ||||||
|             return Hyperverse.getApi().createWorld(worldConfigurationBuilder.createWorldConfiguration()) |  | ||||||
|                     .getBukkitWorld(); |  | ||||||
|         } catch (final Exception e) { |  | ||||||
|             e.printStackTrace(); |  | ||||||
|         } |  | ||||||
|         return null; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public String getName() { |  | ||||||
|         return "bukkit-hyperverse"; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  */ |  | ||||||
| @@ -52,7 +52,7 @@ public class MVdWPlaceholders { | |||||||
|  |  | ||||||
|     @Subscribe |     @Subscribe | ||||||
|     public void onNewPlaceholder(final PlaceholderRegistry.@NonNull PlaceholderAddedEvent event) { |     public void onNewPlaceholder(final PlaceholderRegistry.@NonNull PlaceholderAddedEvent event) { | ||||||
|         this.addPlaceholder(event.getPlaceholder()); |         this.addPlaceholder(event.placeholder()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void addPlaceholder(final @NonNull Placeholder placeholder) { |     private void addPlaceholder(final @NonNull Placeholder placeholder) { | ||||||
|   | |||||||
| @@ -54,7 +54,6 @@ public class BukkitPlayerManager extends PlayerManager<BukkitPlayer, Player> { | |||||||
|  |  | ||||||
|     @NonNull |     @NonNull | ||||||
|     @Override |     @Override | ||||||
|     @SuppressWarnings("deprecation") |  | ||||||
|     public BukkitPlayer getPlayer(final @NonNull Player object) { |     public BukkitPlayer getPlayer(final @NonNull Player object) { | ||||||
|         if (object.getUniqueId().version() == 2) { // not a real player |         if (object.getUniqueId().version() == 2) { // not a real player | ||||||
|             return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, object, false, this.permissionHandler); |             return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, object, false, this.permissionHandler); | ||||||
|   | |||||||
| @@ -62,7 +62,6 @@ public class GenChunk extends ZeroedDelegateScopedQueueCoordinator { | |||||||
|     /** |     /** | ||||||
|      * @param minY minimum world Y, inclusive |      * @param minY minimum world Y, inclusive | ||||||
|      * @param maxY maximum world Y, inclusive |      * @param maxY maximum world Y, inclusive | ||||||
|      * |  | ||||||
|      * @since 6.6.0 |      * @since 6.6.0 | ||||||
|      */ |      */ | ||||||
|     public GenChunk(int minY, int maxY) { |     public GenChunk(int minY, int maxY) { | ||||||
| @@ -110,9 +109,9 @@ public class GenChunk extends ZeroedDelegateScopedQueueCoordinator { | |||||||
|      */ |      */ | ||||||
|     public void setChunk(@NonNull ChunkWrapper wrap) { |     public void setChunk(@NonNull ChunkWrapper wrap) { | ||||||
|         chunk = null; |         chunk = null; | ||||||
|         world = wrap.world; |         world = wrap.world(); | ||||||
|         chunkX = wrap.x; |         chunkX = wrap.x(); | ||||||
|         chunkZ = wrap.z; |         chunkZ = wrap.z(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -124,7 +124,7 @@ public class BukkitSetupUtils extends SetupUtils { | |||||||
|     public String setupWorld(PlotAreaBuilder builder) { |     public String setupWorld(PlotAreaBuilder builder) { | ||||||
|         this.updateGenerators(false); |         this.updateGenerators(false); | ||||||
|         ConfigurationNode[] steps = builder.settingsNodesWrapper() == null ? |         ConfigurationNode[] steps = builder.settingsNodesWrapper() == null ? | ||||||
|                 new ConfigurationNode[0] : builder.settingsNodesWrapper().getSettingsNodes(); |                 new ConfigurationNode[0] : builder.settingsNodesWrapper().settingsNodes(); | ||||||
|         String world = builder.worldName(); |         String world = builder.worldName(); | ||||||
|         PlotAreaType type = builder.plotAreaType(); |         PlotAreaType type = builder.plotAreaType(); | ||||||
|         String worldPath = "worlds." + builder.worldName(); |         String worldPath = "worlds." + builder.worldName(); | ||||||
|   | |||||||
| @@ -60,4 +60,5 @@ public class TranslationUpdateManager { | |||||||
|             e.printStackTrace(); |             e.printStackTrace(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -54,7 +54,8 @@ public class UpdateUtility implements Listener { | |||||||
|         internalVersion = PlotSquared.get().getVersion(); |         internalVersion = PlotSquared.get().getVersion(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @SuppressWarnings({"deprecation", "DefaultCharset"}) // Suppress Json deprecation, we can't use features from gson 2.8.1 and newer yet |     @SuppressWarnings({"deprecation", "DefaultCharset"}) | ||||||
|  |     // Suppress Json deprecation, we can't use features from gson 2.8.1 and newer yet | ||||||
|     public void updateChecker() { |     public void updateChecker() { | ||||||
|         task = Bukkit.getScheduler().runTaskTimerAsynchronously(this.javaPlugin, () -> { |         task = Bukkit.getScheduler().runTaskTimerAsynchronously(this.javaPlugin, () -> { | ||||||
|             try { |             try { | ||||||
|   | |||||||
| @@ -111,8 +111,8 @@ public class SQLiteUUIDService implements UUIDService, Consumer<List<UUIDMapping | |||||||
|         try (final PreparedStatement statement = getConnection() |         try (final PreparedStatement statement = getConnection() | ||||||
|                 .prepareStatement("INSERT OR REPLACE INTO `usercache` (`uuid`, `username`) VALUES(?, ?)")) { |                 .prepareStatement("INSERT OR REPLACE INTO `usercache` (`uuid`, `username`) VALUES(?, ?)")) { | ||||||
|             for (final UUIDMapping mapping : uuidWrappers) { |             for (final UUIDMapping mapping : uuidWrappers) { | ||||||
|                 statement.setString(1, mapping.getUuid().toString()); |                 statement.setString(1, mapping.uuid().toString()); | ||||||
|                 statement.setString(2, mapping.getUsername()); |                 statement.setString(2, mapping.username()); | ||||||
|                 statement.executeUpdate(); |                 statement.executeUpdate(); | ||||||
|             } |             } | ||||||
|         } catch (SQLException e) { |         } catch (SQLException e) { | ||||||
|   | |||||||
| @@ -4,16 +4,16 @@ api-version: "1.13" | |||||||
| version: "${version}" | version: "${version}" | ||||||
| load: STARTUP | load: STARTUP | ||||||
| description: "Easy, yet powerful Plot World generation and management." | description: "Easy, yet powerful Plot World generation and management." | ||||||
| authors: [Citymonstret, Empire92, MattBDev, dordsor21, NotMyFault, SirYwell] | authors: [ Citymonstret, Empire92, MattBDev, dordsor21, NotMyFault, SirYwell ] | ||||||
| website: https://www.spigotmc.org/resources/77506/ | website: https://www.spigotmc.org/resources/77506/ | ||||||
| softdepend: [Vault, PlaceholderAPI, Essentials, LuckPerms, BungeePerms, MVdWPlaceholderAPI] | softdepend: [ Vault, PlaceholderAPI, Essentials, LuckPerms, BungeePerms, MVdWPlaceholderAPI ] | ||||||
| loadbefore: [MultiWorld, Multiverse-Core] | loadbefore: [ MultiWorld, Multiverse-Core ] | ||||||
| depend: [WorldEdit] | depend: [ WorldEdit ] | ||||||
| database: false | database: false | ||||||
| commands: | commands: | ||||||
|   plots: |   plots: | ||||||
|     description: Plot command. |     description: Plot command. | ||||||
|     aliases: [p,plot,ps,plotsquared,p2,2,plotme] |     aliases: [ p,plot,ps,plotsquared,p2,2,plotme ] | ||||||
|     permission: plots.use |     permission: plots.use | ||||||
|     permission-message: "You are lacking the permission node 'plots.use'" |     permission-message: "You are lacking the permission node 'plots.use'" | ||||||
| permissions: | permissions: | ||||||
|   | |||||||
| @@ -55,7 +55,7 @@ further defined and clarified by project maintainers. | |||||||
| ## Enforcement | ## Enforcement | ||||||
|  |  | ||||||
| Instances of abusive, harassing, or otherwise unacceptable behavior may be | Instances of abusive, harassing, or otherwise unacceptable behavior may be | ||||||
| reported by contacting the project team at contact@intellectualsites.com. All | reported by contacting the project team at contact<at>intellectualsites.com. All | ||||||
| complaints will be reviewed and investigated and will result in a response that | 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 | is deemed necessary and appropriate to the circumstances. The project team is | ||||||
| obligated to maintain confidentiality with regard to the reporter of an incident. | obligated to maintain confidentiality with regard to the reporter of an incident. | ||||||
|   | |||||||
| @@ -68,8 +68,8 @@ tasks { | |||||||
|         val isRelease = if (rootProject.version.toString().endsWith("-SNAPSHOT")) "TODO" else rootProject.version.toString() |         val isRelease = if (rootProject.version.toString().endsWith("-SNAPSHOT")) "TODO" else rootProject.version.toString() | ||||||
|         val opt = options as StandardJavadocDocletOptions |         val opt = options as StandardJavadocDocletOptions | ||||||
|         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-core/" + libs.worldeditCore.get().versionConstraint.toString()) |         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-core/" + libs.worldeditCore.get().versionConstraint.toString()) | ||||||
|         opt.links("https://jd.adventure.kyori.net/api/4.12.0/") |         opt.links("https://jd.advntr.dev/api/4.12.0/") | ||||||
|         opt.links("https://jd.adventure.kyori.net/text-minimessage/4.12.0/") |         opt.links("https://jd.advntr.dev/text-minimessage/4.12.0/") | ||||||
|         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") |         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") | ||||||
|         opt.links("https://checkerframework.org/api/") |         opt.links("https://checkerframework.org/api/") | ||||||
|         opt.links("https://javadoc.io/doc/com.intellectualsites.informative-annotations/informative-annotations/latest/") |         opt.links("https://javadoc.io/doc/com.intellectualsites.informative-annotations/informative-annotations/latest/") | ||||||
|   | |||||||
| @@ -270,7 +270,11 @@ public class PlotSquared { | |||||||
|             captionMap = this.captionLoader.loadAll(this.platform.getDirectory().toPath().resolve("lang")); |             captionMap = this.captionLoader.loadAll(this.platform.getDirectory().toPath().resolve("lang")); | ||||||
|         } else { |         } else { | ||||||
|             String fileName = "messages_" + Settings.Enabled_Components.DEFAULT_LOCALE + ".json"; |             String fileName = "messages_" + Settings.Enabled_Components.DEFAULT_LOCALE + ".json"; | ||||||
|             captionMap = this.captionLoader.loadOrCreateSingle(this.platform.getDirectory().toPath().resolve("lang").resolve(fileName)); |             captionMap = this.captionLoader.loadOrCreateSingle(this.platform | ||||||
|  |                     .getDirectory() | ||||||
|  |                     .toPath() | ||||||
|  |                     .resolve("lang") | ||||||
|  |                     .resolve(fileName)); | ||||||
|         } |         } | ||||||
|         this.captionMaps.put(TranslatableCaption.DEFAULT_NAMESPACE, captionMap); |         this.captionMaps.put(TranslatableCaption.DEFAULT_NAMESPACE, captionMap); | ||||||
|         LOGGER.info( |         LOGGER.info( | ||||||
| @@ -1011,7 +1015,7 @@ public class PlotSquared { | |||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Setup the configuration for a plot world based on world arguments. |      * Setup the configuration for a plot world based on world arguments. | ||||||
|      * |      * <p> | ||||||
|      * |      * | ||||||
|      * <i>e.g. /mv create <world> normal -g PlotSquared:<args></i> |      * <i>e.g. /mv create <world> normal -g PlotSquared:<args></i> | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -136,13 +136,9 @@ public class SimpleBackupManager implements BackupManager { | |||||||
|         return this.backupLimit; |         return this.backupLimit; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static final class PlotCacheKey { |     private record PlotCacheKey( | ||||||
|  |             Plot plot | ||||||
|         private final Plot plot; |     ) { | ||||||
|  |  | ||||||
|         private PlotCacheKey(Plot plot) { |  | ||||||
|             this.plot = plot; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
|         public boolean equals(final Object o) { |         public boolean equals(final Object o) { | ||||||
|   | |||||||
| @@ -70,7 +70,8 @@ public class Add extends Command { | |||||||
|                 plot.isOwner(player.getUUID()) || player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_TRUST), |                 plot.isOwner(player.getUUID()) || player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_TRUST), | ||||||
|                 TranslatableCaption.of("permission.no_plot_perms") |                 TranslatableCaption.of("permission.no_plot_perms") | ||||||
|         ); |         ); | ||||||
|         checkTrue(args.length == 1, |         checkTrue( | ||||||
|  |                 args.length == 1, | ||||||
|                 TranslatableCaption.of("commandconfig.command_syntax"), |                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                 TagResolver.resolver("value", Tag.inserting(Component.text("/plot add <player | *>"))) |                 TagResolver.resolver("value", Tag.inserting(Component.text("/plot add <player | *>"))) | ||||||
|         ); |         ); | ||||||
|   | |||||||
| @@ -55,6 +55,7 @@ import com.plotsquared.core.util.TabCompletions; | |||||||
| import com.plotsquared.core.util.WorldUtil; | import com.plotsquared.core.util.WorldUtil; | ||||||
| import com.plotsquared.core.util.task.RunnableVal3; | import com.plotsquared.core.util.task.RunnableVal3; | ||||||
| import com.sk89q.worldedit.EditSession; | import com.sk89q.worldedit.EditSession; | ||||||
|  | import com.sk89q.worldedit.EditSessionBuilder; | ||||||
| import com.sk89q.worldedit.LocalSession; | import com.sk89q.worldedit.LocalSession; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
| import com.sk89q.worldedit.entity.Player; | import com.sk89q.worldedit.entity.Player; | ||||||
| @@ -232,10 +233,9 @@ public class Area extends SubCommand { | |||||||
|                 try (final ClipboardWriter clipboardWriter = BuiltInClipboardFormat.SPONGE_SCHEMATIC.getWriter(new FileOutputStream( |                 try (final ClipboardWriter clipboardWriter = BuiltInClipboardFormat.SPONGE_SCHEMATIC.getWriter(new FileOutputStream( | ||||||
|                         file))) { |                         file))) { | ||||||
|                     final BlockArrayClipboard clipboard = new BlockArrayClipboard(selectedRegion); |                     final BlockArrayClipboard clipboard = new BlockArrayClipboard(selectedRegion); | ||||||
|                     final EditSession editSession = WorldEdit |                     EditSessionBuilder editSessionBuilder = WorldEdit.getInstance().newEditSessionBuilder(); | ||||||
|                             .getInstance() |                     editSessionBuilder.world(selectedRegion.getWorld()); | ||||||
|                             .getEditSessionFactory() |                     final EditSession editSession = editSessionBuilder.build(); | ||||||
|                             .getEditSession(selectedRegion.getWorld(), -1); |  | ||||||
|                     final ForwardExtentCopy forwardExtentCopy = |                     final ForwardExtentCopy forwardExtentCopy = | ||||||
|                             new ForwardExtentCopy(editSession, selectedRegion, clipboard, selectedRegion.getMinimumPoint()); |                             new ForwardExtentCopy(editSession, selectedRegion, clipboard, selectedRegion.getMinimumPoint()); | ||||||
|                     forwardExtentCopy.setCopyingBiomes(true); |                     forwardExtentCopy.setCopyingBiomes(true); | ||||||
|   | |||||||
| @@ -35,6 +35,7 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
|  | import com.plotsquared.core.services.plots.AutoQuery; | ||||||
| import com.plotsquared.core.services.plots.AutoService; | import com.plotsquared.core.services.plots.AutoService; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| @@ -326,7 +327,7 @@ public class Auto extends SubCommand { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         List<Plot> plots = this.servicePipeline |         List<Plot> plots = this.servicePipeline | ||||||
|                 .pump(new AutoService.AutoQuery(player, null, sizeX, sizeZ, plotarea)) |                 .pump(new AutoQuery(player, null, sizeX, sizeZ, plotarea)) | ||||||
|                 .through(AutoService.class) |                 .through(AutoService.class) | ||||||
|                 .getResult(); |                 .getResult(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -107,9 +107,7 @@ public class Clear extends Command { | |||||||
|             } |             } | ||||||
|             BackupManager.backup(player, plot, () -> { |             BackupManager.backup(player, plot, () -> { | ||||||
|                 final long start = System.currentTimeMillis(); |                 final long start = System.currentTimeMillis(); | ||||||
|                 boolean result = plot.getPlotModificationManager().clear(true, false, player, () -> { |                 boolean result = plot.getPlotModificationManager().clear(true, false, player, () -> TaskManager.runTask(() -> { | ||||||
|                     plot.getPlotModificationManager().unlink(); |  | ||||||
|                     TaskManager.runTask(() -> { |  | ||||||
|                     plot.removeRunning(); |                     plot.removeRunning(); | ||||||
|                     // If the state changes, then mark it as no longer done |                     // If the state changes, then mark it as no longer done | ||||||
|                     if (DoneFlag.isDone(plot)) { |                     if (DoneFlag.isDone(plot)) { | ||||||
| @@ -137,8 +135,7 @@ public class Clear extends Command { | |||||||
|                                     .tag("plot", Tag.inserting(Component.text(plot.getId().toString()))) |                                     .tag("plot", Tag.inserting(Component.text(plot.getId().toString()))) | ||||||
|                                     .build() |                                     .build() | ||||||
|                     ); |                     ); | ||||||
|                     }); |                 })); | ||||||
|                 }); |  | ||||||
|                 if (!result) { |                 if (!result) { | ||||||
|                     player.sendMessage(TranslatableCaption.of("errors.wait_for_timer")); |                     player.sendMessage(TranslatableCaption.of("errors.wait_for_timer")); | ||||||
|                 } else { |                 } else { | ||||||
|   | |||||||
| @@ -46,6 +46,7 @@ import java.util.Collections; | |||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| import java.util.LinkedList; | import java.util.LinkedList; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  | import java.util.Objects; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
| import java.util.concurrent.TimeoutException; | import java.util.concurrent.TimeoutException; | ||||||
| @@ -77,8 +78,7 @@ public class Cluster extends SubCommand { | |||||||
|         } |         } | ||||||
|         String sub = args[0].toLowerCase(); |         String sub = args[0].toLowerCase(); | ||||||
|         switch (sub) { |         switch (sub) { | ||||||
|             case "l": |             case "l", "list" -> { | ||||||
|             case "list": { |  | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_LIST)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_LIST)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -133,8 +133,7 @@ public class Cluster extends SubCommand { | |||||||
|                 } |                 } | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "c": |             case "c", "create" -> { | ||||||
|             case "create": { |  | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_CREATE)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_CREATE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -269,9 +268,7 @@ public class Cluster extends SubCommand { | |||||||
|                 ); |                 ); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "disband": |             case "disband", "del", "delete" -> { | ||||||
|             case "del": |  | ||||||
|             case "delete": { |  | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_DELETE)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_DELETE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -330,8 +327,7 @@ public class Cluster extends SubCommand { | |||||||
|                 )); |                 )); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "res": |             case "res", "resize" -> { | ||||||
|             case "resize": { |  | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_RESIZE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -452,9 +448,7 @@ public class Cluster extends SubCommand { | |||||||
|                 player.sendMessage(TranslatableCaption.of("cluster.cluster_resized")); |                 player.sendMessage(TranslatableCaption.of("cluster.cluster_resized")); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "add": |             case "add", "inv", "invite" -> { | ||||||
|             case "inv": |  | ||||||
|             case "invite": { |  | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_INVITE)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_INVITE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -523,9 +517,7 @@ public class Cluster extends SubCommand { | |||||||
|                         }); |                         }); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "k": |             case "k", "remove", "kick" -> { | ||||||
|             case "remove": |  | ||||||
|             case "kick": { |  | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_KICK)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_KICK)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -605,8 +597,7 @@ public class Cluster extends SubCommand { | |||||||
|                         }); |                         }); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "quit": |             case "quit", "leave" -> { | ||||||
|             case "leave": { |  | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_LEAVE)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_LEAVE)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -667,7 +658,7 @@ public class Cluster extends SubCommand { | |||||||
|                 removePlayerPlots(cluster, uuid, player.getLocation().getWorldName()); |                 removePlayerPlots(cluster, uuid, player.getLocation().getWorldName()); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "members": { |             case "members" -> { | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_HELPERS)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_HELPERS)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -728,9 +719,7 @@ public class Cluster extends SubCommand { | |||||||
|                         }); |                         }); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "spawn": |             case "spawn", "home", "tp" -> { | ||||||
|             case "home": |  | ||||||
|             case "tp": { |  | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_TP)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_TP)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -778,10 +767,7 @@ public class Cluster extends SubCommand { | |||||||
|                 player.sendMessage(TranslatableCaption.of("cluster.cluster_teleporting")); |                 player.sendMessage(TranslatableCaption.of("cluster.cluster_teleporting")); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "i": |             case "i", "info", "show", "information" -> { | ||||||
|             case "info": |  | ||||||
|             case "show": |  | ||||||
|             case "information": { |  | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_INFO)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_INFO)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
| @@ -828,11 +814,7 @@ public class Cluster extends SubCommand { | |||||||
|                                 player.sendMessage(TranslatableCaption.of("players.fetching_players_timeout")); |                                 player.sendMessage(TranslatableCaption.of("players.fetching_players_timeout")); | ||||||
|                             } else { |                             } else { | ||||||
|                                 final String owner; |                                 final String owner; | ||||||
|                                 if (username == null) { |                                 owner = Objects.requireNonNullElse(username, "unknown"); | ||||||
|                                     owner = "unknown"; |  | ||||||
|                                 } else { |  | ||||||
|                                     owner = username; |  | ||||||
|                                 } |  | ||||||
|                                 String name = cluster.getName(); |                                 String name = cluster.getName(); | ||||||
|                                 String size = (cluster.getP2().getX() - cluster.getP1().getX() + 1) + "x" + ( |                                 String size = (cluster.getP2().getX() - cluster.getP1().getX() + 1) + "x" + ( | ||||||
|                                         cluster.getP2().getY() - cluster.getP1().getY() + 1); |                                         cluster.getP2().getY() - cluster.getP1().getY() + 1); | ||||||
| @@ -850,9 +832,7 @@ public class Cluster extends SubCommand { | |||||||
|                         }); |                         }); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|             case "sh": |             case "sh", "setspawn", "sethome" -> { | ||||||
|             case "setspawn": |  | ||||||
|             case "sethome": { |  | ||||||
|                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_SETHOME)) { |                 if (!player.hasPermission(Permission.PERMISSION_CLUSTER_SETHOME)) { | ||||||
|                     player.sendMessage( |                     player.sendMessage( | ||||||
|                             TranslatableCaption.of("permission.no_permission"), |                             TranslatableCaption.of("permission.no_permission"), | ||||||
|   | |||||||
| @@ -559,9 +559,10 @@ public abstract class Command { | |||||||
|  |  | ||||||
|     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { |     public Collection<Command> tab(PlotPlayer<?> player, String[] args, boolean space) { | ||||||
|         switch (args.length) { |         switch (args.length) { | ||||||
|             case 0: |             case 0 -> { | ||||||
|                 return this.allCommands; |                 return this.allCommands; | ||||||
|             case 1: |             } | ||||||
|  |             case 1 -> { | ||||||
|                 String arg = args[0].toLowerCase(); |                 String arg = args[0].toLowerCase(); | ||||||
|                 if (space) { |                 if (space) { | ||||||
|                     Command cmd = getCommand(arg); |                     Command cmd = getCommand(arg); | ||||||
| @@ -580,7 +581,8 @@ public abstract class Command { | |||||||
|                     } |                     } | ||||||
|                     return commands; |                     return commands; | ||||||
|                 } |                 } | ||||||
|             default: |             } | ||||||
|  |             default -> { | ||||||
|                 Command cmd = getCommand(args[0]); |                 Command cmd = getCommand(args[0]); | ||||||
|                 if (cmd != null) { |                 if (cmd != null) { | ||||||
|                     return cmd.tab(player, Arrays.copyOfRange(args, 1, args.length), space); |                     return cmd.tab(player, Arrays.copyOfRange(args, 1, args.length), space); | ||||||
| @@ -589,6 +591,7 @@ public abstract class Command { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public String toString() { |     public String toString() { | ||||||
|   | |||||||
| @@ -69,7 +69,8 @@ public class Copy extends SubCommand { | |||||||
|  |  | ||||||
|         plot1.getPlotModificationManager().copy(plot2, player).thenAccept(result -> { |         plot1.getPlotModificationManager().copy(plot2, player).thenAccept(result -> { | ||||||
|             if (result) { |             if (result) { | ||||||
|                 player.sendMessage(TranslatableCaption.of("move.copy_success"), |                 player.sendMessage( | ||||||
|  |                         TranslatableCaption.of("move.copy_success"), | ||||||
|                         TagResolver.builder() |                         TagResolver.builder() | ||||||
|                                 .tag("origin", Tag.inserting(Component.text(plot1.toString()))) |                                 .tag("origin", Tag.inserting(Component.text(plot1.toString()))) | ||||||
|                                 .tag("target", Tag.inserting(Component.text(plot2.toString()))) |                                 .tag("target", Tag.inserting(Component.text(plot2.toString()))) | ||||||
|   | |||||||
| @@ -75,11 +75,13 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|         } |         } | ||||||
|         String kind = args[0].toLowerCase(); |         String kind = args[0].toLowerCase(); | ||||||
|         switch (kind) { |         switch (kind) { | ||||||
|             case "plot": |             case "plot" -> { | ||||||
|                 return regenPlot(player); |                 return regenPlot(player); | ||||||
|             case "region": |             } | ||||||
|  |             case "region" -> { | ||||||
|                 return regenRegion(player, Arrays.copyOfRange(args, 1, args.length)); |                 return regenRegion(player, Arrays.copyOfRange(args, 1, args.length)); | ||||||
|             default: |             } | ||||||
|  |             default -> { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("commandconfig.command_syntax"), |                         TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                         TagResolver.resolver("value", Tag.inserting(Component.text(DebugRoadRegen.USAGE))) |                         TagResolver.resolver("value", Tag.inserting(Component.text(DebugRoadRegen.USAGE))) | ||||||
| @@ -87,6 +89,7 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public boolean regenPlot(PlotPlayer<?> player) { |     public boolean regenPlot(PlotPlayer<?> player) { | ||||||
|         Location location = player.getLocation(); |         Location location = player.getLocation(); | ||||||
|   | |||||||
| @@ -185,8 +185,11 @@ public class Download extends SubCommand { | |||||||
|         if (Settings.Web.LEGACY_WEBINTERFACE) { |         if (Settings.Web.LEGACY_WEBINTERFACE) { | ||||||
|             schematicHandler |             schematicHandler | ||||||
|                     .getCompoundTag(plot) |                     .getCompoundTag(plot) | ||||||
|                     .whenComplete((compoundTag, throwable) -> { |                     .whenComplete((compoundTag, throwable) -> schematicHandler.upload( | ||||||
|                         schematicHandler.upload(compoundTag, null, null, new RunnableVal<>() { |                             compoundTag, | ||||||
|  |                             null, | ||||||
|  |                             null, | ||||||
|  |                             new RunnableVal<>() { | ||||||
|                                 @Override |                                 @Override | ||||||
|                                 public void run(URL value) { |                                 public void run(URL value) { | ||||||
|                                     plot.removeRunning(); |                                     plot.removeRunning(); | ||||||
| @@ -199,8 +202,8 @@ public class Download extends SubCommand { | |||||||
|                                     ); |                                     ); | ||||||
|                                     player.sendMessage(StaticCaption.of(value.toString())); |                                     player.sendMessage(StaticCaption.of(value.toString())); | ||||||
|                                 } |                                 } | ||||||
|                         }); |                             } | ||||||
|                     }); |                     )); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         // TODO legacy support |         // TODO legacy support | ||||||
|   | |||||||
| @@ -60,9 +60,10 @@ public class Help extends Command { | |||||||
|             RunnableVal2<Command, CommandResult> whenDone |             RunnableVal2<Command, CommandResult> whenDone | ||||||
|     ) { |     ) { | ||||||
|         switch (args.length) { |         switch (args.length) { | ||||||
|             case 0: |             case 0 -> { | ||||||
|                 return displayHelp(player, null, 0); |                 return displayHelp(player, null, 0); | ||||||
|             case 1: |             } | ||||||
|  |             case 1 -> { | ||||||
|                 if (MathMan.isInteger(args[0])) { |                 if (MathMan.isInteger(args[0])) { | ||||||
|                     try { |                     try { | ||||||
|                         return displayHelp(player, null, Integer.parseInt(args[0])); |                         return displayHelp(player, null, Integer.parseInt(args[0])); | ||||||
| @@ -72,7 +73,8 @@ public class Help extends Command { | |||||||
|                 } else { |                 } else { | ||||||
|                     return displayHelp(player, args[0], 1); |                     return displayHelp(player, args[0], 1); | ||||||
|                 } |                 } | ||||||
|             case 2: |             } | ||||||
|  |             case 2 -> { | ||||||
|                 if (MathMan.isInteger(args[1])) { |                 if (MathMan.isInteger(args[1])) { | ||||||
|                     try { |                     try { | ||||||
|                         return displayHelp(player, args[0], Integer.parseInt(args[1])); |                         return displayHelp(player, args[0], Integer.parseInt(args[1])); | ||||||
| @@ -81,8 +83,8 @@ public class Help extends Command { | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 return CompletableFuture.completedFuture(false); |                 return CompletableFuture.completedFuture(false); | ||||||
|             default: |             } | ||||||
|                 sendUsage(player); |             default -> sendUsage(player); | ||||||
|         } |         } | ||||||
|         return CompletableFuture.completedFuture(true); |         return CompletableFuture.completedFuture(true); | ||||||
|     } |     } | ||||||
| @@ -132,7 +134,12 @@ public class Help extends Command { | |||||||
|                                 TagResolver.builder() |                                 TagResolver.builder() | ||||||
|                                         .tag("command", Tag.inserting(Component.text("/plot help"))) |                                         .tag("command", Tag.inserting(Component.text("/plot help"))) | ||||||
|                                         .tag("category", Tag.inserting(Component.text("all"))) |                                         .tag("category", Tag.inserting(Component.text("all"))) | ||||||
|                                         .tag("category_desc", Tag.inserting(TranslatableCaption.of("help.help_display_all_commands").toComponent(player))) |                                         .tag( | ||||||
|  |                                                 "category_desc", | ||||||
|  |                                                 Tag.inserting(TranslatableCaption | ||||||
|  |                                                         .of("help.help_display_all_commands") | ||||||
|  |                                                         .toComponent(player)) | ||||||
|  |                                         ) | ||||||
|                                         .build() |                                         .build() | ||||||
|                         )); |                         )); | ||||||
|                 builder.append(Component.newline()).append(MINI_MESSAGE.deserialize(TranslatableCaption |                 builder.append(Component.newline()).append(MINI_MESSAGE.deserialize(TranslatableCaption | ||||||
|   | |||||||
| @@ -85,24 +85,24 @@ public class Inbox extends SubCommand { | |||||||
|         for (int x = page * 12; x < max; x++) { |         for (int x = page * 12; x < max; x++) { | ||||||
|             PlotComment comment = comments[x]; |             PlotComment comment = comments[x]; | ||||||
|             Component commentColored; |             Component commentColored; | ||||||
|             if (player.getName().equals(comment.senderName)) { |             if (player.getName().equals(comment.senderName())) { | ||||||
|                 commentColored = MINI_MESSAGE |                 commentColored = MINI_MESSAGE | ||||||
|                         .deserialize( |                         .deserialize( | ||||||
|                                 TranslatableCaption.of("list.comment_list_by_lister").getComponent(player), |                                 TranslatableCaption.of("list.comment_list_by_lister").getComponent(player), | ||||||
|                                 TagResolver.resolver("comment", Tag.inserting(Component.text(comment.comment))) |                                 TagResolver.resolver("comment", Tag.inserting(Component.text(comment.comment()))) | ||||||
|                         ); |                         ); | ||||||
|             } else { |             } else { | ||||||
|                 commentColored = MINI_MESSAGE |                 commentColored = MINI_MESSAGE | ||||||
|                         .deserialize( |                         .deserialize( | ||||||
|                                 TranslatableCaption.of("list.comment_list_by_other").getComponent(player), |                                 TranslatableCaption.of("list.comment_list_by_other").getComponent(player), | ||||||
|                                 TagResolver.resolver("comment", Tag.inserting(Component.text(comment.comment))) |                                 TagResolver.resolver("comment", Tag.inserting(Component.text(comment.comment()))) | ||||||
|                         ); |                         ); | ||||||
|             } |             } | ||||||
|             TagResolver resolver = TagResolver.builder() |             TagResolver resolver = TagResolver.builder() | ||||||
|                     .tag("number", Tag.inserting(Component.text(x))) |                     .tag("number", Tag.inserting(Component.text(x))) | ||||||
|                     .tag("world", Tag.inserting(Component.text(comment.world))) |                     .tag("world", Tag.inserting(Component.text(comment.world()))) | ||||||
|                     .tag("plot_id", Tag.inserting(Component.text(comment.id.getX() + ";" + comment.id.getY()))) |                     .tag("plot_id", Tag.inserting(Component.text(comment.id().getX() + ";" + comment.id().getY()))) | ||||||
|                     .tag("commenter", Tag.inserting(Component.text(comment.senderName))) |                     .tag("commenter", Tag.inserting(Component.text(comment.senderName()))) | ||||||
|                     .tag("comment", Tag.inserting(commentColored)) |                     .tag("comment", Tag.inserting(commentColored)) | ||||||
|                     .build(); |                     .build(); | ||||||
|             builder.append(MINI_MESSAGE |             builder.append(MINI_MESSAGE | ||||||
| @@ -137,7 +137,7 @@ public class Inbox extends SubCommand { | |||||||
|                                 int unread = 0; |                                 int unread = 0; | ||||||
|                                 for (PlotComment comment : value) { |                                 for (PlotComment comment : value) { | ||||||
|                                     total++; |                                     total++; | ||||||
|                                     if (comment.timestamp > CommentManager |                                     if (comment.timestamp() > CommentManager | ||||||
|                                             .getTimestamp(player, inbox.toString())) { |                                             .getTimestamp(player, inbox.toString())) { | ||||||
|                                         unread++; |                                         unread++; | ||||||
|                                     } |                                     } | ||||||
| @@ -190,7 +190,7 @@ public class Inbox extends SubCommand { | |||||||
|         final int page; |         final int page; | ||||||
|         if (args.length > 1) { |         if (args.length > 1) { | ||||||
|             switch (args[1].toLowerCase()) { |             switch (args[1].toLowerCase()) { | ||||||
|                 case "delete": |                 case "delete" -> { | ||||||
|                     if (!inbox.canModify(plot, player)) { |                     if (!inbox.canModify(plot, player)) { | ||||||
|                         player.sendMessage(TranslatableCaption.of("comment.no_perm_inbox_modify")); |                         player.sendMessage(TranslatableCaption.of("comment.no_perm_inbox_modify")); | ||||||
|                         return false; |                         return false; | ||||||
| @@ -225,7 +225,6 @@ public class Inbox extends SubCommand { | |||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|                     if (!inbox.getComments(plot, new RunnableVal<>() { |                     if (!inbox.getComments(plot, new RunnableVal<>() { | ||||||
|                         @Override |                         @Override | ||||||
|                         public void run(List<PlotComment> value) { |                         public void run(List<PlotComment> value) { | ||||||
| @@ -242,7 +241,7 @@ public class Inbox extends SubCommand { | |||||||
|                             if (success) { |                             if (success) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("comment.comment_removed_success"), |                                         TranslatableCaption.of("comment.comment_removed_success"), | ||||||
|                                         TagResolver.resolver("value", Tag.inserting(Component.text(comment.comment))) |                                         TagResolver.resolver("value", Tag.inserting(Component.text(comment.comment()))) | ||||||
|                                 ); |                                 ); | ||||||
|                             } else { |                             } else { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
| @@ -254,7 +253,8 @@ public class Inbox extends SubCommand { | |||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     return true; |                     return true; | ||||||
|                 case "clear": |                 } | ||||||
|  |                 case "clear" -> { | ||||||
|                     if (!inbox.canModify(plot, player)) { |                     if (!inbox.canModify(plot, player)) { | ||||||
|                         player.sendMessage(TranslatableCaption.of("comment.no_perm_inbox_modify")); |                         player.sendMessage(TranslatableCaption.of("comment.no_perm_inbox_modify")); | ||||||
|                     } |                     } | ||||||
| @@ -268,7 +268,8 @@ public class Inbox extends SubCommand { | |||||||
|                         plot.getPlotCommentContainer().removeComments(comments); |                         plot.getPlotCommentContainer().removeComments(comments); | ||||||
|                     } |                     } | ||||||
|                     return true; |                     return true; | ||||||
|                 default: |                 } | ||||||
|  |                 default -> { | ||||||
|                     try { |                     try { | ||||||
|                         page = Integer.parseInt(args[1]); |                         page = Integer.parseInt(args[1]); | ||||||
|                     } catch (NumberFormatException ignored) { |                     } catch (NumberFormatException ignored) { | ||||||
| @@ -276,6 +277,7 @@ public class Inbox extends SubCommand { | |||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|  |             } | ||||||
|         } else { |         } else { | ||||||
|             page = 1; |             page = 1; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -52,7 +52,8 @@ public class Info extends SubCommand { | |||||||
|             arg = args[0]; |             arg = args[0]; | ||||||
|             switch (arg) { |             switch (arg) { | ||||||
|                 // TODO: (re?)implement /plot info inv. (it was never properly implemented) |                 // TODO: (re?)implement /plot info inv. (it was never properly implemented) | ||||||
|                 case "trusted", "alias", "biome", "denied", "flags", "id", "size", "members", "creationdate", "seen", "owner", "rating", "likes" -> plot = Plot |                 case "trusted", "alias", "biome", "denied", "flags", "id", "size", "members", "creationdate", "seen", "owner", "rating", "likes" -> | ||||||
|  |                         plot = Plot | ||||||
|                                 .getPlotFromString(player, null, false); |                                 .getPlotFromString(player, null, false); | ||||||
|                 default -> { |                 default -> { | ||||||
|                     plot = Plot.getPlotFromString(player, arg, false); |                     plot = Plot.getPlotFromString(player, arg, false); | ||||||
|   | |||||||
| @@ -474,20 +474,20 @@ public class ListCmd extends SubCommand { | |||||||
|                         final List<UUIDMapping> names = PlotSquared.get().getImpromptuUUIDPipeline().getNames(plot.getOwners()) |                         final List<UUIDMapping> names = PlotSquared.get().getImpromptuUUIDPipeline().getNames(plot.getOwners()) | ||||||
|                                 .get(Settings.UUID.BLOCKING_TIMEOUT, TimeUnit.MILLISECONDS); |                                 .get(Settings.UUID.BLOCKING_TIMEOUT, TimeUnit.MILLISECONDS); | ||||||
|                         for (final UUIDMapping uuidMapping : names) { |                         for (final UUIDMapping uuidMapping : names) { | ||||||
|                             PlotPlayer<?> pp = PlotSquared.platform().playerManager().getPlayerIfExists(uuidMapping.getUuid()); |                             PlotPlayer<?> pp = PlotSquared.platform().playerManager().getPlayerIfExists(uuidMapping.uuid()); | ||||||
|                             TagResolver resolver = TagResolver.builder() |                             TagResolver resolver = TagResolver.builder() | ||||||
|                                     .tag("prefix", Tag.inserting(Component.text(prefix))) |                                     .tag("prefix", Tag.inserting(Component.text(prefix))) | ||||||
|                                 .tag("player", Tag.inserting(Component.text(uuidMapping.getUsername()))) |                                     .tag("player", Tag.inserting(Component.text(uuidMapping.username()))) | ||||||
|                                     .build(); |                                     .build(); | ||||||
|                             if (pp != null) { |                             if (pp != null) { | ||||||
|                                 builder.append(MINI_MESSAGE.deserialize(online, resolver)); |                                 builder.append(MINI_MESSAGE.deserialize(online, resolver)); | ||||||
|                             } else if (uuidMapping.getUsername().equalsIgnoreCase("unknown")) { |                             } else if (uuidMapping.username().equalsIgnoreCase("unknown")) { | ||||||
|                                 TagResolver unknownResolver = TagResolver.resolver( |                                 TagResolver unknownResolver = TagResolver.resolver( | ||||||
|                                         "info.unknown", |                                         "info.unknown", | ||||||
|                                         Tag.inserting(TranslatableCaption.of("info.unknown").toComponent(player)) |                                         Tag.inserting(TranslatableCaption.of("info.unknown").toComponent(player)) | ||||||
|                                 ); |                                 ); | ||||||
|                                 builder.append(MINI_MESSAGE.deserialize(unknown, unknownResolver)); |                                 builder.append(MINI_MESSAGE.deserialize(unknown, unknownResolver)); | ||||||
|                             } else if (uuidMapping.getUuid().equals(DBFunc.EVERYONE)) { |                             } else if (uuidMapping.uuid().equals(DBFunc.EVERYONE)) { | ||||||
|                                 TagResolver everyoneResolver = TagResolver.resolver( |                                 TagResolver everyoneResolver = TagResolver.resolver( | ||||||
|                                         "info.everyone", |                                         "info.everyone", | ||||||
|                                         Tag.inserting(TranslatableCaption.of("info.everyone").toComponent(player)) |                                         Tag.inserting(TranslatableCaption.of("info.everyone").toComponent(player)) | ||||||
|   | |||||||
| @@ -90,12 +90,8 @@ public class Purge extends SubCommand { | |||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|             switch (split[0].toLowerCase()) { |             switch (split[0].toLowerCase()) { | ||||||
|                 case "world": |                 case "world", "w" -> world = split[1]; | ||||||
|                 case "w": |                 case "area", "a" -> { | ||||||
|                     world = split[1]; |  | ||||||
|                     break; |  | ||||||
|                 case "area": |  | ||||||
|                 case "a": |  | ||||||
|                     area = this.plotAreaManager.getPlotAreaByString(split[1]); |                     area = this.plotAreaManager.getPlotAreaByString(split[1]); | ||||||
|                     if (area == null) { |                     if (area == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
| @@ -104,9 +100,8 @@ public class Purge extends SubCommand { | |||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     break; |                 } | ||||||
|                 case "plotid": |                 case "plotid", "id" -> { | ||||||
|                 case "id": |  | ||||||
|                     try { |                     try { | ||||||
|                         id = PlotId.fromString(split[1]); |                         id = PlotId.fromString(split[1]); | ||||||
|                     } catch (IllegalArgumentException ignored) { |                     } catch (IllegalArgumentException ignored) { | ||||||
| @@ -116,9 +111,8 @@ public class Purge extends SubCommand { | |||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     break; |                 } | ||||||
|                 case "owner": |                 case "owner", "o" -> { | ||||||
|                 case "o": |  | ||||||
|                     UUIDMapping ownerMapping = PlotSquared.get().getImpromptuUUIDPipeline().getImmediately(split[1]); |                     UUIDMapping ownerMapping = PlotSquared.get().getImpromptuUUIDPipeline().getImmediately(split[1]); | ||||||
|                     if (ownerMapping == null) { |                     if (ownerMapping == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
| @@ -127,10 +121,9 @@ public class Purge extends SubCommand { | |||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     owner = ownerMapping.getUuid(); |                     owner = ownerMapping.uuid(); | ||||||
|                     break; |                 } | ||||||
|                 case "shared": |                 case "shared", "s" -> { | ||||||
|                 case "s": |  | ||||||
|                     UUIDMapping addedMapping = PlotSquared.get().getImpromptuUUIDPipeline().getImmediately(split[1]); |                     UUIDMapping addedMapping = PlotSquared.get().getImpromptuUUIDPipeline().getImmediately(split[1]); | ||||||
|                     if (addedMapping == null) { |                     if (addedMapping == null) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
| @@ -139,25 +132,16 @@ public class Purge extends SubCommand { | |||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     added = addedMapping.getUuid(); |                     added = addedMapping.uuid(); | ||||||
|                     break; |                 } | ||||||
|                 case "clear": |                 case "clear", "c", "delete", "d", "del" -> clear = Boolean.parseBoolean(split[1]); | ||||||
|                 case "c": |                 case "unknown", "?", "u" -> unknown = Boolean.parseBoolean(split[1]); | ||||||
|                 case "delete": |                 default -> { | ||||||
|                 case "d": |  | ||||||
|                 case "del": |  | ||||||
|                     clear = Boolean.parseBoolean(split[1]); |  | ||||||
|                     break; |  | ||||||
|                 case "unknown": |  | ||||||
|                 case "?": |  | ||||||
|                 case "u": |  | ||||||
|                     unknown = Boolean.parseBoolean(split[1]); |  | ||||||
|                     break; |  | ||||||
|                 default: |  | ||||||
|                     sendUsage(player); |                     sendUsage(player); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|         final HashSet<Plot> toDelete = new HashSet<>(); |         final HashSet<Plot> toDelete = new HashSet<>(); | ||||||
|         for (Plot plot : PlotQuery.newQuery().whereBasePlot()) { |         for (Plot plot : PlotQuery.newQuery().whereBasePlot()) { | ||||||
|             if (world != null && !plot.getWorldName().equalsIgnoreCase(world)) { |             if (world != null && !plot.getWorldName().equalsIgnoreCase(world)) { | ||||||
| @@ -236,9 +220,9 @@ public class Purge extends SubCommand { | |||||||
|                             try { |                             try { | ||||||
|                                 ids.add(plot.temp); |                                 ids.add(plot.temp); | ||||||
|                                 if (finalClear) { |                                 if (finalClear) { | ||||||
|                                     plot.getPlotModificationManager().clear(false, true, player, () -> { |                                     plot.getPlotModificationManager().clear(false, true, player, | ||||||
|                                         LOGGER.info("Plot {} cleared by purge", plot.getId()); |                                             () -> LOGGER.info("Plot {} cleared by purge", plot.getId()) | ||||||
|                                     }); |                                     ); | ||||||
|                                 } else { |                                 } else { | ||||||
|                                     plot.getPlotModificationManager().removeSign(); |                                     plot.getPlotModificationManager().removeSign(); | ||||||
|                                 } |                                 } | ||||||
|   | |||||||
| @@ -156,9 +156,9 @@ public class Template extends SubCommand { | |||||||
|              ZipOutputStream zos = new ZipOutputStream(fos)) { |              ZipOutputStream zos = new ZipOutputStream(fos)) { | ||||||
|  |  | ||||||
|             for (FileBytes file : files) { |             for (FileBytes file : files) { | ||||||
|                 ZipEntry ze = new ZipEntry(file.path); |                 ZipEntry ze = new ZipEntry(file.path()); | ||||||
|                 zos.putNextEntry(ze); |                 zos.putNextEntry(ze); | ||||||
|                 zos.write(file.data); |                 zos.write(file.data()); | ||||||
|             } |             } | ||||||
|             zos.closeEntry(); |             zos.closeEntry(); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -35,34 +35,22 @@ import java.util.Map; | |||||||
|  * the component GUI |  * the component GUI | ||||||
|  */ |  */ | ||||||
| @SerializableAs("preset") | @SerializableAs("preset") | ||||||
| public class ComponentPreset implements ConfigurationSerializable { | public record ComponentPreset( | ||||||
|  |         ClassicPlotManagerComponent component, | ||||||
|     private final ClassicPlotManagerComponent component; |         String pattern, | ||||||
|     private final String pattern; |         double cost, | ||||||
|     private final double cost; |         String permission, | ||||||
|     private final String permission; |         String displayName, | ||||||
|     private final String displayName; |         List<String> description, | ||||||
|     private final List<String> description; |         ItemType icon | ||||||
|     private final ItemType icon; | ) implements ConfigurationSerializable { | ||||||
|  |  | ||||||
|     public ComponentPreset( |  | ||||||
|             ClassicPlotManagerComponent component, String pattern, double cost, |  | ||||||
|             String permission, String displayName, List<String> description, final ItemType icon |  | ||||||
|     ) { |  | ||||||
|         this.component = component; |  | ||||||
|         this.pattern = pattern; |  | ||||||
|         this.cost = cost; |  | ||||||
|         this.permission = permission; |  | ||||||
|         this.displayName = displayName; |  | ||||||
|         this.description = description; |  | ||||||
|         this.icon = icon; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @SuppressWarnings("unchecked") |     @SuppressWarnings("unchecked") | ||||||
|     public static ComponentPreset deserialize(final @NonNull Map<String, Object> map) { |     public static ComponentPreset deserialize(final @NonNull Map<String, Object> map) { | ||||||
|         final ClassicPlotManagerComponent classicPlotManagerComponent = ClassicPlotManagerComponent |         final ClassicPlotManagerComponent classicPlotManagerComponent = ClassicPlotManagerComponent | ||||||
|                 .fromString(map.getOrDefault("component", "").toString()).orElseThrow(() -> |                 .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 String pattern = map.getOrDefault("pattern", "").toString(); | ||||||
|         final double cost = Double.parseDouble(map.getOrDefault("cost", "0.0").toString()); |         final double cost = Double.parseDouble(map.getOrDefault("cost", "0.0").toString()); | ||||||
|         final String permission = map.getOrDefault("permission", "").toString(); |         final String permission = map.getOrDefault("permission", "").toString(); | ||||||
| @@ -74,34 +62,6 @@ public class ComponentPreset implements ConfigurationSerializable { | |||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public ClassicPlotManagerComponent getComponent() { |  | ||||||
|         return this.component; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public String getPattern() { |  | ||||||
|         return this.pattern; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public double getCost() { |  | ||||||
|         return this.cost; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public String getPermission() { |  | ||||||
|         return this.permission; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public String getDisplayName() { |  | ||||||
|         return this.displayName; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public List<String> getDescription() { |  | ||||||
|         return this.description; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public ItemType getIcon() { |  | ||||||
|         return this.icon; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public Map<String, Object> serialize() { |     public Map<String, Object> serialize() { | ||||||
|         final Map<String, Object> map = new HashMap<>(); |         final Map<String, Object> map = new HashMap<>(); | ||||||
|   | |||||||
| @@ -165,8 +165,8 @@ public class ComponentPresetManager { | |||||||
|  |  | ||||||
|         final List<ComponentPreset> allowedPresets = new ArrayList<>(this.presets.size()); |         final List<ComponentPreset> allowedPresets = new ArrayList<>(this.presets.size()); | ||||||
|         for (final ComponentPreset componentPreset : this.presets) { |         for (final ComponentPreset componentPreset : this.presets) { | ||||||
|             if (!componentPreset.getPermission().isEmpty() && !player.hasPermission( |             if (!componentPreset.permission().isEmpty() && !player.hasPermission( | ||||||
|                     componentPreset.getPermission() |                     componentPreset.permission() | ||||||
|             )) { |             )) { | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
| @@ -200,30 +200,30 @@ public class ComponentPresetManager { | |||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 final Pattern pattern = PatternUtil.parse(null, componentPreset.getPattern(), false); |                 final Pattern pattern = PatternUtil.parse(null, componentPreset.pattern(), false); | ||||||
|                 if (pattern == null) { |                 if (pattern == null) { | ||||||
|                     getPlayer().sendMessage(TranslatableCaption.of("preset.preset_invalid")); |                     getPlayer().sendMessage(TranslatableCaption.of("preset.preset_invalid")); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 if (componentPreset.getCost() > 0.0D) { |                 if (componentPreset.cost() > 0.0D) { | ||||||
|                     if (!econHandler.isEnabled(plot.getArea())) { |                     if (!econHandler.isEnabled(plot.getArea())) { | ||||||
|                         getPlayer().sendMessage( |                         getPlayer().sendMessage( | ||||||
|                                 TranslatableCaption.of("preset.economy_disabled"), |                                 TranslatableCaption.of("preset.economy_disabled"), | ||||||
|                                 TagResolver.resolver("preset", Tag.inserting(Component.text(componentPreset.getDisplayName()))) |                                 TagResolver.resolver("preset", Tag.inserting(Component.text(componentPreset.displayName()))) | ||||||
|                         ); |                         ); | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     if (econHandler.getMoney(getPlayer()) < componentPreset.getCost()) { |                     if (econHandler.getMoney(getPlayer()) < componentPreset.cost()) { | ||||||
|                         getPlayer().sendMessage(TranslatableCaption.of("preset.preset_cannot_afford")); |                         getPlayer().sendMessage(TranslatableCaption.of("preset.preset_cannot_afford")); | ||||||
|                         return false; |                         return false; | ||||||
|                     } else { |                     } else { | ||||||
|                         econHandler.withdrawMoney(getPlayer(), componentPreset.getCost()); |                         econHandler.withdrawMoney(getPlayer(), componentPreset.cost()); | ||||||
|                         getPlayer().sendMessage( |                         getPlayer().sendMessage( | ||||||
|                                 TranslatableCaption.of("economy.removed_balance"), |                                 TranslatableCaption.of("economy.removed_balance"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
|                                         "money", |                                         "money", | ||||||
|                                         Tag.inserting(Component.text(econHandler.format(componentPreset.getCost()))) |                                         Tag.inserting(Component.text(econHandler.format(componentPreset.cost()))) | ||||||
|                                 ) |                                 ) | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
| @@ -235,7 +235,7 @@ public class ComponentPresetManager { | |||||||
|                     queue.setCompleteTask(plot::removeRunning); |                     queue.setCompleteTask(plot::removeRunning); | ||||||
|                     for (Plot current : plot.getConnectedPlots()) { |                     for (Plot current : plot.getConnectedPlots()) { | ||||||
|                         current.getPlotModificationManager().setComponent( |                         current.getPlotModificationManager().setComponent( | ||||||
|                                 componentPreset.getComponent().name(), |                                 componentPreset.component().name(), | ||||||
|                                 pattern, |                                 pattern, | ||||||
|                                 player, |                                 player, | ||||||
|                                 queue |                                 queue | ||||||
| @@ -252,32 +252,32 @@ public class ComponentPresetManager { | |||||||
|         for (int i = 0; i < allowedPresets.size(); i++) { |         for (int i = 0; i < allowedPresets.size(); i++) { | ||||||
|             final ComponentPreset preset = allowedPresets.get(i); |             final ComponentPreset preset = allowedPresets.get(i); | ||||||
|             final List<String> lore = new ArrayList<>(); |             final List<String> lore = new ArrayList<>(); | ||||||
|             if (preset.getCost() > 0) { |             if (preset.cost() > 0) { | ||||||
|                 if (!this.econHandler.isEnabled(plot.getArea())) { |                 if (!this.econHandler.isEnabled(plot.getArea())) { | ||||||
|                     lore.add(MINI_MESSAGE.serialize(MINI_MESSAGE.deserialize( |                     lore.add(MINI_MESSAGE.serialize(MINI_MESSAGE.deserialize( | ||||||
|                             TranslatableCaption.of("preset.preset_lore_economy_disabled").getComponent(player)))); |                             TranslatableCaption.of("preset.preset_lore_economy_disabled").getComponent(player)))); | ||||||
|                 } else { |                 } else { | ||||||
|                     lore.add(MINI_MESSAGE.serialize(MINI_MESSAGE.deserialize( |                     lore.add(MINI_MESSAGE.serialize(MINI_MESSAGE.deserialize( | ||||||
|                             TranslatableCaption.of("preset.preset_lore_cost").getComponent(player), |                             TranslatableCaption.of("preset.preset_lore_cost").getComponent(player), | ||||||
|                             TagResolver.resolver("cost", Tag.inserting(Component.text(String.format("%.2f", preset.getCost())))) |                             TagResolver.resolver("cost", Tag.inserting(Component.text(String.format("%.2f", preset.cost())))) | ||||||
|                     ))); |                     ))); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             lore.add(MINI_MESSAGE.serialize(MINI_MESSAGE.deserialize( |             lore.add(MINI_MESSAGE.serialize(MINI_MESSAGE.deserialize( | ||||||
|                     TranslatableCaption.of("preset.preset_lore_component").getComponent(player), |                     TranslatableCaption.of("preset.preset_lore_component").getComponent(player), | ||||||
|                     TagResolver.builder() |                     TagResolver.builder() | ||||||
|                             .tag("component", Tag.inserting(Component.text(preset.getComponent().name().toLowerCase()))) |                             .tag("component", Tag.inserting(Component.text(preset.component().name().toLowerCase()))) | ||||||
|                             .tag("prefix", Tag.inserting(TranslatableCaption.of("core.prefix").toComponent(player))) |                             .tag("prefix", Tag.inserting(TranslatableCaption.of("core.prefix").toComponent(player))) | ||||||
|                             .build() |                             .build() | ||||||
|             ))); |             ))); | ||||||
|             lore.removeIf(String::isEmpty); |             lore.removeIf(String::isEmpty); | ||||||
|             lore.addAll(preset.getDescription()); |             lore.addAll(preset.description()); | ||||||
|             plotInventory.setItem( |             plotInventory.setItem( | ||||||
|                     i, |                     i, | ||||||
|                     new PlotItemStack( |                     new PlotItemStack( | ||||||
|                             preset.getIcon().getId().replace("minecraft:", ""), |                             preset.icon().getId().replace("minecraft:", ""), | ||||||
|                             1, |                             1, | ||||||
|                             preset.getDisplayName(), |                             preset.displayName(), | ||||||
|                             lore.toArray(new String[0]) |                             lore.toArray(new String[0]) | ||||||
|                     ) |                     ) | ||||||
|             ); |             ); | ||||||
|   | |||||||
| @@ -42,32 +42,6 @@ public class Config { | |||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + Config.class.getSimpleName()); |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + Config.class.getSimpleName()); | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Get the value for a node<br> |  | ||||||
|      * Probably throws some error if you try to get a non existent key |  | ||||||
|      * |  | ||||||
|      * @param key  configuration key |  | ||||||
|      * @param root configuration class |  | ||||||
|      * @param <T>  value type |  | ||||||
|      * @return value |  | ||||||
|      */ |  | ||||||
|     @SuppressWarnings("unchecked") |  | ||||||
|     public static <T> T get(String key, Class<?> root) { |  | ||||||
|         String[] split = key.split("\\."); |  | ||||||
|         Object instance = getInstance(split, root); |  | ||||||
|         if (instance != null) { |  | ||||||
|             Field field = getField(split, instance); |  | ||||||
|             if (field != null) { |  | ||||||
|                 try { |  | ||||||
|                     return (T) field.get(instance); |  | ||||||
|                 } catch (IllegalAccessException e) { |  | ||||||
|                     e.printStackTrace(); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return null; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Set the value of a specific node<br> |      * Set the value of a specific node<br> | ||||||
|      * Probably throws some error if you supply non existing keys or invalid values |      * Probably throws some error if you supply non existing keys or invalid values | ||||||
| @@ -259,7 +233,6 @@ public class Config { | |||||||
|      * |      * | ||||||
|      * @param split    the node (split by period) |      * @param split    the node (split by period) | ||||||
|      * @param instance the instance |      * @param instance the instance | ||||||
|      * @return |  | ||||||
|      */ |      */ | ||||||
|     private static Field getField(String[] split, Object instance) { |     private static Field getField(String[] split, Object instance) { | ||||||
|         try { |         try { | ||||||
| @@ -445,10 +418,6 @@ public class Config { | |||||||
|             return INSTANCES.values(); |             return INSTANCES.values(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         public Collection<String> getSections() { |  | ||||||
|             return INSTANCES.keySet(); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         private Map<String, T> getRaw() { |         private Map<String, T> getRaw() { | ||||||
|             return INSTANCES; |             return INSTANCES; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -225,7 +225,7 @@ public final class CaptionLoader { | |||||||
|      */ |      */ | ||||||
|     public @NonNull CaptionMap loadOrCreateSingle(final @NonNull Path file) throws IOException { |     public @NonNull CaptionMap loadOrCreateSingle(final @NonNull Path file) throws IOException { | ||||||
|         final Locale locale = this.localeExtractor.apply(file); |         final Locale locale = this.localeExtractor.apply(file); | ||||||
|         if (!Files.exists(file) ) { |         if (!Files.exists(file)) { | ||||||
|             Map<String, String> map = new LinkedHashMap<>(); |             Map<String, String> map = new LinkedHashMap<>(); | ||||||
|             patch(map, locale); |             patch(map, locale); | ||||||
|             save(file, map); |             save(file, map); | ||||||
|   | |||||||
| @@ -56,7 +56,8 @@ final class ClassLoaderCaptionProvider implements DefaultCaptionProvider { | |||||||
|                 LOGGER.info("No resource for locale '{}' found in the plugin file." + |                 LOGGER.info("No resource for locale '{}' found in the plugin file." + | ||||||
|                                 "Please ensure you have placed the latest version of the file messages_{}.json in the 'lang' folder." + |                                 "Please ensure you have placed the latest version of the file messages_{}.json in the 'lang' folder." + | ||||||
|                                 "You may be able to find completed translations at https://intellectualsites.crowdin.com/plotsquared", |                                 "You may be able to find completed translations at https://intellectualsites.crowdin.com/plotsquared", | ||||||
|                         locale, locale); |                         locale, locale | ||||||
|  |                 ); | ||||||
|                 return null; |                 return null; | ||||||
|             } |             } | ||||||
|             try (final BufferedReader reader = new BufferedReader(new InputStreamReader(stream))) { |             try (final BufferedReader reader = new BufferedReader(new InputStreamReader(stream))) { | ||||||
|   | |||||||
| @@ -2400,13 +2400,13 @@ public class SQLManager implements AbstractDB { | |||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|                     statement.setString(1, plot.getArea().toString()); |                     statement.setString(1, plot.getArea().toString()); | ||||||
|                     statement.setInt(2, plot.getId().hashCode()); |                     statement.setInt(2, plot.getId().hashCode()); | ||||||
|                     statement.setString(3, comment.comment); |                     statement.setString(3, comment.comment()); | ||||||
|                     statement.setString(4, comment.inbox); |                     statement.setString(4, comment.inbox()); | ||||||
|                     statement.setString(5, comment.senderName); |                     statement.setString(5, comment.senderName()); | ||||||
|                 } else { |                 } else { | ||||||
|                     statement.setString(1, comment.comment); |                     statement.setString(1, comment.comment()); | ||||||
|                     statement.setString(2, comment.inbox); |                     statement.setString(2, comment.inbox()); | ||||||
|                     statement.setString(3, comment.senderName); |                     statement.setString(3, comment.senderName()); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
| @@ -2518,10 +2518,10 @@ public class SQLManager implements AbstractDB { | |||||||
|             public void set(PreparedStatement statement) throws SQLException { |             public void set(PreparedStatement statement) throws SQLException { | ||||||
|                 statement.setString(1, plot.getArea().toString()); |                 statement.setString(1, plot.getArea().toString()); | ||||||
|                 statement.setInt(2, plot.getId().hashCode()); |                 statement.setInt(2, plot.getId().hashCode()); | ||||||
|                 statement.setString(3, comment.comment); |                 statement.setString(3, comment.comment()); | ||||||
|                 statement.setString(4, comment.inbox); |                 statement.setString(4, comment.inbox()); | ||||||
|                 statement.setInt(5, (int) (comment.timestamp / 1000)); |                 statement.setInt(5, (int) (comment.timestamp() / 1000)); | ||||||
|                 statement.setString(6, comment.senderName); |                 statement.setString(6, comment.senderName()); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             @Override |             @Override | ||||||
| @@ -3414,15 +3414,10 @@ public class SQLManager implements AbstractDB { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static class LegacySettings { |     private record LegacySettings( | ||||||
|  |             int id, | ||||||
|         public final int id; |             PlotSettings settings | ||||||
|         public final PlotSettings settings; |     ) { | ||||||
|  |  | ||||||
|         public LegacySettings(int id, PlotSettings settings) { |  | ||||||
|             this.id = id; |  | ||||||
|             this.settings = settings; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -0,0 +1,64 @@ | |||||||
|  | /* | ||||||
|  |  * 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 6.11.1 | ||||||
|  |  */ | ||||||
|  | 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; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,50 @@ | |||||||
|  | /* | ||||||
|  |  * 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; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -38,6 +38,7 @@ import javax.annotation.Nullable; | |||||||
|  |  | ||||||
| @SuppressWarnings("WeakerAccess") | @SuppressWarnings("WeakerAccess") | ||||||
| public abstract class ClassicPlotWorld extends SquarePlotWorld { | public abstract class ClassicPlotWorld extends SquarePlotWorld { | ||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + ClassicPlotWorld.class.getSimpleName()); |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + ClassicPlotWorld.class.getSimpleName()); | ||||||
|  |  | ||||||
|     public int ROAD_HEIGHT = 62; |     public int ROAD_HEIGHT = 62; | ||||||
| @@ -64,6 +65,21 @@ public abstract class ClassicPlotWorld extends SquarePlotWorld { | |||||||
|         super(worldName, id, generator, min, max, worldConfiguration, blockQueue); |         super(worldName, id, generator, min, max, worldConfiguration, blockQueue); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private static BlockBucket createCheckedBlockBucket(String input, BlockBucket def) { | ||||||
|  |         final BlockBucket bucket = new BlockBucket(input); | ||||||
|  |         Pattern pattern = null; | ||||||
|  |         try { | ||||||
|  |             pattern = bucket.toPattern(); | ||||||
|  |         } catch (Exception ignore) { | ||||||
|  |         } | ||||||
|  |         if (pattern == null) { | ||||||
|  |             LOGGER.error("Failed to parse pattern '{}', check your worlds.yml", input); | ||||||
|  |             LOGGER.error("Falling back to {}", def); | ||||||
|  |             return def; | ||||||
|  |         } | ||||||
|  |         return bucket; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * CONFIG NODE | DEFAULT VALUE | DESCRIPTION | CONFIGURATION TYPE | REQUIRED FOR INITIAL SETUP. |      * CONFIG NODE | DEFAULT VALUE | DESCRIPTION | CONFIGURATION TYPE | REQUIRED FOR INITIAL SETUP. | ||||||
|      * |      * | ||||||
| @@ -144,19 +160,4 @@ public abstract class ClassicPlotWorld extends SquarePlotWorld { | |||||||
|         return Math.min(WALL_HEIGHT, plotRoadMin); |         return Math.min(WALL_HEIGHT, plotRoadMin); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static BlockBucket createCheckedBlockBucket(String input, BlockBucket def) { |  | ||||||
|         final BlockBucket bucket = new BlockBucket(input); |  | ||||||
|         Pattern pattern = null; |  | ||||||
|         try { |  | ||||||
|             pattern = bucket.toPattern(); |  | ||||||
|         } catch (Exception ignore) { |  | ||||||
|         } |  | ||||||
|         if (pattern == null) { |  | ||||||
|             LOGGER.error("Failed to parse pattern '{}', check your worlds.yml", input); |  | ||||||
|             LOGGER.error("Falling back to {}", def); |  | ||||||
|             return def; |  | ||||||
|         } |  | ||||||
|         return bucket; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -341,7 +341,10 @@ public class HybridGen extends IndependentPlotGenerator { | |||||||
|                 for (Entity entity : hybridPlotWorld.getPlotSchematicEntities()) { |                 for (Entity entity : hybridPlotWorld.getPlotSchematicEntities()) { | ||||||
|                     if (region.contains(entity.getLocation().toVector().toBlockPoint())) { |                     if (region.contains(entity.getLocation().toVector().toBlockPoint())) { | ||||||
|                         Vector3 pos = (entity.getLocation().toVector() |                         Vector3 pos = (entity.getLocation().toVector() | ||||||
|                                 .subtract(region.getMinimumPoint().withY(hybridPlotWorld.getPlotSchematicMinPoint().getY()).toVector3())) |                                 .subtract(region | ||||||
|  |                                         .getMinimumPoint() | ||||||
|  |                                         .withY(hybridPlotWorld.getPlotSchematicMinPoint().getY()) | ||||||
|  |                                         .toVector3())) | ||||||
|                                 .add(min.getBlockVector3().withY(hybridPlotWorld.SCHEM_Y).toVector3()); |                                 .add(min.getBlockVector3().withY(hybridPlotWorld.SCHEM_Y).toVector3()); | ||||||
|                         result.setEntity(new PopulatingEntity( |                         result.setEntity(new PopulatingEntity( | ||||||
|                                 entity, |                                 entity, | ||||||
| @@ -399,6 +402,12 @@ public class HybridGen extends IndependentPlotGenerator { | |||||||
|         return biome == null ? hybridPlotWorld.getPlotBiome() : biome; |         return biome == null ? hybridPlotWorld.getPlotBiome() : biome; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private enum SchematicFeature { | ||||||
|  |         BIOMES, | ||||||
|  |         ROAD, | ||||||
|  |         POPULATING | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Wrapper to allow a WorldEdit {@link Entity} to effectively have a mutable location as the location in its NBT should be changed |      * Wrapper to allow a WorldEdit {@link Entity} to effectively have a mutable location as the location in its NBT should be changed | ||||||
|      * when set to the world. |      * when set to the world. | ||||||
| @@ -453,10 +462,4 @@ public class HybridGen extends IndependentPlotGenerator { | |||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private enum SchematicFeature { |  | ||||||
|         BIOMES, |  | ||||||
|         ROAD, |  | ||||||
|         POPULATING |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -141,7 +141,11 @@ public class HybridPlotManager extends ClassicPlotManager { | |||||||
|                         (pos1.getX() + pos2.getX()) / 2, |                         (pos1.getX() + pos2.getX()) / 2, | ||||||
|                         (pos1.getZ() + pos2.getZ()) / 2 |                         (pos1.getZ() + pos2.getZ()) / 2 | ||||||
|                 ), biome)) { |                 ), biome)) { | ||||||
|             WorldUtil.setBiome(hybridPlotWorld.getWorldName(), new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3()), biome); |             WorldUtil.setBiome( | ||||||
|  |                     hybridPlotWorld.getWorldName(), | ||||||
|  |                     new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3()), | ||||||
|  |                     biome | ||||||
|  |             ); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -203,8 +207,18 @@ public class HybridPlotManager extends ClassicPlotManager { | |||||||
|         PlotId id2 = PlotId.of(id.getX(), id.getY() + 1); |         PlotId id2 = PlotId.of(id.getX(), id.getY() + 1); | ||||||
|         Location bot = getPlotBottomLocAbs(id2); |         Location bot = getPlotBottomLocAbs(id2); | ||||||
|         Location top = getPlotTopLocAbs(id); |         Location top = getPlotTopLocAbs(id); | ||||||
|         Location pos1 = Location.at(hybridPlotWorld.getWorldName(), bot.getX() - 1, hybridPlotWorld.getMinGenHeight(), top.getZ() + 1); |         Location pos1 = Location.at( | ||||||
|         Location pos2 = Location.at(hybridPlotWorld.getWorldName(), top.getX() + 1, hybridPlotWorld.getMaxGenHeight(), bot.getZ()); |                 hybridPlotWorld.getWorldName(), | ||||||
|  |                 bot.getX() - 1, | ||||||
|  |                 hybridPlotWorld.getMinGenHeight(), | ||||||
|  |                 top.getZ() + 1 | ||||||
|  |         ); | ||||||
|  |         Location pos2 = Location.at( | ||||||
|  |                 hybridPlotWorld.getWorldName(), | ||||||
|  |                 top.getX() + 1, | ||||||
|  |                 hybridPlotWorld.getMaxGenHeight(), | ||||||
|  |                 bot.getZ() | ||||||
|  |         ); | ||||||
|         this.resetBiome(hybridPlotWorld, pos1, pos2); |         this.resetBiome(hybridPlotWorld, pos1, pos2); | ||||||
|         if (!hybridPlotWorld.ROAD_SCHEMATIC_ENABLED) { |         if (!hybridPlotWorld.ROAD_SCHEMATIC_ENABLED) { | ||||||
|             return true; |             return true; | ||||||
| @@ -274,6 +288,13 @@ public class HybridPlotManager extends ClassicPlotManager { | |||||||
|             queue.setCompleteTask(whenDone); |             queue.setCompleteTask(whenDone); | ||||||
|         } |         } | ||||||
|         if (!canRegen) { |         if (!canRegen) { | ||||||
|  |             if (hybridPlotWorld.getMinBuildHeight() < hybridPlotWorld.getMinGenHeight()) { | ||||||
|  |                 queue.setCuboid( | ||||||
|  |                         pos1.withY(hybridPlotWorld.getMinBuildHeight()), | ||||||
|  |                         pos2.withY(hybridPlotWorld.getMinGenHeight()), | ||||||
|  |                         BlockTypes.AIR.getDefaultState() | ||||||
|  |                 ); | ||||||
|  |             } | ||||||
|             queue.setCuboid( |             queue.setCuboid( | ||||||
|                     pos1.withY(hybridPlotWorld.getMinGenHeight()), |                     pos1.withY(hybridPlotWorld.getMinGenHeight()), | ||||||
|                     pos2.withY(hybridPlotWorld.getMinGenHeight()), |                     pos2.withY(hybridPlotWorld.getMinGenHeight()), | ||||||
| @@ -291,6 +312,13 @@ public class HybridPlotManager extends ClassicPlotManager { | |||||||
|                     pos2.withY(hybridPlotWorld.getMaxGenHeight()), |                     pos2.withY(hybridPlotWorld.getMaxGenHeight()), | ||||||
|                     BlockTypes.AIR.getDefaultState() |                     BlockTypes.AIR.getDefaultState() | ||||||
|             ); |             ); | ||||||
|  |             if (hybridPlotWorld.getMaxGenHeight() < hybridPlotWorld.getMaxBuildHeight() - 1) { | ||||||
|  |                 queue.setCuboid( | ||||||
|  |                         pos1.withY(hybridPlotWorld.getMaxGenHeight()), | ||||||
|  |                         pos2.withY(hybridPlotWorld.getMaxBuildHeight() - 1), | ||||||
|  |                         BlockTypes.AIR.getDefaultState() | ||||||
|  |                 ); | ||||||
|  |             } | ||||||
|             queue.setBiomeCuboid(pos1, pos2, biome); |             queue.setBiomeCuboid(pos1, pos2, biome); | ||||||
|         } else { |         } else { | ||||||
|             queue.setRegenRegion(new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3())); |             queue.setRegenRegion(new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3())); | ||||||
|   | |||||||
| @@ -544,14 +544,6 @@ public class HybridPlotWorld extends ClassicPlotWorld { | |||||||
|         return schem1PopulationNeeded || schem2PopulationNeeded || schem3PopulationNeeded; |         return schem1PopulationNeeded || schem2PopulationNeeded || schem3PopulationNeeded; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * @deprecated in favour of {@link HybridPlotWorld#getSchematicRoot()} |  | ||||||
|      */ |  | ||||||
|     @Deprecated(forRemoval = true, since = "6.9.0") |  | ||||||
|     public File getRoot() { |  | ||||||
|         return this.root; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Get the root folder for this world's generation schematics. May be null if schematics not initialised via |      * Get the root folder for this world's generation schematics. May be null if schematics not initialised via | ||||||
|      * {@link HybridPlotWorld#setupSchematics()} |      * {@link HybridPlotWorld#setupSchematics()} | ||||||
|   | |||||||
| @@ -63,7 +63,6 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
| import java.io.File; | import java.io.File; | ||||||
| import java.util.ArrayDeque; | import java.util.ArrayDeque; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Arrays; |  | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
| @@ -380,22 +379,6 @@ public class HybridUtils { | |||||||
|         run.run(); |         run.run(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public int checkModified(QueueCoordinator queue, int x1, int x2, int y1, int y2, int z1, int z2, BlockState[] blocks) { |  | ||||||
|         int count = 0; |  | ||||||
|         for (int y = y1; y <= y2; y++) { |  | ||||||
|             for (int x = x1; x <= x2; x++) { |  | ||||||
|                 for (int z = z1; z <= z2; z++) { |  | ||||||
|                     BlockState block = queue.getBlock(x, y, z); |  | ||||||
|                     boolean same = Arrays.stream(blocks).anyMatch(p -> this.worldUtil.isBlockSame(block, p)); |  | ||||||
|                     if (!same) { |  | ||||||
|                         count++; |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return count; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public final ArrayList<BlockVector2> getChunks(BlockVector2 region) { |     public final ArrayList<BlockVector2> getChunks(BlockVector2 region) { | ||||||
|         ArrayList<BlockVector2> chunks = new ArrayList<>(); |         ArrayList<BlockVector2> chunks = new ArrayList<>(); | ||||||
|         int sx = region.getX() << 5; |         int sx = region.getX() << 5; | ||||||
|   | |||||||
| @@ -57,7 +57,8 @@ public abstract class IndependentPlotGenerator { | |||||||
|      * @param setting PlotArea (settings) |      * @param setting PlotArea (settings) | ||||||
|      * @since TODO |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public void populateChunk(ZeroedDelegateScopedQueueCoordinator result, PlotArea setting) {} |     public void populateChunk(ZeroedDelegateScopedQueueCoordinator result, PlotArea setting) { | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Return a new PlotArea object. |      * Return a new PlotArea object. | ||||||
|   | |||||||
| @@ -185,31 +185,39 @@ public abstract class SquarePlotManager extends GridPlotManager { | |||||||
|                 return null; |                 return null; | ||||||
|             } |             } | ||||||
|             switch (hash) { |             switch (hash) { | ||||||
|                 case 8: |                 case 8 -> { | ||||||
|                     // north |                     // north | ||||||
|                     return plot.isMerged(Direction.NORTH) ? id : null; |                     return plot.isMerged(Direction.NORTH) ? id : null; | ||||||
|                 case 4: |                 } | ||||||
|  |                 case 4 -> { | ||||||
|                     // east |                     // east | ||||||
|                     return plot.isMerged(Direction.EAST) ? id : null; |                     return plot.isMerged(Direction.EAST) ? id : null; | ||||||
|                 case 2: |                 } | ||||||
|  |                 case 2 -> { | ||||||
|                     // south |                     // south | ||||||
|                     return plot.isMerged(Direction.SOUTH) ? id : null; |                     return plot.isMerged(Direction.SOUTH) ? id : null; | ||||||
|                 case 1: |                 } | ||||||
|  |                 case 1 -> { | ||||||
|                     // west |                     // west | ||||||
|                     return plot.isMerged(Direction.WEST) ? id : null; |                     return plot.isMerged(Direction.WEST) ? id : null; | ||||||
|                 case 12: |                 } | ||||||
|  |                 case 12 -> { | ||||||
|                     // northeast |                     // northeast | ||||||
|                     return plot.isMerged(Direction.NORTHEAST) ? id : null; |                     return plot.isMerged(Direction.NORTHEAST) ? id : null; | ||||||
|                 case 6: |                 } | ||||||
|  |                 case 6 -> { | ||||||
|                     // southeast |                     // southeast | ||||||
|                     return plot.isMerged(Direction.SOUTHEAST) ? id : null; |                     return plot.isMerged(Direction.SOUTHEAST) ? id : null; | ||||||
|                 case 3: |                 } | ||||||
|  |                 case 3 -> { | ||||||
|                     // southwest |                     // southwest | ||||||
|                     return plot.isMerged(Direction.SOUTHWEST) ? id : null; |                     return plot.isMerged(Direction.SOUTHWEST) ? id : null; | ||||||
|                 case 9: |                 } | ||||||
|  |                 case 9 -> { | ||||||
|                     // northwest |                     // northwest | ||||||
|                     return plot.isMerged(Direction.NORTHWEST) ? id : null; |                     return plot.isMerged(Direction.NORTHWEST) ? id : null; | ||||||
|                 } |                 } | ||||||
|  |             } | ||||||
|         } catch (Exception ignored) { |         } catch (Exception ignored) { | ||||||
|             LOGGER.error("Invalid plot / road width in settings.yml for world: {}", squarePlotWorld.getWorldName()); |             LOGGER.error("Invalid plot / road width in settings.yml for world: {}", squarePlotWorld.getWorldName()); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -142,7 +142,9 @@ public class PlotListener { | |||||||
|                     Map.Entry<UUID, List<StatusEffect>> entry = iterator.next(); |                     Map.Entry<UUID, List<StatusEffect>> entry = iterator.next(); | ||||||
|                     List<StatusEffect> effects = entry.getValue(); |                     List<StatusEffect> effects = entry.getValue(); | ||||||
|                     effects.removeIf(effect -> currentTime > effect.expiresAt); |                     effects.removeIf(effect -> currentTime > effect.expiresAt); | ||||||
|                     if (effects.isEmpty()) iterator.remove(); |                     if (effects.isEmpty()) { | ||||||
|  |                         iterator.remove(); | ||||||
|  |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, TaskTime.seconds(1L)); |         }, TaskTime.seconds(1L)); | ||||||
| @@ -341,14 +343,14 @@ public class PlotListener { | |||||||
|             } |             } | ||||||
|  |  | ||||||
|             TimedFlag.Timed<Integer> feed = plot.getFlag(FeedFlag.class); |             TimedFlag.Timed<Integer> feed = plot.getFlag(FeedFlag.class); | ||||||
|             if (feed.getInterval() != 0 && feed.getValue() != 0) { |             if (feed.interval() != 0 && feed.value() != 0) { | ||||||
|                 feedRunnable |                 feedRunnable | ||||||
|                         .put(player.getUUID(), new Interval(feed.getInterval(), feed.getValue(), 20)); |                         .put(player.getUUID(), new Interval(feed.interval(), feed.value(), 20)); | ||||||
|             } |             } | ||||||
|             TimedFlag.Timed<Integer> heal = plot.getFlag(HealFlag.class); |             TimedFlag.Timed<Integer> heal = plot.getFlag(HealFlag.class); | ||||||
|             if (heal.getInterval() != 0 && heal.getValue() != 0) { |             if (heal.interval() != 0 && heal.value() != 0) { | ||||||
|                 healRunnable |                 healRunnable | ||||||
|                         .put(player.getUUID(), new Interval(heal.getInterval(), heal.getValue(), 20)); |                         .put(player.getUUID(), new Interval(heal.interval(), heal.value(), 20)); | ||||||
|             } |             } | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| @@ -486,6 +488,7 @@ public class PlotListener { | |||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Marks an effect as a status effect that will be removed on leaving a plot |      * Marks an effect as a status effect that will be removed on leaving a plot | ||||||
|  |      * | ||||||
|      * @param uuid      The uuid of the player the effect belongs to |      * @param uuid      The uuid of the player the effect belongs to | ||||||
|      * @param name      The name of the status effect |      * @param name      The name of the status effect | ||||||
|      * @param expiresAt The time when the effect expires |      * @param expiresAt The time when the effect expires | ||||||
|   | |||||||
| @@ -21,17 +21,11 @@ package com.plotsquared.core.location; | |||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
|  |  | ||||||
| public class ChunkWrapper { | public record ChunkWrapper( | ||||||
|  |         String world, | ||||||
|     public final int x; |         int x, | ||||||
|     public final int z; |         int z | ||||||
|     public final String world; | ) { | ||||||
|  |  | ||||||
|     public ChunkWrapper(String world, int x, int z) { |  | ||||||
|         this.world = world; |  | ||||||
|         this.x = x; |  | ||||||
|         this.z = z; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public int hashCode() { |     public int hashCode() { | ||||||
|   | |||||||
| @@ -51,7 +51,6 @@ public final class UncheckedWorldLocation extends Location { | |||||||
|      * @param y     Y coordinate |      * @param y     Y coordinate | ||||||
|      * @param z     Z coordinate |      * @param z     Z coordinate | ||||||
|      * @return New location |      * @return New location | ||||||
|      * |  | ||||||
|      * @since 6.9.0 |      * @since 6.9.0 | ||||||
|      */ |      */ | ||||||
|     @DoNotUse |     @DoNotUse | ||||||
|   | |||||||
| @@ -215,17 +215,11 @@ public final class BlockBucket implements ConfigurationSerializable { | |||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static final class Range { |     private record Range( | ||||||
|  |             int min, | ||||||
|         private final int min; |             int max, | ||||||
|         private final int max; |             boolean automatic | ||||||
|         private final boolean automatic; |     ) { | ||||||
|  |  | ||||||
|         public Range(int min, int max, boolean automatic) { |  | ||||||
|             this.min = min; |  | ||||||
|             this.max = max; |  | ||||||
|             this.automatic = automatic; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public int getWeight() { |         public int getWeight() { | ||||||
|             return max - min; |             return max - min; | ||||||
| @@ -235,46 +229,6 @@ public final class BlockBucket implements ConfigurationSerializable { | |||||||
|             return num <= max && num >= min; |             return num <= max && num >= min; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         public int getMin() { |  | ||||||
|             return this.min; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public int getMax() { |  | ||||||
|             return this.max; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public boolean equals(final Object o) { |  | ||||||
|             if (o == this) { |  | ||||||
|                 return true; |  | ||||||
|             } |  | ||||||
|             if (!(o instanceof final Range other)) { |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|             if (this.getMin() != other.getMin()) { |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|             if (this.getMax() != other.getMax()) { |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|             if (this.isAutomatic() != other.isAutomatic()) { |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|             return true; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public int hashCode() { |  | ||||||
|             final int PRIME = 59; |  | ||||||
|             int result = 1; |  | ||||||
|             result = result * PRIME + this.getMin(); |  | ||||||
|             result = result * PRIME + this.getMax(); |  | ||||||
|             result = result * PRIME + (this.isAutomatic() ? 79 : 97); |  | ||||||
|             return result; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public boolean isAutomatic() { |  | ||||||
|             return this.automatic; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -658,8 +658,10 @@ public abstract class PlotArea implements ComponentLike { | |||||||
|                     TranslatableCaption.of("height.height_limit"), |                     TranslatableCaption.of("height.height_limit"), | ||||||
|                     TagResolver.builder() |                     TagResolver.builder() | ||||||
|                             .tag("minHeight", Tag.inserting(Component.text(minBuildHeight))) |                             .tag("minHeight", Tag.inserting(Component.text(minBuildHeight))) | ||||||
|                             .tag("maxHeight", |                             .tag( | ||||||
|                             Tag.inserting(Component.text(maxBuildHeight))).build() |                                     "maxHeight", | ||||||
|  |                                     Tag.inserting(Component.text(maxBuildHeight)) | ||||||
|  |                             ).build() | ||||||
|             ); |             ); | ||||||
|             // Return true if "failed" as the method will always be inverted otherwise |             // Return true if "failed" as the method will always be inverted otherwise | ||||||
|             return true; |             return true; | ||||||
|   | |||||||
| @@ -222,17 +222,6 @@ public final class PlotModificationManager { | |||||||
|         if (isDelete) { |         if (isDelete) { | ||||||
|             this.removeSign(); |             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(); |         final PlotManager manager = this.plot.getArea().getPlotManager(); | ||||||
|         Runnable run = new Runnable() { |         Runnable run = new Runnable() { | ||||||
|             @Override |             @Override | ||||||
| @@ -283,7 +272,21 @@ public final class PlotModificationManager { | |||||||
|                 manager.clearPlot(current, this, actor, null); |                 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; |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -323,7 +326,23 @@ public final class PlotModificationManager { | |||||||
|      * @return success/!cancelled |      * @return success/!cancelled | ||||||
|      */ |      */ | ||||||
|     public boolean unlinkPlot(final boolean createRoad, final boolean createSign) { |     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 (!this.plot.isMerged()) { | ||||||
|  |             if (whenDone != null) { | ||||||
|  |                 whenDone.run(); | ||||||
|  |             } | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         final Set<Plot> plots = this.plot.getConnectedPlots(); |         final Set<Plot> plots = this.plot.getConnectedPlots(); | ||||||
| @@ -368,14 +387,17 @@ public final class PlotModificationManager { | |||||||
|                     current.getPlotModificationManager().setSign(PlayerManager.resolveName(current.getOwnerAbs()).getComponent( |                     current.getPlotModificationManager().setSign(PlayerManager.resolveName(current.getOwnerAbs()).getComponent( | ||||||
|                             LocaleHolder.console())); |                             LocaleHolder.console())); | ||||||
|                 } |                 } | ||||||
|  |                 if (whenDone != null) { | ||||||
|  |                     TaskManager.runTask(whenDone); | ||||||
|  |                 } | ||||||
|             })); |             })); | ||||||
|  |         } else if (whenDone != null) { | ||||||
|  |             queue.setCompleteTask(whenDone); | ||||||
|         } |         } | ||||||
|         if (createRoad) { |         if (createRoad) { | ||||||
|             manager.finishPlotUnlink(ids, queue); |             manager.finishPlotUnlink(ids, queue); | ||||||
|         } |         } | ||||||
|         if (queue != null) { |  | ||||||
|         queue.enqueue(); |         queue.enqueue(); | ||||||
|         } |  | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -79,14 +79,6 @@ public class PlotSettings { | |||||||
|         this.ratings = ratings; |         this.ratings = ratings; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public boolean setMerged(int direction, boolean merged) { |  | ||||||
|         if (this.merged[direction] != merged) { |  | ||||||
|             this.merged[direction] = merged; |  | ||||||
|             return true; |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public boolean setMerged(Direction direction, boolean merged) { |     public boolean setMerged(Direction direction, boolean merged) { | ||||||
|         if (Direction.ALL == direction) { |         if (Direction.ALL == direction) { | ||||||
|             throw new IllegalArgumentException("You cannot use Direction.ALL in this method!"); |             throw new IllegalArgumentException("You cannot use Direction.ALL in this method!"); | ||||||
| @@ -113,13 +105,12 @@ public class PlotSettings { | |||||||
|         this.position = position; |         this.position = position; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @SuppressWarnings({"UnstableApiUsage"}) |  | ||||||
|     public List<PlotComment> getComments(String inbox) { |     public List<PlotComment> getComments(String inbox) { | ||||||
|         if (this.comments == null) { |         if (this.comments == null) { | ||||||
|             return Collections.emptyList(); |             return Collections.emptyList(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         return this.comments.stream().filter(comment -> comment.inbox.equals(inbox)) |         return this.comments.stream().filter(comment -> comment.inbox().equals(inbox)) | ||||||
|                 .collect(ImmutableList.toImmutableList()); |                 .collect(ImmutableList.toImmutableList()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -58,7 +58,7 @@ public class CommentManager { | |||||||
|                         if (value != null) { |                         if (value != null) { | ||||||
|                             int num = 0; |                             int num = 0; | ||||||
|                             for (PlotComment comment : value) { |                             for (PlotComment comment : value) { | ||||||
|                                 if (comment.timestamp > getTimestamp(player, inbox.toString())) { |                                 if (comment.timestamp() > getTimestamp(player, inbox.toString())) { | ||||||
|                                     num++; |                                     num++; | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
|   | |||||||
| @@ -20,25 +20,13 @@ package com.plotsquared.core.plot.comment; | |||||||
|  |  | ||||||
| import com.plotsquared.core.plot.PlotId; | import com.plotsquared.core.plot.PlotId; | ||||||
|  |  | ||||||
| public class PlotComment { | public record PlotComment( | ||||||
|  |         String world, | ||||||
|     public final String comment; |         PlotId id, | ||||||
|     public final String inbox; |         String comment, | ||||||
|     public final String senderName; |         String senderName, | ||||||
|     public final PlotId id; |         String inbox, | ||||||
|     public final String world; |  | ||||||
|     public final long timestamp; |  | ||||||
|  |  | ||||||
|     public PlotComment( |  | ||||||
|             String world, PlotId id, String comment, String senderName, String inbox, |  | ||||||
|         long timestamp |         long timestamp | ||||||
|     ) { | ) { | ||||||
|         this.world = world; |  | ||||||
|         this.id = id; |  | ||||||
|         this.comment = comment; |  | ||||||
|         this.senderName = senderName; |  | ||||||
|         this.inbox = inbox; |  | ||||||
|         this.timestamp = timestamp; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -154,6 +154,7 @@ public class ExpiryTask { | |||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Returns {@code true} if this task respects unknown owners |      * Returns {@code true} if this task respects unknown owners | ||||||
|  |      * | ||||||
|      * @return {@code true} if unknown owners should be counted as never online |      * @return {@code true} if unknown owners should be counted as never online | ||||||
|      * @since 6.4.0 |      * @since 6.4.0 | ||||||
|      */ |      */ | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ public class BeaconEffectsFlag extends BooleanFlag<BeaconEffectsFlag> { | |||||||
|     public static final BeaconEffectsFlag BEACON_EFFECT_TRUE = new BeaconEffectsFlag(true); |     public static final BeaconEffectsFlag BEACON_EFFECT_TRUE = new BeaconEffectsFlag(true); | ||||||
|     public static final BeaconEffectsFlag BEACON_EFFECT_FALSE = new BeaconEffectsFlag(false); |     public static final BeaconEffectsFlag BEACON_EFFECT_FALSE = new BeaconEffectsFlag(false); | ||||||
|  |  | ||||||
|     private BeaconEffectsFlag(boolean value){ |     private BeaconEffectsFlag(boolean value) { | ||||||
|         super(value, TranslatableCaption.of("flags.flag_description_beacon_effect")); |         super(value, TranslatableCaption.of("flags.flag_description_beacon_effect")); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -57,25 +57,16 @@ public class DenyTeleportFlag extends PlotFlag<DenyTeleportFlag.DeniedGroup, Den | |||||||
|         } |         } | ||||||
|         final boolean result; |         final boolean result; | ||||||
|         switch (value) { |         switch (value) { | ||||||
|             case TRUSTED: |             case TRUSTED -> result = !plot.getTrusted().contains(player.getUUID()); | ||||||
|                 result = !plot.getTrusted().contains(player.getUUID()); |             case MEMBERS -> result = !plot.getMembers().contains(player.getUUID()); | ||||||
|                 break; |             case NONMEMBERS -> result = plot.isAdded(player.getUUID()); | ||||||
|             case MEMBERS: |             case NONTRUSTED -> result = | ||||||
|                 result = !plot.getMembers().contains(player.getUUID()); |  | ||||||
|                 break; |  | ||||||
|             case NONMEMBERS: |  | ||||||
|                 result = plot.isAdded(player.getUUID()); |  | ||||||
|                 break; |  | ||||||
|             case NONTRUSTED: |  | ||||||
|                 result = |  | ||||||
|                     plot.getTrusted().contains(player.getUUID()) || plot.isOwner(player.getUUID()); |                     plot.getTrusted().contains(player.getUUID()) || plot.isOwner(player.getUUID()); | ||||||
|                 break; |             case NONOWNERS -> result = plot.isOwner(player.getUUID()); | ||||||
|             case NONOWNERS: |             default -> { | ||||||
|                 result = plot.isOwner(player.getUUID()); |  | ||||||
|                 break; |  | ||||||
|             default: |  | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|  |         } | ||||||
|         return result || player.hasPermission("plots.admin.entry.denied"); |         return result || player.hasPermission("plots.admin.entry.denied"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -60,7 +60,7 @@ public class FeedFlag extends TimedFlag<Integer, FeedFlag> { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     protected Integer mergeValue(Integer other) { |     protected Integer mergeValue(Integer other) { | ||||||
|         return this.getValue().getValue() + other; |         return this.getValue().value() + other; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -68,14 +68,11 @@ public class FlyFlag extends PlotFlag<FlyFlag.FlyStatus, FlyFlag> { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     protected FlyFlag flagOf(final @NonNull FlyStatus value) { |     protected FlyFlag flagOf(final @NonNull FlyStatus value) { | ||||||
|         switch (value) { |         return switch (value) { | ||||||
|             case ENABLED: |             case ENABLED -> FLIGHT_FLAG_ENABLED; | ||||||
|                 return FLIGHT_FLAG_ENABLED; |             case DISABLED -> FLIGHT_FLAG_DISABLED; | ||||||
|             case DISABLED: |             default -> FLIGHT_FLAG_DEFAULT; | ||||||
|                 return FLIGHT_FLAG_DISABLED; |         }; | ||||||
|             default: |  | ||||||
|                 return FLIGHT_FLAG_DEFAULT; |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -60,7 +60,7 @@ public class HealFlag extends TimedFlag<Integer, HealFlag> { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     protected Integer mergeValue(Integer other) { |     protected Integer mergeValue(Integer other) { | ||||||
|         return this.getValue().getValue() + other; |         return this.getValue().value() + other; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ public class ProjectilesFlag extends BooleanFlag<ProjectilesFlag> { | |||||||
|     public static final ProjectilesFlag PROJECTILES_TRUE = new ProjectilesFlag(true); |     public static final ProjectilesFlag PROJECTILES_TRUE = new ProjectilesFlag(true); | ||||||
|     public static final ProjectilesFlag PROJECTILES_FALSE = new ProjectilesFlag(false); |     public static final ProjectilesFlag PROJECTILES_FALSE = new ProjectilesFlag(false); | ||||||
|  |  | ||||||
|     private ProjectilesFlag(boolean value){ |     private ProjectilesFlag(boolean value) { | ||||||
|         super(value, TranslatableCaption.of("flags.flag_description_projectiles")); |         super(value, TranslatableCaption.of("flags.flag_description_projectiles")); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -76,23 +76,10 @@ public abstract class TimedFlag<T, F extends PlotFlag<TimedFlag.Timed<T>, F>> | |||||||
|         return getValue().toString(); |         return getValue().toString(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static final class Timed<T> { |     public record Timed<T>( | ||||||
|  |             int interval, | ||||||
|         private final int interval; |             T value | ||||||
|         private final T value; |     ) { | ||||||
|  |  | ||||||
|         public Timed(int interval, T value) { |  | ||||||
|             this.interval = interval; |  | ||||||
|             this.value = value; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public int getInterval() { |  | ||||||
|             return interval; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public T getValue() { |  | ||||||
|             return value; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
|         public String toString() { |         public String toString() { | ||||||
|   | |||||||
| @@ -76,6 +76,7 @@ public class SinglePlotArea extends GridPlotWorld { | |||||||
|      * Returns true if the given string matches the naming system used to identify single plot worlds |      * Returns true if the given string matches the naming system used to identify single plot worlds | ||||||
|      * e.g. -1_5 represents plot id *;-1;5. "*" being the plot area name given to single plot world |      * e.g. -1_5 represents plot id *;-1;5. "*" being the plot area name given to single plot world | ||||||
|      * {@link com.plotsquared.core.plot.PlotArea}. |      * {@link com.plotsquared.core.plot.PlotArea}. | ||||||
|  |      * | ||||||
|      * @since 6.1.4 |      * @since 6.1.4 | ||||||
|      */ |      */ | ||||||
|     public static boolean isSinglePlotWorld(String worldName) { |     public static boolean isSinglePlotWorld(String worldName) { | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
|  * The min and max points of this queue are offset according to the minimum point given in the constructor, and the offsets set |  * The min and max points of this queue are offset according to the minimum point given in the constructor, and the offsets set | ||||||
|  * in {@link BlockArrayCacheScopedQueueCoordinator#setOffsetX(int)} and |  * in {@link BlockArrayCacheScopedQueueCoordinator#setOffsetX(int)} and | ||||||
|  * {@link BlockArrayCacheScopedQueueCoordinator#setOffsetZ(int)} |  * {@link BlockArrayCacheScopedQueueCoordinator#setOffsetZ(int)} | ||||||
|  * |  * <p> | ||||||
|  * Internal use only. Subject to change at any time and created for specific use cases. |  * Internal use only. Subject to change at any time and created for specific use cases. | ||||||
|  */ |  */ | ||||||
| @NotPublic | @NotPublic | ||||||
| @@ -54,6 +54,7 @@ public class BlockArrayCacheScopedQueueCoordinator extends ZeroedDelegateScopedQ | |||||||
|     private final int scopeMaxZ; |     private final int scopeMaxZ; | ||||||
|     private int offsetX = 0; |     private int offsetX = 0; | ||||||
|     private int offsetZ = 0; |     private int offsetZ = 0; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Construct a new instance |      * Construct a new instance | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -29,6 +29,7 @@ public abstract class ChunkCoordinator implements Runnable { | |||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Cancel the chunk coordinator. |      * Cancel the chunk coordinator. | ||||||
|  |      * | ||||||
|      * @since 6.0.10 |      * @since 6.0.10 | ||||||
|      */ |      */ | ||||||
|     public abstract void cancel(); |     public abstract void cancel(); | ||||||
|   | |||||||
| @@ -43,11 +43,10 @@ import java.util.function.Consumer; | |||||||
|  |  | ||||||
| public abstract class QueueCoordinator { | public abstract class QueueCoordinator { | ||||||
|  |  | ||||||
|  |     private final AtomicBoolean enqueued = new AtomicBoolean(); | ||||||
|     private boolean forceSync = false; |     private boolean forceSync = false; | ||||||
|     @Nullable |     @Nullable | ||||||
|     private Object chunkObject; |     private Object chunkObject; | ||||||
|     private final AtomicBoolean enqueued = new AtomicBoolean(); |  | ||||||
|  |  | ||||||
|     @SuppressWarnings({"unused", "FieldCanBeLocal"}) |     @SuppressWarnings({"unused", "FieldCanBeLocal"}) | ||||||
|     @Inject |     @Inject | ||||||
|     private GlobalBlockQueue blockQueue; |     private GlobalBlockQueue blockQueue; | ||||||
| @@ -203,7 +202,7 @@ public abstract class QueueCoordinator { | |||||||
|      * @return success or not |      * @return success or not | ||||||
|      * @deprecated Biomes now take XYZ, see {@link #setBiome(int, int, int, BiomeType)} |      * @deprecated Biomes now take XYZ, see {@link #setBiome(int, int, int, BiomeType)} | ||||||
|      *         <br> |      *         <br> | ||||||
|      *         Scheduled for removal once we drop the support for versions not supporting 3D biomes. |      *         Scheduled for removal once we drop the support for versions not supporting 3D biomes, 1.18 and earlier. | ||||||
|      */ |      */ | ||||||
|     @Deprecated(forRemoval = true, since = "6.0.0") |     @Deprecated(forRemoval = true, since = "6.0.0") | ||||||
|     public abstract boolean setBiome(int x, int z, @NonNull BiomeType biome); |     public abstract boolean setBiome(int x, int z, @NonNull BiomeType biome); | ||||||
|   | |||||||
| @@ -36,6 +36,7 @@ import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | |||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import javax.annotation.Nullable; | import javax.annotation.Nullable; | ||||||
|  | import java.util.Objects; | ||||||
| import java.util.concurrent.atomic.AtomicBoolean; | import java.util.concurrent.atomic.AtomicBoolean; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -92,11 +93,7 @@ public class DefaultProgressSubscriber implements ProgressSubscriber { | |||||||
|         this.actor = actor; |         this.actor = actor; | ||||||
|         this.interval = TaskTime.ms(interval); |         this.interval = TaskTime.ms(interval); | ||||||
|         this.wait = TaskTime.ms(wait); |         this.wait = TaskTime.ms(wait); | ||||||
|         if (caption == null) { |         this.caption = Objects.requireNonNullElseGet(caption, () -> TranslatableCaption.of("working.progress")); | ||||||
|             this.caption = TranslatableCaption.of("working.progress"); |  | ||||||
|         } else { |  | ||||||
|             this.caption = caption; |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -0,0 +1,94 @@ | |||||||
|  | /* | ||||||
|  |  * 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.services.plots; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.player.PlotPlayer; | ||||||
|  | import com.plotsquared.core.plot.PlotArea; | ||||||
|  | import com.plotsquared.core.plot.PlotId; | ||||||
|  | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Crate a new auto query | ||||||
|  |  * | ||||||
|  |  * @param player   Player to claim for | ||||||
|  |  * @param startId  Plot ID to start searching from | ||||||
|  |  * @param sizeX    Number of plots along the X axis | ||||||
|  |  * @param sizeZ    Number of plots along the Z axis | ||||||
|  |  * @param plotArea Plot area to search in | ||||||
|  |  */ | ||||||
|  | public record AutoQuery( | ||||||
|  |         @NonNull PlotPlayer<?> player, | ||||||
|  |         @Nullable PlotId startId, | ||||||
|  |         int sizeX, | ||||||
|  |         int sizeZ, | ||||||
|  |         @NonNull PlotArea plotArea | ||||||
|  | ) { | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the player that the plots are meant for | ||||||
|  |      * | ||||||
|  |      * @return Player | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public @NonNull PlotPlayer<?> player() { | ||||||
|  |         return this.player; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the plot ID to start searching from | ||||||
|  |      * | ||||||
|  |      * @return Start ID | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public @Nullable PlotId startId() { | ||||||
|  |         return this.startId; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the number of plots along the X axis | ||||||
|  |      * | ||||||
|  |      * @return Number of plots along the X axis | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public int sizeX() { | ||||||
|  |         return this.sizeX; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the number of plots along the Z axis | ||||||
|  |      * | ||||||
|  |      * @return Number of plots along the Z axis | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public int sizeZ() { | ||||||
|  |         return this.sizeZ; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the plot area to search in | ||||||
|  |      * | ||||||
|  |      * @return Plot area | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public @NonNull PlotArea plotArea() { | ||||||
|  |         return this.plotArea; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -21,9 +21,7 @@ package com.plotsquared.core.services.plots; | |||||||
| import cloud.commandframework.services.types.Service; | import cloud.commandframework.services.types.Service; | ||||||
| import com.google.common.cache.Cache; | import com.google.common.cache.Cache; | ||||||
| import com.google.common.cache.CacheBuilder; | import com.google.common.cache.CacheBuilder; | ||||||
| import com.plotsquared.core.player.PlotPlayer; |  | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; |  | ||||||
| import com.plotsquared.core.plot.PlotAreaType; | import com.plotsquared.core.plot.PlotAreaType; | ||||||
| import com.plotsquared.core.plot.PlotId; | import com.plotsquared.core.plot.PlotId; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| @@ -34,88 +32,12 @@ import java.util.List; | |||||||
| import java.util.concurrent.TimeUnit; | import java.util.concurrent.TimeUnit; | ||||||
| import java.util.function.Predicate; | import java.util.function.Predicate; | ||||||
|  |  | ||||||
| public interface AutoService extends Service<AutoService.AutoQuery, List<Plot>> { | public interface AutoService extends Service<AutoQuery, List<Plot>> { | ||||||
|  |  | ||||||
|     Cache<PlotId, Plot> plotCandidateCache = CacheBuilder.newBuilder() |     Cache<PlotId, Plot> plotCandidateCache = CacheBuilder.newBuilder() | ||||||
|             .expireAfterWrite(20, TimeUnit.SECONDS).build(); |             .expireAfterWrite(20, TimeUnit.SECONDS).build(); | ||||||
|     Object plotLock = new Object(); |     Object plotLock = new Object(); | ||||||
|  |  | ||||||
|     final class AutoQuery { |  | ||||||
|  |  | ||||||
|         private final PlotPlayer<?> player; |  | ||||||
|         private final PlotId startId; |  | ||||||
|         private final int sizeX; |  | ||||||
|         private final int sizeZ; |  | ||||||
|         private final PlotArea plotArea; |  | ||||||
|  |  | ||||||
|         /** |  | ||||||
|          * Crate a new auto query |  | ||||||
|          * |  | ||||||
|          * @param player   Player to claim for |  | ||||||
|          * @param startId  Plot ID to start searching from |  | ||||||
|          * @param sizeX    Number of plots along the X axis |  | ||||||
|          * @param sizeZ    Number of plots along the Z axis |  | ||||||
|          * @param plotArea Plot area to search in |  | ||||||
|          */ |  | ||||||
|         public AutoQuery( |  | ||||||
|                 final @NonNull PlotPlayer<?> player, final @Nullable PlotId startId, |  | ||||||
|                 final int sizeX, final int sizeZ, final @NonNull PlotArea plotArea |  | ||||||
|         ) { |  | ||||||
|             this.player = player; |  | ||||||
|             this.startId = startId; |  | ||||||
|             this.sizeX = sizeX; |  | ||||||
|             this.sizeZ = sizeZ; |  | ||||||
|             this.plotArea = plotArea; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         /** |  | ||||||
|          * Get the player that the plots are meant for |  | ||||||
|          * |  | ||||||
|          * @return Player |  | ||||||
|          */ |  | ||||||
|         public @NonNull PlotPlayer<?> getPlayer() { |  | ||||||
|             return this.player; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         /** |  | ||||||
|          * Get the plot ID to start searching from |  | ||||||
|          * |  | ||||||
|          * @return Start ID |  | ||||||
|          */ |  | ||||||
|         public @Nullable PlotId getStartId() { |  | ||||||
|             return this.startId; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         /** |  | ||||||
|          * Get the number of plots along the X axis |  | ||||||
|          * |  | ||||||
|          * @return Number of plots along the X axis |  | ||||||
|          */ |  | ||||||
|         public int getSizeX() { |  | ||||||
|             return this.sizeX; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         /** |  | ||||||
|          * Get the number of plots along the Z axis |  | ||||||
|          * |  | ||||||
|          * @return Number of plots along the Z axis |  | ||||||
|          */ |  | ||||||
|         public int getSizeZ() { |  | ||||||
|             return this.sizeZ; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         /** |  | ||||||
|          * Get the plot area to search in |  | ||||||
|          * |  | ||||||
|          * @return Plot area |  | ||||||
|          */ |  | ||||||
|         public @NonNull PlotArea getPlotArea() { |  | ||||||
|             return this.plotArea; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     final class DefaultAutoService implements AutoService { |     final class DefaultAutoService implements AutoService { | ||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
| @@ -125,17 +47,16 @@ public interface AutoService extends Service<AutoService.AutoQuery, List<Plot>> | |||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     final class SinglePlotService implements AutoService, Predicate<AutoQuery> { |     final class SinglePlotService implements AutoService, Predicate<AutoQuery> { | ||||||
|  |  | ||||||
|         @Nullable |         @Nullable | ||||||
|         @Override |         @Override | ||||||
|         public List<Plot> handle(@NonNull AutoQuery autoQuery) { |         public List<Plot> handle(@NonNull AutoQuery autoQuery) { | ||||||
|             Plot plot; |             Plot plot; | ||||||
|             PlotId nextId = autoQuery.getStartId(); |             PlotId nextId = autoQuery.startId(); | ||||||
|             do { |             do { | ||||||
|                 synchronized (plotLock) { |                 synchronized (plotLock) { | ||||||
|                     plot = autoQuery.getPlotArea().getNextFreePlot(autoQuery.getPlayer(), nextId); |                     plot = autoQuery.plotArea().getNextFreePlot(autoQuery.player(), nextId); | ||||||
|                     if (plot != null && plotCandidateCache.getIfPresent(plot.getId()) == null) { |                     if (plot != null && plotCandidateCache.getIfPresent(plot.getId()) == null) { | ||||||
|                         plotCandidateCache.put(plot.getId(), plot); |                         plotCandidateCache.put(plot.getId(), plot); | ||||||
|                         return Collections.singletonList(plot); |                         return Collections.singletonList(plot); | ||||||
| @@ -151,12 +72,11 @@ public interface AutoService extends Service<AutoService.AutoQuery, List<Plot>> | |||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
|         public boolean test(final @NonNull AutoQuery autoQuery) { |         public boolean test(final @NonNull AutoQuery autoQuery) { | ||||||
|             return autoQuery.sizeX == 1 && autoQuery.sizeZ == 1; |             return autoQuery.sizeX() == 1 && autoQuery.sizeZ() == 1; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     final class MultiPlotService implements AutoService, Predicate<AutoQuery> { |     final class MultiPlotService implements AutoService, Predicate<AutoQuery> { | ||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
| @@ -166,14 +86,14 @@ public interface AutoService extends Service<AutoService.AutoQuery, List<Plot>> | |||||||
|             while (true) { |             while (true) { | ||||||
|                 synchronized (plotLock) { |                 synchronized (plotLock) { | ||||||
|                     final PlotId start = |                     final PlotId start = | ||||||
|                             autoQuery.getPlotArea().getMeta("lastPlot", PlotId.of(0, 0)).getNextId(); |                             autoQuery.plotArea().getMeta("lastPlot", PlotId.of(0, 0)).getNextId(); | ||||||
|                     final PlotId end = PlotId.of( |                     final PlotId end = PlotId.of( | ||||||
|                             start.getX() + autoQuery.getSizeX() - 1, |                             start.getX() + autoQuery.sizeX() - 1, | ||||||
|                             start.getY() + autoQuery.getSizeZ() - 1 |                             start.getY() + autoQuery.sizeZ() - 1 | ||||||
|                     ); |                     ); | ||||||
|                     final List<Plot> plots = |                     final List<Plot> plots = | ||||||
|                             autoQuery.getPlotArea().canClaim(autoQuery.getPlayer(), start, end); |                             autoQuery.plotArea().canClaim(autoQuery.player(), start, end); | ||||||
|                     autoQuery.getPlotArea().setMeta("lastPlot", start); // set entry point for next try |                     autoQuery.plotArea().setMeta("lastPlot", start); // set entry point for next try | ||||||
|                     if (plots != null && !plots.isEmpty()) { |                     if (plots != null && !plots.isEmpty()) { | ||||||
|                         for (final Plot plot : plots) { |                         for (final Plot plot : plots) { | ||||||
|                             if (plotCandidateCache.getIfPresent(plot.getId()) != null) { |                             if (plotCandidateCache.getIfPresent(plot.getId()) != null) { | ||||||
| @@ -189,7 +109,7 @@ public interface AutoService extends Service<AutoService.AutoQuery, List<Plot>> | |||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
|         public boolean test(final @NonNull AutoQuery autoQuery) { |         public boolean test(final @NonNull AutoQuery autoQuery) { | ||||||
|             return autoQuery.getPlotArea().getType() != PlotAreaType.PARTIAL; |             return autoQuery.plotArea().getType() != PlotAreaType.PARTIAL; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -48,10 +48,10 @@ public class SettingsNodeStep implements SetupStep { | |||||||
|     ) { |     ) { | ||||||
|         this.configurationNode = configurationNode; |         this.configurationNode = configurationNode; | ||||||
|         this.id = id; |         this.id = id; | ||||||
|         if (wrapper.getSettingsNodes().length > id + 1) { |         if (wrapper.settingsNodes().length > id + 1) { | ||||||
|             this.next = new SettingsNodeStep(wrapper.getSettingsNodes()[id + 1], id + 1, wrapper); |             this.next = new SettingsNodeStep(wrapper.settingsNodes()[id + 1], id + 1, wrapper); | ||||||
|         } else { |         } else { | ||||||
|             this.next = wrapper.getAfterwards(); |             this.next = wrapper.afterwards(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -23,15 +23,10 @@ import com.plotsquared.core.configuration.ConfigurationNode; | |||||||
| /** | /** | ||||||
|  * This class wraps an array of {@link ConfigurationNode}s. |  * This class wraps an array of {@link ConfigurationNode}s. | ||||||
|  */ |  */ | ||||||
| public class SettingsNodesWrapper { | public record SettingsNodesWrapper( | ||||||
|  |         ConfigurationNode[] settingsNodes, | ||||||
|     private final ConfigurationNode[] settingsNodes; |         SetupStep afterwards | ||||||
|     private final SetupStep afterwards; | ) { | ||||||
|  |  | ||||||
|     public SettingsNodesWrapper(final ConfigurationNode[] settingsNodes, final SetupStep afterwards) { |  | ||||||
|         this.settingsNodes = settingsNodes; |  | ||||||
|         this.afterwards = afterwards; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Returns the first step of this wrapper or the step or the |      * Returns the first step of this wrapper or the step or the | ||||||
| @@ -43,12 +38,4 @@ public class SettingsNodesWrapper { | |||||||
|         return this.settingsNodes.length == 0 ? this.afterwards : new SettingsNodeStep(this.settingsNodes[0], 0, this); |         return this.settingsNodes.length == 0 ? this.afterwards : new SettingsNodeStep(this.settingsNodes[0], 0, this); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public ConfigurationNode[] getSettingsNodes() { |  | ||||||
|         return this.settingsNodes; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public SetupStep getAfterwards() { |  | ||||||
|         return this.afterwards; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -31,8 +31,6 @@ import com.sk89q.worldedit.world.registry.LegacyMapper; | |||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| import java.util.Map; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * {@link BlockState} related utility methods |  * {@link BlockState} related utility methods | ||||||
|  */ |  */ | ||||||
| @@ -109,34 +107,4 @@ public final class BlockUtil { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Parse a comma delimited list of block states |  | ||||||
|      * |  | ||||||
|      * @param commaDelimited List of block states |  | ||||||
|      * @return Parsed block states |  | ||||||
|      */ |  | ||||||
|     public static @NonNull BlockState[] parse(final @NonNull String commaDelimited) { |  | ||||||
|         final String[] split = commaDelimited.split(",(?![^\\(\\[]*[\\]\\)])"); |  | ||||||
|         final BlockState[] result = new BlockState[split.length]; |  | ||||||
|         for (int i = 0; i < split.length; i++) { |  | ||||||
|             result[i] = get(split[i]); |  | ||||||
|         } |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Deserialize a serialized {@link BlockState} |  | ||||||
|      * |  | ||||||
|      * @param map Serialized block state |  | ||||||
|      * @return Deserialized block state, or {@code null} if the map is |  | ||||||
|      *         not a properly serialized block state |  | ||||||
|      */ |  | ||||||
|     public static @Nullable BlockState deserialize(final @NonNull Map<String, Object> map) { |  | ||||||
|         if (map.containsKey("material")) { |  | ||||||
|             final Object object = map.get("material"); |  | ||||||
|             return get(object.toString()); |  | ||||||
|         } |  | ||||||
|         return null; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -18,10 +18,6 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.core.util; | package com.plotsquared.core.util; | ||||||
|  |  | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.sk89q.worldedit.math.BlockVector2; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * This cache is used for world generation and just saves a bit of calculation time when checking if something is in the plot area. |  * This cache is used for world generation and just saves a bit of calculation time when checking if something is in the plot area. | ||||||
|  */ |  */ | ||||||
| @@ -107,22 +103,4 @@ public class ChunkUtil { | |||||||
|         return z_loc[j]; |         return z_loc[j]; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Returns true if the region pos1-pos2 contains the chunk |  | ||||||
|      * |  | ||||||
|      * @param pos1  Region minimum point |  | ||||||
|      * @param pos2  Region maximum point |  | ||||||
|      * @param chunk BlockVector2 of chunk coordinates |  | ||||||
|      * @return {@code true} if the region pos1-pos2 contains the chunk |  | ||||||
|      */ |  | ||||||
|     public static boolean isWholeChunk(@NonNull Location pos1, @NonNull Location pos2, @NonNull BlockVector2 chunk) { |  | ||||||
|         int x1 = pos1.getX(); |  | ||||||
|         int z1 = pos1.getZ(); |  | ||||||
|         int x2 = pos2.getX(); |  | ||||||
|         int z2 = pos2.getZ(); |  | ||||||
|         int cx = chunk.getX() << 4; |  | ||||||
|         int cz = chunk.getZ() << 4; |  | ||||||
|         return cx > x1 && cz > z1 && cx < x2 && cz < z2; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -45,6 +45,7 @@ import com.plotsquared.core.events.PlotFlagRemoveEvent; | |||||||
| import com.plotsquared.core.events.PlotMergeEvent; | import com.plotsquared.core.events.PlotMergeEvent; | ||||||
| import com.plotsquared.core.events.PlotRateEvent; | import com.plotsquared.core.events.PlotRateEvent; | ||||||
| import com.plotsquared.core.events.PlotUnlinkEvent; | import com.plotsquared.core.events.PlotUnlinkEvent; | ||||||
|  | import com.plotsquared.core.events.RemoveRoadEntityEvent; | ||||||
| import com.plotsquared.core.events.TeleportCause; | import com.plotsquared.core.events.TeleportCause; | ||||||
| import com.plotsquared.core.events.post.PostPlayerAutoPlotEvent; | import com.plotsquared.core.events.post.PostPlayerAutoPlotEvent; | ||||||
| import com.plotsquared.core.events.post.PostPlotChangeOwnerEvent; | import com.plotsquared.core.events.post.PostPlotChangeOwnerEvent; | ||||||
| @@ -71,6 +72,7 @@ import com.plotsquared.core.plot.flag.types.BlockTypeWrapper; | |||||||
| import com.plotsquared.core.plot.world.SinglePlotArea; | import com.plotsquared.core.plot.world.SinglePlotArea; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
|  | import com.sk89q.worldedit.entity.Entity; | ||||||
| import com.sk89q.worldedit.function.pattern.Pattern; | import com.sk89q.worldedit.function.pattern.Pattern; | ||||||
| import com.sk89q.worldedit.world.block.BlockType; | import com.sk89q.worldedit.world.block.BlockType; | ||||||
| import com.sk89q.worldedit.world.block.BlockTypes; | import com.sk89q.worldedit.world.block.BlockTypes; | ||||||
| @@ -298,6 +300,12 @@ public class EventDispatcher { | |||||||
|         return event; |         return event; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public RemoveRoadEntityEvent callRemoveRoadEntity(Entity entity) { | ||||||
|  |         RemoveRoadEntityEvent event = new RemoveRoadEntityEvent(entity); | ||||||
|  |         eventBus.post(event); | ||||||
|  |         return event; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public void doJoinTask(final PlotPlayer<?> player) { |     public void doJoinTask(final PlotPlayer<?> player) { | ||||||
|         if (player == null) { |         if (player == null) { | ||||||
|             return; //possible future warning message to figure out where we are retrieving null |             return; //possible future warning message to figure out where we are retrieving null | ||||||
| @@ -351,11 +359,13 @@ public class EventDispatcher { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         switch (type) { |         switch (type) { | ||||||
|             case TELEPORT_OBJECT: |             case TELEPORT_OBJECT -> { | ||||||
|                 return false; |                 return false; | ||||||
|             case READ: |             } | ||||||
|  |             case READ -> { | ||||||
|                 return true; |                 return true; | ||||||
|             case INTERACT_BLOCK: { |             } | ||||||
|  |             case INTERACT_BLOCK -> { | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     final List<BlockTypeWrapper> use = area.getRoadFlag(UseFlag.class); |                     final List<BlockTypeWrapper> use = area.getRoadFlag(UseFlag.class); | ||||||
|                     for (final BlockTypeWrapper blockTypeWrapper : use) { |                     for (final BlockTypeWrapper blockTypeWrapper : use) { | ||||||
| @@ -390,7 +400,7 @@ public class EventDispatcher { | |||||||
|                 } |                 } | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|             case TRIGGER_PHYSICAL: { |             case TRIGGER_PHYSICAL -> { | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     final List<BlockTypeWrapper> use = area.getRoadFlag(UseFlag.class); |                     final List<BlockTypeWrapper> use = area.getRoadFlag(UseFlag.class); | ||||||
|                     for (final BlockTypeWrapper blockTypeWrapper : use) { |                     for (final BlockTypeWrapper blockTypeWrapper : use) { | ||||||
| @@ -422,7 +432,7 @@ public class EventDispatcher { | |||||||
|                         false |                         false | ||||||
|                 ); |                 ); | ||||||
|             } |             } | ||||||
|             case SPAWN_MOB: { |             case SPAWN_MOB -> { | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     return player.hasPermission( |                     return player.hasPermission( | ||||||
|                             Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString(), notifyPerms |                             Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString(), notifyPerms | ||||||
| @@ -464,7 +474,7 @@ public class EventDispatcher { | |||||||
|                 } |                 } | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|             case PLACE_MISC: { |             case PLACE_MISC -> { | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     return player.hasPermission( |                     return player.hasPermission( | ||||||
|                             Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString(), notifyPerms |                             Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString(), notifyPerms | ||||||
| @@ -506,7 +516,7 @@ public class EventDispatcher { | |||||||
|                 } |                 } | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|             case PLACE_VEHICLE: |             case PLACE_VEHICLE -> { | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     return player.hasPermission( |                     return player.hasPermission( | ||||||
|                             Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString(), notifyPerms |                             Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString(), notifyPerms | ||||||
| @@ -518,8 +528,9 @@ public class EventDispatcher { | |||||||
|                     ); |                     ); | ||||||
|                 } |                 } | ||||||
|                 return plot.getFlag(VehiclePlaceFlag.class); |                 return plot.getFlag(VehiclePlaceFlag.class); | ||||||
|             default: |             } | ||||||
|                 break; |             default -> { | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -18,14 +18,9 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.core.util; | package com.plotsquared.core.util; | ||||||
|  |  | ||||||
| public class FileBytes { | public record FileBytes( | ||||||
|  |         String path, | ||||||
|     public final String path; |         byte[] data | ||||||
|     public final byte[] data; | ) { | ||||||
|  |  | ||||||
|     public FileBytes(String path, byte[] data) { |  | ||||||
|         this.path = path; |  | ||||||
|         this.data = data; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -53,8 +53,10 @@ public abstract class InventoryUtil { | |||||||
|      * @param item          The item to place into the inventory |      * @param item          The item to place into the inventory | ||||||
|      * @see #setItemChecked(PlotInventory, int, PlotItemStack) |      * @see #setItemChecked(PlotInventory, int, PlotItemStack) | ||||||
|      */ |      */ | ||||||
|     public void setItem(final PlotInventory plotInventory, final int index, |     public void setItem( | ||||||
|                         final PlotItemStack item) { |             final PlotInventory plotInventory, final int index, | ||||||
|  |             final PlotItemStack item | ||||||
|  |     ) { | ||||||
|         setItemChecked(plotInventory, index, item); |         setItemChecked(plotInventory, index, item); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -70,103 +70,6 @@ public class MathMan { | |||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static long pairInt(int x, int y) { |  | ||||||
|         return (((long) x) << 32) | (y & 0xffffffffL); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static int unpairIntX(long pair) { |  | ||||||
|         return (int) (pair >> 32); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static int unpairIntY(long pair) { |  | ||||||
|         return (int) pair; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static byte pair16(byte x, byte y) { |  | ||||||
|         return (byte) (x + (y << 4)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static byte unpair16x(byte value) { |  | ||||||
|         return (byte) (value & 0xF); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static byte unpair16y(byte value) { |  | ||||||
|         return (byte) ((value >> 4) & 0xF); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static long inverseRound(double val) { |  | ||||||
|         long round = Math.round(val); |  | ||||||
|         return (long) (round + Math.signum(val - round)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static int sqrt(int x) { |  | ||||||
|         int xn; |  | ||||||
|  |  | ||||||
|         if (x >= 0x10000) { |  | ||||||
|             if (x >= 0x1000000) { |  | ||||||
|                 if (x >= 0x10000000) { |  | ||||||
|                     if (x >= 0x40000000) { |  | ||||||
|                         xn = table[x >> 24] << 8; |  | ||||||
|                     } else { |  | ||||||
|                         xn = table[x >> 22] << 7; |  | ||||||
|                     } |  | ||||||
|                 } else { |  | ||||||
|                     if (x >= 0x4000000) { |  | ||||||
|                         xn = table[x >> 20] << 6; |  | ||||||
|                     } else { |  | ||||||
|                         xn = table[x >> 18] << 5; |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 xn = (xn + 1 + (x / xn)) >> 1; |  | ||||||
|                 xn = (xn + 1 + (x / xn)) >> 1; |  | ||||||
|                 return ((xn * xn) > x) ? --xn : xn; |  | ||||||
|             } else { |  | ||||||
|                 if (x >= 0x100000) { |  | ||||||
|                     if (x >= 0x400000) { |  | ||||||
|                         xn = table[x >> 16] << 4; |  | ||||||
|                     } else { |  | ||||||
|                         xn = table[x >> 14] << 3; |  | ||||||
|                     } |  | ||||||
|                 } else { |  | ||||||
|                     if (x >= 0x40000) { |  | ||||||
|                         xn = table[x >> 12] << 2; |  | ||||||
|                     } else { |  | ||||||
|                         xn = table[x >> 10] << 1; |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 xn = (xn + 1 + (x / xn)) >> 1; |  | ||||||
|  |  | ||||||
|                 return ((xn * xn) > x) ? --xn : xn; |  | ||||||
|             } |  | ||||||
|         } else { |  | ||||||
|             if (x >= 0x100) { |  | ||||||
|                 if (x >= 0x1000) { |  | ||||||
|                     if (x >= 0x4000) { |  | ||||||
|                         xn = (table[x >> 8]) + 1; |  | ||||||
|                     } else { |  | ||||||
|                         xn = (table[x >> 6] >> 1) + 1; |  | ||||||
|                     } |  | ||||||
|                 } else { |  | ||||||
|                     if (x >= 0x400) { |  | ||||||
|                         xn = (table[x >> 4] >> 2) + 1; |  | ||||||
|                     } else { |  | ||||||
|                         xn = (table[x >> 2] >> 3) + 1; |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 return ((xn * xn) > x) ? --xn : xn; |  | ||||||
|             } else { |  | ||||||
|                 if (x >= 0) { |  | ||||||
|                     return table[x] >> 4; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         throw new IllegalArgumentException("Invalid number:" + x); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     public static double getMean(int[] array) { |     public static double getMean(int[] array) { | ||||||
|         double count = 0; |         double count = 0; | ||||||
|         for (int i : array) { |         for (int i : array) { | ||||||
| @@ -175,14 +78,6 @@ public class MathMan { | |||||||
|         return count / array.length; |         return count / array.length; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static double getMean(double[] array) { |  | ||||||
|         double count = 0; |  | ||||||
|         for (double i : array) { |  | ||||||
|             count += i; |  | ||||||
|         } |  | ||||||
|         return count / array.length; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static int pair(short x, short y) { |     public static int pair(short x, short y) { | ||||||
|         return (x << 16) | (y & 0xFFFF); |         return (x << 16) | (y & 0xFFFF); | ||||||
|     } |     } | ||||||
| @@ -191,105 +86,10 @@ public class MathMan { | |||||||
|         return (a & b) + (a ^ b) / 2; |         return (a & b) + (a ^ b) / 2; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static short unpairX(int hash) { |  | ||||||
|         return (short) (hash >> 16); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static short unpairY(int hash) { |  | ||||||
|         return (short) (hash & 0xFFFF); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * get the x,y,z unit vector from pitch and yaw specified |  | ||||||
|      * |  | ||||||
|      * @param yaw   yaw |  | ||||||
|      * @param pitch pitch |  | ||||||
|      * @return x, y, z unit vector |  | ||||||
|      */ |  | ||||||
|     public static float[] getDirection(float yaw, float pitch) { |  | ||||||
|         double pitch_sin = Math.sin(pitch); |  | ||||||
|         return new float[]{(float) (pitch_sin * Math.cos(yaw)), |  | ||||||
|                 (float) (pitch_sin * Math.sin(yaw)), (float) Math.cos(pitch)}; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static int floorMod(int x, int y) { |  | ||||||
|         int i = x % y; |  | ||||||
|         if (i < 0) { |  | ||||||
|             i += y; |  | ||||||
|         } |  | ||||||
|         return i; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static int roundInt(double value) { |     public static int roundInt(double value) { | ||||||
|         return (int) (value < 0 ? (value == (int) value) ? value : value - 1 : value); |         return (int) (value < 0 ? (value == (int) value) ? value : value - 1 : value); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Returns [ pitch, yaw ] |  | ||||||
|      * |  | ||||||
|      * @param x x |  | ||||||
|      * @param y y |  | ||||||
|      * @param z z |  | ||||||
|      * @return pitch and yaw of x,y,z from 0,0,0 |  | ||||||
|      */ |  | ||||||
|     public static float[] getPitchAndYaw(float x, float y, float z) { |  | ||||||
|         float distance = sqrtApprox((z * z) + (x * x)); |  | ||||||
|         return new float[]{atan2(y, distance), atan2(x, z)}; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static final float atan2(float y, float x) { |  | ||||||
|         float add; |  | ||||||
|         float mul; |  | ||||||
|  |  | ||||||
|         if (x < 0.0f) { |  | ||||||
|             if (y < 0.0f) { |  | ||||||
|                 x = -x; |  | ||||||
|                 y = -y; |  | ||||||
|  |  | ||||||
|                 mul = 1.0f; |  | ||||||
|             } else { |  | ||||||
|                 x = -x; |  | ||||||
|                 mul = -1.0f; |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             add = -3.141592653f; |  | ||||||
|         } else { |  | ||||||
|             if (y < 0.0f) { |  | ||||||
|                 y = -y; |  | ||||||
|                 mul = -1.0f; |  | ||||||
|             } else { |  | ||||||
|                 mul = 1.0f; |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             add = 0.0f; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         float invDiv = 1.0f / (((x < y) ? y : x) * INV_ATAN2_DIM_MINUS_1); |  | ||||||
|  |  | ||||||
|         int xi = (int) (x * invDiv); |  | ||||||
|         int yi = (int) (y * invDiv); |  | ||||||
|  |  | ||||||
|         return (atan2[(yi * ATAN2_DIM) + xi] + add) * mul; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static float sqrtApprox(float f) { |  | ||||||
|         return f * Float.intBitsToFloat(0x5f375a86 - (Float.floatToIntBits(f) >> 1)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static double sqrtApprox(double d) { |  | ||||||
|         return Double |  | ||||||
|                 .longBitsToDouble(((Double.doubleToLongBits(d) - (1L << 52)) >> 1) + (1L << 61)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static float invSqrt(float x) { |  | ||||||
|         float xhalf = 0.5f * x; |  | ||||||
|         int i = Float.floatToIntBits(x); |  | ||||||
|         i = 0x5f3759df - (i >> 1); |  | ||||||
|         x = Float.intBitsToFloat(i); |  | ||||||
|         x = x * (1.5f - (xhalf * x * x)); |  | ||||||
|         return x; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static int getPositiveId(int i) { |     public static int getPositiveId(int i) { | ||||||
|         if (i < 0) { |         if (i < 0) { | ||||||
|             return (-i * 2) - 1; |             return (-i * 2) - 1; | ||||||
| @@ -321,14 +121,6 @@ public class MathMan { | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static double getSD(double[] array, double av) { |  | ||||||
|         double sd = 0; |  | ||||||
|         for (double element : array) { |  | ||||||
|             sd += Math.pow(Math.abs(element - av), 2); |  | ||||||
|         } |  | ||||||
|         return Math.sqrt(sd / array.length); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static double getSD(int[] array, double av) { |     public static double getSD(int[] array, double av) { | ||||||
|         double sd = 0; |         double sd = 0; | ||||||
|         for (int element : array) { |         for (int element : array) { | ||||||
| @@ -337,22 +129,4 @@ public class MathMan { | |||||||
|         return Math.sqrt(sd / array.length); |         return Math.sqrt(sd / array.length); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static int mod(int x, int y) { |  | ||||||
|         if (isPowerOfTwo(y)) { |  | ||||||
|             return x & (y - 1); |  | ||||||
|         } |  | ||||||
|         return x % y; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static int unsignedmod(int x, int y) { |  | ||||||
|         if (isPowerOfTwo(y)) { |  | ||||||
|             return x & (y - 1); |  | ||||||
|         } |  | ||||||
|         return x % y; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static boolean isPowerOfTwo(int number) { |  | ||||||
|         return (number & (number - 1)) == 0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -98,7 +98,7 @@ public abstract class PlayerManager<P extends PlotPlayer<? extends T>, T> { | |||||||
|                             consumer.accept(null, throwable); |                             consumer.accept(null, throwable); | ||||||
|                         } else { |                         } else { | ||||||
|                             for (final UUIDMapping uuid : uuids) { |                             for (final UUIDMapping uuid : uuids) { | ||||||
|                                 result.add(uuid.getUuid()); |                                 result.add(uuid.uuid()); | ||||||
|                             } |                             } | ||||||
|                             consumer.accept(result, null); |                             consumer.accept(result, null); | ||||||
|                         } |                         } | ||||||
| @@ -136,7 +136,7 @@ public abstract class PlayerManager<P extends PlotPlayer<? extends T>, T> { | |||||||
|         try { |         try { | ||||||
|             for (final UUIDMapping mapping : PlotSquared.get().getImpromptuUUIDPipeline() |             for (final UUIDMapping mapping : PlotSquared.get().getImpromptuUUIDPipeline() | ||||||
|                     .getNames(players).get(Settings.UUID.BLOCKING_TIMEOUT, TimeUnit.MILLISECONDS)) { |                     .getNames(players).get(Settings.UUID.BLOCKING_TIMEOUT, TimeUnit.MILLISECONDS)) { | ||||||
|                 users.add(Component.text(mapping.getUsername())); |                 users.add(Component.text(mapping.username())); | ||||||
|             } |             } | ||||||
|         } catch (final Exception e) { |         } catch (final Exception e) { | ||||||
|             e.printStackTrace(); |             e.printStackTrace(); | ||||||
| @@ -200,7 +200,7 @@ public abstract class PlayerManager<P extends PlotPlayer<? extends T>, T> { | |||||||
|             final UUIDMapping uuidMapping = |             final UUIDMapping uuidMapping = | ||||||
|                     PlotSquared.get().getImpromptuUUIDPipeline().getImmediately(owner); |                     PlotSquared.get().getImpromptuUUIDPipeline().getImmediately(owner); | ||||||
|             if (uuidMapping != null) { |             if (uuidMapping != null) { | ||||||
|                 name = uuidMapping.getUsername(); |                 name = uuidMapping.username(); | ||||||
|             } else { |             } else { | ||||||
|                 name = null; |                 name = null; | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -272,7 +272,8 @@ public abstract class RegionManager { | |||||||
|         fromQueue1.addReadChunks(new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3()).getChunks()); |         fromQueue1.addReadChunks(new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3()).getChunks()); | ||||||
|         fromQueue2.addReadChunks(new CuboidRegion( |         fromQueue2.addReadChunks(new CuboidRegion( | ||||||
|                 swapPos.getBlockVector3(), |                 swapPos.getBlockVector3(), | ||||||
|                 BlockVector3.at(swapPos.getX() + pos2.getX() - pos1.getX(), |                 BlockVector3.at( | ||||||
|  |                         swapPos.getX() + pos2.getX() - pos1.getX(), | ||||||
|                         pos1.getY(), |                         pos1.getY(), | ||||||
|                         swapPos.getZ() + pos2.getZ() - pos1.getZ() |                         swapPos.getZ() + pos2.getZ() - pos1.getZ() | ||||||
|                 ) |                 ) | ||||||
|   | |||||||
| @@ -19,12 +19,10 @@ | |||||||
| package com.plotsquared.core.util; | package com.plotsquared.core.util; | ||||||
|  |  | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.sk89q.worldedit.math.BlockVector2; |  | ||||||
| import com.sk89q.worldedit.math.BlockVector3; | import com.sk89q.worldedit.math.BlockVector3; | ||||||
| import com.sk89q.worldedit.regions.CuboidRegion; | import com.sk89q.worldedit.regions.CuboidRegion; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.awt.geom.Rectangle2D; |  | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
|  |  | ||||||
| @@ -90,12 +88,6 @@ public class RegionUtil { | |||||||
|                 .getY() && y <= max.getY(); |                 .getY() && y <= max.getY(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static @NonNull Rectangle2D toRectangle(final @NonNull CuboidRegion region) { |  | ||||||
|         final BlockVector2 min = region.getMinimumPoint().toBlockVector2(); |  | ||||||
|         final BlockVector2 max = region.getMaximumPoint().toBlockVector2(); |  | ||||||
|         return new Rectangle2D.Double(min.getX(), min.getZ(), max.getX(), max.getZ()); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     // Because WorldEdit (not FastAsyncWorldEdit) lack this for CuboidRegion |     // Because WorldEdit (not FastAsyncWorldEdit) lack this for CuboidRegion | ||||||
|     public static boolean intersects(CuboidRegion region, CuboidRegion other) { |     public static boolean intersects(CuboidRegion region, CuboidRegion other) { | ||||||
|         BlockVector3 regionMin = region.getMinimumPoint(); |         BlockVector3 regionMin = region.getMinimumPoint(); | ||||||
|   | |||||||
| @@ -491,6 +491,10 @@ public abstract class SchematicHandler { | |||||||
|         return null; |         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) { |     public List<String> getSaves(UUID uuid) { | ||||||
|         String rawJSON; |         String rawJSON; | ||||||
|         try { |         try { | ||||||
|   | |||||||
| @@ -18,19 +18,13 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.core.util; | package com.plotsquared.core.util; | ||||||
|  |  | ||||||
| import com.plotsquared.core.PlotSquared; |  | ||||||
| import com.plotsquared.core.configuration.caption.Caption; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.lang.reflect.Array; |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| import java.util.Comparator; | import java.util.Comparator; | ||||||
| import java.util.Iterator; |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Map; |  | ||||||
| import java.util.Map.Entry; |  | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.regex.Pattern; | import java.util.regex.Pattern; | ||||||
|  |  | ||||||
| @@ -39,27 +33,6 @@ public class StringMan { | |||||||
|     // Stolen from https://stackoverflow.com/a/366532/12620913 | Debug: https://regex101.com/r/DudJLb/1 |     // Stolen from https://stackoverflow.com/a/366532/12620913 | Debug: https://regex101.com/r/DudJLb/1 | ||||||
|     private static final Pattern STRING_SPLIT_PATTERN = Pattern.compile("[^\\s\"]+|\"([^\"]*)\""); |     private static final Pattern STRING_SPLIT_PATTERN = Pattern.compile("[^\\s\"]+|\"([^\"]*)\""); | ||||||
|  |  | ||||||
|     public static String replaceFromMap(String string, Map<String, String> replacements) { |  | ||||||
|         StringBuilder sb = new StringBuilder(string); |  | ||||||
|         int size = string.length(); |  | ||||||
|         for (Entry<String, String> entry : replacements.entrySet()) { |  | ||||||
|             if (size == 0) { |  | ||||||
|                 break; |  | ||||||
|             } |  | ||||||
|             String key = entry.getKey(); |  | ||||||
|             String value = entry.getValue(); |  | ||||||
|             int start = sb.indexOf(key, 0); |  | ||||||
|             while (start > -1) { |  | ||||||
|                 int end = start + key.length(); |  | ||||||
|                 int nextSearchStart = start + value.length(); |  | ||||||
|                 sb.replace(start, end, value); |  | ||||||
|                 size -= end - start; |  | ||||||
|                 start = sb.indexOf(key, nextSearchStart); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return sb.toString(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static int intersection(Set<String> options, String[] toCheck) { |     public static int intersection(Set<String> options, String[] toCheck) { | ||||||
|         int count = 0; |         int count = 0; | ||||||
|         for (String check : toCheck) { |         for (String check : toCheck) { | ||||||
| @@ -70,91 +43,6 @@ public class StringMan { | |||||||
|         return count; |         return count; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static String getString(Object obj) { |  | ||||||
|         if (obj == null) { |  | ||||||
|             return "null"; |  | ||||||
|         } |  | ||||||
|         if (obj instanceof String) { |  | ||||||
|             return (String) obj; |  | ||||||
|         } |  | ||||||
|         if (obj instanceof Caption) { |  | ||||||
|             return ((Caption) obj).getComponent(PlotSquared.platform()); |  | ||||||
|         } |  | ||||||
|         if (obj.getClass().isArray()) { |  | ||||||
|             StringBuilder result = new StringBuilder(); |  | ||||||
|             String prefix = ""; |  | ||||||
|  |  | ||||||
|             for (int i = 0; i < Array.getLength(obj); i++) { |  | ||||||
|                 result.append(prefix).append(getString(Array.get(obj, i))); |  | ||||||
|                 prefix = ","; |  | ||||||
|             } |  | ||||||
|             return "( " + result + " )"; |  | ||||||
|         } else if (obj instanceof Collection<?>) { |  | ||||||
|             StringBuilder result = new StringBuilder(); |  | ||||||
|             String prefix = ""; |  | ||||||
|             for (Object element : (Collection<?>) obj) { |  | ||||||
|                 result.append(prefix).append(getString(element)); |  | ||||||
|                 prefix = ","; |  | ||||||
|             } |  | ||||||
|             return "[ " + result + " ]"; |  | ||||||
|         } else { |  | ||||||
|             return obj.toString(); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static String replaceFirst(char c, String s) { |  | ||||||
|         if (s == null) { |  | ||||||
|             return ""; |  | ||||||
|         } |  | ||||||
|         if (s.isEmpty()) { |  | ||||||
|             return s; |  | ||||||
|         } |  | ||||||
|         char[] chars = s.toCharArray(); |  | ||||||
|         char[] newChars = new char[chars.length]; |  | ||||||
|         int used = 0; |  | ||||||
|         boolean found = false; |  | ||||||
|         for (char cc : chars) { |  | ||||||
|             if (!found && (c == cc)) { |  | ||||||
|                 found = true; |  | ||||||
|             } else { |  | ||||||
|                 newChars[used++] = cc; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         if (found) { |  | ||||||
|             chars = new char[newChars.length - 1]; |  | ||||||
|             System.arraycopy(newChars, 0, chars, 0, chars.length); |  | ||||||
|             return String.valueOf(chars); |  | ||||||
|         } |  | ||||||
|         return s; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static String replaceAll(String string, Object... pairs) { |  | ||||||
|         StringBuilder sb = new StringBuilder(string); |  | ||||||
|         for (int i = 0; i < pairs.length; i += 2) { |  | ||||||
|             String key = pairs[i] + ""; |  | ||||||
|             String value = pairs[i + 1] + ""; |  | ||||||
|             int start = sb.indexOf(key, 0); |  | ||||||
|             while (start > -1) { |  | ||||||
|                 int end = start + key.length(); |  | ||||||
|                 int nextSearchStart = start + value.length(); |  | ||||||
|                 sb.replace(start, end, value); |  | ||||||
|                 start = sb.indexOf(key, nextSearchStart); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return sb.toString(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static boolean isAlphanumeric(String str) { |  | ||||||
|         for (int i = 0; i < str.length(); i++) { |  | ||||||
|             char c = str.charAt(i); |  | ||||||
|             if ((c < 0x30) || ((c >= 0x3a) && (c <= 0x40)) || ((c > 0x5a) && (c <= 0x60)) || (c |  | ||||||
|                     > 0x7a)) { |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static boolean isAlphanumericUnd(String str) { |     public static boolean isAlphanumericUnd(String str) { | ||||||
|         for (int i = 0; i < str.length(); i++) { |         for (int i = 0; i < str.length(); i++) { | ||||||
|             char c = str.charAt(i); |             char c = str.charAt(i); | ||||||
| @@ -165,16 +53,6 @@ public class StringMan { | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static boolean isAlpha(String str) { |  | ||||||
|         for (int i = 0; i < str.length(); i++) { |  | ||||||
|             char c = str.charAt(i); |  | ||||||
|             if ((c <= 0x40) || ((c > 0x5a) && (c <= 0x60)) || (c > 0x7a)) { |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static String join(Collection<?> collection, String delimiter) { |     public static String join(Collection<?> collection, String delimiter) { | ||||||
|         return join(collection.toArray(), delimiter); |         return join(collection.toArray(), delimiter); | ||||||
|     } |     } | ||||||
| @@ -185,23 +63,6 @@ public class StringMan { | |||||||
|         return join(array, delimiter); |         return join(array, delimiter); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static String join(Collection<?> collection, char delimiter) { |  | ||||||
|         return join(collection.toArray(), delimiter + ""); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static boolean isAsciiPrintable(char c) { |  | ||||||
|         return (c >= ' ') && (c < ''); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static boolean isAsciiPrintable(String s) { |  | ||||||
|         for (char c : s.toCharArray()) { |  | ||||||
|             if (!isAsciiPrintable(c)) { |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static int getLevenshteinDistance(String s, String t) { |     public static int getLevenshteinDistance(String s, String t) { | ||||||
|         int n = s.length(); |         int n = s.length(); | ||||||
|         int m = t.length(); |         int m = t.length(); | ||||||
| @@ -249,23 +110,6 @@ public class StringMan { | |||||||
|         return result.toString(); |         return result.toString(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static String join(int[] array, String delimiter) { |  | ||||||
|         Integer[] wrapped = new Integer[array.length]; |  | ||||||
|         for (int i = 0; i < array.length; i++) { |  | ||||||
|             wrapped[i] = array[i]; |  | ||||||
|         } |  | ||||||
|         return join(wrapped, delimiter); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static boolean isEqualToAny(String a, String... args) { |  | ||||||
|         for (String arg : args) { |  | ||||||
|             if (StringMan.isEqual(a, arg)) { |  | ||||||
|                 return true; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static boolean isEqualIgnoreCaseToAny(@NonNull String a, String... args) { |     public static boolean isEqualIgnoreCaseToAny(@NonNull String a, String... args) { | ||||||
|         for (String arg : args) { |         for (String arg : args) { | ||||||
|             if (a.equalsIgnoreCase(arg)) { |             if (a.equalsIgnoreCase(arg)) { | ||||||
| @@ -284,41 +128,12 @@ public class StringMan { | |||||||
|         return a.equals(b); |         return a.equals(b); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static boolean isEqualIgnoreCase(String a, String b) { |  | ||||||
|         return a.equals(b) || ((a != null) && (b != null) && (a.length() == b.length()) && a |  | ||||||
|                 .equalsIgnoreCase(b)); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static String repeat(String s, int n) { |     public static String repeat(String s, int n) { | ||||||
|         StringBuilder sb = new StringBuilder(); |         StringBuilder sb = new StringBuilder(); | ||||||
|         sb.append(String.valueOf(s).repeat(Math.max(0, n))); |         sb.append(String.valueOf(s).repeat(Math.max(0, n))); | ||||||
|         return sb.toString(); |         return sb.toString(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static boolean contains(String name, char c) { |  | ||||||
|         for (char current : name.toCharArray()) { |  | ||||||
|             if (c == current) { |  | ||||||
|                 return true; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public <T> Collection<T> match(Collection<T> col, String startsWith) { |  | ||||||
|         if (col == null) { |  | ||||||
|             return null; |  | ||||||
|         } |  | ||||||
|         startsWith = startsWith.toLowerCase(); |  | ||||||
|         Iterator<?> iterator = col.iterator(); |  | ||||||
|         while (iterator.hasNext()) { |  | ||||||
|             Object item = iterator.next(); |  | ||||||
|             if (item == null || !item.toString().toLowerCase().startsWith(startsWith)) { |  | ||||||
|                 iterator.remove(); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return col; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @param message an input string |      * @param message an input string | ||||||
|      * @return a list of strings |      * @return a list of strings | ||||||
|   | |||||||
| @@ -238,8 +238,8 @@ public final class TabCompletions { | |||||||
|                         PlotSquared.get().getImpromptuUUIDPipeline().getAllImmediately(); |                         PlotSquared.get().getImpromptuUUIDPipeline().getAllImmediately(); | ||||||
|                 players = new ArrayList<>(mappings.size()); |                 players = new ArrayList<>(mappings.size()); | ||||||
|                 for (final UUIDMapping mapping : mappings) { |                 for (final UUIDMapping mapping : mappings) { | ||||||
|                     if (uuidFilter.test(mapping.getUuid())) { |                     if (uuidFilter.test(mapping.uuid())) { | ||||||
|                         players.add(mapping.getUsername()); |                         players.add(mapping.username()); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 cachedCompletionValues.put(cacheIdentifier, players); |                 cachedCompletionValues.put(cacheIdentifier, players); | ||||||
|   | |||||||
| @@ -58,29 +58,6 @@ public class WEManager { | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static boolean maskContains(Set<CuboidRegion> mask, double dx, double dy, double dz) { |  | ||||||
|         int x = Math.toIntExact(Math.round(dx >= 0 ? dx - 0.5 : dx + 0.5)); |  | ||||||
|         int y = Math.toIntExact(Math.round(dy - 0.5)); |  | ||||||
|         int z = Math.toIntExact(Math.round(dz >= 0 ? dz - 0.5 : dz + 0.5)); |  | ||||||
|         for (CuboidRegion region : mask) { |  | ||||||
|             if (RegionUtil.contains(region, x, y, z)) { |  | ||||||
|                 return true; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static boolean maskContains(Set<CuboidRegion> mask, double dx, double dz) { |  | ||||||
|         int x = Math.toIntExact(Math.round(dx >= 0 ? dx - 0.5 : dx + 0.5)); |  | ||||||
|         int z = Math.toIntExact(Math.round(dz >= 0 ? dz - 0.5 : dz + 0.5)); |  | ||||||
|         for (CuboidRegion region : mask) { |  | ||||||
|             if (RegionUtil.contains(region, x, z)) { |  | ||||||
|                 return true; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static HashSet<CuboidRegion> getMask(PlotPlayer<?> player) { |     public static HashSet<CuboidRegion> getMask(PlotPlayer<?> player) { | ||||||
|         HashSet<CuboidRegion> regions = new HashSet<>(); |         HashSet<CuboidRegion> regions = new HashSet<>(); | ||||||
|         UUID uuid = player.getUUID(); |         UUID uuid = player.getUUID(); | ||||||
| @@ -116,17 +93,4 @@ public class WEManager { | |||||||
|         return regions; |         return regions; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static boolean intersects(CuboidRegion region1, CuboidRegion region2) { |  | ||||||
|         return RegionUtil.intersects(region1, region2); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public static boolean regionContains(CuboidRegion selection, HashSet<CuboidRegion> mask) { |  | ||||||
|         for (CuboidRegion region : mask) { |  | ||||||
|             if (intersects(region, selection)) { |  | ||||||
|                 return true; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return false; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -231,6 +231,10 @@ public abstract class WorldUtil { | |||||||
|      */ |      */ | ||||||
|     public abstract void refreshChunk(int x, int z, String world); |     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( |     public void upload( | ||||||
|             final @NonNull Plot plot, |             final @NonNull Plot plot, | ||||||
|             final @Nullable UUID uuid, |             final @Nullable UUID uuid, | ||||||
| @@ -281,7 +285,8 @@ public abstract class WorldUtil { | |||||||
|                         int trz = top.getZ() >> 9; |                         int trz = top.getZ() >> 9; | ||||||
|                         Set<BlockVector2> files = getChunkChunks(bot.getWorldName()); |                         Set<BlockVector2> files = getChunkChunks(bot.getWorldName()); | ||||||
|                         for (BlockVector2 mca : files) { |                         for (BlockVector2 mca : files) { | ||||||
|                             if (mca.getX() >= brx && mca.getX() <= trx && mca.getZ() >= brz && mca.getZ() <= trz && !added.contains(mca)) { |                             if (mca.getX() >= brx && mca.getX() <= trx && mca.getZ() >= brz && mca.getZ() <= trz && !added.contains( | ||||||
|  |                                     mca)) { | ||||||
|                                 final File file = getMcr(plot.getWorldName(), mca.getX(), mca.getZ()); |                                 final File file = getMcr(plot.getWorldName(), mca.getX(), mca.getZ()); | ||||||
|                                 if (file != null) { |                                 if (file != null) { | ||||||
|                                     //final String name = "r." + (x - cx) + "." + (z - cz) + ".mca"; |                                     //final String name = "r." + (x - cx) + "." + (z - cz) + ".mca"; | ||||||
|   | |||||||
| @@ -102,7 +102,7 @@ public final class PlaceholderRegistry { | |||||||
|             return plot.getAlias(); |             return plot.getAlias(); | ||||||
|         }); |         }); | ||||||
|         this.createPlaceholder("currentplot_owner", (player, plot) -> { |         this.createPlaceholder("currentplot_owner", (player, plot) -> { | ||||||
|             if (plot.getFlag(ServerPlotFlag.class)){ |             if (plot.getFlag(ServerPlotFlag.class)) { | ||||||
|                 return legacyComponent(TranslatableCaption.of("info.server"), player); |                 return legacyComponent(TranslatableCaption.of("info.server"), player); | ||||||
|             } |             } | ||||||
|             final UUID plotOwner = plot.getOwnerAbs(); |             final UUID plotOwner = plot.getOwnerAbs(); | ||||||
| @@ -300,17 +300,9 @@ public final class PlaceholderRegistry { | |||||||
|     /** |     /** | ||||||
|      * Event called when a new {@link Placeholder} has been added |      * Event called when a new {@link Placeholder} has been added | ||||||
|      */ |      */ | ||||||
|     public static class PlaceholderAddedEvent { |     public record PlaceholderAddedEvent( | ||||||
|  |             Placeholder placeholder | ||||||
|         private final Placeholder placeholder; |     ) { | ||||||
|  |  | ||||||
|         public PlaceholderAddedEvent(Placeholder placeholder) { |  | ||||||
|             this.placeholder = placeholder; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         public Placeholder getPlaceholder() { |  | ||||||
|             return this.placeholder; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user