mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-11-03 10:43:45 +01:00 
			
		
		
		
	Compare commits
	
		
			86 Commits
		
	
	
		
			refactor/v
			...
			fix/stop-i
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					e2bb8a4b32 | ||
| 
						 | 
					c523feeb79 | ||
| 
						 | 
					958c66b28f | ||
| 
						 | 
					c656190e14 | ||
| 
						 | 
					e914cb210e | ||
| 
						 | 
					94c6af74d2 | ||
| 
						 | 
					ebb82bd66d | ||
| 
						 | 
					66f907eb5d | ||
| 
						 | 
					9ffede2c5c | ||
| 
						 | 
					97172df0dc | ||
| 
						 | 
					c9746b182c | ||
| 
						 | 
					10a2b80ffc | ||
| 
						 | 
					ca0f38255d | ||
| 
						 | 
					0484ac73af | ||
| 
						 | 
					1a712ad3c1 | ||
| 
						 | 
					2d1f483469 | ||
| 
						 | 
					91830e233b | ||
| 
						 | 
					561edb83bf | ||
| 
						 | 
					0e09cf223a | ||
| 
						 | 
					d78360d6eb | ||
| 
						 | 
					1464804c11 | ||
| 
						 | 
					8629eae5fc | ||
| 
						 | 
					7b8ba7c3ac | ||
| 
						 | 
					77c7466c17 | ||
| 
						 | 
					82fe76fd37 | ||
| 
						 | 
					3f81ea4ef8 | ||
| 
						 | 
					745b06a008 | ||
| 
						 | 
					77b2bd166a | ||
| 
						 | 
					8e02336c44 | ||
| 
						 | 
					3adfbde45a | ||
| 
						 | 
					e6db8e2750 | ||
| 
						 | 
					9cd0ee9b49 | ||
| 
						 | 
					d455d1fcd7 | ||
| 
						 | 
					ea19ff783f | ||
| 
						 | 
					447e4c7d58 | ||
| 
						 | 
					89031447f2 | ||
| 
						 | 
					4210a3a555 | ||
| 
						 | 
					42e146b8c7 | ||
| 
						 | 
					a5fdcda673 | ||
| 
						 | 
					52823f5024 | ||
| 
						 | 
					1326c257a0 | ||
| 
						 | 
					fc3137cd96 | ||
| 
						 | 
					a5c53a96d1 | ||
| 
						 | 
					c46cc73f52 | ||
| 
						 | 
					276e619caa | ||
| 
						 | 
					f11acacedd | ||
| 
						 | 
					f636a5ec63 | ||
| 
						 | 
					d1bac90745 | ||
| 
						 | 
					785362c576 | ||
| 
						 | 
					e98f628d34 | ||
| 
						 | 
					b2ab61559c | ||
| 
						 | 
					dd6eb8e74f | ||
| 
						 | 
					97cdd03ea4 | ||
| 
						 | 
					f5118e6802 | ||
| 
						 | 
					94ca5cf679 | ||
| 
						 | 
					5a55a1f602 | ||
| 
						 | 
					1e7ba7d173 | ||
| 
						 | 
					ed33635a15 | ||
| 
						 | 
					888682e5d0 | ||
| 
						 | 
					72bb5f00b0 | ||
| 
						 | 
					773fd6f59f | ||
| 
						 | 
					aa784e98f8 | ||
| 
						 | 
					5cce86d924 | ||
| 
						 | 
					84567bcb00 | ||
| 
						 | 
					d7c2ab1d16 | ||
| 
						 | 
					0d359ade0c | ||
| 
						 | 
					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
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.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'
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										14
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.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'
 | 
				
			||||||
@@ -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,14 +36,13 @@ 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@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 }}
 | 
				
			||||||
@@ -57,8 +54,7 @@ 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@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 }}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										10
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.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@v2
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          languages: ${{ matrix.language }}
 | 
					          languages: ${{ matrix.language }}
 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Autobuild
 | 
					      - name: Autobuild
 | 
				
			||||||
        uses: github/codeql-action/autobuild@v2
 | 
					        uses: github/codeql-action/autobuild@v2
 | 
				
			||||||
 | 
					 | 
				
			||||||
      - name: Perform CodeQL Analysis
 | 
					      - name: Perform CodeQL Analysis
 | 
				
			||||||
        uses: github/codeql-action/analyze@v2
 | 
					        uses: github/codeql-action/analyze@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 }}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							@@ -137,3 +137,7 @@ docs/
 | 
				
			|||||||
build/
 | 
					build/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.DS_Store
 | 
					.DS_Store
 | 
				
			||||||
 | 
					# Ignore run folders
 | 
				
			||||||
 | 
					run-[0-0].[0-9]/
 | 
				
			||||||
 | 
					run-[0-0].[0-9].[0-9]/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										154
									
								
								.idea/icon.svg
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										154
									
								
								.idea/icon.svg
									
									
									
										generated
									
									
									
								
							@@ -1,48 +1,144 @@
 | 
				
			|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
 | 
					<?xml version="1.0" encoding="UTF-8" standalone="no"?>
 | 
				
			||||||
<svg xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:cc="http://creativecommons.org/ns#" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:svg="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" version="1.1" id="svg2" xml:space="preserve" width="4000" height="3333.3333" viewBox="0 0 4000 3333.3333" sodipodi:docname="PlotSquared.ai">
 | 
					<svg
 | 
				
			||||||
		<metadata id="metadata8">
 | 
					   version="1.1"
 | 
				
			||||||
 | 
					   id="svg2"
 | 
				
			||||||
 | 
					   xml:space="preserve"
 | 
				
			||||||
 | 
					   width="512"
 | 
				
			||||||
 | 
					   height="512"
 | 
				
			||||||
 | 
					   viewBox="0 0 512 512.00001"
 | 
				
			||||||
 | 
					   sodipodi:docname="icon.svg"
 | 
				
			||||||
 | 
					   inkscape:version="1.1.2 (b8e25be8, 2022-02-05)"
 | 
				
			||||||
 | 
					   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
 | 
				
			||||||
 | 
					   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
 | 
				
			||||||
 | 
					   xmlns="http://www.w3.org/2000/svg"
 | 
				
			||||||
 | 
					   xmlns:svg="http://www.w3.org/2000/svg"
 | 
				
			||||||
 | 
					   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
 | 
				
			||||||
 | 
					   xmlns:cc="http://creativecommons.org/ns#"
 | 
				
			||||||
 | 
					   xmlns:dc="http://purl.org/dc/elements/1.1/">
 | 
				
			||||||
 | 
							<metadata
 | 
				
			||||||
 | 
					   id="metadata8">
 | 
				
			||||||
			<rdf:RDF>
 | 
								<rdf:RDF>
 | 
				
			||||||
				<cc:Work rdf:about="">
 | 
									<cc:Work
 | 
				
			||||||
 | 
					   rdf:about="">
 | 
				
			||||||
					<dc:format>image/svg+xml</dc:format>
 | 
										<dc:format>image/svg+xml</dc:format>
 | 
				
			||||||
                    <dc:type rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
 | 
					                    <dc:type
 | 
				
			||||||
 | 
					   rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
 | 
				
			||||||
				</cc:Work>
 | 
									</cc:Work>
 | 
				
			||||||
			</rdf:RDF>
 | 
								</rdf:RDF>
 | 
				
			||||||
		</metadata>
 | 
							</metadata>
 | 
				
			||||||
    <defs id="defs6">
 | 
					    <defs
 | 
				
			||||||
			<clipPath clipPathUnits="userSpaceOnUse" id="clipPath18">
 | 
					   id="defs6">
 | 
				
			||||||
				<path d="M 0,2500 H 3000 V 0 H 0 Z" id="path16" />
 | 
								<clipPath
 | 
				
			||||||
 | 
					   clipPathUnits="userSpaceOnUse"
 | 
				
			||||||
 | 
					   id="clipPath18">
 | 
				
			||||||
 | 
									<path
 | 
				
			||||||
 | 
					   d="M 0,2500 H 3000 V 0 H 0 Z"
 | 
				
			||||||
 | 
					   id="path16" />
 | 
				
			||||||
			</clipPath>
 | 
								</clipPath>
 | 
				
			||||||
		</defs>
 | 
							</defs>
 | 
				
			||||||
    <sodipodi:namedview pagecolor="#ffffff" bordercolor="#666666" borderopacity="1" objecttolerance="10" gridtolerance="10" guidetolerance="10" inkscape:pageopacity="0" inkscape:pageshadow="2" inkscape:window-width="640" inkscape:window-height="480" id="namedview4" />
 | 
					    <sodipodi:namedview
 | 
				
			||||||
    <g id="g10" inkscape:groupmode="layer" inkscape:label="PlotSquared" transform="matrix(1.3333333,0,0,-1.3333333,0,3333.3333)">
 | 
					   pagecolor="#ffffff"
 | 
				
			||||||
			<g id="g12">
 | 
					   bordercolor="#666666"
 | 
				
			||||||
				<g id="g14" clip-path="url(#clipPath18)">
 | 
					   borderopacity="1"
 | 
				
			||||||
					<g id="g20" transform="translate(1486.1511,2242.6453)">
 | 
					   objecttolerance="10"
 | 
				
			||||||
						<path d="m 0,0 c 16.533,10.846 33.211,21.453 50.104,31.699 78.972,-48.281 153.985,-102.704 227.269,-159.144 148.61,-115.422 287.884,-243.01 414.393,-382.333 111.39,-122.861 212.751,-255.152 298.898,-396.971 52.744,-87.322 100.544,-177.884 139.514,-272.214 -11.638,-3.551 -23.108,-7.655 -34.362,-12.286 l -0.24,0.288 c -11.135,12.982 -24.141,24.212 -34.915,37.506 -22.557,23.013 -45.425,45.737 -68.03,68.678 -19.725,20.253 -40.601,39.45 -58.958,60.974 -36.355,36.451 -72.517,73.093 -108.944,109.471 -22.628,26.013 -48.064,49.385 -71.965,74.197 -19.029,19.485 -38.706,38.346 -57.519,57.999 -12.166,14.998 -26.684,27.716 -39.93,41.658 -27.668,27.524 -54.903,55.479 -82.571,82.979 -23.924,27.956 -51.664,52.264 -76.692,79.164 -4.68,4.487 -8.855,10.774 -15.886,11.326 -22.34,34.027 -58.311,57.327 -97.377,67.502 -104.312,99.153 -215.487,191.202 -332.661,274.782 -117.942,-83.94 -229.476,-176.781 -334.484,-276.39 -26.684,-0.024 -53.368,0.024 -80.076,-0.024 0.024,-26.564 0.048,-53.104 0,-79.668 -72.229,-73.021 -139.491,-150.937 -202.385,-232.092 -63.758,-82.619 -121.973,-169.51 -173.541,-260.264 131.932,-69.061 257.864,-149.521 375.926,-240.275 0.096,-26.444 -0.12,-52.888 0.096,-79.332 l 0.744,-0.984 c 20.109,-24.14 43.409,-45.233 65.126,-67.861 15.118,-15.382 30.571,-30.404 45.569,-45.881 17.565,-20.733 37.698,-39.042 56.607,-58.503 19.917,-20.781 41.25,-40.218 59.967,-62.151 29.156,-29.299 58.167,-58.815 87.515,-87.922 29.155,-33.043 61.502,-63.111 92.169,-94.738 13.726,-12.67 25.124,-27.571 38.634,-40.457 25.029,-25.365 50.129,-50.657 75.325,-75.853 -37.914,-51.208 -73.741,-103.952 -107.192,-158.183 -167.83,273.317 -397.235,507.305 -662.37,687.158 -81.875,55.335 -167.23,105.584 -255.681,149.641 -52.815,26.276 -106.831,50.248 -162.239,70.381 99.393,233.628 242.795,446.715 410.289,636.79 93.562,106.088 194.634,205.433 301.466,298.13 C -217.335,-155.808 -111.439,-73.789 0,0" style="fill:#062f4c;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path22" />
 | 
					   gridtolerance="10"
 | 
				
			||||||
 | 
					   guidetolerance="10"
 | 
				
			||||||
 | 
					   inkscape:pageopacity="0"
 | 
				
			||||||
 | 
					   inkscape:pageshadow="2"
 | 
				
			||||||
 | 
					   inkscape:window-width="1440"
 | 
				
			||||||
 | 
					   inkscape:window-height="900"
 | 
				
			||||||
 | 
					   id="namedview4"
 | 
				
			||||||
 | 
					   inkscape:pagecheckerboard="0"
 | 
				
			||||||
 | 
					   showgrid="false"
 | 
				
			||||||
 | 
					   inkscape:zoom="0.1632"
 | 
				
			||||||
 | 
					   inkscape:cx="1087.6225"
 | 
				
			||||||
 | 
					   inkscape:cy="1666.6666"
 | 
				
			||||||
 | 
					   inkscape:window-x="0"
 | 
				
			||||||
 | 
					   inkscape:window-y="0"
 | 
				
			||||||
 | 
					   inkscape:window-maximized="0"
 | 
				
			||||||
 | 
					   inkscape:current-layer="g10" />
 | 
				
			||||||
 | 
					    <g
 | 
				
			||||||
 | 
					   id="g10"
 | 
				
			||||||
 | 
					   inkscape:groupmode="layer"
 | 
				
			||||||
 | 
					   inkscape:label="PlotSquared"
 | 
				
			||||||
 | 
					   transform="matrix(1.3333333,0,0,-1.3333333,0,3333.3333)">
 | 
				
			||||||
 | 
								<g
 | 
				
			||||||
 | 
					   id="g12"
 | 
				
			||||||
 | 
					   transform="matrix(0.16955078,0,0,0.16955078,-68.456969,2101.8529)">
 | 
				
			||||||
 | 
									<g
 | 
				
			||||||
 | 
					   id="g14"
 | 
				
			||||||
 | 
					   clip-path="url(#clipPath18)">
 | 
				
			||||||
 | 
										<g
 | 
				
			||||||
 | 
					   id="g20"
 | 
				
			||||||
 | 
					   transform="translate(1486.1511,2242.6453)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 16.533,10.846 33.211,21.453 50.104,31.699 78.972,-48.281 153.985,-102.704 227.269,-159.144 148.61,-115.422 287.884,-243.01 414.393,-382.333 111.39,-122.861 212.751,-255.152 298.898,-396.971 52.744,-87.322 100.544,-177.884 139.514,-272.214 -11.638,-3.551 -23.108,-7.655 -34.362,-12.286 l -0.24,0.288 c -11.135,12.982 -24.141,24.212 -34.915,37.506 -22.557,23.013 -45.425,45.737 -68.03,68.678 -19.725,20.253 -40.601,39.45 -58.958,60.974 -36.355,36.451 -72.517,73.093 -108.944,109.471 -22.628,26.013 -48.064,49.385 -71.965,74.197 -19.029,19.485 -38.706,38.346 -57.519,57.999 -12.166,14.998 -26.684,27.716 -39.93,41.658 -27.668,27.524 -54.903,55.479 -82.571,82.979 -23.924,27.956 -51.664,52.264 -76.692,79.164 -4.68,4.487 -8.855,10.774 -15.886,11.326 -22.34,34.027 -58.311,57.327 -97.377,67.502 -104.312,99.153 -215.487,191.202 -332.661,274.782 -117.942,-83.94 -229.476,-176.781 -334.484,-276.39 -26.684,-0.024 -53.368,0.024 -80.076,-0.024 0.024,-26.564 0.048,-53.104 0,-79.668 -72.229,-73.021 -139.491,-150.937 -202.385,-232.092 -63.758,-82.619 -121.973,-169.51 -173.541,-260.264 131.932,-69.061 257.864,-149.521 375.926,-240.275 0.096,-26.444 -0.12,-52.888 0.096,-79.332 l 0.744,-0.984 c 20.109,-24.14 43.409,-45.233 65.126,-67.861 15.118,-15.382 30.571,-30.404 45.569,-45.881 17.565,-20.733 37.698,-39.042 56.607,-58.503 19.917,-20.781 41.25,-40.218 59.967,-62.151 29.156,-29.299 58.167,-58.815 87.515,-87.922 29.155,-33.043 61.502,-63.111 92.169,-94.738 13.726,-12.67 25.124,-27.571 38.634,-40.457 25.029,-25.365 50.129,-50.657 75.325,-75.853 -37.914,-51.208 -73.741,-103.952 -107.192,-158.183 -167.83,273.317 -397.235,507.305 -662.37,687.158 -81.875,55.335 -167.23,105.584 -255.681,149.641 -52.815,26.276 -106.831,50.248 -162.239,70.381 99.393,233.628 242.795,446.715 410.289,636.79 93.562,106.088 194.634,205.433 301.466,298.13 C -217.335,-155.808 -111.439,-73.789 0,0"
 | 
				
			||||||
 | 
					   style="fill:#062f4c;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path22" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g24" transform="translate(1201.7948,1741.5303)">
 | 
					                    <g
 | 
				
			||||||
						<path d="M 0,0 C 105.008,99.609 216.543,192.45 334.485,276.39 451.659,192.81 562.833,100.76 667.146,1.608 c -34.987,8.83 -71.51,9.718 -107.264,6.431 -41.202,-4.296 -82.907,-19.077 -112.543,-48.953 -33.019,-32.155 -49.456,-77.604 -55.311,-122.501 -28.124,27.908 -56.104,55.983 -84.035,84.083 -2.976,2.976 -6.839,4.823 -10.391,6.911 -19.029,26.348 -45.953,46.673 -76.62,57.495 C 187.555,-2.472 151.513,-0.12 116.166,0 Z" style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path26" />
 | 
					   id="g24"
 | 
				
			||||||
 | 
					   transform="translate(1201.7948,1741.5303)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="M 0,0 C 105.008,99.609 216.543,192.45 334.485,276.39 451.659,192.81 562.833,100.76 667.146,1.608 c -34.987,8.83 -71.51,9.718 -107.264,6.431 -41.202,-4.296 -82.907,-19.077 -112.543,-48.953 -33.019,-32.155 -49.456,-77.604 -55.311,-122.501 -28.124,27.908 -56.104,55.983 -84.035,84.083 -2.976,2.976 -6.839,4.823 -10.391,6.911 -19.029,26.348 -45.953,46.673 -76.62,57.495 C 187.555,-2.472 151.513,-0.12 116.166,0 Z"
 | 
				
			||||||
 | 
					   style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path26" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g28" transform="translate(919.3342,1429.7462)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 c 62.894,81.156 130.156,159.072 202.385,232.092 0.048,-244.21 0.024,-488.421 0,-732.631 C 84.323,-409.785 -41.61,-329.325 -173.541,-260.264 -121.973,-169.51 -63.758,-82.619 0,0" style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path30" />
 | 
					   id="g28"
 | 
				
			||||||
 | 
					   transform="translate(919.3342,1429.7462)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 62.894,81.156 130.156,159.072 202.385,232.092 0.048,-244.21 0.024,-488.421 0,-732.631 C 84.323,-409.785 -41.61,-329.325 -173.541,-260.264 -121.973,-169.51 -63.758,-82.619 0,0"
 | 
				
			||||||
 | 
					   style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path30" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g32" transform="translate(1649.134,1700.6166)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 c 29.635,29.875 71.341,44.657 112.543,48.952 35.754,3.288 72.277,2.4 107.263,-6.431 39.066,-10.174 75.037,-33.474 97.377,-67.501 11.879,-17.661 20.181,-37.411 26.42,-57.687 10.871,-38.802 11.95,-79.356 11.446,-119.358 -44.345,-0.072 -88.69,0.048 -133.035,-0.072 -1.032,30.907 3.263,63.686 -10.175,92.626 -9.526,20.325 -32.107,31.243 -53.751,32.131 -21.453,1.44 -45.065,-4.32 -59.175,-21.597 -12.79,-15.861 -15.382,-37.002 -16.558,-56.655 -1.295,-29.132 3.696,-59.031 17.518,-84.923 16.821,-30.619 39.378,-57.783 64.526,-81.9 31.387,-32.634 67.501,-60.374 97.857,-94.041 27.332,-28.988 51.256,-61.479 68.005,-97.785 20.541,-41.13 26.972,-87.827 25.82,-133.372 -0.912,-32.107 -5.231,-64.406 -16.149,-94.737 -11.59,-31.699 -31.123,-61.047 -58.335,-81.371 -25.124,-19.125 -55.696,-29.852 -86.651,-34.771 -49.552,-6.743 -101.888,-4.847 -148.465,14.854 -35.227,14.829 -64.238,42.689 -81.708,76.548 -20.996,40.242 -27.115,86.339 -27.259,131.212 0.048,17.829 0,35.658 0.048,53.463 44.345,0.048 88.69,-0.023 133.059,0.048 1.728,-35.538 -4.055,-72.06 5.663,-106.807 5.783,-22.173 26.204,-37.794 48.185,-41.754 20.733,-3.431 43.577,-2.015 61.622,9.791 15.502,9.43 23.949,26.78 26.78,44.225 5.903,35.922 1.872,74.293 -15.381,106.688 -16.918,30.595 -39.474,57.711 -64.55,81.899 -33.187,34.099 -71.173,63.254 -102.585,99.081 -26.756,28.867 -49.408,61.646 -65.486,97.641 -24.572,52.48 -26.731,112.422 -20.18,169.102 C -49.456,-77.604 -33.019,-32.155 0,0" style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path34" />
 | 
					   id="g32"
 | 
				
			||||||
 | 
					   transform="translate(1649.134,1700.6166)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 29.635,29.875 71.341,44.657 112.543,48.952 35.754,3.288 72.277,2.4 107.263,-6.431 39.066,-10.174 75.037,-33.474 97.377,-67.501 11.879,-17.661 20.181,-37.411 26.42,-57.687 10.871,-38.802 11.95,-79.356 11.446,-119.358 -44.345,-0.072 -88.69,0.048 -133.035,-0.072 -1.032,30.907 3.263,63.686 -10.175,92.626 -9.526,20.325 -32.107,31.243 -53.751,32.131 -21.453,1.44 -45.065,-4.32 -59.175,-21.597 -12.79,-15.861 -15.382,-37.002 -16.558,-56.655 -1.295,-29.132 3.696,-59.031 17.518,-84.923 16.821,-30.619 39.378,-57.783 64.526,-81.9 31.387,-32.634 67.501,-60.374 97.857,-94.041 27.332,-28.988 51.256,-61.479 68.005,-97.785 20.541,-41.13 26.972,-87.827 25.82,-133.372 -0.912,-32.107 -5.231,-64.406 -16.149,-94.737 -11.59,-31.699 -31.123,-61.047 -58.335,-81.371 -25.124,-19.125 -55.696,-29.852 -86.651,-34.771 -49.552,-6.743 -101.888,-4.847 -148.465,14.854 -35.227,14.829 -64.238,42.689 -81.708,76.548 -20.996,40.242 -27.115,86.339 -27.259,131.212 0.048,17.829 0,35.658 0.048,53.463 44.345,0.048 88.69,-0.023 133.059,0.048 1.728,-35.538 -4.055,-72.06 5.663,-106.807 5.783,-22.173 26.204,-37.794 48.185,-41.754 20.733,-3.431 43.577,-2.015 61.622,9.791 15.502,9.43 23.949,26.78 26.78,44.225 5.903,35.922 1.872,74.293 -15.381,106.688 -16.918,30.595 -39.474,57.711 -64.55,81.899 -33.187,34.099 -71.173,63.254 -102.585,99.081 -26.756,28.867 -49.408,61.646 -65.486,97.641 -24.572,52.48 -26.731,112.422 -20.18,169.102 C -49.456,-77.604 -33.019,-32.155 0,0"
 | 
				
			||||||
 | 
					   style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path34" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g36" transform="translate(1262.7214,1613.126)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 v -301.13 c 23.204,0.024 46.409,-0.048 69.613,0.024 18.525,0.288 38.202,6.575 50.153,21.429 12.43,17.277 13.917,39.522 14.613,60.111 0.024,43.985 -0.048,87.994 0.024,131.979 -0.48,23.637 -0.983,50.369 -17.277,69.23 C 104.864,-5.711 86.867,-0.24 69.589,0 46.385,0.048 23.204,0.024 0,0 m -141.002,128.38 c 26.708,0.048 53.392,0 80.075,0.024 H 55.24 c 35.346,-0.12 71.389,-2.471 104.815,-14.925 30.668,-10.823 57.592,-31.148 76.621,-57.496 26.852,-39.09 36.69,-87.202 38.058,-133.947 0.024,-48.833 0.096,-97.689 -0.024,-146.521 -1.728,-47.993 -11.974,-97.953 -41.514,-136.971 -22.748,-30.644 -57.495,-50.801 -94.281,-59.583 -45.377,-11.878 -92.578,-6.791 -138.891,-7.847 -0.072,-111.799 0,-223.574 -0.024,-335.373 -13.942,0 -27.86,0.024 -41.778,-0.024 -32.802,0.072 -65.605,0 -98.384,0.048 l -0.744,0.984 c -0.216,26.444 0,52.888 -0.096,79.332 0.024,244.211 0.048,488.421 0,732.632 0.048,26.563 0.024,53.103 0,79.667" style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path38" />
 | 
					   id="g36"
 | 
				
			||||||
 | 
					   transform="translate(1262.7214,1613.126)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 v -301.13 c 23.204,0.024 46.409,-0.048 69.613,0.024 18.525,0.288 38.202,6.575 50.153,21.429 12.43,17.277 13.917,39.522 14.613,60.111 0.024,43.985 -0.048,87.994 0.024,131.979 -0.48,23.637 -0.983,50.369 -17.277,69.23 C 104.864,-5.711 86.867,-0.24 69.589,0 46.385,0.048 23.204,0.024 0,0 m -141.002,128.38 c 26.708,0.048 53.392,0 80.075,0.024 H 55.24 c 35.346,-0.12 71.389,-2.471 104.815,-14.925 30.668,-10.823 57.592,-31.148 76.621,-57.496 26.852,-39.09 36.69,-87.202 38.058,-133.947 0.024,-48.833 0.096,-97.689 -0.024,-146.521 -1.728,-47.993 -11.974,-97.953 -41.514,-136.971 -22.748,-30.644 -57.495,-50.801 -94.281,-59.583 -45.377,-11.878 -92.578,-6.791 -138.891,-7.847 -0.072,-111.799 0,-223.574 -0.024,-335.373 -13.942,0 -27.86,0.024 -41.778,-0.024 -32.802,0.072 -65.605,0 -98.384,0.048 l -0.744,0.984 c -0.216,26.444 0,52.888 -0.096,79.332 0.024,244.211 0.048,488.421 0,732.632 0.048,26.563 0.024,53.103 0,79.667"
 | 
				
			||||||
 | 
					   style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path38" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g40" transform="translate(1966.3174,1675.6364)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 c 7.031,-0.552 11.206,-6.839 15.885,-11.326 25.029,-26.9 52.768,-51.208 76.693,-79.164 27.667,-27.5 54.903,-55.456 82.571,-82.979 13.246,-13.942 27.764,-26.66 39.93,-41.658 18.813,-19.653 38.49,-38.514 57.519,-57.999 23.9,-24.812 49.337,-48.185 71.965,-74.197 36.427,-36.378 72.589,-73.02 108.943,-109.471 18.358,-21.524 39.234,-40.722 58.959,-60.974 22.605,-22.941 45.473,-45.665 68.03,-68.678 10.774,-13.294 23.78,-24.524 34.914,-37.506 -103.904,-41.97 -203.488,-94.114 -298.922,-152.761 -246.994,-152.28 -466.224,-350.298 -639.333,-583.398 -25.197,25.196 -50.297,50.488 -75.325,75.852 -13.51,12.886 -24.908,27.788 -38.634,40.458 -30.667,31.627 -63.014,61.695 -92.17,94.738 -29.347,29.107 -58.359,58.623 -87.514,87.922 -18.717,21.933 -40.05,41.37 -59.967,62.151 -18.909,19.461 -39.042,37.77 -56.607,58.503 -14.998,15.477 -30.452,30.499 -45.569,45.88 -21.717,22.629 -45.017,43.722 -65.126,67.862 32.779,-0.048 65.582,0.024 98.384,-0.048 114.391,-98.097 220.407,-205.984 315.384,-322.99 92.914,114.318 196.242,220.022 307.753,316.271 30.955,4.919 61.526,15.646 86.65,34.771 27.212,20.325 46.745,49.672 58.335,81.371 107.312,77.988 219.327,149.929 337.509,210.376 -35.299,64.67 -75.829,126.437 -118.254,186.643 C 176.253,-228.037 104.24,-140.115 26.42,-57.687 20.181,-37.41 11.878,-17.661 0,0" style="fill:#042338;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path42" />
 | 
					   id="g40"
 | 
				
			||||||
 | 
					   transform="translate(1966.3174,1675.6364)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 7.031,-0.552 11.206,-6.839 15.885,-11.326 25.029,-26.9 52.768,-51.208 76.693,-79.164 27.667,-27.5 54.903,-55.456 82.571,-82.979 13.246,-13.942 27.764,-26.66 39.93,-41.658 18.813,-19.653 38.49,-38.514 57.519,-57.999 23.9,-24.812 49.337,-48.185 71.965,-74.197 36.427,-36.378 72.589,-73.02 108.943,-109.471 18.358,-21.524 39.234,-40.722 58.959,-60.974 22.605,-22.941 45.473,-45.665 68.03,-68.678 10.774,-13.294 23.78,-24.524 34.914,-37.506 -103.904,-41.97 -203.488,-94.114 -298.922,-152.761 -246.994,-152.28 -466.224,-350.298 -639.333,-583.398 -25.197,25.196 -50.297,50.488 -75.325,75.852 -13.51,12.886 -24.908,27.788 -38.634,40.458 -30.667,31.627 -63.014,61.695 -92.17,94.738 -29.347,29.107 -58.359,58.623 -87.514,87.922 -18.717,21.933 -40.05,41.37 -59.967,62.151 -18.909,19.461 -39.042,37.77 -56.607,58.503 -14.998,15.477 -30.452,30.499 -45.569,45.88 -21.717,22.629 -45.017,43.722 -65.126,67.862 32.779,-0.048 65.582,0.024 98.384,-0.048 114.391,-98.097 220.407,-205.984 315.384,-322.99 92.914,114.318 196.242,220.022 307.753,316.271 30.955,4.919 61.526,15.646 86.65,34.771 27.212,20.325 46.745,49.672 58.335,81.371 107.312,77.988 219.327,149.929 337.509,210.376 -35.299,64.67 -75.829,126.437 -118.254,186.643 C 176.253,-228.037 104.24,-140.115 26.42,-57.687 20.181,-37.41 11.878,-17.661 0,0"
 | 
				
			||||||
 | 
					   style="fill:#042338;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path42" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g44" transform="translate(1499.3971,1669.1094)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 c 3.551,-2.088 7.415,-3.935 10.39,-6.911 27.932,-28.1 55.912,-56.175 84.036,-84.083 -6.551,-56.679 -4.392,-116.622 20.18,-169.102 16.078,-35.994 38.73,-68.774 65.486,-97.641 31.412,-35.826 69.398,-64.982 102.585,-99.081 25.076,-24.188 47.632,-51.304 64.55,-81.899 17.253,-32.395 21.284,-70.765 15.381,-106.688 -2.831,-17.445 -11.278,-34.794 -26.78,-44.225 -18.045,-11.806 -40.889,-13.222 -61.622,-9.79 -21.981,3.959 -42.402,19.58 -48.185,41.753 -9.718,34.747 -3.935,71.269 -5.663,106.808 -44.369,-0.072 -88.714,0 -133.059,-0.048 -0.048,-17.806 0,-35.635 -0.048,-53.464 0.144,-44.873 6.263,-90.97 27.259,-131.212 17.47,-33.859 46.481,-61.718 81.708,-76.548 46.577,-19.701 98.913,-21.597 148.465,-14.854 -111.511,-96.249 -214.839,-201.953 -307.753,-316.271 -94.977,117.006 -200.993,224.893 -315.383,322.99 13.918,0.048 27.836,0.024 41.777,0.024 0.024,111.799 -0.048,223.574 0.024,335.372 46.313,1.056 93.514,-4.031 138.891,7.847 36.786,8.783 71.533,28.94 94.282,59.583 29.539,39.018 39.785,88.978 41.513,136.971 0.12,48.833 0.048,97.689 0.024,146.522 C 36.69,-87.203 26.852,-39.09 0,0" style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path46" />
 | 
					   id="g44"
 | 
				
			||||||
 | 
					   transform="translate(1499.3971,1669.1094)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 3.551,-2.088 7.415,-3.935 10.39,-6.911 27.932,-28.1 55.912,-56.175 84.036,-84.083 -6.551,-56.679 -4.392,-116.622 20.18,-169.102 16.078,-35.994 38.73,-68.774 65.486,-97.641 31.412,-35.826 69.398,-64.982 102.585,-99.081 25.076,-24.188 47.632,-51.304 64.55,-81.899 17.253,-32.395 21.284,-70.765 15.381,-106.688 -2.831,-17.445 -11.278,-34.794 -26.78,-44.225 -18.045,-11.806 -40.889,-13.222 -61.622,-9.79 -21.981,3.959 -42.402,19.58 -48.185,41.753 -9.718,34.747 -3.935,71.269 -5.663,106.808 -44.369,-0.072 -88.714,0 -133.059,-0.048 -0.048,-17.806 0,-35.635 -0.048,-53.464 0.144,-44.873 6.263,-90.97 27.259,-131.212 17.47,-33.859 46.481,-61.718 81.708,-76.548 46.577,-19.701 98.913,-21.597 148.465,-14.854 -111.511,-96.249 -214.839,-201.953 -307.753,-316.271 -94.977,117.006 -200.993,224.893 -315.383,322.99 13.918,0.048 27.836,0.024 41.777,0.024 0.024,111.799 -0.048,223.574 0.024,335.372 46.313,1.056 93.514,-4.031 138.891,7.847 36.786,8.783 71.533,28.94 94.282,59.583 29.539,39.018 39.785,88.978 41.513,136.971 0.12,48.833 0.048,97.689 0.024,146.522 C 36.69,-87.203 26.852,-39.09 0,0"
 | 
				
			||||||
 | 
					   style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path46" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g48" transform="translate(1748.0469,1601.6797)">
 | 
					                    <g
 | 
				
			||||||
						<path d="M 0,0 C 14.11,17.277 37.722,23.036 59.175,21.597 80.82,20.709 103.4,9.791 112.927,-10.534 c 13.438,-28.94 9.142,-61.719 10.174,-92.626 44.345,0.12 88.691,0 133.036,0.072 0.504,40.002 -0.576,80.556 -11.447,119.358 77.82,-82.428 149.833,-170.35 215.583,-262.664 42.426,-60.207 82.956,-121.973 118.254,-186.643 -118.182,-60.447 -230.196,-132.388 -337.508,-210.376 10.918,30.331 15.238,62.63 16.149,94.737 1.152,45.545 -5.279,92.242 -25.82,133.372 -16.749,36.306 -40.673,68.797 -68.005,97.785 -30.355,33.667 -66.47,61.406 -97.857,94.041 -25.148,24.117 -47.705,51.28 -64.526,81.9 -13.822,25.892 -18.813,55.791 -17.517,84.923 C -15.382,-37.002 -12.79,-15.862 0,0" style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path50" />
 | 
					   id="g48"
 | 
				
			||||||
 | 
					   transform="translate(1748.0469,1601.6797)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="M 0,0 C 14.11,17.277 37.722,23.036 59.175,21.597 80.82,20.709 103.4,9.791 112.927,-10.534 c 13.438,-28.94 9.142,-61.719 10.174,-92.626 44.345,0.12 88.691,0 133.036,0.072 0.504,40.002 -0.576,80.556 -11.447,119.358 77.82,-82.428 149.833,-170.35 215.583,-262.664 42.426,-60.207 82.956,-121.973 118.254,-186.643 -118.182,-60.447 -230.196,-132.388 -337.508,-210.376 10.918,30.331 15.238,62.63 16.149,94.737 1.152,45.545 -5.279,92.242 -25.82,133.372 -16.749,36.306 -40.673,68.797 -68.005,97.785 -30.355,33.667 -66.47,61.406 -97.857,94.041 -25.148,24.117 -47.705,51.28 -64.526,81.9 -13.822,25.892 -18.813,55.791 -17.517,84.923 C -15.382,-37.002 -12.79,-15.862 0,0"
 | 
				
			||||||
 | 
					   style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path50" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g52" transform="translate(1262.7214,1613.126)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 c 23.204,0.024 46.385,0.048 69.589,0 17.278,-0.24 35.275,-5.711 47.537,-18.357 16.294,-18.861 16.797,-45.593 17.277,-69.23 -0.072,-43.985 0,-87.994 -0.024,-131.979 -0.696,-20.589 -2.183,-42.834 -14.613,-60.111 -11.951,-14.854 -31.628,-21.141 -50.153,-21.429 -23.204,-0.072 -46.409,0 -69.613,-0.024 z" style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path54" />
 | 
					   id="g52"
 | 
				
			||||||
 | 
					   transform="translate(1262.7214,1613.126)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 23.204,0.024 46.385,0.048 69.589,0 17.278,-0.24 35.275,-5.711 47.537,-18.357 16.294,-18.861 16.797,-45.593 17.277,-69.23 -0.072,-43.985 0,-87.994 -0.024,-131.979 -0.696,-20.589 -2.183,-42.834 -14.613,-60.111 -11.951,-14.854 -31.628,-21.141 -50.153,-21.429 -23.204,-0.072 -46.409,0 -69.613,-0.024 z"
 | 
				
			||||||
 | 
					   style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path54" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
				</g>
 | 
									</g>
 | 
				
			||||||
			</g>
 | 
								</g>
 | 
				
			||||||
 
 | 
				
			|||||||
| 
		 Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 12 KiB  | 
@@ -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
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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;
 | 
				
			||||||
@@ -293,8 +296,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl
 | 
				
			|||||||
        this.injector.injectMembers(this);
 | 
					        this.injector.injectMembers(this);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        try {
 | 
					        try {
 | 
				
			||||||
            this.injector.getInstance(TranslationUpdateManager.class);
 | 
					            this.injector.getInstance(TranslationUpdateManager.class).upgradeTranslationFile();
 | 
				
			||||||
            TranslationUpdateManager.upgradeTranslationFile();
 | 
					 | 
				
			||||||
        } catch (IOException e) {
 | 
					        } catch (IOException e) {
 | 
				
			||||||
            throw new RuntimeException(e);
 | 
					            throw new RuntimeException(e);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
@@ -819,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;
 | 
				
			||||||
                                }
 | 
					                                }
 | 
				
			||||||
@@ -833,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;
 | 
				
			||||||
@@ -844,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;
 | 
				
			||||||
@@ -875,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();
 | 
					 | 
				
			||||||
                                            }
 | 
					                                            }
 | 
				
			||||||
                                        }
 | 
					                                        }
 | 
				
			||||||
                                    }
 | 
					                                    }
 | 
				
			||||||
@@ -981,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 {
 | 
				
			||||||
@@ -993,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();
 | 
					 | 
				
			||||||
                                        }
 | 
					                                        }
 | 
				
			||||||
                                    }
 | 
					                                    }
 | 
				
			||||||
                                }
 | 
					                                }
 | 
				
			||||||
@@ -1008,8 +1005,20 @@ 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 ChunkGenerator getDefaultWorldGenerator(
 | 
					    public @Nullable
 | 
				
			||||||
 | 
					    final ChunkGenerator getDefaultWorldGenerator(
 | 
				
			||||||
            final @NonNull String worldName,
 | 
					            final @NonNull String worldName,
 | 
				
			||||||
            final @Nullable String id
 | 
					            final @Nullable String id
 | 
				
			||||||
    ) {
 | 
					    ) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -18,9 +18,14 @@
 | 
				
			|||||||
 */
 | 
					 */
 | 
				
			||||||
package com.plotsquared.bukkit.entity;
 | 
					package com.plotsquared.bukkit.entity;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import org.bukkit.entity.Horse;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class HorseStats {
 | 
					class HorseStats {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    double jump;
 | 
					    double jump;
 | 
				
			||||||
    boolean chest;
 | 
					    boolean chest;
 | 
				
			||||||
 | 
					    Horse.Variant variant;
 | 
				
			||||||
 | 
					    Horse.Color color;
 | 
				
			||||||
 | 
					    Horse.Style style;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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,41 +142,43 @@ 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();
 | 
				
			||||||
                if (horse instanceof ChestedHorse horse1) {
 | 
					                if (horse instanceof ChestedHorse horse1) {
 | 
				
			||||||
                    this.horse.chest = horse1.isCarryingChest();
 | 
					                    this.horse.chest = horse1.isCarryingChest();
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 | 
					                //todo these horse features need fixing
 | 
				
			||||||
 | 
					                //this.horse.variant = horse.getVariant();
 | 
				
			||||||
 | 
					                //this.horse.style = horse.getStyle();
 | 
				
			||||||
 | 
					                //this.horse.color = horse.getColor();
 | 
				
			||||||
                storeTameable(horse);
 | 
					                storeTameable(horse);
 | 
				
			||||||
                storeAgeable(horse);
 | 
					                storeAgeable(horse);
 | 
				
			||||||
                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;
 | 
				
			||||||
@@ -210,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(),
 | 
				
			||||||
@@ -234,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;
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
@@ -278,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 //
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -461,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;
 | 
				
			||||||
@@ -502,91 +451,70 @@ 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) {
 | 
				
			||||||
                    ((ChestedHorse) horse).setCarryingChest(this.horse.chest);
 | 
					                    ((ChestedHorse) horse).setCarryingChest(this.horse.chest);
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 | 
					                //todo broken as of 1.13
 | 
				
			||||||
 | 
					                //horse.setVariant(this.horse.variant);
 | 
				
			||||||
 | 
					                //horse.setStyle(this.horse.style);
 | 
				
			||||||
 | 
					                //horse.setColor(this.horse.color);
 | 
				
			||||||
                restoreTameable(horse);
 | 
					                restoreTameable(horse);
 | 
				
			||||||
                restoreAgeable(horse);
 | 
					                restoreAgeable(horse);
 | 
				
			||||||
                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);
 | 
				
			||||||
@@ -597,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) {
 | 
				
			||||||
@@ -685,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
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -24,7 +24,6 @@ import com.plotsquared.core.generator.IndependentPlotGenerator;
 | 
				
			|||||||
import com.plotsquared.core.location.Location;
 | 
					import com.plotsquared.core.location.Location;
 | 
				
			||||||
import com.plotsquared.core.location.UncheckedWorldLocation;
 | 
					import com.plotsquared.core.location.UncheckedWorldLocation;
 | 
				
			||||||
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.SinglePlotArea;
 | 
					import com.plotsquared.core.plot.world.SinglePlotArea;
 | 
				
			||||||
import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator;
 | 
					import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator;
 | 
				
			||||||
import org.bukkit.generator.BlockPopulator;
 | 
					import org.bukkit.generator.BlockPopulator;
 | 
				
			||||||
@@ -47,17 +46,6 @@ final class BlockStatePopulator extends BlockPopulator {
 | 
				
			|||||||
        this.plotGenerator = plotGenerator;
 | 
					        this.plotGenerator = plotGenerator;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * @deprecated Use {@link BlockStatePopulator#BlockStatePopulator(IndependentPlotGenerator)} as plotAreManager is unused
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.0")
 | 
					 | 
				
			||||||
    public BlockStatePopulator(
 | 
					 | 
				
			||||||
            final @NonNull IndependentPlotGenerator plotGenerator,
 | 
					 | 
				
			||||||
            final @NonNull PlotAreaManager plotAreaManager
 | 
					 | 
				
			||||||
    ) {
 | 
					 | 
				
			||||||
        this.plotGenerator = plotGenerator;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
    public void populate(
 | 
					    public void populate(
 | 
				
			||||||
            @NonNull final WorldInfo worldInfo,
 | 
					            @NonNull final WorldInfo worldInfo,
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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.");
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -67,6 +67,16 @@ public class ChunkListener implements Listener {
 | 
				
			|||||||
    private RefMethod methodGetHandleChunk;
 | 
					    private RefMethod methodGetHandleChunk;
 | 
				
			||||||
    private RefMethod methodGetHandleWorld;
 | 
					    private RefMethod methodGetHandleWorld;
 | 
				
			||||||
    private RefField mustSave;
 | 
					    private RefField mustSave;
 | 
				
			||||||
 | 
					    /*
 | 
				
			||||||
 | 
					    private RefMethod methodGetFullChunk;
 | 
				
			||||||
 | 
					    private RefMethod methodGetBukkitChunk;
 | 
				
			||||||
 | 
					    private RefMethod methodGetChunkProvider;
 | 
				
			||||||
 | 
					    private RefMethod methodGetVisibleMap;
 | 
				
			||||||
 | 
					    private RefField worldServer;
 | 
				
			||||||
 | 
					    private RefField playerChunkMap;
 | 
				
			||||||
 | 
					    private RefField updatingChunks;
 | 
				
			||||||
 | 
					    private RefField visibleChunks;
 | 
				
			||||||
 | 
					    */
 | 
				
			||||||
    private Chunk lastChunk;
 | 
					    private Chunk lastChunk;
 | 
				
			||||||
    private boolean ignoreUnload = false;
 | 
					    private boolean ignoreUnload = false;
 | 
				
			||||||
    private boolean isTrueForNotSave = true;
 | 
					    private boolean isTrueForNotSave = true;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -113,7 +113,15 @@ public class EntityEventListener implements Listener {
 | 
				
			|||||||
            return;
 | 
					            return;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        Entity victim = event.getEntity();
 | 
					        Entity victim = event.getEntity();
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					        if (victim.getType().equals(EntityType.ITEM_FRAME)) {
 | 
				
			||||||
 | 
					            Plot plot = BukkitUtil.getLocation(victim).getPlot();
 | 
				
			||||||
 | 
					            if (plot != null && !plot.isAdded(damager.getUniqueId())) {
 | 
				
			||||||
 | 
					                event.setCancelled(true);
 | 
				
			||||||
 | 
					                return;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					*/
 | 
				
			||||||
        if (!BukkitEntityUtil.entityDamage(damager, victim, event.getCause())) {
 | 
					        if (!BukkitEntityUtil.entityDamage(damager, victim, event.getCause())) {
 | 
				
			||||||
            if (event.isCancelled()) {
 | 
					            if (event.isCancelled()) {
 | 
				
			||||||
                if (victim instanceof Ageable ageable) {
 | 
					                if (victim instanceof Ageable ageable) {
 | 
				
			||||||
@@ -137,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) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,93 +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.listener;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import com.google.inject.Inject;
 | 
					 | 
				
			||||||
import com.plotsquared.bukkit.util.BukkitUtil;
 | 
					 | 
				
			||||||
import com.plotsquared.core.configuration.Settings;
 | 
					 | 
				
			||||||
import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
					 | 
				
			||||||
import com.plotsquared.core.location.Location;
 | 
					 | 
				
			||||||
import com.plotsquared.core.player.PlotPlayer;
 | 
					 | 
				
			||||||
import com.plotsquared.core.plot.PlotArea;
 | 
					 | 
				
			||||||
import com.plotsquared.core.plot.world.PlotAreaManager;
 | 
					 | 
				
			||||||
import net.kyori.adventure.text.Component;
 | 
					 | 
				
			||||||
import net.kyori.adventure.text.minimessage.tag.Tag;
 | 
					 | 
				
			||||||
import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver;
 | 
					 | 
				
			||||||
import org.bukkit.block.Banner;
 | 
					 | 
				
			||||||
import org.bukkit.block.Beacon;
 | 
					 | 
				
			||||||
import org.bukkit.block.BlockState;
 | 
					 | 
				
			||||||
import org.bukkit.block.CommandBlock;
 | 
					 | 
				
			||||||
import org.bukkit.block.Comparator;
 | 
					 | 
				
			||||||
import org.bukkit.block.Conduit;
 | 
					 | 
				
			||||||
import org.bukkit.block.Container;
 | 
					 | 
				
			||||||
import org.bukkit.block.CreatureSpawner;
 | 
					 | 
				
			||||||
import org.bukkit.block.DaylightDetector;
 | 
					 | 
				
			||||||
import org.bukkit.block.EnchantingTable;
 | 
					 | 
				
			||||||
import org.bukkit.block.EndGateway;
 | 
					 | 
				
			||||||
import org.bukkit.block.EnderChest;
 | 
					 | 
				
			||||||
import org.bukkit.block.Jukebox;
 | 
					 | 
				
			||||||
import org.bukkit.block.Sign;
 | 
					 | 
				
			||||||
import org.bukkit.block.Skull;
 | 
					 | 
				
			||||||
import org.bukkit.block.Structure;
 | 
					 | 
				
			||||||
import org.bukkit.block.data.type.Bed;
 | 
					 | 
				
			||||||
import org.bukkit.event.EventHandler;
 | 
					 | 
				
			||||||
import org.bukkit.event.block.BlockPlaceEvent;
 | 
					 | 
				
			||||||
import org.checkerframework.checker.nullness.qual.NonNull;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * @deprecated P2 effectively no longer supports 1.13
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
@Deprecated(forRemoval = true, since = "6.10.4")
 | 
					 | 
				
			||||||
public class PaperListener113 extends PaperListener {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Inject
 | 
					 | 
				
			||||||
    public PaperListener113(@NonNull PlotAreaManager plotAreaManager) {
 | 
					 | 
				
			||||||
        super(plotAreaManager);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @EventHandler
 | 
					 | 
				
			||||||
    public void onBlockPlace(BlockPlaceEvent event) {
 | 
					 | 
				
			||||||
        if (!Settings.Paper_Components.TILE_ENTITY_CHECK || !Settings.Enabled_Components.CHUNK_PROCESSOR) {
 | 
					 | 
				
			||||||
            return;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        BlockState state = event.getBlock().getState(false);
 | 
					 | 
				
			||||||
        if (!(state instanceof Banner || state instanceof Beacon || state instanceof Bed || state instanceof CommandBlock
 | 
					 | 
				
			||||||
                || state instanceof Comparator || state instanceof Conduit || state instanceof Container || state instanceof CreatureSpawner
 | 
					 | 
				
			||||||
                || state instanceof DaylightDetector || state instanceof EnchantingTable || state instanceof EnderChest || state instanceof EndGateway
 | 
					 | 
				
			||||||
                || state instanceof Jukebox || state instanceof Sign || state instanceof Skull || state instanceof Structure)) {
 | 
					 | 
				
			||||||
            return;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        final Location location = BukkitUtil.adapt(event.getBlock().getLocation());
 | 
					 | 
				
			||||||
        final PlotArea plotArea = location.getPlotArea();
 | 
					 | 
				
			||||||
        if (plotArea == null) {
 | 
					 | 
				
			||||||
            return;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        final int tileEntityCount = event.getBlock().getChunk().getTileEntities(false).length;
 | 
					 | 
				
			||||||
        if (tileEntityCount >= Settings.Chunk_Processor.MAX_TILES) {
 | 
					 | 
				
			||||||
            final PlotPlayer<?> plotPlayer = BukkitUtil.adapt(event.getPlayer());
 | 
					 | 
				
			||||||
            plotPlayer.sendMessage(
 | 
					 | 
				
			||||||
                    TranslatableCaption.of("errors.tile_entity_cap_reached"),
 | 
					 | 
				
			||||||
                    TagResolver.resolver("amount", Tag.inserting(Component.text(Settings.Chunk_Processor.MAX_TILES)))
 | 
					 | 
				
			||||||
            );
 | 
					 | 
				
			||||||
            event.setCancelled(true);
 | 
					 | 
				
			||||||
            event.setBuild(false);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -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;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
@@ -844,6 +844,10 @@ public class PlayerEventListener implements Listener {
 | 
				
			|||||||
    @SuppressWarnings("deprecation")
 | 
					    @SuppressWarnings("deprecation")
 | 
				
			||||||
    @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
 | 
					    @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
 | 
				
			||||||
    public void onInventoryClick(InventoryClickEvent event) {
 | 
					    public void onInventoryClick(InventoryClickEvent event) {
 | 
				
			||||||
 | 
					        /*if (!event.isLeftClick() || (event.getAction() != InventoryAction.PLACE_ALL) || event
 | 
				
			||||||
 | 
					            .isShiftClick()) {
 | 
				
			||||||
 | 
					            return;
 | 
				
			||||||
 | 
					        }*/
 | 
				
			||||||
        HumanEntity entity = event.getWhoClicked();
 | 
					        HumanEntity entity = event.getWhoClicked();
 | 
				
			||||||
        if (!(entity instanceof Player) || !this.plotAreaManager
 | 
					        if (!(entity instanceof Player) || !this.plotAreaManager
 | 
				
			||||||
                .hasPlotArea(entity.getWorld().getName())) {
 | 
					                .hasPlotArea(entity.getWorld().getName())) {
 | 
				
			||||||
@@ -1112,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());
 | 
				
			||||||
@@ -1140,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;
 | 
				
			||||||
@@ -1187,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.
 | 
				
			||||||
@@ -1200,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;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -89,6 +89,11 @@ public class SingleWorldListener implements Listener {
 | 
				
			|||||||
        markChunkAsClean(event.getChunk());
 | 
					        markChunkAsClean(event.getChunk());
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    //    @EventHandler
 | 
				
			||||||
 | 
					    //    public void onPopulate(ChunkPopulateEvent event) {
 | 
				
			||||||
 | 
					    //        handle(event);
 | 
				
			||||||
 | 
					    //    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @EventHandler(priority = EventPriority.LOWEST)
 | 
					    @EventHandler(priority = EventPriority.LOWEST)
 | 
				
			||||||
    public void onChunkLoad(ChunkLoadEvent event) {
 | 
					    public void onChunkLoad(ChunkLoadEvent event) {
 | 
				
			||||||
        handle(event);
 | 
					        handle(event);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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";
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
@@ -41,9 +41,13 @@ public class BukkitOfflinePlayer implements OfflinePlotPlayer {
 | 
				
			|||||||
     * @param player            Bukkit OfflinePlayer player to convert
 | 
					     * @param player            Bukkit OfflinePlayer player to convert
 | 
				
			||||||
     * @param permissionHandler Permission Profile to be used
 | 
					     * @param permissionHandler Permission Profile to be used
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public BukkitOfflinePlayer(final @NonNull OfflinePlayer player, final @NonNull PermissionHandler permissionHandler) {
 | 
					    public BukkitOfflinePlayer(
 | 
				
			||||||
 | 
					            final @NonNull OfflinePlayer player, final @NonNull
 | 
				
			||||||
 | 
					    PermissionHandler permissionHandler
 | 
				
			||||||
 | 
					    ) {
 | 
				
			||||||
        this.player = player;
 | 
					        this.player = player;
 | 
				
			||||||
        this.permissionProfile = permissionHandler.getPermissionProfile(this).orElse(NullPermissionProfile.INSTANCE);
 | 
					        this.permissionProfile = permissionHandler.getPermissionProfile(this)
 | 
				
			||||||
 | 
					                .orElse(NullPermissionProfile.INSTANCE);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @NonNull
 | 
					    @NonNull
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -71,29 +71,8 @@ public class BukkitPlayer extends PlotPlayer<Player> {
 | 
				
			|||||||
     * @param eventDispatcher   EventDispatcher instance
 | 
					     * @param eventDispatcher   EventDispatcher instance
 | 
				
			||||||
     * @param player            Bukkit player instance
 | 
					     * @param player            Bukkit player instance
 | 
				
			||||||
     * @param permissionHandler PermissionHandler instance
 | 
					     * @param permissionHandler PermissionHandler instance
 | 
				
			||||||
     * @deprecated Please do not use this method. Instead use {@link BukkitUtil#adapt(Player)}, as it caches player objects.
 | 
					 | 
				
			||||||
     *         This method will be made private in a future release.
 | 
					 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "TODO")
 | 
					    BukkitPlayer(
 | 
				
			||||||
    public BukkitPlayer(
 | 
					 | 
				
			||||||
            final @NonNull PlotAreaManager plotAreaManager,
 | 
					 | 
				
			||||||
            final @NonNull EventDispatcher eventDispatcher,
 | 
					 | 
				
			||||||
            final @NonNull Player player,
 | 
					 | 
				
			||||||
            final @NonNull PermissionHandler permissionHandler
 | 
					 | 
				
			||||||
    ) {
 | 
					 | 
				
			||||||
        this(plotAreaManager, eventDispatcher, player, false, permissionHandler);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * @param plotAreaManager   PlotAreaManager instance
 | 
					 | 
				
			||||||
     * @param eventDispatcher   EventDispatcher instance
 | 
					 | 
				
			||||||
     * @param player            Bukkit player instance
 | 
					 | 
				
			||||||
     * @param permissionHandler PermissionHandler instance
 | 
					 | 
				
			||||||
     * @deprecated Please do not use this method. Instead use {@link BukkitUtil#adapt(Player)}, as it caches player objects.
 | 
					 | 
				
			||||||
     *         This method will be made private in a future release.
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "TODO")
 | 
					 | 
				
			||||||
    public BukkitPlayer(
 | 
					 | 
				
			||||||
            final @NonNull PlotAreaManager plotAreaManager,
 | 
					            final @NonNull PlotAreaManager plotAreaManager,
 | 
				
			||||||
            final @NonNull EventDispatcher eventDispatcher,
 | 
					            final @NonNull EventDispatcher eventDispatcher,
 | 
				
			||||||
            final @NonNull Player player,
 | 
					            final @NonNull Player player,
 | 
				
			||||||
@@ -197,6 +176,10 @@ public class BukkitPlayer extends PlotPlayer<Player> {
 | 
				
			|||||||
            final Set<PermissionAttachmentInfo> effective = player.getEffectivePermissions();
 | 
					            final Set<PermissionAttachmentInfo> effective = player.getEffectivePermissions();
 | 
				
			||||||
            if (!effective.isEmpty()) {
 | 
					            if (!effective.isEmpty()) {
 | 
				
			||||||
                for (PermissionAttachmentInfo attach : effective) {
 | 
					                for (PermissionAttachmentInfo attach : effective) {
 | 
				
			||||||
 | 
					                    // Ignore all "false" permissions
 | 
				
			||||||
 | 
					                    if (!attach.getValue()) {
 | 
				
			||||||
 | 
					                        continue;
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
                    String permStr = attach.getPermission();
 | 
					                    String permStr = attach.getPermission();
 | 
				
			||||||
                    if (permStr.startsWith(stubPlus)) {
 | 
					                    if (permStr.startsWith(stubPlus)) {
 | 
				
			||||||
                        hasAny = true;
 | 
					                        hasAny = true;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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);
 | 
				
			||||||
@@ -66,13 +65,12 @@ public class BukkitPlayerManager extends PlayerManager<BukkitPlayer, Player> {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
    @SuppressWarnings("deprecation")
 | 
					 | 
				
			||||||
    public @NonNull BukkitPlayer createPlayer(final @NonNull UUID uuid) {
 | 
					    public @NonNull BukkitPlayer createPlayer(final @NonNull UUID uuid) {
 | 
				
			||||||
        final Player player = Bukkit.getPlayer(uuid);
 | 
					        final Player player = Bukkit.getPlayer(uuid);
 | 
				
			||||||
        if (player == null || !player.isOnline()) {
 | 
					        if (player == null || !player.isOnline()) {
 | 
				
			||||||
            throw new NoSuchPlayerException(uuid);
 | 
					            throw new NoSuchPlayerException(uuid);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, player, this.permissionHandler);
 | 
					        return new BukkitPlayer(this.plotAreaManager, this.eventDispatcher, player, false, this.permissionHandler);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Nullable
 | 
					    @Nullable
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -18,6 +18,8 @@
 | 
				
			|||||||
 */
 | 
					 */
 | 
				
			||||||
package com.plotsquared.bukkit.schematic;
 | 
					package com.plotsquared.bukkit.schematic;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import com.destroystokyo.paper.profile.PlayerProfile;
 | 
				
			||||||
 | 
					import com.destroystokyo.paper.profile.ProfileProperty;
 | 
				
			||||||
import com.plotsquared.bukkit.util.BukkitUtil;
 | 
					import com.plotsquared.bukkit.util.BukkitUtil;
 | 
				
			||||||
import com.sk89q.jnbt.ByteTag;
 | 
					import com.sk89q.jnbt.ByteTag;
 | 
				
			||||||
import com.sk89q.jnbt.CompoundTag;
 | 
					import com.sk89q.jnbt.CompoundTag;
 | 
				
			||||||
@@ -28,16 +30,22 @@ import com.sk89q.jnbt.Tag;
 | 
				
			|||||||
import com.sk89q.worldedit.blocks.BaseItemStack;
 | 
					import com.sk89q.worldedit.blocks.BaseItemStack;
 | 
				
			||||||
import com.sk89q.worldedit.bukkit.BukkitAdapter;
 | 
					import com.sk89q.worldedit.bukkit.BukkitAdapter;
 | 
				
			||||||
import com.sk89q.worldedit.world.item.ItemType;
 | 
					import com.sk89q.worldedit.world.item.ItemType;
 | 
				
			||||||
 | 
					import io.papermc.lib.PaperLib;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.LogManager;
 | 
				
			||||||
 | 
					import org.apache.logging.log4j.Logger;
 | 
				
			||||||
import org.bukkit.Bukkit;
 | 
					import org.bukkit.Bukkit;
 | 
				
			||||||
import org.bukkit.ChatColor;
 | 
					import org.bukkit.ChatColor;
 | 
				
			||||||
 | 
					import org.bukkit.DyeColor;
 | 
				
			||||||
import org.bukkit.World;
 | 
					import org.bukkit.World;
 | 
				
			||||||
 | 
					import org.bukkit.block.Banner;
 | 
				
			||||||
import org.bukkit.block.Block;
 | 
					import org.bukkit.block.Block;
 | 
				
			||||||
import org.bukkit.block.Container;
 | 
					import org.bukkit.block.Container;
 | 
				
			||||||
import org.bukkit.block.Sign;
 | 
					import org.bukkit.block.Sign;
 | 
				
			||||||
import org.bukkit.block.Skull;
 | 
					import org.bukkit.block.Skull;
 | 
				
			||||||
 | 
					import org.bukkit.block.banner.Pattern;
 | 
				
			||||||
 | 
					import org.bukkit.block.banner.PatternType;
 | 
				
			||||||
import org.bukkit.enchantments.Enchantment;
 | 
					import org.bukkit.enchantments.Enchantment;
 | 
				
			||||||
import org.bukkit.inventory.Inventory;
 | 
					import org.bukkit.inventory.Inventory;
 | 
				
			||||||
import org.bukkit.inventory.InventoryHolder;
 | 
					 | 
				
			||||||
import org.bukkit.inventory.ItemStack;
 | 
					import org.bukkit.inventory.ItemStack;
 | 
				
			||||||
import org.checkerframework.checker.nullness.qual.NonNull;
 | 
					import org.checkerframework.checker.nullness.qual.NonNull;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -46,20 +54,15 @@ import java.util.HashMap;
 | 
				
			|||||||
import java.util.List;
 | 
					import java.util.List;
 | 
				
			||||||
import java.util.Map;
 | 
					import java.util.Map;
 | 
				
			||||||
import java.util.Map.Entry;
 | 
					import java.util.Map.Entry;
 | 
				
			||||||
 | 
					import java.util.Objects;
 | 
				
			||||||
 | 
					import java.util.UUID;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public class StateWrapper {
 | 
					public class StateWrapper {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public org.bukkit.block.BlockState state = null;
 | 
					    public CompoundTag tag;
 | 
				
			||||||
    public CompoundTag tag = null;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    private boolean paperErrorTextureSent = false;
 | 
				
			||||||
     * @deprecated in favour of using WE methods for obtaining NBT, specifically by obtaining a
 | 
					    private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + StateWrapper.class.getSimpleName());
 | 
				
			||||||
     *         {@link com.sk89q.worldedit.world.block.BaseBlock} and then using {@link com.sk89q.worldedit.world.block.BaseBlock#getNbtData()}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.0")
 | 
					 | 
				
			||||||
    public StateWrapper(org.bukkit.block.BlockState state) {
 | 
					 | 
				
			||||||
        this.state = state;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public StateWrapper(CompoundTag tag) {
 | 
					    public StateWrapper(CompoundTag tag) {
 | 
				
			||||||
        this.tag = tag;
 | 
					        this.tag = tag;
 | 
				
			||||||
@@ -237,9 +240,8 @@ public class StateWrapper {
 | 
				
			|||||||
                        return true;
 | 
					                        return true;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                    String player = skullOwner.getString("Name");
 | 
					                    String player = skullOwner.getString("Name");
 | 
				
			||||||
                    if (player == null || player.isEmpty()) {
 | 
					
 | 
				
			||||||
                        return false;
 | 
					                    if (player != null && !player.isEmpty()) {
 | 
				
			||||||
                    }
 | 
					 | 
				
			||||||
                        try {
 | 
					                        try {
 | 
				
			||||||
                            skull.setOwningPlayer(Bukkit.getOfflinePlayer(player));
 | 
					                            skull.setOwningPlayer(Bukkit.getOfflinePlayer(player));
 | 
				
			||||||
                            skull.update(true);
 | 
					                            skull.update(true);
 | 
				
			||||||
@@ -248,31 +250,61 @@ public class StateWrapper {
 | 
				
			|||||||
                        }
 | 
					                        }
 | 
				
			||||||
                        return true;
 | 
					                        return true;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                return false;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return false;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					                    final CompoundTag properties = (CompoundTag) skullOwner.getValue().get("Properties");
 | 
				
			||||||
     * Get a CompoundTag of the contents of a block's inventory (chest, furnace, etc.).
 | 
					                    if (properties == null) {
 | 
				
			||||||
     *
 | 
					                        return false;
 | 
				
			||||||
     * @deprecated in favour of using WorldEdit methods for obtaining NBT, specifically by obtaining a
 | 
					 | 
				
			||||||
     *         {@link com.sk89q.worldedit.world.block.BaseBlock} and then using {@link com.sk89q.worldedit.world.block.BaseBlock#getNbtData()}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.0")
 | 
					 | 
				
			||||||
    public CompoundTag getTag() {
 | 
					 | 
				
			||||||
        if (this.tag != null) {
 | 
					 | 
				
			||||||
            return this.tag;
 | 
					 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
        if (this.state instanceof InventoryHolder inv) {
 | 
					                    final ListTag textures = properties.getListTag("textures");
 | 
				
			||||||
            ItemStack[] contents = inv.getInventory().getContents();
 | 
					                    if (textures.getValue().isEmpty()) {
 | 
				
			||||||
            Map<String, Tag> values = new HashMap<>();
 | 
					                        return false;
 | 
				
			||||||
            values.put("Items", new ListTag(CompoundTag.class, serializeInventory(contents)));
 | 
					 | 
				
			||||||
            return new CompoundTag(values);
 | 
					 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
 | 
					                    final CompoundTag textureCompound = (CompoundTag) textures.getValue().get(0);
 | 
				
			||||||
 | 
					                    if (textureCompound == null) {
 | 
				
			||||||
 | 
					                        return false;
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
 | 
					                    String textureValue = textureCompound.getString("Value");
 | 
				
			||||||
 | 
					                    if (textureValue == null) {
 | 
				
			||||||
 | 
					                        return false;
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
 | 
					                    if (!PaperLib.isPaper()) {
 | 
				
			||||||
 | 
					                        if (!paperErrorTextureSent) {
 | 
				
			||||||
 | 
					                            paperErrorTextureSent = true;
 | 
				
			||||||
 | 
					                            LOGGER.error("Failed to populate skull data in your road schematic - This is a Spigot limitation.");
 | 
				
			||||||
 | 
					                        }
 | 
				
			||||||
 | 
					                        return false;
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
 | 
					                    final PlayerProfile profile = Bukkit.createProfile(UUID.randomUUID());
 | 
				
			||||||
 | 
					                    profile.setProperty(new ProfileProperty("textures", textureValue));
 | 
				
			||||||
 | 
					                    skull.setPlayerProfile(profile);
 | 
				
			||||||
 | 
					                    skull.update(true);
 | 
				
			||||||
 | 
					                    return true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                return false;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            case "banner" -> {
 | 
				
			||||||
 | 
					                if (state instanceof Banner banner) {
 | 
				
			||||||
 | 
					                    List<Tag> patterns = this.tag.getListTag("Patterns").getValue();
 | 
				
			||||||
 | 
					                    if (patterns == null || patterns.isEmpty()) {
 | 
				
			||||||
 | 
					                        return false;
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
 | 
					                    banner.setPatterns(patterns.stream().map(t -> (CompoundTag) t).map(compoundTag -> {
 | 
				
			||||||
 | 
					                        DyeColor color = DyeColor.getByWoolData((byte) compoundTag.getInt("Color"));
 | 
				
			||||||
 | 
					                        PatternType patternType = PatternType.getByIdentifier(compoundTag.getString("Pattern"));
 | 
				
			||||||
 | 
					                        if (color == null || patternType == null) {
 | 
				
			||||||
                            return null;
 | 
					                            return null;
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
 | 
					                        return new Pattern(color, patternType);
 | 
				
			||||||
 | 
					                    }).filter(Objects::nonNull).toList());
 | 
				
			||||||
 | 
					                    banner.update(true);
 | 
				
			||||||
 | 
					                    return true;
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                return false;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return false;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public String getId() {
 | 
					    public String getId() {
 | 
				
			||||||
        String tileid = this.tag.getString("id").toLowerCase();
 | 
					        String tileid = this.tag.getString("id").toLowerCase();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -69,9 +69,8 @@ public class BukkitRegionManager extends RegionManager {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    @Inject
 | 
					    @Inject
 | 
				
			||||||
    public BukkitRegionManager(
 | 
					    public BukkitRegionManager(
 | 
				
			||||||
            @NonNull WorldUtil worldUtil,
 | 
					            @NonNull WorldUtil worldUtil, @NonNull GlobalBlockQueue blockQueue, @NonNull
 | 
				
			||||||
            @NonNull GlobalBlockQueue blockQueue,
 | 
					    ProgressSubscriberFactory subscriberFactory
 | 
				
			||||||
            @NonNull ProgressSubscriberFactory subscriberFactory
 | 
					 | 
				
			||||||
    ) {
 | 
					    ) {
 | 
				
			||||||
        super(worldUtil, blockQueue, subscriberFactory);
 | 
					        super(worldUtil, blockQueue, subscriberFactory);
 | 
				
			||||||
        this.blockQueue = blockQueue;
 | 
					        this.blockQueue = blockQueue;
 | 
				
			||||||
@@ -258,7 +257,7 @@ public class BukkitRegionManager extends RegionManager {
 | 
				
			|||||||
            map.saveEntitiesOut(Bukkit.getWorld(world.getName()).getChunkAt(x, z), currentPlotClear);
 | 
					            map.saveEntitiesOut(Bukkit.getWorld(world.getName()).getChunkAt(x, z), currentPlotClear);
 | 
				
			||||||
            AugmentedUtils.bypass(
 | 
					            AugmentedUtils.bypass(
 | 
				
			||||||
                    ignoreAugment,
 | 
					                    ignoreAugment,
 | 
				
			||||||
                    () -> ChunkManager.setChunkInPlotArea(null, new RunnableVal<>() {
 | 
					                    () -> ChunkManager.setChunkInPlotArea(null, new RunnableVal<ZeroedDelegateScopedQueueCoordinator>() {
 | 
				
			||||||
                        @Override
 | 
					                        @Override
 | 
				
			||||||
                        public void run(ZeroedDelegateScopedQueueCoordinator value) {
 | 
					                        public void run(ZeroedDelegateScopedQueueCoordinator value) {
 | 
				
			||||||
                            Location min = value.getMin();
 | 
					                            Location min = value.getMin();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -31,6 +31,7 @@ import org.apache.logging.log4j.Logger;
 | 
				
			|||||||
import org.bukkit.Chunk;
 | 
					import org.bukkit.Chunk;
 | 
				
			||||||
import org.bukkit.World;
 | 
					import org.bukkit.World;
 | 
				
			||||||
import org.bukkit.entity.Entity;
 | 
					import org.bukkit.entity.Entity;
 | 
				
			||||||
 | 
					import org.bukkit.entity.Player;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import java.util.HashMap;
 | 
					import java.util.HashMap;
 | 
				
			||||||
import java.util.HashSet;
 | 
					import java.util.HashSet;
 | 
				
			||||||
@@ -84,6 +85,28 @@ public class ContentMap {
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    void saveEntitiesIn(Chunk chunk, CuboidRegion region, boolean delete) {
 | 
				
			||||||
 | 
					        for (Entity entity : chunk.getEntities()) {
 | 
				
			||||||
 | 
					            Location location = BukkitUtil.adapt(entity.getLocation());
 | 
				
			||||||
 | 
					            int x = location.getX();
 | 
				
			||||||
 | 
					            int z = location.getZ();
 | 
				
			||||||
 | 
					            if (!BukkitChunkManager.isIn(region, x, z)) {
 | 
				
			||||||
 | 
					                continue;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            if (entity.getVehicle() != null) {
 | 
				
			||||||
 | 
					                continue;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            EntityWrapper wrap = new ReplicatingEntityWrapper(entity, (short) 2);
 | 
				
			||||||
 | 
					            wrap.saveEntity();
 | 
				
			||||||
 | 
					            this.entities.add(wrap);
 | 
				
			||||||
 | 
					            if (delete) {
 | 
				
			||||||
 | 
					                if (!(entity instanceof Player)) {
 | 
				
			||||||
 | 
					                    entity.remove();
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    void restoreEntities(World world) {
 | 
					    void restoreEntities(World world) {
 | 
				
			||||||
        for (EntityWrapper entity : this.entities) {
 | 
					        for (EntityWrapper entity : this.entities) {
 | 
				
			||||||
            try {
 | 
					            try {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -54,8 +54,8 @@ public class UpdateUtility implements Listener {
 | 
				
			|||||||
        internalVersion = PlotSquared.get().getVersion();
 | 
					        internalVersion = PlotSquared.get().getVersion();
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // Suppress Json deprecation, we can't use features from gson 2.8.1 and newer yet
 | 
					 | 
				
			||||||
    @SuppressWarnings({"deprecation", "DefaultCharset"})
 | 
					    @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 {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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/")
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -203,7 +203,7 @@ public interface PlotPlatform<P> extends LocaleHolder {
 | 
				
			|||||||
     * @return Player manager
 | 
					     * @return Player manager
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    default @NonNull PlayerManager<? extends PlotPlayer<P>, ? extends P> playerManager() {
 | 
					    default @NonNull PlayerManager<? extends PlotPlayer<P>, ? extends P> playerManager() {
 | 
				
			||||||
        return injector().getInstance(Key.get(new TypeLiteral<>() {
 | 
					        return injector().getInstance(Key.get(new TypeLiteral<PlayerManager<? extends PlotPlayer<P>, ? extends P>>() {
 | 
				
			||||||
        }));
 | 
					        }));
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -133,6 +133,8 @@ public class PlotSquared {
 | 
				
			|||||||
    private final Map<String, CaptionMap> captionMaps = new HashMap<>();
 | 
					    private final Map<String, CaptionMap> captionMaps = new HashMap<>();
 | 
				
			||||||
    public HashMap<String, HashMap<PlotId, Plot>> plots_tmp;
 | 
					    public HashMap<String, HashMap<PlotId, Plot>> plots_tmp;
 | 
				
			||||||
    private CaptionLoader captionLoader;
 | 
					    private CaptionLoader captionLoader;
 | 
				
			||||||
 | 
					    // WorldEdit instance
 | 
				
			||||||
 | 
					    private WorldEdit worldedit;
 | 
				
			||||||
    private File configFile;
 | 
					    private File configFile;
 | 
				
			||||||
    private File worldsFile;
 | 
					    private File worldsFile;
 | 
				
			||||||
    private YamlConfiguration worldConfiguration;
 | 
					    private YamlConfiguration worldConfiguration;
 | 
				
			||||||
@@ -221,11 +223,11 @@ public class PlotSquared {
 | 
				
			|||||||
                }
 | 
					                }
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            WorldEdit worldedit = WorldEdit.getInstance();
 | 
					            this.worldedit = WorldEdit.getInstance();
 | 
				
			||||||
            WorldEdit.getInstance().getEventBus().register(new WEPlatformReadyListener());
 | 
					            WorldEdit.getInstance().getEventBus().register(new WEPlatformReadyListener());
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            // Create Event utility class
 | 
					            // Create Event utility class
 | 
				
			||||||
            this.eventDispatcher = new EventDispatcher(worldedit);
 | 
					            this.eventDispatcher = new EventDispatcher(this.worldedit);
 | 
				
			||||||
            // Create plot listener
 | 
					            // Create plot listener
 | 
				
			||||||
            this.plotListener = new PlotListener(this.eventDispatcher);
 | 
					            this.plotListener = new PlotListener(this.eventDispatcher);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1013,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>
 | 
				
			||||||
     *
 | 
					     *
 | 
				
			||||||
@@ -1523,6 +1525,10 @@ public class PlotSquared {
 | 
				
			|||||||
        return this.backgroundUUIDPipeline;
 | 
					        return this.backgroundUUIDPipeline;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public @NonNull WorldEdit getWorldEdit() {
 | 
				
			||||||
 | 
					        return this.worldedit;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public @NonNull File getConfigFile() {
 | 
					    public @NonNull File getConfigFile() {
 | 
				
			||||||
        return this.configFile;
 | 
					        return this.configFile;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -136,7 +136,9 @@ public class SimpleBackupManager implements BackupManager {
 | 
				
			|||||||
        return this.backupLimit;
 | 
					        return this.backupLimit;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private record PlotCacheKey(Plot plot) {
 | 
					    private record PlotCacheKey(
 | 
				
			||||||
 | 
					            Plot plot
 | 
				
			||||||
 | 
					    ) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        @Override
 | 
					        @Override
 | 
				
			||||||
        public boolean equals(final Object o) {
 | 
					        public boolean equals(final Object o) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -173,7 +173,7 @@ public class QuadMap<T> {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    public QuadMap<T> newInstance(int newsize, int x, int z, int min) {
 | 
					    public QuadMap<T> newInstance(int newsize, int x, int z, int min) {
 | 
				
			||||||
        try {
 | 
					        try {
 | 
				
			||||||
            return new QuadMap<>(newsize, x, z, min) {
 | 
					            return new QuadMap<T>(newsize, x, z, min) {
 | 
				
			||||||
                @Override
 | 
					                @Override
 | 
				
			||||||
                public CuboidRegion getRegion(T value) {
 | 
					                public CuboidRegion getRegion(T value) {
 | 
				
			||||||
                    return QuadMap.this.getRegion(value);
 | 
					                    return QuadMap.this.getRegion(value);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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,13 +233,11 @@ 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.getInstance().newEditSession(selectedRegion.getWorld());
 | 
					                    EditSessionBuilder editSessionBuilder = WorldEdit.getInstance().newEditSessionBuilder();
 | 
				
			||||||
                    final ForwardExtentCopy forwardExtentCopy = new ForwardExtentCopy(
 | 
					                    editSessionBuilder.world(selectedRegion.getWorld());
 | 
				
			||||||
                            editSession,
 | 
					                    final EditSession editSession = editSessionBuilder.build();
 | 
				
			||||||
                            selectedRegion,
 | 
					                    final ForwardExtentCopy forwardExtentCopy =
 | 
				
			||||||
                            clipboard,
 | 
					                            new ForwardExtentCopy(editSession, selectedRegion, clipboard, selectedRegion.getMinimumPoint());
 | 
				
			||||||
                            selectedRegion.getMinimumPoint()
 | 
					 | 
				
			||||||
                    );
 | 
					 | 
				
			||||||
                    forwardExtentCopy.setCopyingBiomes(true);
 | 
					                    forwardExtentCopy.setCopyingBiomes(true);
 | 
				
			||||||
                    forwardExtentCopy.setCopyingEntities(true);
 | 
					                    forwardExtentCopy.setCopyingEntities(true);
 | 
				
			||||||
                    Operations.complete(forwardExtentCopy);
 | 
					                    Operations.complete(forwardExtentCopy);
 | 
				
			||||||
@@ -725,7 +724,7 @@ public class Area extends SubCommand {
 | 
				
			|||||||
                        return false;
 | 
					                        return false;
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                final List<PlotArea> areas = new ArrayList<>(Arrays.asList(this.plotAreaManager.getAllPlotAreas()));
 | 
					                final List<PlotArea> areas = new ArrayList<>(Arrays.asList(this.plotAreaManager.getAllPlotAreas()));
 | 
				
			||||||
                paginate(player, areas, 8, page, new RunnableVal3<>() {
 | 
					                paginate(player, areas, 8, page, new RunnableVal3<Integer, PlotArea, CaptionHolder>() {
 | 
				
			||||||
                    @Override
 | 
					                    @Override
 | 
				
			||||||
                    public void run(Integer i, PlotArea area, CaptionHolder caption) {
 | 
					                    public void run(Integer i, PlotArea area, CaptionHolder caption) {
 | 
				
			||||||
                        String name;
 | 
					                        String name;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -83,7 +83,7 @@ public class Caps extends SubCommand {
 | 
				
			|||||||
        final int current = countedEntities[type];
 | 
					        final int current = countedEntities[type];
 | 
				
			||||||
        final int max = plot.getFlag(capFlag);
 | 
					        final int max = plot.getFlag(capFlag);
 | 
				
			||||||
        final String percentage = String.format("%.1f", 100 * ((float) current / max));
 | 
					        final String percentage = String.format("%.1f", 100 * ((float) current / max));
 | 
				
			||||||
        ComponentLike maxBeautified = max == Integer.MAX_VALUE
 | 
					        ComponentLike maxBeautified = max >= Integer.MAX_VALUE
 | 
				
			||||||
                ? TranslatableCaption.of("info.infinite").toComponent(player)
 | 
					                ? TranslatableCaption.of("info.infinite").toComponent(player)
 | 
				
			||||||
                : Component.text(max);
 | 
					                : Component.text(max);
 | 
				
			||||||
        player.sendMessage(
 | 
					        player.sendMessage(
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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 {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -813,7 +813,8 @@ public class Cluster extends SubCommand {
 | 
				
			|||||||
                            if (throwable instanceof TimeoutException) {
 | 
					                            if (throwable instanceof TimeoutException) {
 | 
				
			||||||
                                player.sendMessage(TranslatableCaption.of("players.fetching_players_timeout"));
 | 
					                                player.sendMessage(TranslatableCaption.of("players.fetching_players_timeout"));
 | 
				
			||||||
                            } else {
 | 
					                            } else {
 | 
				
			||||||
                                final String owner = Objects.requireNonNullElse(username, "unknown");
 | 
					                                final String owner;
 | 
				
			||||||
 | 
					                                owner = Objects.requireNonNullElse(username, "unknown");
 | 
				
			||||||
                                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);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -502,9 +502,9 @@ public abstract class Command {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    public String getCommandString() {
 | 
					    public String getCommandString() {
 | 
				
			||||||
        if (this.parent == null) {
 | 
					        if (this.parent == null) {
 | 
				
			||||||
            return "/" + this;
 | 
					            return "/" + toString();
 | 
				
			||||||
        } else {
 | 
					        } else {
 | 
				
			||||||
            return this.parent.getCommandString() + " " + this;
 | 
					            return this.parent.getCommandString() + " " + toString();
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -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() {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -37,7 +37,7 @@ public class Confirm extends SubCommand {
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
        CmdConfirm.removePending(player);
 | 
					        CmdConfirm.removePending(player);
 | 
				
			||||||
        if ((System.currentTimeMillis() - command.timestamp)
 | 
					        if ((System.currentTimeMillis() - command.timestamp)
 | 
				
			||||||
                > Settings.Confirmation.CONFIRMATION_TIMEOUT_SECONDS * 1000L) {
 | 
					                > Settings.Confirmation.CONFIRMATION_TIMEOUT_SECONDS * 1000) {
 | 
				
			||||||
            player.sendMessage(TranslatableCaption.of("confirm.expired_confirm"));
 | 
					            player.sendMessage(TranslatableCaption.of("confirm.expired_confirm"));
 | 
				
			||||||
            return false;
 | 
					            return false;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -103,7 +103,7 @@ public class Done extends SubCommand {
 | 
				
			|||||||
                public void run(PlotAnalysis value) {
 | 
					                public void run(PlotAnalysis value) {
 | 
				
			||||||
                    plot.removeRunning();
 | 
					                    plot.removeRunning();
 | 
				
			||||||
                    boolean result =
 | 
					                    boolean result =
 | 
				
			||||||
                            value.getComplexity(doneRequirements) <= doneRequirements.THRESHOLD;
 | 
					                            value.getComplexity(doneRequirements) >= doneRequirements.THRESHOLD;
 | 
				
			||||||
                    finish(plot, player, result);
 | 
					                    finish(plot, player, result);
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
            });
 | 
					            });
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -183,7 +183,9 @@ public class Download extends SubCommand {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    private void upload(PlotPlayer<?> player, Plot plot) {
 | 
					    private void upload(PlotPlayer<?> player, Plot plot) {
 | 
				
			||||||
        if (Settings.Web.LEGACY_WEBINTERFACE) {
 | 
					        if (Settings.Web.LEGACY_WEBINTERFACE) {
 | 
				
			||||||
            schematicHandler.getCompoundTag(plot).whenComplete((compoundTag, throwable) -> schematicHandler.upload(
 | 
					            schematicHandler
 | 
				
			||||||
 | 
					                    .getCompoundTag(plot)
 | 
				
			||||||
 | 
					                    .whenComplete((compoundTag, throwable) -> schematicHandler.upload(
 | 
				
			||||||
                            compoundTag,
 | 
					                            compoundTag,
 | 
				
			||||||
                            null,
 | 
					                            null,
 | 
				
			||||||
                            null,
 | 
					                            null,
 | 
				
			||||||
@@ -191,10 +193,13 @@ public class Download extends SubCommand {
 | 
				
			|||||||
                                @Override
 | 
					                                @Override
 | 
				
			||||||
                                public void run(URL value) {
 | 
					                                public void run(URL value) {
 | 
				
			||||||
                                    plot.removeRunning();
 | 
					                                    plot.removeRunning();
 | 
				
			||||||
                            player.sendMessage(TranslatableCaption.of("web.generation_link_success"), TagResolver.builder().tag(
 | 
					                                    player.sendMessage(
 | 
				
			||||||
                                    "download",
 | 
					                                            TranslatableCaption.of("web.generation_link_success"),
 | 
				
			||||||
                                    Tag.preProcessParsed(value.toString())
 | 
					                                            TagResolver.builder()
 | 
				
			||||||
                            ).tag("delete", Tag.preProcessParsed("Not available")).build());
 | 
					                                                    .tag("download", Tag.preProcessParsed(value.toString()))
 | 
				
			||||||
 | 
					                                                    .tag("delete", Tag.preProcessParsed("Not available"))
 | 
				
			||||||
 | 
					                                                    .build()
 | 
				
			||||||
 | 
					                                    );
 | 
				
			||||||
                                    player.sendMessage(StaticCaption.of(value.toString()));
 | 
					                                    player.sendMessage(StaticCaption.of(value.toString()));
 | 
				
			||||||
                                }
 | 
					                                }
 | 
				
			||||||
                            }
 | 
					                            }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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) {
 | 
				
			||||||
@@ -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;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -117,7 +117,7 @@ public class ListCmd extends SubCommand {
 | 
				
			|||||||
        if (player.hasPermission(Permission.PERMISSION_LIST_FUZZY)) {
 | 
					        if (player.hasPermission(Permission.PERMISSION_LIST_FUZZY)) {
 | 
				
			||||||
            args.add("fuzzy <search...>");
 | 
					            args.add("fuzzy <search...>");
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        return args.toArray(new String[0]);
 | 
					        return args.toArray(new String[args.size()]);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public void noArgs(PlotPlayer<?> player) {
 | 
					    public void noArgs(PlotPlayer<?> player) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -28,6 +28,7 @@ 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 java.util.List;
 | 
				
			||||||
import java.util.concurrent.CompletableFuture;
 | 
					import java.util.concurrent.CompletableFuture;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@CommandDeclaration(command = "near",
 | 
					@CommandDeclaration(command = "near",
 | 
				
			||||||
@@ -55,4 +56,8 @@ public class Near extends Command {
 | 
				
			|||||||
        return CompletableFuture.completedFuture(true);
 | 
					        return CompletableFuture.completedFuture(true);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private List<PlotPlayer<?>> getPlayersInPlotVisible(Plot plot, PlotPlayer<?> executor) {
 | 
				
			||||||
 | 
					        return plot.getPlayersInPlot().stream().filter(executor::canSee).toList();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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(
 | 
				
			||||||
@@ -128,9 +122,8 @@ public class Purge extends SubCommand {
 | 
				
			|||||||
                        return false;
 | 
					                        return false;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                    owner = ownerMapping.uuid();
 | 
					                    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(
 | 
				
			||||||
@@ -140,24 +133,15 @@ public class Purge extends SubCommand {
 | 
				
			|||||||
                        return false;
 | 
					                        return false;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                    added = addedMapping.uuid();
 | 
					                    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,10 +220,7 @@ public class Purge extends SubCommand {
 | 
				
			|||||||
                            try {
 | 
					                            try {
 | 
				
			||||||
                                ids.add(plot.temp);
 | 
					                                ids.add(plot.temp);
 | 
				
			||||||
                                if (finalClear) {
 | 
					                                if (finalClear) {
 | 
				
			||||||
                                    plot.getPlotModificationManager().clear(
 | 
					                                    plot.getPlotModificationManager().clear(false, true, player,
 | 
				
			||||||
                                            false,
 | 
					 | 
				
			||||||
                                            true,
 | 
					 | 
				
			||||||
                                            player,
 | 
					 | 
				
			||||||
                                            () -> LOGGER.info("Plot {} cleared by purge", plot.getId())
 | 
					                                            () -> LOGGER.info("Plot {} cleared by purge", plot.getId())
 | 
				
			||||||
                                    );
 | 
					                                    );
 | 
				
			||||||
                                } else {
 | 
					                                } else {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -35,14 +35,22 @@ import java.util.Map;
 | 
				
			|||||||
 * the component GUI
 | 
					 * the component GUI
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
@SerializableAs("preset")
 | 
					@SerializableAs("preset")
 | 
				
			||||||
public record ComponentPreset(ClassicPlotManagerComponent component, String pattern, double cost, String permission,
 | 
					public record ComponentPreset(
 | 
				
			||||||
                              String displayName, List<String> description, ItemType icon) implements ConfigurationSerializable {
 | 
					        ClassicPlotManagerComponent component,
 | 
				
			||||||
 | 
					        String pattern,
 | 
				
			||||||
 | 
					        double cost,
 | 
				
			||||||
 | 
					        String permission,
 | 
				
			||||||
 | 
					        String displayName,
 | 
				
			||||||
 | 
					        List<String> description,
 | 
				
			||||||
 | 
					        ItemType icon
 | 
				
			||||||
 | 
					) implements ConfigurationSerializable {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @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();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -233,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 {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -146,6 +146,7 @@ public final class CaptionLoader {
 | 
				
			|||||||
     * @param reader the reader to read the map from.
 | 
					     * @param reader the reader to read the map from.
 | 
				
			||||||
     * @return the translation map.
 | 
					     * @return the translation map.
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
 | 
					    @SuppressWarnings("UnstableApiUsage")
 | 
				
			||||||
    static @NonNull Map<@NonNull String, @NonNull String> loadFromReader(final @NonNull Reader reader) {
 | 
					    static @NonNull Map<@NonNull String, @NonNull String> loadFromReader(final @NonNull Reader reader) {
 | 
				
			||||||
        final Type type = new TypeToken<Map<String, String>>() {
 | 
					        final Type type = new TypeToken<Map<String, String>>() {
 | 
				
			||||||
        }.getType();
 | 
					        }.getType();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2499,7 +2499,7 @@ public class SQLManager implements AbstractDB {
 | 
				
			|||||||
                            id = null;
 | 
					                            id = null;
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
                        String msg = set.getString("comment");
 | 
					                        String msg = set.getString("comment");
 | 
				
			||||||
                        long timestamp = set.getInt("timestamp") * 1000L;
 | 
					                        long timestamp = set.getInt("timestamp") * 1000;
 | 
				
			||||||
                        PlotComment comment =
 | 
					                        PlotComment comment =
 | 
				
			||||||
                                new PlotComment(world, id, msg, sender, inbox, timestamp);
 | 
					                                new PlotComment(world, id, msg, sender, inbox, timestamp);
 | 
				
			||||||
                        comments.add(comment);
 | 
					                        comments.add(comment);
 | 
				
			||||||
@@ -3414,7 +3414,10 @@ public class SQLManager implements AbstractDB {
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private record LegacySettings(int id, PlotSettings settings) {
 | 
					    private record LegacySettings(
 | 
				
			||||||
 | 
					            int id,
 | 
				
			||||||
 | 
					            PlotSettings 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;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -105,38 +105,6 @@ public class PlayerAutoPlotEvent extends PlotEvent implements CancellablePlotEve
 | 
				
			|||||||
        return this.plotArea;
 | 
					        return this.plotArea;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * @deprecated for removal. Use {@link PlayerAutoPlotEvent#getSizeX()}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.1.0")
 | 
					 | 
				
			||||||
    public int getSize_x() {
 | 
					 | 
				
			||||||
        return getSizeX();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * @deprecated for removal. Use {@link PlayerAutoPlotEvent#setSizeX(int)}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.1.0")
 | 
					 | 
				
			||||||
    public void setSize_x(int sizeX) {
 | 
					 | 
				
			||||||
        setSizeX(sizeX);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * @deprecated for removal. Use {@link PlayerAutoPlotEvent#getSizeZ()}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.1.0")
 | 
					 | 
				
			||||||
    public int getSize_z() {
 | 
					 | 
				
			||||||
        return getSizeZ();
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * @deprecated for removal. Use {@link PlayerAutoPlotEvent#setSizeZ(int)}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.1.0")
 | 
					 | 
				
			||||||
    public void setSize_z(int sizeZ) {
 | 
					 | 
				
			||||||
        setSizeZ(sizeZ);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Get the x size of the auto-area
 | 
					     * Get the x size of the auto-area
 | 
				
			||||||
     *
 | 
					     *
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -65,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.
 | 
				
			||||||
     *
 | 
					     *
 | 
				
			||||||
@@ -145,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;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -368,6 +368,7 @@ public class HybridGen extends IndependentPlotGenerator {
 | 
				
			|||||||
                }
 | 
					                }
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					        return;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
@@ -401,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.
 | 
				
			||||||
@@ -455,10 +462,4 @@ public class HybridGen extends IndependentPlotGenerator {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private enum SchematicFeature {
 | 
					 | 
				
			||||||
        BIOMES,
 | 
					 | 
				
			||||||
        ROAD,
 | 
					 | 
				
			||||||
        POPULATING
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -288,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()),
 | 
				
			||||||
@@ -305,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()));
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -68,8 +68,6 @@ public class HybridPlotWorld extends ClassicPlotWorld {
 | 
				
			|||||||
    private static final AffineTransform transform = new AffineTransform().rotateY(90);
 | 
					    private static final AffineTransform transform = new AffineTransform().rotateY(90);
 | 
				
			||||||
    public boolean ROAD_SCHEMATIC_ENABLED;
 | 
					    public boolean ROAD_SCHEMATIC_ENABLED;
 | 
				
			||||||
    public boolean PLOT_SCHEMATIC = false;
 | 
					    public boolean PLOT_SCHEMATIC = false;
 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.0")
 | 
					 | 
				
			||||||
    public int PLOT_SCHEMATIC_HEIGHT = -1;
 | 
					 | 
				
			||||||
    public short PATH_WIDTH_LOWER;
 | 
					    public short PATH_WIDTH_LOWER;
 | 
				
			||||||
    public short PATH_WIDTH_UPPER;
 | 
					    public short PATH_WIDTH_UPPER;
 | 
				
			||||||
    public HashMap<Integer, BaseBlock[]> G_SCH;
 | 
					    public HashMap<Integer, BaseBlock[]> G_SCH;
 | 
				
			||||||
@@ -104,22 +102,6 @@ public class HybridPlotWorld extends ClassicPlotWorld {
 | 
				
			|||||||
        PlotSquared.platform().injector().injectMembers(this);
 | 
					        PlotSquared.platform().injector().injectMembers(this);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.0")
 | 
					 | 
				
			||||||
    public static byte wrap(byte data, int start) {
 | 
					 | 
				
			||||||
        if ((data >= start) && (data < (start + 4))) {
 | 
					 | 
				
			||||||
            data = (byte) ((((data - start) + 2) & 3) + start);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return data;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.0")
 | 
					 | 
				
			||||||
    public static byte wrap2(byte data, int start) {
 | 
					 | 
				
			||||||
        if ((data >= start) && (data < (start + 2))) {
 | 
					 | 
				
			||||||
            data = (byte) ((((data - start) + 1) & 1) + start);
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return data;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public static BaseBlock rotate(BaseBlock id) {
 | 
					    public static BaseBlock rotate(BaseBlock id) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        CompoundTag tag = id.getNbtData();
 | 
					        CompoundTag tag = id.getNbtData();
 | 
				
			||||||
@@ -341,11 +323,21 @@ public class HybridPlotWorld extends ClassicPlotWorld {
 | 
				
			|||||||
            short w3 = (short) d3.getX();
 | 
					            short w3 = (short) d3.getX();
 | 
				
			||||||
            short l3 = (short) d3.getZ();
 | 
					            short l3 = (short) d3.getZ();
 | 
				
			||||||
            short h3 = (short) d3.getY();
 | 
					            short h3 = (short) d3.getY();
 | 
				
			||||||
            if (w3 > PLOT_WIDTH || h3 > PLOT_WIDTH) {
 | 
					            if (w3 > PLOT_WIDTH || l3 > PLOT_WIDTH) {
 | 
				
			||||||
                this.ROAD_SCHEMATIC_ENABLED = true;
 | 
					                this.ROAD_SCHEMATIC_ENABLED = true;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            int centerShiftZ = (this.PLOT_WIDTH - l3) / 2;
 | 
					            int centerShiftZ;
 | 
				
			||||||
            int centerShiftX = (this.PLOT_WIDTH - w3) / 2;
 | 
					            if (l3 < this.PLOT_WIDTH) {
 | 
				
			||||||
 | 
					                centerShiftZ = (this.PLOT_WIDTH - l3) / 2;
 | 
				
			||||||
 | 
					            } else {
 | 
				
			||||||
 | 
					                centerShiftZ = (PLOT_WIDTH - l3) / 2;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            int centerShiftX;
 | 
				
			||||||
 | 
					            if (w3 < this.PLOT_WIDTH) {
 | 
				
			||||||
 | 
					                centerShiftX = (this.PLOT_WIDTH - w3) / 2;
 | 
				
			||||||
 | 
					            } else {
 | 
				
			||||||
 | 
					                centerShiftX = (PLOT_WIDTH - w3) / 2;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            BlockVector3 min = blockArrayClipboard3.getMinimumPoint();
 | 
					            BlockVector3 min = blockArrayClipboard3.getMinimumPoint();
 | 
				
			||||||
            for (short x = 0; x < w3; x++) {
 | 
					            for (short x = 0; x < w3; x++) {
 | 
				
			||||||
@@ -386,7 +378,7 @@ public class HybridPlotWorld extends ClassicPlotWorld {
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
        if ((schematic1 == null && schematic2 == null) || this.ROAD_WIDTH == 0) {
 | 
					        if ((schematic1 == null && schematic2 == null) || this.ROAD_WIDTH == 0) {
 | 
				
			||||||
            if (Settings.DEBUG) {
 | 
					            if (Settings.DEBUG) {
 | 
				
			||||||
                LOGGER.info("- schematic: false");
 | 
					                LOGGER.info("- road schematic: false");
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
@@ -476,11 +468,7 @@ public class HybridPlotWorld extends ClassicPlotWorld {
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    private void addOverlayBlock(short x, short y, short z, BaseBlock id, boolean rotate, int height) {
 | 
				
			||||||
     * @deprecated This method should not be available for public API usage and will be made private.
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.10.2")
 | 
					 | 
				
			||||||
    public void addOverlayBlock(short x, short y, short z, BaseBlock id, boolean rotate, int height) {
 | 
					 | 
				
			||||||
        if (z < 0) {
 | 
					        if (z < 0) {
 | 
				
			||||||
            z += this.SIZE;
 | 
					            z += this.SIZE;
 | 
				
			||||||
        } else if (z >= this.SIZE) {
 | 
					        } else if (z >= this.SIZE) {
 | 
				
			||||||
@@ -511,11 +499,7 @@ public class HybridPlotWorld extends ClassicPlotWorld {
 | 
				
			|||||||
        existing[y] = id;
 | 
					        existing[y] = id;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    private void addOverlayBiome(short x, short z, BiomeType id) {
 | 
				
			||||||
     * @deprecated This method should not be available for public API usage and will be made private.
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.10.2")
 | 
					 | 
				
			||||||
    public void addOverlayBiome(short x, short z, BiomeType id) {
 | 
					 | 
				
			||||||
        if (z < 0) {
 | 
					        if (z < 0) {
 | 
				
			||||||
            z += this.SIZE;
 | 
					            z += this.SIZE;
 | 
				
			||||||
        } else if (z >= this.SIZE) {
 | 
					        } else if (z >= this.SIZE) {
 | 
				
			||||||
@@ -560,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()}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -37,6 +37,7 @@ import com.plotsquared.core.plot.world.PlotAreaManager;
 | 
				
			|||||||
import com.plotsquared.core.queue.BlockArrayCacheScopedQueueCoordinator;
 | 
					import com.plotsquared.core.queue.BlockArrayCacheScopedQueueCoordinator;
 | 
				
			||||||
import com.plotsquared.core.queue.GlobalBlockQueue;
 | 
					import com.plotsquared.core.queue.GlobalBlockQueue;
 | 
				
			||||||
import com.plotsquared.core.queue.QueueCoordinator;
 | 
					import com.plotsquared.core.queue.QueueCoordinator;
 | 
				
			||||||
 | 
					import com.plotsquared.core.util.ChunkManager;
 | 
				
			||||||
import com.plotsquared.core.util.EventDispatcher;
 | 
					import com.plotsquared.core.util.EventDispatcher;
 | 
				
			||||||
import com.plotsquared.core.util.MathMan;
 | 
					import com.plotsquared.core.util.MathMan;
 | 
				
			||||||
import com.plotsquared.core.util.RegionManager;
 | 
					import com.plotsquared.core.util.RegionManager;
 | 
				
			||||||
@@ -86,6 +87,7 @@ public class HybridUtils {
 | 
				
			|||||||
    public static boolean UPDATE = false;
 | 
					    public static boolean UPDATE = false;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private final PlotAreaManager plotAreaManager;
 | 
					    private final PlotAreaManager plotAreaManager;
 | 
				
			||||||
 | 
					    private final ChunkManager chunkManager;
 | 
				
			||||||
    private final GlobalBlockQueue blockQueue;
 | 
					    private final GlobalBlockQueue blockQueue;
 | 
				
			||||||
    private final WorldUtil worldUtil;
 | 
					    private final WorldUtil worldUtil;
 | 
				
			||||||
    private final SchematicHandler schematicHandler;
 | 
					    private final SchematicHandler schematicHandler;
 | 
				
			||||||
@@ -94,12 +96,14 @@ public class HybridUtils {
 | 
				
			|||||||
    @Inject
 | 
					    @Inject
 | 
				
			||||||
    public HybridUtils(
 | 
					    public HybridUtils(
 | 
				
			||||||
            final @NonNull PlotAreaManager plotAreaManager,
 | 
					            final @NonNull PlotAreaManager plotAreaManager,
 | 
				
			||||||
 | 
					            final @NonNull ChunkManager chunkManager,
 | 
				
			||||||
            final @NonNull GlobalBlockQueue blockQueue,
 | 
					            final @NonNull GlobalBlockQueue blockQueue,
 | 
				
			||||||
            final @NonNull WorldUtil worldUtil,
 | 
					            final @NonNull WorldUtil worldUtil,
 | 
				
			||||||
            final @NonNull SchematicHandler schematicHandler,
 | 
					            final @NonNull SchematicHandler schematicHandler,
 | 
				
			||||||
            final @NonNull EventDispatcher eventDispatcher
 | 
					            final @NonNull EventDispatcher eventDispatcher
 | 
				
			||||||
    ) {
 | 
					    ) {
 | 
				
			||||||
        this.plotAreaManager = plotAreaManager;
 | 
					        this.plotAreaManager = plotAreaManager;
 | 
				
			||||||
 | 
					        this.chunkManager = chunkManager;
 | 
				
			||||||
        this.blockQueue = blockQueue;
 | 
					        this.blockQueue = blockQueue;
 | 
				
			||||||
        this.worldUtil = worldUtil;
 | 
					        this.worldUtil = worldUtil;
 | 
				
			||||||
        this.schematicHandler = schematicHandler;
 | 
					        this.schematicHandler = schematicHandler;
 | 
				
			||||||
@@ -624,7 +628,7 @@ public class HybridUtils {
 | 
				
			|||||||
            queue = queueCoordinator;
 | 
					            queue = queueCoordinator;
 | 
				
			||||||
            enqueue = false;
 | 
					            enqueue = false;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        if (id2 == null || id1 != id2) {
 | 
					        if (id1 == null || id2 == null || id1 != id2) {
 | 
				
			||||||
            if (id1 != null) {
 | 
					            if (id1 != null) {
 | 
				
			||||||
                Plot p1 = area.getPlotAbs(id1);
 | 
					                Plot p1 = area.getPlotAbs(id1);
 | 
				
			||||||
                if (p1 != null && p1.hasOwner() && p1.isMerged()) {
 | 
					                if (p1 != null && p1.hasOwner() && p1.isMerged()) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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());
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -64,6 +64,7 @@ import com.sk89q.worldedit.world.item.ItemType;
 | 
				
			|||||||
import com.sk89q.worldedit.world.item.ItemTypes;
 | 
					import com.sk89q.worldedit.world.item.ItemTypes;
 | 
				
			||||||
import net.kyori.adventure.text.Component;
 | 
					import net.kyori.adventure.text.Component;
 | 
				
			||||||
import net.kyori.adventure.text.ComponentLike;
 | 
					import net.kyori.adventure.text.ComponentLike;
 | 
				
			||||||
 | 
					import net.kyori.adventure.text.minimessage.MiniMessage;
 | 
				
			||||||
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 org.checkerframework.checker.nullness.qual.NonNull;
 | 
					import org.checkerframework.checker.nullness.qual.NonNull;
 | 
				
			||||||
@@ -79,6 +80,8 @@ import java.util.UUID;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
public class PlotListener {
 | 
					public class PlotListener {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private static final MiniMessage MINI_MESSAGE = MiniMessage.miniMessage();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private final HashMap<UUID, Interval> feedRunnable = new HashMap<>();
 | 
					    private final HashMap<UUID, Interval> feedRunnable = new HashMap<>();
 | 
				
			||||||
    private final HashMap<UUID, Interval> healRunnable = new HashMap<>();
 | 
					    private final HashMap<UUID, Interval> healRunnable = new HashMap<>();
 | 
				
			||||||
    private final Map<UUID, List<StatusEffect>> playerEffects = new HashMap<>();
 | 
					    private final Map<UUID, List<StatusEffect>> playerEffects = new HashMap<>();
 | 
				
			||||||
@@ -517,6 +520,11 @@ public class PlotListener {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    private record StatusEffect(@NonNull String name, long expiresAt) {
 | 
					    private record StatusEffect(@NonNull String name, long expiresAt) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        private StatusEffect(@NonNull String name, long expiresAt) {
 | 
				
			||||||
 | 
					            this.name = name;
 | 
				
			||||||
 | 
					            this.expiresAt = expiresAt;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -21,7 +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 record ChunkWrapper(String world, int x, int z) {
 | 
					public record ChunkWrapper(
 | 
				
			||||||
 | 
					        String world,
 | 
				
			||||||
 | 
					        int x,
 | 
				
			||||||
 | 
					        int z
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
    public int hashCode() {
 | 
					    public int hashCode() {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -215,7 +215,11 @@ public final class BlockBucket implements ConfigurationSerializable {
 | 
				
			|||||||
        return result;
 | 
					        return result;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private record Range(int min, int max, boolean automatic) {
 | 
					    private record Range(
 | 
				
			||||||
 | 
					            int min,
 | 
				
			||||||
 | 
					            int max,
 | 
				
			||||||
 | 
					            boolean automatic
 | 
				
			||||||
 | 
					    ) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        public int getWeight() {
 | 
					        public int getWeight() {
 | 
				
			||||||
            return max - min;
 | 
					            return max - min;
 | 
				
			||||||
@@ -225,31 +229,6 @@ public final class BlockBucket implements ConfigurationSerializable {
 | 
				
			|||||||
            return num <= max && num >= min;
 | 
					            return num <= max && num >= min;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        public boolean equals(final Object o) {
 | 
					 | 
				
			||||||
            if (o == this) {
 | 
					 | 
				
			||||||
                return true;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            if (!(o instanceof final Range other)) {
 | 
					 | 
				
			||||||
                return false;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            if (this.min() != other.min()) {
 | 
					 | 
				
			||||||
                return false;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            if (this.max() != other.max()) {
 | 
					 | 
				
			||||||
                return false;
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            return this.automatic() == other.automatic();
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        public int hashCode() {
 | 
					 | 
				
			||||||
            final int PRIME = 59;
 | 
					 | 
				
			||||||
            int result = 1;
 | 
					 | 
				
			||||||
            result = result * PRIME + this.min();
 | 
					 | 
				
			||||||
            result = result * PRIME + this.max();
 | 
					 | 
				
			||||||
            result = result * PRIME + (this.automatic() ? 79 : 97);
 | 
					 | 
				
			||||||
            return result;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,7 +20,6 @@ package com.plotsquared.core.plot;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import com.google.common.collect.ImmutableSet;
 | 
					import com.google.common.collect.ImmutableSet;
 | 
				
			||||||
import com.google.common.collect.Lists;
 | 
					import com.google.common.collect.Lists;
 | 
				
			||||||
import com.google.common.collect.Sets;
 | 
					 | 
				
			||||||
import com.google.inject.Inject;
 | 
					import com.google.inject.Inject;
 | 
				
			||||||
import com.plotsquared.core.PlotSquared;
 | 
					import com.plotsquared.core.PlotSquared;
 | 
				
			||||||
import com.plotsquared.core.command.Like;
 | 
					import com.plotsquared.core.command.Like;
 | 
				
			||||||
@@ -2418,7 +2417,6 @@ public class Plot {
 | 
				
			|||||||
        if (!this.isMerged()) {
 | 
					        if (!this.isMerged()) {
 | 
				
			||||||
            Location pos1 = this.getBottomAbs().withY(getArea().getMinBuildHeight());
 | 
					            Location pos1 = this.getBottomAbs().withY(getArea().getMinBuildHeight());
 | 
				
			||||||
            Location pos2 = this.getTopAbs().withY(getArea().getMaxBuildHeight());
 | 
					            Location pos2 = this.getTopAbs().withY(getArea().getMaxBuildHeight());
 | 
				
			||||||
            this.connectedCache = Sets.newHashSet(this);
 | 
					 | 
				
			||||||
            CuboidRegion rg = new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3());
 | 
					            CuboidRegion rg = new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3());
 | 
				
			||||||
            return Collections.singleton(rg);
 | 
					            return Collections.singleton(rg);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -382,6 +382,9 @@ public abstract class PlotArea implements ComponentLike {
 | 
				
			|||||||
            this.defaultHome = new BlockLoc(Integer.MAX_VALUE, Integer.MIN_VALUE, Integer.MAX_VALUE);
 | 
					            this.defaultHome = new BlockLoc(Integer.MAX_VALUE, Integer.MIN_VALUE, Integer.MAX_VALUE);
 | 
				
			||||||
        } else {
 | 
					        } else {
 | 
				
			||||||
            try {
 | 
					            try {
 | 
				
			||||||
 | 
					                /*String[] split = homeDefault.split(",");
 | 
				
			||||||
 | 
					                this.DEFAULT_HOME =
 | 
				
			||||||
 | 
					                    new PlotLoc(Integer.parseInt(split[0]), Integer.parseInt(split[1]));*/
 | 
				
			||||||
                this.defaultHome = BlockLoc.fromString(homeDefault);
 | 
					                this.defaultHome = BlockLoc.fromString(homeDefault);
 | 
				
			||||||
            } catch (NumberFormatException ignored) {
 | 
					            } catch (NumberFormatException ignored) {
 | 
				
			||||||
                this.defaultHome = null;
 | 
					                this.defaultHome = null;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -106,17 +106,6 @@ public final class PlotId {
 | 
				
			|||||||
        return PlotId.of(hash >> 16, hash & 0xFFFF);
 | 
					        return PlotId.of(hash >> 16, hash & 0xFFFF);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * Get a copy of the plot ID
 | 
					 | 
				
			||||||
     *
 | 
					 | 
				
			||||||
     * @return Plot ID copy
 | 
					 | 
				
			||||||
     * @deprecated PlotId is immutable, copy is not required.
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.10.2")
 | 
					 | 
				
			||||||
    public @NonNull PlotId copy() {
 | 
					 | 
				
			||||||
        return this;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * Get the ID X component
 | 
					     * Get the ID X component
 | 
				
			||||||
     *
 | 
					     *
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,6 +20,13 @@ package com.plotsquared.core.plot.comment;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import com.plotsquared.core.plot.PlotId;
 | 
					import com.plotsquared.core.plot.PlotId;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public record PlotComment(String world, PlotId id, String comment, String senderName, String inbox, long timestamp) {
 | 
					public record PlotComment(
 | 
				
			||||||
 | 
					        String world,
 | 
				
			||||||
 | 
					        PlotId id,
 | 
				
			||||||
 | 
					        String comment,
 | 
				
			||||||
 | 
					        String senderName,
 | 
				
			||||||
 | 
					        String inbox,
 | 
				
			||||||
 | 
					        long timestamp
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,7 +19,6 @@
 | 
				
			|||||||
package com.plotsquared.core.plot.expiration;
 | 
					package com.plotsquared.core.plot.expiration;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import com.google.inject.Inject;
 | 
					import com.google.inject.Inject;
 | 
				
			||||||
import com.plotsquared.core.PlotPlatform;
 | 
					 | 
				
			||||||
import com.plotsquared.core.PlotSquared;
 | 
					import com.plotsquared.core.PlotSquared;
 | 
				
			||||||
import com.plotsquared.core.configuration.caption.Caption;
 | 
					import com.plotsquared.core.configuration.caption.Caption;
 | 
				
			||||||
import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
					import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
				
			||||||
@@ -63,11 +62,6 @@ import java.util.concurrent.ConcurrentLinkedDeque;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
public class ExpireManager {
 | 
					public class ExpireManager {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * @deprecated Use {@link PlotPlatform#expireManager()} instead
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.10.2")
 | 
					 | 
				
			||||||
    public static ExpireManager IMP;
 | 
					 | 
				
			||||||
    private final ConcurrentHashMap<UUID, Long> dates_cache;
 | 
					    private final ConcurrentHashMap<UUID, Long> dates_cache;
 | 
				
			||||||
    private final ConcurrentHashMap<UUID, Long> account_age_cache;
 | 
					    private final ConcurrentHashMap<UUID, Long> account_age_cache;
 | 
				
			||||||
    private final EventDispatcher eventDispatcher;
 | 
					    private final EventDispatcher eventDispatcher;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,6 +19,7 @@
 | 
				
			|||||||
package com.plotsquared.core.plot.flag.implementations;
 | 
					package com.plotsquared.core.plot.flag.implementations;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
					import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
				
			||||||
 | 
					import com.plotsquared.core.plot.flag.FlagParseException;
 | 
				
			||||||
import com.plotsquared.core.plot.flag.InternalFlag;
 | 
					import com.plotsquared.core.plot.flag.InternalFlag;
 | 
				
			||||||
import com.plotsquared.core.plot.flag.types.ListFlag;
 | 
					import com.plotsquared.core.plot.flag.types.ListFlag;
 | 
				
			||||||
import org.checkerframework.checker.nullness.qual.NonNull;
 | 
					import org.checkerframework.checker.nullness.qual.NonNull;
 | 
				
			||||||
@@ -33,7 +34,7 @@ public class AnalysisFlag extends ListFlag<Integer, AnalysisFlag> implements Int
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
    public AnalysisFlag parse(@NonNull String input) {
 | 
					    public AnalysisFlag parse(@NonNull String input) throws FlagParseException {
 | 
				
			||||||
        final String[] split = input.split(",");
 | 
					        final String[] split = input.split(",");
 | 
				
			||||||
        final List<Integer> numbers = new ArrayList<>();
 | 
					        final List<Integer> numbers = new ArrayList<>();
 | 
				
			||||||
        for (final String element : split) {
 | 
					        for (final String element : split) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,6 +19,7 @@
 | 
				
			|||||||
package com.plotsquared.core.plot.flag.implementations;
 | 
					package com.plotsquared.core.plot.flag.implementations;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
					import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
				
			||||||
 | 
					import com.plotsquared.core.plot.flag.FlagParseException;
 | 
				
			||||||
import com.plotsquared.core.plot.flag.types.ListFlag;
 | 
					import com.plotsquared.core.plot.flag.types.ListFlag;
 | 
				
			||||||
import org.checkerframework.checker.nullness.qual.NonNull;
 | 
					import org.checkerframework.checker.nullness.qual.NonNull;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -38,7 +39,7 @@ public class BlockedCmdsFlag extends ListFlag<String, BlockedCmdsFlag> {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
    public BlockedCmdsFlag parse(@NonNull String input) {
 | 
					    public BlockedCmdsFlag parse(@NonNull String input) throws FlagParseException {
 | 
				
			||||||
        return flagOf(Arrays.asList(input.split(",")));
 | 
					        return flagOf(Arrays.asList(input.split(",")));
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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");
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,6 +19,7 @@
 | 
				
			|||||||
package com.plotsquared.core.plot.flag.implementations;
 | 
					package com.plotsquared.core.plot.flag.implementations;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
					import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
				
			||||||
 | 
					import com.plotsquared.core.plot.flag.FlagParseException;
 | 
				
			||||||
import com.plotsquared.core.plot.flag.PlotFlag;
 | 
					import com.plotsquared.core.plot.flag.PlotFlag;
 | 
				
			||||||
import com.sk89q.worldedit.world.gamemode.GameMode;
 | 
					import com.sk89q.worldedit.world.gamemode.GameMode;
 | 
				
			||||||
import com.sk89q.worldedit.world.gamemode.GameModes;
 | 
					import com.sk89q.worldedit.world.gamemode.GameModes;
 | 
				
			||||||
@@ -56,7 +57,7 @@ public class GamemodeFlag extends PlotFlag<GameMode, GamemodeFlag> {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
    public GamemodeFlag parse(@NonNull String input) {
 | 
					    public GamemodeFlag parse(@NonNull String input) throws FlagParseException {
 | 
				
			||||||
        return switch (input) {
 | 
					        return switch (input) {
 | 
				
			||||||
            case "creative", "c", "1" -> flagOf(GameModes.CREATIVE);
 | 
					            case "creative", "c", "1" -> flagOf(GameModes.CREATIVE);
 | 
				
			||||||
            case "adventure", "a", "2" -> flagOf(GameModes.ADVENTURE);
 | 
					            case "adventure", "a", "2" -> flagOf(GameModes.ADVENTURE);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,6 +19,7 @@
 | 
				
			|||||||
package com.plotsquared.core.plot.flag.implementations;
 | 
					package com.plotsquared.core.plot.flag.implementations;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
					import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
				
			||||||
 | 
					import com.plotsquared.core.plot.flag.FlagParseException;
 | 
				
			||||||
import com.plotsquared.core.plot.flag.PlotFlag;
 | 
					import com.plotsquared.core.plot.flag.PlotFlag;
 | 
				
			||||||
import com.sk89q.worldedit.world.gamemode.GameMode;
 | 
					import com.sk89q.worldedit.world.gamemode.GameMode;
 | 
				
			||||||
import com.sk89q.worldedit.world.gamemode.GameModes;
 | 
					import com.sk89q.worldedit.world.gamemode.GameModes;
 | 
				
			||||||
@@ -51,7 +52,7 @@ public class GuestGamemodeFlag extends PlotFlag<GameMode, GuestGamemodeFlag> {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
    public GuestGamemodeFlag parse(@NonNull String input) {
 | 
					    public GuestGamemodeFlag parse(@NonNull String input) throws FlagParseException {
 | 
				
			||||||
        return switch (input) {
 | 
					        return switch (input) {
 | 
				
			||||||
            case "creative", "c", "1" -> flagOf(GameModes.CREATIVE);
 | 
					            case "creative", "c", "1" -> flagOf(GameModes.CREATIVE);
 | 
				
			||||||
            case "adventure", "a", "2" -> flagOf(GameModes.ADVENTURE);
 | 
					            case "adventure", "a", "2" -> flagOf(GameModes.ADVENTURE);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -30,6 +30,7 @@ import org.checkerframework.checker.nullness.qual.NonNull;
 | 
				
			|||||||
import java.util.ArrayList;
 | 
					import java.util.ArrayList;
 | 
				
			||||||
import java.util.Collection;
 | 
					import java.util.Collection;
 | 
				
			||||||
import java.util.List;
 | 
					import java.util.List;
 | 
				
			||||||
 | 
					import java.util.stream.Collectors;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public abstract class BlockTypeListFlag<F extends ListFlag<BlockTypeWrapper, F>>
 | 
					public abstract class BlockTypeListFlag<F extends ListFlag<BlockTypeWrapper, F>>
 | 
				
			||||||
        extends ListFlag<BlockTypeWrapper, F> {
 | 
					        extends ListFlag<BlockTypeWrapper, F> {
 | 
				
			||||||
@@ -72,9 +73,11 @@ public abstract class BlockTypeListFlag<F extends ListFlag<BlockTypeWrapper, F>>
 | 
				
			|||||||
    public Collection<String> getTabCompletions() {
 | 
					    public Collection<String> getTabCompletions() {
 | 
				
			||||||
        final Collection<String> tabCompletions = new ArrayList<>();
 | 
					        final Collection<String> tabCompletions = new ArrayList<>();
 | 
				
			||||||
        tabCompletions.addAll(
 | 
					        tabCompletions.addAll(
 | 
				
			||||||
                BlockType.REGISTRY.keySet().stream().map(val -> val.replace("minecraft:", "")).toList());
 | 
					                BlockType.REGISTRY.keySet().stream().map(val -> val.replace("minecraft:", ""))
 | 
				
			||||||
 | 
					                        .collect(Collectors.toList()));
 | 
				
			||||||
        tabCompletions.addAll(
 | 
					        tabCompletions.addAll(
 | 
				
			||||||
                BlockCategory.REGISTRY.keySet().stream().map(val -> "#" + val.replace("minecraft:", "")).toList());
 | 
					                BlockCategory.REGISTRY.keySet().stream().map(val -> "#" + val.replace("minecraft:", ""))
 | 
				
			||||||
 | 
					                        .collect(Collectors.toList()));
 | 
				
			||||||
        return tabCompletions;
 | 
					        return tabCompletions;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -76,7 +76,10 @@ public abstract class TimedFlag<T, F extends PlotFlag<TimedFlag.Timed<T>, F>>
 | 
				
			|||||||
        return getValue().toString();
 | 
					        return getValue().toString();
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public record Timed<T>(int interval, T value) {
 | 
					    public record Timed<T>(
 | 
				
			||||||
 | 
					            int interval,
 | 
				
			||||||
 | 
					            T value
 | 
				
			||||||
 | 
					    ) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        @Override
 | 
					        @Override
 | 
				
			||||||
        public String toString() {
 | 
					        public String toString() {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -194,6 +194,17 @@ public class SinglePlotArea extends GridPlotWorld {
 | 
				
			|||||||
        } catch (final Exception e) {
 | 
					        } catch (final Exception e) {
 | 
				
			||||||
            e.printStackTrace();
 | 
					            e.printStackTrace();
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        //        String worldName = plot.getWorldName();
 | 
				
			||||||
 | 
					        //        World world = Bukkit.getWorld(worldName);
 | 
				
			||||||
 | 
					        //        if (world != null) {
 | 
				
			||||||
 | 
					        //            return world;
 | 
				
			||||||
 | 
					        //        }
 | 
				
			||||||
 | 
					        //        WorldCreator wc = new WorldCreator(worldName);
 | 
				
			||||||
 | 
					        //        wc.generator("PlotSquared:single");
 | 
				
			||||||
 | 
					        //        wc.environment(World.Environment.NORMAL);
 | 
				
			||||||
 | 
					        //        wc.type(WorldType.FLAT);
 | 
				
			||||||
 | 
					        //        return AsyncWorld.create(wc);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -41,6 +41,9 @@ public class ZeroedDelegateScopedQueueCoordinator extends DelegateQueueCoordinat
 | 
				
			|||||||
    private final int minX;
 | 
					    private final int minX;
 | 
				
			||||||
    private final int minZ;
 | 
					    private final int minZ;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private final int maxX;
 | 
				
			||||||
 | 
					    private final int maxZ;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private final int dx;
 | 
					    private final int dx;
 | 
				
			||||||
    private final int dz;
 | 
					    private final int dz;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -56,8 +59,11 @@ public class ZeroedDelegateScopedQueueCoordinator extends DelegateQueueCoordinat
 | 
				
			|||||||
        this.minX = min.getX();
 | 
					        this.minX = min.getX();
 | 
				
			||||||
        this.minZ = min.getZ();
 | 
					        this.minZ = min.getZ();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        this.dx = max.getX() - minX;
 | 
					        this.maxX = max.getX();
 | 
				
			||||||
        this.dz = max.getZ() - minZ;
 | 
					        this.maxZ = max.getZ();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        this.dx = maxX - minX;
 | 
				
			||||||
 | 
					        this.dz = maxZ - minZ;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -93,7 +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);
 | 
				
			||||||
        this.caption = Objects.requireNonNullElse(caption, TranslatableCaption.of("working.progress"));
 | 
					        this.caption = Objects.requireNonNullElseGet(caption, () -> TranslatableCaption.of("working.progress"));
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @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,87 +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();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    record AutoQuery(PlotPlayer<?> player, PlotId startId, int sizeX, int sizeZ, 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
 | 
					 | 
				
			||||||
         */
 | 
					 | 
				
			||||||
        @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;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    final class DefaultAutoService implements AutoService {
 | 
					    final class DefaultAutoService implements AutoService {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        @Override
 | 
					        @Override
 | 
				
			||||||
@@ -124,7 +47,6 @@ 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
 | 
				
			||||||
@@ -150,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
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -72,7 +72,7 @@ public enum CommonSetupSteps implements SetupStep {
 | 
				
			|||||||
        @Override
 | 
					        @Override
 | 
				
			||||||
        public SetupStep handleInput(PlotPlayer<?> plotPlayer, PlotAreaBuilder builder, String arg) {
 | 
					        public SetupStep handleInput(PlotPlayer<?> plotPlayer, PlotAreaBuilder builder, String arg) {
 | 
				
			||||||
            Optional<PlotAreaType> plotAreaType = PlotAreaType.fromString(arg);
 | 
					            Optional<PlotAreaType> plotAreaType = PlotAreaType.fromString(arg);
 | 
				
			||||||
            if (plotAreaType.isEmpty()) {
 | 
					            if (!plotAreaType.isPresent()) {
 | 
				
			||||||
                plotPlayer.sendMessage(TranslatableCaption.of("setup.setup_world_type_error"));
 | 
					                plotPlayer.sendMessage(TranslatableCaption.of("setup.setup_world_type_error"));
 | 
				
			||||||
                return this;
 | 
					                return this;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
@@ -180,7 +180,8 @@ public enum CommonSetupSteps implements SetupStep {
 | 
				
			|||||||
        @Override
 | 
					        @Override
 | 
				
			||||||
        public SetupStep handleInput(PlotPlayer<?> plotPlayer, PlotAreaBuilder builder, String argument) {
 | 
					        public SetupStep handleInput(PlotPlayer<?> plotPlayer, PlotAreaBuilder builder, String argument) {
 | 
				
			||||||
            Optional<PlotAreaTerrainType> optTerrain;
 | 
					            Optional<PlotAreaTerrainType> optTerrain;
 | 
				
			||||||
            if ((optTerrain = PlotAreaTerrainType.fromString(argument)).isEmpty()) {
 | 
					            if (!(optTerrain = PlotAreaTerrainType.fromString(argument))
 | 
				
			||||||
 | 
					                    .isPresent()) {
 | 
				
			||||||
                plotPlayer.sendMessage(TranslatableCaption.of("setup.setup_partial_area_error"));
 | 
					                plotPlayer.sendMessage(TranslatableCaption.of("setup.setup_partial_area_error"));
 | 
				
			||||||
                return this;
 | 
					                return this;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -25,11 +25,17 @@ import com.plotsquared.core.plot.PlotAreaTerrainType;
 | 
				
			|||||||
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 com.plotsquared.core.util.SetupUtils;
 | 
					import com.plotsquared.core.util.SetupUtils;
 | 
				
			||||||
 | 
					import org.jetbrains.annotations.Contract;
 | 
				
			||||||
 | 
					import org.jetbrains.annotations.NotNull;
 | 
				
			||||||
 | 
					import org.jetbrains.annotations.Nullable;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Objects;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public class PlotAreaBuilder {
 | 
					public class PlotAreaBuilder {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private String generatorName;
 | 
					    private String generatorName;
 | 
				
			||||||
    private String plotManager;
 | 
					    private String plotManager;
 | 
				
			||||||
 | 
					    @Nullable
 | 
				
			||||||
    private PlotAreaType plotAreaType;
 | 
					    private PlotAreaType plotAreaType;
 | 
				
			||||||
    private PlotAreaTerrainType terrainType;
 | 
					    private PlotAreaTerrainType terrainType;
 | 
				
			||||||
    private String worldName;
 | 
					    private String worldName;
 | 
				
			||||||
@@ -85,8 +91,10 @@ public class PlotAreaBuilder {
 | 
				
			|||||||
        return this.plotManager;
 | 
					        return this.plotManager;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @NotNull
 | 
				
			||||||
 | 
					    @Contract(" -> !null")
 | 
				
			||||||
    public PlotAreaType plotAreaType() {
 | 
					    public PlotAreaType plotAreaType() {
 | 
				
			||||||
        return this.plotAreaType;
 | 
					        return Objects.requireNonNullElse(this.plotAreaType, PlotAreaType.NORMAL);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public PlotAreaTerrainType terrainType() {
 | 
					    public PlotAreaTerrainType terrainType() {
 | 
				
			||||||
@@ -127,7 +135,8 @@ public class PlotAreaBuilder {
 | 
				
			|||||||
        return this;
 | 
					        return this;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public PlotAreaBuilder plotAreaType(PlotAreaType plotAreaType) {
 | 
					    public PlotAreaBuilder plotAreaType(@NotNull PlotAreaType plotAreaType) {
 | 
				
			||||||
 | 
					        Objects.requireNonNull(plotAreaType, "PlotAreaType must not be null");
 | 
				
			||||||
        this.plotAreaType = plotAreaType;
 | 
					        this.plotAreaType = plotAreaType;
 | 
				
			||||||
        return this;
 | 
					        return this;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -23,7 +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 record SettingsNodesWrapper(ConfigurationNode[] settingsNodes, SetupStep afterwards) {
 | 
					public record SettingsNodesWrapper(
 | 
				
			||||||
 | 
					        ConfigurationNode[] settingsNodes,
 | 
				
			||||||
 | 
					        SetupStep 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
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -42,15 +42,27 @@ public class EntityUtil {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private static int capNumeral(final @NonNull String flagName) {
 | 
					    private static int capNumeral(final @NonNull String flagName) {
 | 
				
			||||||
        int i = switch (flagName) {
 | 
					        int i;
 | 
				
			||||||
            case "mob-cap" -> CAP_MOB;
 | 
					        switch (flagName) {
 | 
				
			||||||
            case "hostile-cap" -> CAP_MONSTER;
 | 
					            case "mob-cap":
 | 
				
			||||||
            case "animal-cap" -> CAP_ANIMAL;
 | 
					                i = CAP_MOB;
 | 
				
			||||||
            case "vehicle-cap" -> CAP_VEHICLE;
 | 
					                break;
 | 
				
			||||||
            case "misc-cap" -> CAP_MISC;
 | 
					            case "hostile-cap":
 | 
				
			||||||
            // "entity-cap"
 | 
					                i = CAP_MONSTER;
 | 
				
			||||||
            default -> CAP_ENTITY;
 | 
					                break;
 | 
				
			||||||
        };
 | 
					            case "animal-cap":
 | 
				
			||||||
 | 
					                i = CAP_ANIMAL;
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					            case "vehicle-cap":
 | 
				
			||||||
 | 
					                i = CAP_VEHICLE;
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					            case "misc-cap":
 | 
				
			||||||
 | 
					                i = CAP_MISC;
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					            case "entity-cap":
 | 
				
			||||||
 | 
					            default:
 | 
				
			||||||
 | 
					                i = CAP_ENTITY;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
        return i;
 | 
					        return i;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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,6 +18,9 @@
 | 
				
			|||||||
 */
 | 
					 */
 | 
				
			||||||
package com.plotsquared.core.util;
 | 
					package com.plotsquared.core.util;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public record FileBytes(String path, byte[] data) {
 | 
					public record FileBytes(
 | 
				
			||||||
 | 
					        String path,
 | 
				
			||||||
 | 
					        byte[] data
 | 
				
			||||||
 | 
					) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -56,7 +56,7 @@ public final class ItemUtil {
 | 
				
			|||||||
        return ItemTypes.get(input);
 | 
					        return ItemTypes.get(input);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public static ItemType[] parse(String commaDelimited) {
 | 
					    public static final ItemType[] parse(String commaDelimited) {
 | 
				
			||||||
        String[] split = commaDelimited.split(",(?![^\\(\\[]*[\\]\\)])");
 | 
					        String[] split = commaDelimited.split(",(?![^\\(\\[]*[\\]\\)])");
 | 
				
			||||||
        ItemType[] result = new ItemType[split.length];
 | 
					        ItemType[] result = new ItemType[split.length];
 | 
				
			||||||
        for (int i = 0; i < split.length; i++) {
 | 
					        for (int i = 0; i < split.length; i++) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,14 +20,49 @@ package com.plotsquared.core.util;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
public class MathMan {
 | 
					public class MathMan {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public static int gcd(int a, int b) {
 | 
					    private static final int ATAN2_BITS = 7;
 | 
				
			||||||
 | 
					    private static final int ATAN2_BITS2 = ATAN2_BITS << 1;
 | 
				
			||||||
 | 
					    private static final int ATAN2_MASK = ~(-1 << ATAN2_BITS2);
 | 
				
			||||||
 | 
					    private static final int ATAN2_COUNT = ATAN2_MASK + 1;
 | 
				
			||||||
 | 
					    private static final int ATAN2_DIM = (int) Math.sqrt(ATAN2_COUNT);
 | 
				
			||||||
 | 
					    private static final float INV_ATAN2_DIM_MINUS_1 = 1.0f / (ATAN2_DIM - 1);
 | 
				
			||||||
 | 
					    private static final float[] atan2 = new float[ATAN2_COUNT];
 | 
				
			||||||
 | 
					    private static final int[] table =
 | 
				
			||||||
 | 
					            {0, 16, 22, 27, 32, 35, 39, 42, 45, 48, 50, 53, 55, 57, 59, 61, 64, 65, 67, 69, 71, 73, 75,
 | 
				
			||||||
 | 
					                    76, 78, 80, 81, 83, 84, 86, 87, 89, 90, 91, 93, 94, 96, 97, 98, 99, 101, 102, 103, 104,
 | 
				
			||||||
 | 
					                    106, 107, 108, 109, 110, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122, 123,
 | 
				
			||||||
 | 
					                    124, 125, 126, 128, 128, 129, 130, 131, 132, 133, 134, 135, 136, 137, 138, 139, 140,
 | 
				
			||||||
 | 
					                    141, 142, 143, 144, 144, 145, 146, 147, 148, 149, 150, 150, 151, 152, 153, 154, 155,
 | 
				
			||||||
 | 
					                    155, 156, 157, 158, 159, 160, 160, 161, 162, 163, 163, 164, 165, 166, 167, 167, 168,
 | 
				
			||||||
 | 
					                    169, 170, 170, 171, 172, 173, 173, 174, 175, 176, 176, 177, 178, 178, 179, 180, 181,
 | 
				
			||||||
 | 
					                    181, 182, 183, 183, 184, 185, 185, 186, 187, 187, 188, 189, 189, 190, 191, 192, 192,
 | 
				
			||||||
 | 
					                    193, 193, 194, 195, 195, 196, 197, 197, 198, 199, 199, 200, 201, 201, 202, 203, 203,
 | 
				
			||||||
 | 
					                    204, 204, 205, 206, 206, 207, 208, 208, 209, 209, 210, 211, 211, 212, 212, 213, 214,
 | 
				
			||||||
 | 
					                    214, 215, 215, 216, 217, 217, 218, 218, 219, 219, 220, 221, 221, 222, 222, 223, 224,
 | 
				
			||||||
 | 
					                    224, 225, 225, 226, 226, 227, 227, 228, 229, 229, 230, 230, 231, 231, 232, 232, 233,
 | 
				
			||||||
 | 
					                    234, 234, 235, 235, 236, 236, 237, 237, 238, 238, 239, 240, 240, 241, 241, 242, 242,
 | 
				
			||||||
 | 
					                    243, 243, 244, 244, 245, 245, 246, 246, 247, 247, 248, 248, 249, 249, 250, 250, 251,
 | 
				
			||||||
 | 
					                    251, 252, 252, 253, 253, 254, 254, 255};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    static {
 | 
				
			||||||
 | 
					        for (int i = 0; i < ATAN2_DIM; i++) {
 | 
				
			||||||
 | 
					            for (int j = 0; j < ATAN2_DIM; j++) {
 | 
				
			||||||
 | 
					                float x0 = (float) i / ATAN2_DIM;
 | 
				
			||||||
 | 
					                float y0 = (float) j / ATAN2_DIM;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                atan2[(j * ATAN2_DIM) + i] = (float) Math.atan2(y0, x0);
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public static final int gcd(int a, int b) {
 | 
				
			||||||
        if (b == 0) {
 | 
					        if (b == 0) {
 | 
				
			||||||
            return a;
 | 
					            return a;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        return gcd(b, a % b);
 | 
					        return gcd(b, a % b);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public static int gcd(int[] a) {
 | 
					    public static final int gcd(int[] a) {
 | 
				
			||||||
        int result = a[0];
 | 
					        int result = a[0];
 | 
				
			||||||
        for (int i = 1; i < a.length; i++) {
 | 
					        for (int i = 1; i < a.length; i++) {
 | 
				
			||||||
            result = gcd(result, a[i]);
 | 
					            result = gcd(result, a[i]);
 | 
				
			||||||
@@ -47,7 +82,7 @@ public class MathMan {
 | 
				
			|||||||
        return (x << 16) | (y & 0xFFFF);
 | 
					        return (x << 16) | (y & 0xFFFF);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public static int average(int a, int b) {
 | 
					    public static final int average(int a, int b) {
 | 
				
			||||||
        return (a & b) + (a ^ b) / 2;
 | 
					        return (a & b) + (a ^ b) / 2;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,150 +0,0 @@
 | 
				
			|||||||
/*
 | 
					 | 
				
			||||||
 * PlotSquared, a land and world management plugin for Minecraft.
 | 
					 | 
				
			||||||
 * Copyright (C) IntellectualSites <https://intellectualsites.com>
 | 
					 | 
				
			||||||
 * Copyright (C) IntellectualSites team and contributors
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * This program is free software: you can redistribute it and/or modify
 | 
					 | 
				
			||||||
 * it under the terms of the GNU General Public License as published by
 | 
					 | 
				
			||||||
 * the Free Software Foundation, either version 3 of the License, or
 | 
					 | 
				
			||||||
 * (at your option) any later version.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * This program is distributed in the hope that it will be useful,
 | 
					 | 
				
			||||||
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
					 | 
				
			||||||
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
					 | 
				
			||||||
 * GNU General Public License for more details.
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * You should have received a copy of the GNU General Public License
 | 
					 | 
				
			||||||
 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
package com.plotsquared.core.util;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import com.plotsquared.core.configuration.Settings;
 | 
					 | 
				
			||||||
import com.plotsquared.core.configuration.caption.TranslatableCaption;
 | 
					 | 
				
			||||||
import com.plotsquared.core.permissions.Permission;
 | 
					 | 
				
			||||||
import com.plotsquared.core.permissions.PermissionHolder;
 | 
					 | 
				
			||||||
import com.plotsquared.core.player.PlotPlayer;
 | 
					 | 
				
			||||||
import net.kyori.adventure.text.Component;
 | 
					 | 
				
			||||||
import net.kyori.adventure.text.minimessage.tag.Tag;
 | 
					 | 
				
			||||||
import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver;
 | 
					 | 
				
			||||||
import org.checkerframework.checker.nullness.qual.NonNull;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * The Permissions class handles checking user permissions.<br>
 | 
					 | 
				
			||||||
 * - This will respect * nodes and plots.admin and can be used to check permission ranges (e.g. plots.plot.5)<br>
 | 
					 | 
				
			||||||
 * - Checking the PlotPlayer class directly will not take the above into account<br>
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * @deprecated all logic that may once have been in the class lives elsewhere. We also want to do away with statically-accessed
 | 
					 | 
				
			||||||
 *         classes
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
@Deprecated(forRemoval = true, since = "6.9.3")
 | 
					 | 
				
			||||||
public class Permissions {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * @deprecated all logic that may once have been in the class lives elsewhere. We also want to do away with statically-accessed
 | 
					 | 
				
			||||||
     *         classes. Use {@link PlotPlayer#hasPermission(String, boolean)}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.3")
 | 
					 | 
				
			||||||
    public static boolean hasPermission(PlotPlayer<?> player, Permission permission, boolean notify) {
 | 
					 | 
				
			||||||
        return hasPermission(player, permission.toString(), notify);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * Check if the owner of the profile has a given (global) permission
 | 
					 | 
				
			||||||
     *
 | 
					 | 
				
			||||||
     * @param caller     permission holder
 | 
					 | 
				
			||||||
     * @param permission Permission
 | 
					 | 
				
			||||||
     * @return {@code true} if the owner has the given permission, else {@code false}
 | 
					 | 
				
			||||||
     * @deprecated all logic that may once have been in the class lives elsewhere. We also want to do away with statically-accessed
 | 
					 | 
				
			||||||
     *         classes. Use {@link PermissionHolder#hasPermission(Permission)}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.3")
 | 
					 | 
				
			||||||
    public static boolean hasPermission(final @NonNull PermissionHolder caller, final @NonNull Permission permission) {
 | 
					 | 
				
			||||||
        return caller.hasPermission(permission.toString());
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * Check if the owner of the profile has a given (global) permission. There is no guarantee that per-world permissions will
 | 
					 | 
				
			||||||
     * be checked because unmaintained crap plugins like PEX exist.
 | 
					 | 
				
			||||||
     *
 | 
					 | 
				
			||||||
     * @param caller     permission holder
 | 
					 | 
				
			||||||
     * @param permission Permission
 | 
					 | 
				
			||||||
     * @return {@code true} if the owner has the given permission, else {@code false}
 | 
					 | 
				
			||||||
     * @deprecated all logic that may once have been in the class lives elsewhere. We also want to do away with statically-accessed
 | 
					 | 
				
			||||||
     *         classes. Use {@link PermissionHolder#hasPermission(String)}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.3")
 | 
					 | 
				
			||||||
    public static boolean hasPermission(final @NonNull PermissionHolder caller, final @NonNull String permission) {
 | 
					 | 
				
			||||||
        return caller.hasPermission(permission);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * Check if the owner of the profile has a given (global) keyed permission. Checks both {@code permission.key}
 | 
					 | 
				
			||||||
     * and {@code permission.*}
 | 
					 | 
				
			||||||
     *
 | 
					 | 
				
			||||||
     * @param caller     permission holder
 | 
					 | 
				
			||||||
     * @param permission Permission
 | 
					 | 
				
			||||||
     * @param key        Permission "key"
 | 
					 | 
				
			||||||
     * @return {@code true} if the owner has the given permission, else {@code false}
 | 
					 | 
				
			||||||
     * @since 6.0.10
 | 
					 | 
				
			||||||
     * @deprecated all logic that may once have been in the class lives elsewhere. We also want to do away with statically-accessed
 | 
					 | 
				
			||||||
     *         classes. Use {@link PermissionHolder#hasKeyedPermission(String, String)}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.3")
 | 
					 | 
				
			||||||
    public static boolean hasKeyedPermission(
 | 
					 | 
				
			||||||
            final @NonNull PermissionHolder caller, final @NonNull String permission,
 | 
					 | 
				
			||||||
            final @NonNull String key
 | 
					 | 
				
			||||||
    ) {
 | 
					 | 
				
			||||||
        return caller.hasKeyedPermission(permission, key);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * Checks if a PlotPlayer has a permission, and optionally send the no permission message if applicable.
 | 
					 | 
				
			||||||
     *
 | 
					 | 
				
			||||||
     * @param player     permission holder
 | 
					 | 
				
			||||||
     * @param permission permission
 | 
					 | 
				
			||||||
     * @param notify     if to notify the permission holder
 | 
					 | 
				
			||||||
     * @return if permission is had
 | 
					 | 
				
			||||||
     * @deprecated all logic that may once have been in the class lives elsewhere. We also want to do away with statically-accessed
 | 
					 | 
				
			||||||
     *         classes. Use {@link PlotPlayer#hasPermission(String, boolean)}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.3")
 | 
					 | 
				
			||||||
    public static boolean hasPermission(PlotPlayer<?> player, String permission, boolean notify) {
 | 
					 | 
				
			||||||
        if (!hasPermission(player, permission)) {
 | 
					 | 
				
			||||||
            if (notify) {
 | 
					 | 
				
			||||||
                player.sendMessage(
 | 
					 | 
				
			||||||
                        TranslatableCaption.of("permission.no_permission_event"),
 | 
					 | 
				
			||||||
                        TagResolver.resolver("node", Tag.inserting(Component.text(permission)))
 | 
					 | 
				
			||||||
                );
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
            return false;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        return true;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * @deprecated all logic that may once have been in the class lives elsewhere. We also want to do away with statically-accessed
 | 
					 | 
				
			||||||
     *         classes. Use {@link PlotPlayer#hasPermissionRange(Permission, int)}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.3")
 | 
					 | 
				
			||||||
    public static int hasPermissionRange(PlotPlayer<?> player, Permission Permission, int range) {
 | 
					 | 
				
			||||||
        return hasPermissionRange(player, Permission.toString(), range);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * Check the highest permission a PlotPlayer has within a specified range.<br>
 | 
					 | 
				
			||||||
     * - Excessively high values will lag<br>
 | 
					 | 
				
			||||||
     * - The default range that is checked is {@link Settings.Limit#MAX_PLOTS}<br>
 | 
					 | 
				
			||||||
     *
 | 
					 | 
				
			||||||
     * @param player Player to check for
 | 
					 | 
				
			||||||
     * @param stub   The permission stub to check e.g. for `plots.plot.#` the stub is `plots.plot`
 | 
					 | 
				
			||||||
     * @param range  The range to check
 | 
					 | 
				
			||||||
     * @return The highest permission they have within that range
 | 
					 | 
				
			||||||
     * @deprecated all logic that may once have been in the class lives elsewhere. We also want to do away with statically-accessed
 | 
					 | 
				
			||||||
     *         classes. Use {@link PlotPlayer#hasPermissionRange(String, int)}
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    @Deprecated(forRemoval = true, since = "6.9.3")
 | 
					 | 
				
			||||||
    public static int hasPermissionRange(PlotPlayer<?> player, String stub, int range) {
 | 
					 | 
				
			||||||
        return player.hasPermissionRange(stub, range);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -429,7 +429,9 @@ public abstract class SchematicHandler {
 | 
				
			|||||||
        if (parent.exists()) {
 | 
					        if (parent.exists()) {
 | 
				
			||||||
            final String[] rawNames = parent.list((dir, name) -> name.endsWith(".schematic") || name.endsWith(".schem"));
 | 
					            final String[] rawNames = parent.list((dir, name) -> name.endsWith(".schematic") || name.endsWith(".schem"));
 | 
				
			||||||
            if (rawNames != null) {
 | 
					            if (rawNames != null) {
 | 
				
			||||||
                final List<String> transformed = Arrays.stream(rawNames).toList();
 | 
					                final List<String> transformed = Arrays.stream(rawNames)
 | 
				
			||||||
 | 
					                        //.map(rawName -> rawName.substring(0, rawName.length() - 10))
 | 
				
			||||||
 | 
					                        .collect(Collectors.toList());
 | 
				
			||||||
                names.addAll(transformed);
 | 
					                names.addAll(transformed);
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
@@ -489,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 {
 | 
				
			||||||
@@ -725,7 +731,10 @@ public abstract class SchematicHandler {
 | 
				
			|||||||
                                    }
 | 
					                                    }
 | 
				
			||||||
                                    BaseBlock block = aabb.getWorld().getFullBlock(point);
 | 
					                                    BaseBlock block = aabb.getWorld().getFullBlock(point);
 | 
				
			||||||
                                    if (block.getNbtData() != null) {
 | 
					                                    if (block.getNbtData() != null) {
 | 
				
			||||||
                                        Map<String, Tag> values = new HashMap<>(block.getNbtData().getValue());
 | 
					                                        Map<String, Tag> values = new HashMap<>();
 | 
				
			||||||
 | 
					                                        for (Map.Entry<String, Tag> entry : block.getNbtData().getValue().entrySet()) {
 | 
				
			||||||
 | 
					                                            values.put(entry.getKey(), entry.getValue());
 | 
				
			||||||
 | 
					                                        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                                        // Positions are kept in NBT, we don't want that.
 | 
					                                        // Positions are kept in NBT, we don't want that.
 | 
				
			||||||
                                        values.remove("x");
 | 
					                                        values.remove("x");
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -129,7 +129,9 @@ public class StringMan {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public static String repeat(String s, int n) {
 | 
					    public static String repeat(String s, int n) {
 | 
				
			||||||
        return String.valueOf(s).repeat(Math.max(0, n));
 | 
					        StringBuilder sb = new StringBuilder();
 | 
				
			||||||
 | 
					        sb.append(String.valueOf(s).repeat(Math.max(0, n)));
 | 
				
			||||||
 | 
					        return sb.toString();
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -92,23 +92,23 @@ public final class TimeUtil {
 | 
				
			|||||||
                case "wks":
 | 
					                case "wks":
 | 
				
			||||||
                case "w":
 | 
					                case "w":
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                    time += 604800L * numbers;
 | 
					                    time += 604800 * numbers;
 | 
				
			||||||
                case "days":
 | 
					                case "days":
 | 
				
			||||||
                case "day":
 | 
					                case "day":
 | 
				
			||||||
                case "d":
 | 
					                case "d":
 | 
				
			||||||
                    time += 86400L * numbers;
 | 
					                    time += 86400 * numbers;
 | 
				
			||||||
                case "hour":
 | 
					                case "hour":
 | 
				
			||||||
                case "hr":
 | 
					                case "hr":
 | 
				
			||||||
                case "hrs":
 | 
					                case "hrs":
 | 
				
			||||||
                case "hours":
 | 
					                case "hours":
 | 
				
			||||||
                case "h":
 | 
					                case "h":
 | 
				
			||||||
                    time += 3600L * numbers;
 | 
					                    time += 3600 * numbers;
 | 
				
			||||||
                case "minutes":
 | 
					                case "minutes":
 | 
				
			||||||
                case "minute":
 | 
					                case "minute":
 | 
				
			||||||
                case "mins":
 | 
					                case "mins":
 | 
				
			||||||
                case "min":
 | 
					                case "min":
 | 
				
			||||||
                case "m":
 | 
					                case "m":
 | 
				
			||||||
                    time += 60L * numbers;
 | 
					                    time += 60 * numbers;
 | 
				
			||||||
                case "seconds":
 | 
					                case "seconds":
 | 
				
			||||||
                case "second":
 | 
					                case "second":
 | 
				
			||||||
                case "secs":
 | 
					                case "secs":
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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,
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -89,7 +89,7 @@ public final class PlaceholderRegistry {
 | 
				
			|||||||
        this.createPlaceholder("world_name", player -> player.getLocation().getWorldName());
 | 
					        this.createPlaceholder("world_name", player -> player.getLocation().getWorldName());
 | 
				
			||||||
        this.createPlaceholder("has_plot", player -> player.getPlotCount() > 0 ? "true" : "false");
 | 
					        this.createPlaceholder("has_plot", player -> player.getPlotCount() > 0 ? "true" : "false");
 | 
				
			||||||
        this.createPlaceholder("allowed_plot_count", (player) -> {
 | 
					        this.createPlaceholder("allowed_plot_count", (player) -> {
 | 
				
			||||||
            if (player.getAllowedPlots() == Integer.MAX_VALUE) { // Beautifies cases with '*' permission
 | 
					            if (player.getAllowedPlots() >= Integer.MAX_VALUE) { // Beautifies cases with '*' permission
 | 
				
			||||||
                return legacyComponent(TranslatableCaption.of("info.infinite"), player);
 | 
					                return legacyComponent(TranslatableCaption.of("info.infinite"), player);
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            return Integer.toString(player.getAllowedPlots());
 | 
					            return Integer.toString(player.getAllowedPlots());
 | 
				
			||||||
@@ -300,7 +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 record PlaceholderAddedEvent(Placeholder placeholder) {
 | 
					    public record PlaceholderAddedEvent(
 | 
				
			||||||
 | 
					            Placeholder placeholder
 | 
				
			||||||
 | 
					    ) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -72,7 +72,8 @@ class SearchPlotProvider implements PlotProvider {
 | 
				
			|||||||
                IntStream.range(0, size).mapToObj(i -> new ArrayList<Plot>())
 | 
					                IntStream.range(0, size).mapToObj(i -> new ArrayList<Plot>())
 | 
				
			||||||
                        .collect(Collectors.toCollection(() -> new ArrayList<>(size)));
 | 
					                        .collect(Collectors.toCollection(() -> new ArrayList<>(size)));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        PlotArea area = PlotSquared.get().getPlotAreaManager().getPlotAreaByString(search);
 | 
					        PlotArea area = null;
 | 
				
			||||||
 | 
					        String alias = null;
 | 
				
			||||||
        for (Plot plot : PlotQuery.newQuery().allPlots()) {
 | 
					        for (Plot plot : PlotQuery.newQuery().allPlots()) {
 | 
				
			||||||
            int count = 0;
 | 
					            int count = 0;
 | 
				
			||||||
            if (!uuids.isEmpty()) {
 | 
					            if (!uuids.isEmpty()) {
 | 
				
			||||||
@@ -89,10 +90,10 @@ class SearchPlotProvider implements PlotProvider {
 | 
				
			|||||||
                    count++;
 | 
					                    count++;
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            if (plot.getArea() != null && plot.getArea().equals(area)) {
 | 
					            if (area != null && plot.getArea().equals(area)) {
 | 
				
			||||||
                count++;
 | 
					                count++;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            if (search.equals(plot.getAlias())) {
 | 
					            if (alias != null && alias.equals(plot.getAlias())) {
 | 
				
			||||||
                count += 2;
 | 
					                count += 2;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            if (count != 0) {
 | 
					            if (count != 0) {
 | 
				
			||||||
 
 | 
				
			|||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user