mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-24 23:23:44 +02:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			fix/consis
			...
			enhanced-s
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | b8b5dd8d13 | ||
|   | ad522358c7 | 
							
								
								
									
										5
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,7 +8,7 @@ body: | |||||||
|       value: | |       value: | | ||||||
|         Thanks for taking the time to fill out this bug report for PlotSquared! Fill out the following form to your best ability to help us fix the problem. |         Thanks for taking the time to fill out this bug report for PlotSquared! Fill out the following form to your best ability to help us fix the problem. | ||||||
|         Only use this if you're absolutely sure that you found a bug and can reproduce it. For anything else, use: [our Discord server](https://discord.gg/intellectualsites) or [the wiki](https://intellectualsites.github.io/plotsquared-documentation/). |         Only use this if you're absolutely sure that you found a bug and can reproduce it. For anything else, use: [our Discord server](https://discord.gg/intellectualsites) or [the wiki](https://intellectualsites.github.io/plotsquared-documentation/). | ||||||
|         Do NOT use the public issue tracker to report security vulnerabilities! They are disclosed using [this](https://github.com/IntellectualSites/PlotSquared/security/policy) GitHub form! |         Do NOT use the public issue tracker to report security vulnerabilities! They are disclosed using [this](https://forms.gle/btgdRn9yhGtzEiGW8) form! | ||||||
|  |  | ||||||
|   - type: dropdown |   - type: dropdown | ||||||
|     attributes: |     attributes: | ||||||
| @@ -27,9 +27,6 @@ body: | |||||||
|       description: Which server version version you using? If your server version is not listed, it is not supported. Update to a supported version first. |       description: Which server version version you using? If your server version is not listed, it is not supported. Update to a supported version first. | ||||||
|       multiple: false |       multiple: false | ||||||
|       options: |       options: | ||||||
|         - '1.20.1' |  | ||||||
|         - '1.20' |  | ||||||
|         - '1.19.4' |  | ||||||
|         - '1.19.3' |         - '1.19.3' | ||||||
|         - '1.19.2' |         - '1.19.2' | ||||||
|         - '1.19.1' |         - '1.19.1' | ||||||
|   | |||||||
| @@ -1,7 +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 | ||||||
| @@ -11,7 +11,7 @@ jobs: | |||||||
|           DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} |           DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }} | ||||||
|           DISCORD_USERNAME: PlotSquared Release |           DISCORD_USERNAME: PlotSquared Release | ||||||
|           DISCORD_AVATAR: https://raw.githubusercontent.com/IntellectualSites/Assets/main/plugins/PlotSquared/PlotSquared.png |           DISCORD_AVATAR: https://raw.githubusercontent.com/IntellectualSites/Assets/main/plugins/PlotSquared/PlotSquared.png | ||||||
|         uses: Ilshidur/action-discord@0.3.2 |         uses: Ilshidur/action-discord@08d9328877d6954120eef2b07abbc79249bb6210 # ratchet:Ilshidur/action-discord@0.3.2 | ||||||
|         with: |         with: | ||||||
|           args: | |           args: | | ||||||
|             "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>" |             "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>" | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,17 +1,17 @@ | |||||||
| 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' | ||||||
|     runs-on: ${{ matrix.os }} |     runs-on: ${{ matrix.os }} | ||||||
|     strategy: |     strategy: | ||||||
|       matrix: |       matrix: | ||||||
|         os: [ ubuntu-latest, windows-latest, macos-latest ] |         os: [ubuntu-latest, windows-latest, macos-latest] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout Repository |       - name: Checkout Repository | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
|       - name: Validate Gradle Wrapper |       - name: Validate Gradle Wrapper | ||||||
|         uses: gradle/wrapper-validation-action@v1 |         uses: gradle/wrapper-validation-action@55e685c48d84285a5b0418cd094606e199cca3b6 # v1 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v3 |         uses: actions/setup-java@v3 | ||||||
|         with: |         with: | ||||||
|   | |||||||
							
								
								
									
										21
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										21
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -2,7 +2,7 @@ name: build | |||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - main |       - v7 | ||||||
| jobs: | jobs: | ||||||
|   build: |   build: | ||||||
|     if: github.repository_owner == 'IntellectualSites' |     if: github.repository_owner == 'IntellectualSites' | ||||||
| @@ -11,7 +11,7 @@ jobs: | |||||||
|       - name: Checkout Repository |       - name: Checkout Repository | ||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
|       - name: Validate Gradle Wrapper |       - name: Validate Gradle Wrapper | ||||||
|         uses: gradle/wrapper-validation-action@v1 |         uses: gradle/wrapper-validation-action@55e685c48d84285a5b0418cd094606e199cca3b6 # v1 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v3 |         uses: actions/setup-java@v3 | ||||||
|         with: |         with: | ||||||
| @@ -28,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/main'}} |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} | ||||||
|         run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository |         run: ./gradlew publishToSonatype closeAndReleaseSonatypeStagingRepository | ||||||
|         env: |         env: | ||||||
|           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} |           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} | ||||||
| @@ -36,14 +36,20 @@ 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/main' }} |         if: ${{ runner.os == 'Linux' && env.STATUS != 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7' }} | ||||||
|         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/main'}} | <<<<<<< HEAD | ||||||
|  |        # if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} | ||||||
|  |         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 | ||||||
|  | ======= | ||||||
|  |         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} | ||||||
|  |         uses: cpina/github-action-push-to-another-repository@0a14457bb28b04dfa1652e0ffdfda866d2845c73 # main | ||||||
|  | >>>>>>> v6 | ||||||
|         env: |         env: | ||||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} |           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||||
|         with: |         with: | ||||||
| @@ -54,8 +60,9 @@ 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/main'}} |        # if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} | ||||||
|         uses: cpina/github-action-push-to-another-repository@main |         if: ${{ runner.os == 'Linux' && env.STATUS == 'snapshot' && github.event_name == 'push' && github.ref == 'refs/heads/v7'}} | ||||||
|  |         uses: cpina/github-action-push-to-another-repository@0a14457bb28b04dfa1652e0ffdfda866d2845c73 # main | ||||||
|         env: |         env: | ||||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} |           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} | ||||||
|         with: |         with: | ||||||
|   | |||||||
							
								
								
									
										17
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										17
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,10 +1,10 @@ | |||||||
| name: "CodeQL" | name: "CodeQL" | ||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: [ main ] |     branches: [ v7 ] | ||||||
|   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: [ main ] |     branches: [ v7 ] | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   analyze: |   analyze: | ||||||
| @@ -17,20 +17,15 @@ jobs: | |||||||
|     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: Setup Java |  | ||||||
|         uses: actions/setup-java@v3 |  | ||||||
|         with: |  | ||||||
|           distribution: temurin |  | ||||||
|           java-version: 17 |  | ||||||
|       - name: Initialize CodeQL |       - name: Initialize CodeQL | ||||||
|         uses: github/codeql-action/init@v2 |         uses: github/codeql-action/init@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2 | ||||||
|         with: |         with: | ||||||
|           languages: ${{ matrix.language }} |           languages: ${{ matrix.language }} | ||||||
|       - name: Autobuild |       - name: Autobuild | ||||||
|         uses: github/codeql-action/autobuild@v2 |         uses: github/codeql-action/autobuild@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2 | ||||||
|       - name: Perform CodeQL Analysis |       - name: Perform CodeQL Analysis | ||||||
|         uses: github/codeql-action/analyze@v2 |         uses: github/codeql-action/analyze@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2 | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/release-drafter.yml
									
									
									
									
										vendored
									
									
								
							| @@ -2,11 +2,11 @@ name: draft release | |||||||
| on: | on: | ||||||
|   push: |   push: | ||||||
|     branches: |     branches: | ||||||
|       - main |       - v6 | ||||||
|   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,7 +137,3 @@ 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,144 +1,48 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
| <svg | <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"> | ||||||
|    version="1.1" | 		<metadata id="metadata8"> | ||||||
|    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 | 				<cc:Work rdf:about=""> | ||||||
|    rdf:about=""> |  | ||||||
| 					<dc:format>image/svg+xml</dc:format> | 					<dc:format>image/svg+xml</dc:format> | ||||||
|                     <dc:type |                     <dc:type rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> | ||||||
|    rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |  | ||||||
| 				</cc:Work> | 				</cc:Work> | ||||||
| 			</rdf:RDF> | 			</rdf:RDF> | ||||||
| 		</metadata> | 		</metadata> | ||||||
|     <defs |     <defs id="defs6"> | ||||||
|    id="defs6"> | 			<clipPath clipPathUnits="userSpaceOnUse" id="clipPath18"> | ||||||
| 			<clipPath | 				<path d="M 0,2500 H 3000 V 0 H 0 Z" id="path16" /> | ||||||
|    clipPathUnits="userSpaceOnUse" |  | ||||||
|    id="clipPath18"> |  | ||||||
| 				<path |  | ||||||
|    d="M 0,2500 H 3000 V 0 H 0 Z" |  | ||||||
|    id="path16" /> |  | ||||||
| 			</clipPath> | 			</clipPath> | ||||||
| 		</defs> | 		</defs> | ||||||
|     <sodipodi:namedview |     <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" /> | ||||||
|    pagecolor="#ffffff" |     <g id="g10" inkscape:groupmode="layer" inkscape:label="PlotSquared" transform="matrix(1.3333333,0,0,-1.3333333,0,3333.3333)"> | ||||||
|    bordercolor="#666666" | 			<g id="g12"> | ||||||
|    borderopacity="1" | 				<g id="g14" clip-path="url(#clipPath18)"> | ||||||
|    objecttolerance="10" | 					<g id="g20" transform="translate(1486.1511,2242.6453)"> | ||||||
|    gridtolerance="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" /> | ||||||
|    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 |                     <g id="g24" transform="translate(1201.7948,1741.5303)"> | ||||||
|    id="g24" | 						<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" /> | ||||||
|    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 |                     <g id="g28" transform="translate(919.3342,1429.7462)"> | ||||||
|    id="g28" | 						<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" /> | ||||||
|    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 |                     <g id="g32" transform="translate(1649.134,1700.6166)"> | ||||||
|    id="g32" | 						<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" /> | ||||||
|    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 |                     <g id="g36" transform="translate(1262.7214,1613.126)"> | ||||||
|    id="g36" | 						<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" /> | ||||||
|    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 |                     <g id="g40" transform="translate(1966.3174,1675.6364)"> | ||||||
|    id="g40" | 						<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" /> | ||||||
|    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 |                     <g id="g44" transform="translate(1499.3971,1669.1094)"> | ||||||
|    id="g44" | 						<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" /> | ||||||
|    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 |                     <g id="g48" transform="translate(1748.0469,1601.6797)"> | ||||||
|    id="g48" | 						<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" /> | ||||||
|    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 |                     <g id="g52" transform="translate(1262.7214,1613.126)"> | ||||||
|    id="g52" | 						<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" /> | ||||||
|    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: 12 KiB After Width: | Height: | Size: 11 KiB | 
| @@ -18,7 +18,7 @@ repositories { | |||||||
| } | } | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|     api(projects.plotsquaredCore) |     api(projects.plotSquaredCore) | ||||||
|  |  | ||||||
|     // Metrics |     // Metrics | ||||||
|     implementation("org.bstats:bstats-bukkit") |     implementation("org.bstats:bstats-bukkit") | ||||||
| @@ -62,7 +62,6 @@ tasks.processResources { | |||||||
| } | } | ||||||
|  |  | ||||||
| tasks.named<ShadowJar>("shadowJar") { | tasks.named<ShadowJar>("shadowJar") { | ||||||
|     dependsOn(":plotsquared-core:shadowJar") |  | ||||||
|     dependencies { |     dependencies { | ||||||
|         exclude(dependency("org.checkerframework:")) |         exclude(dependency("org.checkerframework:")) | ||||||
|     } |     } | ||||||
| @@ -103,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.advntr.dev/api/4.14.0/") |         opt.links("https://jd.adventure.kyori.net/api/4.12.0/") | ||||||
|         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") |         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") | ||||||
|         opt.links("https://checkerframework.org/api/") |         opt.links("https://checkerframework.org/api/") | ||||||
|         opt.isLinkSource = true |         opt.isLinkSource = true | ||||||
|   | |||||||
| @@ -49,6 +49,7 @@ import com.plotsquared.bukkit.player.BukkitPlayerManager; | |||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.plotsquared.bukkit.util.BukkitWorld; | import com.plotsquared.bukkit.util.BukkitWorld; | ||||||
| import com.plotsquared.bukkit.util.SetGenCB; | import com.plotsquared.bukkit.util.SetGenCB; | ||||||
|  | import com.plotsquared.bukkit.util.UpdateUtility; | ||||||
| import com.plotsquared.bukkit.util.TranslationUpdateManager; | import com.plotsquared.bukkit.util.TranslationUpdateManager; | ||||||
| import com.plotsquared.bukkit.util.task.BukkitTaskManager; | import com.plotsquared.bukkit.util.task.BukkitTaskManager; | ||||||
| import com.plotsquared.bukkit.util.task.PaperTimeConverter; | import com.plotsquared.bukkit.util.task.PaperTimeConverter; | ||||||
| @@ -302,11 +303,9 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|  |  | ||||||
|         this.serverLocale = Locale.forLanguageTag(Settings.Enabled_Components.DEFAULT_LOCALE); |         this.serverLocale = Locale.forLanguageTag(Settings.Enabled_Components.DEFAULT_LOCALE); | ||||||
|  |  | ||||||
|         /* TODO Enable update checker before v7 is released to GA |  | ||||||
|         if (PremiumVerification.isPremium() && Settings.Enabled_Components.UPDATE_NOTIFICATIONS) { |         if (PremiumVerification.isPremium() && Settings.Enabled_Components.UPDATE_NOTIFICATIONS) { | ||||||
|             injector.getInstance(UpdateUtility.class).updateChecker(); |             injector.getInstance(UpdateUtility.class).updateChecker(); | ||||||
|         } |         } | ||||||
|          */ |  | ||||||
|  |  | ||||||
|         if (PremiumVerification.isPremium()) { |         if (PremiumVerification.isPremium()) { | ||||||
|             LOGGER.info("PlotSquared version licensed to Spigot user {}", getUserID()); |             LOGGER.info("PlotSquared version licensed to Spigot user {}", getUserID()); | ||||||
| @@ -367,7 +366,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|             getServer().getPluginManager().registerEvents(injector().getInstance(ServerListener.class), this); |             getServer().getPluginManager().registerEvents(injector().getInstance(ServerListener.class), this); | ||||||
|             getServer().getPluginManager().registerEvents(injector().getInstance(EntitySpawnListener.class), this); |             getServer().getPluginManager().registerEvents(injector().getInstance(EntitySpawnListener.class), this); | ||||||
|             if (PaperLib.isPaper() && Settings.Paper_Components.PAPER_LISTENERS) { |             if (PaperLib.isPaper() && Settings.Paper_Components.PAPER_LISTENERS) { | ||||||
|                 getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener.class), this); |                     getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener.class), this); | ||||||
|             } else { |             } else { | ||||||
|                 getServer().getPluginManager().registerEvents(injector().getInstance(SpigotListener.class), this); |                 getServer().getPluginManager().registerEvents(injector().getInstance(SpigotListener.class), this); | ||||||
|             } |             } | ||||||
| @@ -1186,17 +1185,9 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|     public @NonNull String worldEditImplementations() { |     public @NonNull String worldEditImplementations() { | ||||||
|         StringBuilder msg = new StringBuilder(); |         StringBuilder msg = new StringBuilder(); | ||||||
|         if (Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit") != null) { |         if (Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit") != null) { | ||||||
|             msg.append("FastAsyncWorldEdit: ").append(Bukkit |             msg.append("FastAsyncWorldEdit: ").append(Bukkit.getPluginManager().getPlugin("FastAsyncWorldEdit").getDescription().getVersion()); | ||||||
|                     .getPluginManager() |  | ||||||
|                     .getPlugin("FastAsyncWorldEdit") |  | ||||||
|                     .getDescription() |  | ||||||
|                     .getVersion()); |  | ||||||
|         } else if (Bukkit.getPluginManager().getPlugin("AsyncWorldEdit") != null) { |         } else if (Bukkit.getPluginManager().getPlugin("AsyncWorldEdit") != null) { | ||||||
|             msg.append("AsyncWorldEdit: ").append(Bukkit |             msg.append("AsyncWorldEdit: ").append(Bukkit.getPluginManager().getPlugin("AsyncWorldEdit").getDescription().getVersion()).append("\n"); | ||||||
|                     .getPluginManager() |  | ||||||
|                     .getPlugin("AsyncWorldEdit") |  | ||||||
|                     .getDescription() |  | ||||||
|                     .getVersion()).append("\n"); |  | ||||||
|             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); |             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); | ||||||
|         } else { |         } else { | ||||||
|             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); |             msg.append("WorldEdit: ").append(Bukkit.getPluginManager().getPlugin("WorldEdit").getDescription().getVersion()); | ||||||
|   | |||||||
| @@ -34,12 +34,9 @@ import com.plotsquared.core.queue.ZeroedDelegateScopedQueueCoordinator; | |||||||
| import com.plotsquared.core.util.ChunkManager; | import com.plotsquared.core.util.ChunkManager; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.math.BlockVector2; | import com.sk89q.worldedit.math.BlockVector2; | ||||||
| import com.sk89q.worldedit.math.BlockVector3; |  | ||||||
| import org.apache.logging.log4j.LogManager; | import org.apache.logging.log4j.LogManager; | ||||||
| import org.apache.logging.log4j.Logger; | import org.apache.logging.log4j.Logger; | ||||||
| import org.bukkit.HeightMap; | import org.bukkit.HeightMap; | ||||||
| import org.bukkit.NamespacedKey; |  | ||||||
| import org.bukkit.Registry; |  | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| import org.bukkit.block.Biome; | import org.bukkit.block.Biome; | ||||||
| import org.bukkit.generator.BiomeProvider; | import org.bukkit.generator.BiomeProvider; | ||||||
| @@ -51,17 +48,13 @@ import org.jetbrains.annotations.NotNull; | |||||||
| import org.jetbrains.annotations.Nullable; | import org.jetbrains.annotations.Nullable; | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Arrays; |  | ||||||
| import java.util.EnumSet; |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Random; | import java.util.Random; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
|  |  | ||||||
| import static java.util.function.Predicate.not; |  | ||||||
|  |  | ||||||
| public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrapper<ChunkGenerator> { | public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrapper<ChunkGenerator> { | ||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + BukkitPlotGenerator.class.getSimpleName()); |     private static final Logger LOGGER =  LogManager.getLogger("PlotSquared/" + BukkitPlotGenerator.class.getSimpleName()); | ||||||
|  |  | ||||||
|     @SuppressWarnings("unused") |     @SuppressWarnings("unused") | ||||||
|     public final boolean PAPER_ASYNC_SAFE = true; |     public final boolean PAPER_ASYNC_SAFE = true; | ||||||
| @@ -192,6 +185,12 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         world.setWaterAnimalSpawnLimit(limit); |         world.setWaterAnimalSpawnLimit(limit); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * The entire method is deprecated, but kept for compatibility with versions lower than or equal to 1.16.2. | ||||||
|  |      * The method will be removed in future versions, because WorldEdit and FastAsyncWorldEdit only support the latest point | ||||||
|  |      * release. | ||||||
|  |      */ | ||||||
|  |     @Deprecated(forRemoval = true, since = "6.11.0") | ||||||
|     @Override |     @Override | ||||||
|     public void generateNoise( |     public void generateNoise( | ||||||
|             @NotNull final WorldInfo worldInfo, |             @NotNull final WorldInfo worldInfo, | ||||||
| @@ -284,14 +283,9 @@ 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 = "7.0.0") |     @Deprecated(since = "TODO") | ||||||
|     public @NonNull ChunkData generateChunkData( |     public @NonNull ChunkData generateChunkData( | ||||||
|             @NonNull World world, @NonNull Random random, int x, int z, @NonNull BiomeGrid biome |             @NonNull World world, @NonNull Random random, int x, int z, @NonNull BiomeGrid biome | ||||||
|     ) { |     ) { | ||||||
| @@ -299,8 +293,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 { | ||||||
|                 // Throw exception to be caught by the server that indicates the new generation API is being used. |                 // Return super as it will throw an exception caught by the server that will mean this method is no longer used. | ||||||
|                 throw new UnsupportedOperationException("Using new generation methods. This method is unsupported."); |                 return super.generateChunkData(world, random, x, z, biome); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -421,14 +415,9 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         if (lastPlotArea != null && name.equals(this.levelName) && chunkX == lastChunkX && chunkZ == lastChunkZ) { |         if (lastPlotArea != null && name.equals(this.levelName) && chunkX == lastChunkX && chunkZ == lastChunkZ) { | ||||||
|             return lastPlotArea; |             return lastPlotArea; | ||||||
|         } |         } | ||||||
|         BlockVector3 loc = BlockVector3.at(chunkX << 4, 0, chunkZ << 4); |         PlotArea area = UncheckedWorldLocation.at(name, chunkX << 4, 0, chunkZ << 4).getPlotArea(); | ||||||
|         if (lastPlotArea != null && lastPlotArea.getRegion().contains(loc) && lastPlotArea.getRegion().contains(loc)) { |  | ||||||
|             return lastPlotArea; |  | ||||||
|         } |  | ||||||
|         PlotArea area = UncheckedWorldLocation.at(name, loc).getPlotArea(); |  | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             throw new IllegalStateException(String.format( |             throw new IllegalStateException(String.format("Cannot generate chunk that does not belong to a plot area. World: %s", | ||||||
|                     "Cannot generate chunk that does not belong to a plot area. World: %s", |  | ||||||
|                     name |                     name | ||||||
|             )); |             )); | ||||||
|         } |         } | ||||||
| @@ -445,16 +434,9 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         private static final List<Biome> BIOMES; |         private static final List<Biome> BIOMES; | ||||||
|  |  | ||||||
|         static { |         static { | ||||||
|             Set<Biome> disabledBiomes = EnumSet.of(Biome.CUSTOM); |             ArrayList<Biome> biomes = new ArrayList<>(List.of(Biome.values())); | ||||||
|             if (PlotSquared.platform().serverVersion()[1] <= 19) { |             biomes.remove(Biome.CUSTOM); | ||||||
|                 final Biome cherryGrove = Registry.BIOME.get(NamespacedKey.minecraft("cherry_grove")); |             BIOMES = List.copyOf(biomes); | ||||||
|                 if (cherryGrove != null) { |  | ||||||
|                     disabledBiomes.add(cherryGrove); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             BIOMES = Arrays.stream(Biome.values()) |  | ||||||
|                     .filter(not(disabledBiomes::contains)) |  | ||||||
|                     .toList(); |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
|   | |||||||
| @@ -759,9 +759,7 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (block.getBlockData() instanceof Farmland farmland && event |         if (block.getBlockData() instanceof Farmland farmland && event.getNewState().getBlockData() instanceof Farmland newFarmland) { | ||||||
|                 .getNewState() |  | ||||||
|                 .getBlockData() instanceof Farmland newFarmland) { |  | ||||||
|             int currentMoisture = farmland.getMoisture(); |             int currentMoisture = farmland.getMoisture(); | ||||||
|             int newMoisture = newFarmland.getMoisture(); |             int newMoisture = newFarmland.getMoisture(); | ||||||
|  |  | ||||||
| @@ -1116,7 +1114,6 @@ public class BlockEventListener implements Listener { | |||||||
|             if (plot != null) { |             if (plot != null) { | ||||||
|                 plot.debug("Explosion was cancelled because explosion = false"); |                 plot.debug("Explosion was cancelled because explosion = false"); | ||||||
|             } |             } | ||||||
|             return; |  | ||||||
|         } |         } | ||||||
|         event.blockList().removeIf(blox -> !plot.equals(area.getOwnedPlot(BukkitUtil.adapt(blox.getLocation())))); |         event.blockList().removeIf(blox -> !plot.equals(area.getOwnedPlot(BukkitUtil.adapt(blox.getLocation())))); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -26,7 +26,6 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.flag.implementations.CopperOxideFlag; | import com.plotsquared.core.plot.flag.implementations.CopperOxideFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.MiscInteractFlag; | import com.plotsquared.core.plot.flag.implementations.MiscInteractFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.SculkSensorInteractFlag; |  | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| @@ -93,16 +92,12 @@ public class BlockEventListener117 implements Listener { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null && !PlotFlagUtil.isAreaRoadFlagsAndFlagEquals( |         if (plot == null && !PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, MiscInteractFlag.class, true) || plot != null && !plot.getFlag( | ||||||
|                 area, |                 MiscInteractFlag.class)) { | ||||||
|                 MiscInteractFlag.class, |  | ||||||
|                 true |  | ||||||
|         ) || plot != null && (!plot.getFlag(MiscInteractFlag.class) || !plot.getFlag(SculkSensorInteractFlag.class))) { |  | ||||||
|             if (plotPlayer != null) { |             if (plotPlayer != null) { | ||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|                     if (!plot.isAdded(plotPlayer.getUUID())) { |                     if (!plot.isAdded(plotPlayer.getUUID())) { | ||||||
|                         plot.debug(plotPlayer.getName() + " couldn't trigger sculk sensors because both " + |                         plot.debug(plotPlayer.getName() + " couldn't trigger sculk sensors because misc-interact = false"); | ||||||
|                                 "sculk-sensor-interact and misc-interact = false"); |  | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -113,15 +108,13 @@ public class BlockEventListener117 implements Listener { | |||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|                     if (itemThrower == null && (itemThrower = item.getOwner()) == null) { |                     if (itemThrower == null && (itemThrower = item.getOwner()) == null) { | ||||||
|                         plot.debug( |                         plot.debug( | ||||||
|                                 "A thrown item couldn't trigger sculk sensors because both sculk-sensor-interact and " + |                                 "A thrown item couldn't trigger sculk sensors because misc-interact = false and the item's owner could not be resolved."); | ||||||
|                                         "misc-interact = false and the item's owner could not be resolved."); |  | ||||||
|                         event.setCancelled(true); |                         event.setCancelled(true); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     if (!plot.isAdded(itemThrower)) { |                     if (!plot.isAdded(itemThrower)) { | ||||||
|                         if (!plot.isAdded(itemThrower)) { |                         if (!plot.isAdded(itemThrower)) { | ||||||
|                             plot.debug("A thrown item couldn't trigger sculk sensors because both sculk-sensor-interact and " + |                             plot.debug("A thrown item couldn't trigger sculk sensors because misc-interact = false"); | ||||||
|                                     "misc-interact = false"); |  | ||||||
|                             event.setCancelled(true); |                             event.setCancelled(true); | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
| @@ -140,6 +133,7 @@ public class BlockEventListener117 implements Listener { | |||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             for (int i = blocks.size() - 1; i >= 0; i--) { |             for (int i = blocks.size() - 1; i >= 0; i--) { | ||||||
|                 Location blockLocation = BukkitUtil.adapt(blocks.get(i).getLocation()); |                 Location blockLocation = BukkitUtil.adapt(blocks.get(i).getLocation()); | ||||||
|  |                 blockLocation = BukkitUtil.adapt(blocks.get(i).getLocation()); | ||||||
|                 if (blockLocation.isPlotArea()) { |                 if (blockLocation.isPlotArea()) { | ||||||
|                     blocks.remove(i); |                     blocks.remove(i); | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -234,8 +234,7 @@ public class ChunkListener implements Listener { | |||||||
|         Chunk chunk = event.getChunk(); |         Chunk chunk = event.getChunk(); | ||||||
|         if (Settings.Chunk_Processor.AUTO_TRIM) { |         if (Settings.Chunk_Processor.AUTO_TRIM) { | ||||||
|             String world = chunk.getWorld().getName(); |             String world = chunk.getWorld().getName(); | ||||||
|             if ((!Settings.Enabled_Components.WORLDS || !SinglePlotArea.isSinglePlotWorld(world)) && this.plotAreaManager.hasPlotArea( |             if ((!Settings.Enabled_Components.WORLDS || !SinglePlotArea.isSinglePlotWorld(world)) && this.plotAreaManager.hasPlotArea(world)) { | ||||||
|                     world)) { |  | ||||||
|                 if (unloadChunk(world, chunk, true)) { |                 if (unloadChunk(world, chunk, true)) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -43,10 +43,10 @@ import com.plotsquared.core.plot.flag.implementations.DoneFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | ||||||
| import com.plotsquared.core.plot.flag.types.BooleanFlag; | import com.plotsquared.core.plot.flag.types.BooleanFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; |  | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
|  | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import org.bukkit.Chunk; | import org.bukkit.Chunk; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.TileState; | import org.bukkit.block.TileState; | ||||||
| @@ -439,11 +439,9 @@ public class PaperListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private boolean getBooleanFlagValue( |     private boolean getBooleanFlagValue(@NonNull FlagContainer container, | ||||||
|             @NonNull FlagContainer container, |                                         @NonNull Class<? extends BooleanFlag<?>> flagClass, | ||||||
|             @NonNull Class<? extends BooleanFlag<?>> flagClass, |                                         boolean defaultValue) { | ||||||
|             boolean defaultValue |  | ||||||
|     ) { |  | ||||||
|         BooleanFlag<?> flag = container.getFlag(flagClass); |         BooleanFlag<?> flag = container.getFlag(flagClass); | ||||||
|         return flag == null ? defaultValue : flag.getValue(); |         return flag == null ? defaultValue : flag.getValue(); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -572,8 +572,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             if (now == null) { |             if (now == null) { | ||||||
|                 try (final MetaDataAccess<Boolean> kickAccess = |                 try (final MetaDataAccess<Boolean> kickAccess = | ||||||
|                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { |                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { | ||||||
|                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse( |                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { | ||||||
|                             false)) { |  | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -666,8 +665,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 try (final MetaDataAccess<Boolean> kickAccess = |                 try (final MetaDataAccess<Boolean> kickAccess = | ||||||
|                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { |                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { | ||||||
|                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse( |                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { | ||||||
|                             false)) { |  | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 TagResolver.resolver( |                                 TagResolver.resolver( | ||||||
| @@ -1167,7 +1165,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (type.isEdible()) { |                 if (type.isEdible()) { | ||||||
|                     //Allow all players to eat while also allowing the block place event to be fired |                     //Allow all players to eat while also allowing the block place event ot be fired | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (type == Material.ARMOR_STAND) { |                 if (type == Material.ARMOR_STAND) { | ||||||
|   | |||||||
| @@ -30,9 +30,9 @@ import com.plotsquared.core.plot.PlotArea; | |||||||
| import com.plotsquared.core.plot.PlotHandler; | import com.plotsquared.core.plot.PlotHandler; | ||||||
| import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
|  | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.LivingEntity; | import org.bukkit.entity.LivingEntity; | ||||||
| import org.bukkit.entity.Player; | import org.bukkit.entity.Player; | ||||||
|   | |||||||
| @@ -0,0 +1,63 @@ | |||||||
|  | /* | ||||||
|  |  * 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"; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  */ | ||||||
| @@ -43,7 +43,7 @@ public class BukkitOfflinePlayer implements OfflinePlotPlayer { | |||||||
|      */ |      */ | ||||||
|     public BukkitOfflinePlayer( |     public BukkitOfflinePlayer( | ||||||
|             final @NonNull OfflinePlayer player, final @NonNull |             final @NonNull OfflinePlayer player, final @NonNull | ||||||
|     PermissionHandler permissionHandler |             PermissionHandler permissionHandler | ||||||
|     ) { |     ) { | ||||||
|         this.player = player; |         this.player = player; | ||||||
|         this.permissionProfile = permissionHandler.getPermissionProfile(this) |         this.permissionProfile = permissionHandler.getPermissionProfile(this) | ||||||
|   | |||||||
| @@ -176,10 +176,6 @@ 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; | ||||||
|   | |||||||
| @@ -270,7 +270,7 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|             if (getChunkObject() instanceof Chunk chunkObject) { |             if (getChunkObject() instanceof Chunk chunkObject) { | ||||||
|                 existing = chunkObject.getBlock(x & 15, y, z & 15); |                 existing = chunkObject.getBlock(x & 15, y, z & 15); | ||||||
|             } else { |             } else { | ||||||
|                 existing = getBukkitWorld().getBlockAt(x, y, z); |                  existing = getBukkitWorld().getBlockAt(x, y, z); | ||||||
|             } |             } | ||||||
|             final BlockState existingBaseBlock = BukkitAdapter.adapt(existing.getBlockData()); |             final BlockState existingBaseBlock = BukkitAdapter.adapt(existing.getBlockData()); | ||||||
|             if (BukkitBlockUtil.get(existing).equals(existingBaseBlock) && existing.getBlockData().matches(blockData)) { |             if (BukkitBlockUtil.get(existing).equals(existingBaseBlock) && existing.getBlockData().matches(blockData)) { | ||||||
|   | |||||||
| @@ -62,6 +62,7 @@ public class GenChunk extends ZeroedDelegateScopedQueueCoordinator { | |||||||
|     /** |     /** | ||||||
|      * @param minY minimum world Y, inclusive |      * @param minY minimum world Y, inclusive | ||||||
|      * @param maxY maximum world Y, inclusive |      * @param maxY maximum world Y, inclusive | ||||||
|  |      * | ||||||
|      * @since 6.6.0 |      * @since 6.6.0 | ||||||
|      */ |      */ | ||||||
|     public GenChunk(int minY, int maxY) { |     public GenChunk(int minY, int maxY) { | ||||||
|   | |||||||
| @@ -18,8 +18,6 @@ | |||||||
|  */ |  */ | ||||||
| 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; | ||||||
| @@ -30,20 +28,13 @@ 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.ItemStack; | import org.bukkit.inventory.ItemStack; | ||||||
| @@ -54,15 +45,11 @@ 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 CompoundTag tag; |     public org.bukkit.block.BlockState state = null; | ||||||
|  |     public CompoundTag tag = null; | ||||||
|     private boolean paperErrorTextureSent = false; |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + StateWrapper.class.getSimpleName()); |  | ||||||
|  |  | ||||||
|     public StateWrapper(CompoundTag tag) { |     public StateWrapper(CompoundTag tag) { | ||||||
|         this.tag = tag; |         this.tag = tag; | ||||||
| @@ -240,64 +227,15 @@ public class StateWrapper { | |||||||
|                         return true; |                         return true; | ||||||
|                     } |                     } | ||||||
|                     String player = skullOwner.getString("Name"); |                     String player = skullOwner.getString("Name"); | ||||||
|  |                     if (player == null || player.isEmpty()) { | ||||||
|                     if (player != null && !player.isEmpty()) { |  | ||||||
|                         try { |  | ||||||
|                             skull.setOwningPlayer(Bukkit.getOfflinePlayer(player)); |  | ||||||
|                             skull.update(true); |  | ||||||
|                         } catch (Exception e) { |  | ||||||
|                             e.printStackTrace(); |  | ||||||
|                         } |  | ||||||
|                         return true; |  | ||||||
|                     } |  | ||||||
|  |  | ||||||
|                     final CompoundTag properties = (CompoundTag) skullOwner.getValue().get("Properties"); |  | ||||||
|                     if (properties == null) { |  | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|                     final ListTag textures = properties.getListTag("textures"); |                     try { | ||||||
|                     if (textures.getValue().isEmpty()) { |                         skull.setOwningPlayer(Bukkit.getOfflinePlayer(player)); | ||||||
|                         return false; |                         skull.update(true); | ||||||
|  |                     } catch (Exception e) { | ||||||
|  |                         e.printStackTrace(); | ||||||
|                     } |                     } | ||||||
|                     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 new Pattern(color, patternType); |  | ||||||
|                     }).filter(Objects::nonNull).toList()); |  | ||||||
|                     banner.update(true); |  | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 return false; |                 return false; | ||||||
|   | |||||||
| @@ -70,7 +70,7 @@ public class BukkitRegionManager extends RegionManager { | |||||||
|     @Inject |     @Inject | ||||||
|     public BukkitRegionManager( |     public BukkitRegionManager( | ||||||
|             @NonNull WorldUtil worldUtil, @NonNull GlobalBlockQueue blockQueue, @NonNull |             @NonNull WorldUtil worldUtil, @NonNull GlobalBlockQueue blockQueue, @NonNull | ||||||
|     ProgressSubscriberFactory subscriberFactory |             ProgressSubscriberFactory subscriberFactory | ||||||
|     ) { |     ) { | ||||||
|         super(worldUtil, blockQueue, subscriberFactory); |         super(worldUtil, blockQueue, subscriberFactory); | ||||||
|         this.blockQueue = blockQueue; |         this.blockQueue = blockQueue; | ||||||
|   | |||||||
| @@ -28,32 +28,24 @@ import java.nio.file.Paths; | |||||||
| import java.util.stream.Stream; | import java.util.stream.Stream; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * This is a helper class which replaces older syntax no longer supported by MiniMessage with replacements in messages_%.json. |  * This is a helper class which replaces occurrences of 'suggest_command' with 'run_command' in messages_%.json. | ||||||
|  * MiniMessage changed the syntax between major releases. To warrant a smooth upgrade, we attempt to replace any occurrences |  * MiniMessage changed the syntax between major releases. To warrant a smooth upgrade, we attempt to replace any occurrences | ||||||
|  * while loading PlotSquared. |  * while loading PlotSquared. | ||||||
|  * |  * | ||||||
|  * @since 7.0.0 |  * @since TODO | ||||||
|  */ |  */ | ||||||
| @NotPublic | @NotPublic | ||||||
| public class TranslationUpdateManager { | public class TranslationUpdateManager { | ||||||
|  |  | ||||||
|     public static void upgradeTranslationFile() throws IOException { |     public static void upgradeTranslationFile() throws IOException { | ||||||
|         String suggestCommand = "suggest_command"; |         String searchText = "suggest_command"; | ||||||
|         String suggestCommandReplacement = "run_command"; |         String replacementText = "run_command"; | ||||||
|         String minHeight = "minHeight"; |  | ||||||
|         String minheightReplacement = "minheight"; |  | ||||||
|         String maxHeight = "maxHeight"; |  | ||||||
|         String maxheightReplacement = "maxheight"; |  | ||||||
|  |  | ||||||
|         try (Stream<Path> paths = Files.walk(Paths.get(PlotSquared.platform().getDirectory().toPath().resolve("lang").toUri()))) { |         try (Stream<Path> paths = Files.walk(Paths.get(PlotSquared.platform().getDirectory().toPath().resolve("lang").toUri()))) { | ||||||
|             paths |             paths | ||||||
|                     .filter(Files::isRegularFile) |                     .filter(Files::isRegularFile) | ||||||
|                     .filter(p -> p.getFileName().toString().matches("messages_[a-z]{2}\\.json")) |                     .filter(p -> p.getFileName().toString().matches("messages_[a-z]{2}\\.json")) | ||||||
|                     .forEach(p -> { |                     .forEach(p -> replaceInFile(p, searchText, replacementText)); | ||||||
|                         replaceInFile(p, suggestCommand, suggestCommandReplacement); |  | ||||||
|                         replaceInFile(p, minHeight, minheightReplacement); |  | ||||||
|                         replaceInFile(p, maxHeight, maxheightReplacement); |  | ||||||
|                     }); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -68,5 +60,4 @@ public class TranslationUpdateManager { | |||||||
|             e.printStackTrace(); |             e.printStackTrace(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -54,8 +54,7 @@ public class UpdateUtility implements Listener { | |||||||
|         internalVersion = PlotSquared.get().getVersion(); |         internalVersion = PlotSquared.get().getVersion(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @SuppressWarnings({"deprecation", "DefaultCharset"}) |     @SuppressWarnings({"deprecation", "DefaultCharset"}) // Suppress Json deprecation, we can't use features from gson 2.8.1 and newer yet | ||||||
|     // 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: | ||||||
|   | |||||||
| @@ -23,13 +23,13 @@ include: | |||||||
| Examples of unacceptable behavior by participants include: | Examples of unacceptable behavior by participants include: | ||||||
|  |  | ||||||
| * The use of sexualized language or imagery and unwelcome sexual attention or | * The use of sexualized language or imagery and unwelcome sexual attention or | ||||||
|   advances |  advances | ||||||
| * Trolling, insulting/derogatory comments, and personal or political attacks | * Trolling, insulting/derogatory comments, and personal or political attacks | ||||||
| * Public or private harassment | * Public or private harassment | ||||||
| * Publishing others' private information, such as a physical or electronic | * Publishing others' private information, such as a physical or electronic | ||||||
|   address, without explicit permission |  address, without explicit permission | ||||||
| * Other conduct which could reasonably be considered inappropriate in a | * Other conduct which could reasonably be considered inappropriate in a | ||||||
|   professional setting |  professional setting | ||||||
|  |  | ||||||
| ## Our Responsibilities | ## Our Responsibilities | ||||||
|  |  | ||||||
|   | |||||||
| @@ -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.advntr.dev/api/4.14.0/") |         opt.links("https://jd.adventure.kyori.net/api/4.12.0/") | ||||||
|         opt.links("https://jd.advntr.dev/text-minimessage/4.14.0/") |         opt.links("https://jd.adventure.kyori.net/text-minimessage/4.12.0/") | ||||||
|         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") |         opt.links("https://google.github.io/guice/api-docs/" + libs.guice.get().versionConstraint.toString() + "/javadoc/") | ||||||
|         opt.links("https://checkerframework.org/api/") |         opt.links("https://checkerframework.org/api/") | ||||||
|         opt.links("https://javadoc.io/doc/com.intellectualsites.informative-annotations/informative-annotations/latest/") |         opt.links("https://javadoc.io/doc/com.intellectualsites.informative-annotations/informative-annotations/latest/") | ||||||
|   | |||||||
| @@ -270,11 +270,7 @@ public class PlotSquared { | |||||||
|             captionMap = this.captionLoader.loadAll(this.platform.getDirectory().toPath().resolve("lang")); |             captionMap = this.captionLoader.loadAll(this.platform.getDirectory().toPath().resolve("lang")); | ||||||
|         } else { |         } else { | ||||||
|             String fileName = "messages_" + Settings.Enabled_Components.DEFAULT_LOCALE + ".json"; |             String fileName = "messages_" + Settings.Enabled_Components.DEFAULT_LOCALE + ".json"; | ||||||
|             captionMap = this.captionLoader.loadOrCreateSingle(this.platform |             captionMap = this.captionLoader.loadOrCreateSingle(this.platform.getDirectory().toPath().resolve("lang").resolve(fileName)); | ||||||
|                     .getDirectory() |  | ||||||
|                     .toPath() |  | ||||||
|                     .resolve("lang") |  | ||||||
|                     .resolve(fileName)); |  | ||||||
|         } |         } | ||||||
|         this.captionMaps.put(TranslatableCaption.DEFAULT_NAMESPACE, captionMap); |         this.captionMaps.put(TranslatableCaption.DEFAULT_NAMESPACE, captionMap); | ||||||
|         LOGGER.info( |         LOGGER.info( | ||||||
| @@ -1015,7 +1011,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> | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -141,24 +141,24 @@ public class SimpleBackupManager implements BackupManager { | |||||||
|     ) { |     ) { | ||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
|         public boolean equals(final Object o) { |             public boolean equals(final Object o) { | ||||||
|             if (this == o) { |                 if (this == o) { | ||||||
|                 return true; |                     return true; | ||||||
|  |                 } | ||||||
|  |                 if (o == null || getClass() != o.getClass()) { | ||||||
|  |                     return false; | ||||||
|  |                 } | ||||||
|  |                 final PlotCacheKey that = (PlotCacheKey) o; | ||||||
|  |                 return Objects.equals(plot.getArea(), that.plot.getArea()) | ||||||
|  |                         && Objects.equals(plot.getId(), that.plot.getId()) | ||||||
|  |                         && Objects.equals(plot.getOwnerAbs(), that.plot.getOwnerAbs()); | ||||||
|             } |             } | ||||||
|             if (o == null || getClass() != o.getClass()) { |  | ||||||
|                 return false; |             @Override | ||||||
|  |             public int hashCode() { | ||||||
|  |                 return Objects.hash(plot.getArea(), plot.getId(), plot.getOwnerAbs()); | ||||||
|             } |             } | ||||||
|             final PlotCacheKey that = (PlotCacheKey) o; |  | ||||||
|             return Objects.equals(plot.getArea(), that.plot.getArea()) |  | ||||||
|                     && Objects.equals(plot.getId(), that.plot.getId()) |  | ||||||
|                     && Objects.equals(plot.getOwnerAbs(), that.plot.getOwnerAbs()); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         @Override |  | ||||||
|         public int hashCode() { |  | ||||||
|             return Objects.hash(plot.getArea(), plot.getId(), plot.getOwnerAbs()); |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -70,8 +70,7 @@ public class Add extends Command { | |||||||
|                 plot.isOwner(player.getUUID()) || player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_TRUST), |                 plot.isOwner(player.getUUID()) || player.hasPermission(Permission.PERMISSION_ADMIN_COMMAND_TRUST), | ||||||
|                 TranslatableCaption.of("permission.no_plot_perms") |                 TranslatableCaption.of("permission.no_plot_perms") | ||||||
|         ); |         ); | ||||||
|         checkTrue( |         checkTrue(args.length == 1, | ||||||
|                 args.length == 1, |  | ||||||
|                 TranslatableCaption.of("commandconfig.command_syntax"), |                 TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                 TagResolver.resolver("value", Tag.inserting(Component.text("/plot add <player | *>"))) |                 TagResolver.resolver("value", Tag.inserting(Component.text("/plot add <player | *>"))) | ||||||
|         ); |         ); | ||||||
|   | |||||||
| @@ -296,13 +296,10 @@ public class Auto extends SubCommand { | |||||||
|         } |         } | ||||||
|         if (this.econHandler != null && plotarea.useEconomy()) { |         if (this.econHandler != null && plotarea.useEconomy()) { | ||||||
|             PlotExpression costExp = plotarea.getPrices().get("claim"); |             PlotExpression costExp = plotarea.getPrices().get("claim"); | ||||||
|             PlotExpression mergeCostExp = plotarea.getPrices().get("merge"); |  | ||||||
|             int size = sizeX * sizeZ; |  | ||||||
|             double mergeCost = size <= 1 || mergeCostExp == null ? 0d : mergeCostExp.evaluate(size); |  | ||||||
|             double cost = costExp.evaluate(Settings.Limit.GLOBAL ? |             double cost = costExp.evaluate(Settings.Limit.GLOBAL ? | ||||||
|                     player.getPlotCount() : |                     player.getPlotCount() : | ||||||
|                     player.getPlotCount(plotarea.getWorldName())); |                     player.getPlotCount(plotarea.getWorldName())); | ||||||
|             cost = size * cost + mergeCost; |             cost = (sizeX * sizeZ) * cost; | ||||||
|             if (cost > 0d) { |             if (cost > 0d) { | ||||||
|                 if (!this.econHandler.isSupported()) { |                 if (!this.econHandler.isSupported()) { | ||||||
|                     player.sendMessage(TranslatableCaption.of("economy.vault_or_consumer_null")); |                     player.sendMessage(TranslatableCaption.of("economy.vault_or_consumer_null")); | ||||||
|   | |||||||
| @@ -69,8 +69,7 @@ public class Copy extends SubCommand { | |||||||
|  |  | ||||||
|         plot1.getPlotModificationManager().copy(plot2, player).thenAccept(result -> { |         plot1.getPlotModificationManager().copy(plot2, player).thenAccept(result -> { | ||||||
|             if (result) { |             if (result) { | ||||||
|                 player.sendMessage( |                 player.sendMessage(TranslatableCaption.of("move.copy_success"), | ||||||
|                         TranslatableCaption.of("move.copy_success"), |  | ||||||
|                         TagResolver.builder() |                         TagResolver.builder() | ||||||
|                                 .tag("origin", Tag.inserting(Component.text(plot1.toString()))) |                                 .tag("origin", Tag.inserting(Component.text(plot1.toString()))) | ||||||
|                                 .tag("target", Tag.inserting(Component.text(plot2.toString()))) |                                 .tag("target", Tag.inserting(Component.text(plot2.toString()))) | ||||||
|   | |||||||
| @@ -71,9 +71,9 @@ public class DebugPaste extends SubCommand { | |||||||
|                 StringBuilder b = new StringBuilder(); |                 StringBuilder b = new StringBuilder(); | ||||||
|                 b.append( |                 b.append( | ||||||
|                         """ |                         """ | ||||||
|                                 # Welcome to this paste |                          # Welcome to this paste | ||||||
|                                 # It is meant to provide us at IntellectualSites with better information about your problem |                          # It is meant to provide us at IntellectualSites with better information about your problem | ||||||
|                                 """ |                          """ | ||||||
|                 ); |                 ); | ||||||
|                 b.append("# PlotSquared Information\n"); |                 b.append("# PlotSquared Information\n"); | ||||||
|                 b.append("PlotSquared Version: ").append(PlotSquared.get().getVersion()) |                 b.append("PlotSquared Version: ").append(PlotSquared.get().getVersion()) | ||||||
|   | |||||||
| @@ -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); | ||||||
|                 } |                 } | ||||||
|             }); |             }); | ||||||
|   | |||||||
| @@ -185,25 +185,22 @@ public class Download extends SubCommand { | |||||||
|         if (Settings.Web.LEGACY_WEBINTERFACE) { |         if (Settings.Web.LEGACY_WEBINTERFACE) { | ||||||
|             schematicHandler |             schematicHandler | ||||||
|                     .getCompoundTag(plot) |                     .getCompoundTag(plot) | ||||||
|                     .whenComplete((compoundTag, throwable) -> schematicHandler.upload( |                     .whenComplete((compoundTag, throwable) -> { | ||||||
|                             compoundTag, |                         schematicHandler.upload(compoundTag, null, null, new RunnableVal<>() { | ||||||
|                             null, |                             @Override | ||||||
|                             null, |                             public void run(URL value) { | ||||||
|                             new RunnableVal<>() { |                                 plot.removeRunning(); | ||||||
|                                 @Override |                                 player.sendMessage( | ||||||
|                                 public void run(URL value) { |                                         TranslatableCaption.of("web.generation_link_success"), | ||||||
|                                     plot.removeRunning(); |                                         TagResolver.builder() | ||||||
|                                     player.sendMessage( |                                                 .tag("download", Tag.preProcessParsed(value.toString())) | ||||||
|                                             TranslatableCaption.of("web.generation_link_success"), |                                                 .tag("delete", Tag.preProcessParsed("Not available")) | ||||||
|                                             TagResolver.builder() |                                                 .build() | ||||||
|                                                     .tag("download", Tag.preProcessParsed(value.toString())) |                                 ); | ||||||
|                                                     .tag("delete", Tag.preProcessParsed("Not available")) |                                 player.sendMessage(StaticCaption.of(value.toString())); | ||||||
|                                                     .build() |  | ||||||
|                                     ); |  | ||||||
|                                     player.sendMessage(StaticCaption.of(value.toString())); |  | ||||||
|                                 } |  | ||||||
|                             } |                             } | ||||||
|                     )); |                         }); | ||||||
|  |                     }); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         // TODO legacy support |         // TODO legacy support | ||||||
|   | |||||||
| @@ -134,12 +134,7 @@ public class Help extends Command { | |||||||
|                                 TagResolver.builder() |                                 TagResolver.builder() | ||||||
|                                         .tag("command", Tag.inserting(Component.text("/plot help"))) |                                         .tag("command", Tag.inserting(Component.text("/plot help"))) | ||||||
|                                         .tag("category", Tag.inserting(Component.text("all"))) |                                         .tag("category", Tag.inserting(Component.text("all"))) | ||||||
|                                         .tag( |                                         .tag("category_desc", Tag.inserting(TranslatableCaption.of("help.help_display_all_commands").toComponent(player))) | ||||||
|                                                 "category_desc", |  | ||||||
|                                                 Tag.inserting(TranslatableCaption |  | ||||||
|                                                         .of("help.help_display_all_commands") |  | ||||||
|                                                         .toComponent(player)) |  | ||||||
|                                         ) |  | ||||||
|                                         .build() |                                         .build() | ||||||
|                         )); |                         )); | ||||||
|                 builder.append(Component.newline()).append(MINI_MESSAGE.deserialize(TranslatableCaption |                 builder.append(Component.newline()).append(MINI_MESSAGE.deserialize(TranslatableCaption | ||||||
|   | |||||||
| @@ -52,9 +52,8 @@ public class Info extends SubCommand { | |||||||
|             arg = args[0]; |             arg = args[0]; | ||||||
|             switch (arg) { |             switch (arg) { | ||||||
|                 // TODO: (re?)implement /plot info inv. (it was never properly implemented) |                 // TODO: (re?)implement /plot info inv. (it was never properly implemented) | ||||||
|                 case "trusted", "alias", "biome", "denied", "flags", "id", "size", "members", "creationdate", "seen", "owner", "rating", "likes" -> |                 case "trusted", "alias", "biome", "denied", "flags", "id", "size", "members", "creationdate", "seen", "owner", "rating", "likes" -> plot = Plot | ||||||
|                         plot = Plot |                         .getPlotFromString(player, null, false); | ||||||
|                                 .getPlotFromString(player, null, false); |  | ||||||
|                 default -> { |                 default -> { | ||||||
|                     plot = Plot.getPlotFromString(player, arg, false); |                     plot = Plot.getPlotFromString(player, arg, false); | ||||||
|                     if (args.length == 2) { |                     if (args.length == 2) { | ||||||
|   | |||||||
| @@ -112,15 +112,15 @@ public class Kick extends SubCommand { | |||||||
|                 for (PlotPlayer<?> player2 : players) { |                 for (PlotPlayer<?> player2 : players) { | ||||||
|                     if (!plot.equals(player2.getCurrentPlot())) { |                     if (!plot.equals(player2.getCurrentPlot())) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("kick.player_not_in_plot"), |                                 TranslatableCaption.of("errors.invalid_player"), | ||||||
|                                 TagResolver.resolver("player", Tag.inserting(Component.text(player2.getName()))) |                                 TagResolver.resolver("value", Tag.inserting(Component.text(args[0]))) | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     if (player2.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_DENIED)) { |                     if (player2.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_DENIED)) { | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("kick.cannot_kick_player"), |                                 TranslatableCaption.of("cluster.cannot_kick_player"), | ||||||
|                                 TagResolver.resolver("player", Tag.inserting(Component.text(player2.getName()))) |                                 TagResolver.resolver("name", Tag.inserting(Component.text(player2.getName()))) | ||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|   | |||||||
| @@ -476,11 +476,11 @@ public class ListCmd extends SubCommand { | |||||||
|                         for (final UUIDMapping uuidMapping : names) { |                         for (final UUIDMapping uuidMapping : names) { | ||||||
|                             PlotPlayer<?> pp = PlotSquared.platform().playerManager().getPlayerIfExists(uuidMapping.uuid()); |                             PlotPlayer<?> pp = PlotSquared.platform().playerManager().getPlayerIfExists(uuidMapping.uuid()); | ||||||
|                             TagResolver resolver = TagResolver.builder() |                             TagResolver resolver = TagResolver.builder() | ||||||
|                                     .tag("prefix", Tag.inserting(Component.text(prefix))) |                                 .tag("prefix", Tag.inserting(Component.text(prefix))) | ||||||
|                                     .tag("player", Tag.inserting(Component.text(uuidMapping.username()))) |                                 .tag("player", Tag.inserting(Component.text(uuidMapping.username()))) | ||||||
|                                     .build(); |                                 .build(); | ||||||
|                             if (pp != null) { |                         if (pp != null) { | ||||||
|                                 builder.append(MINI_MESSAGE.deserialize(online, resolver)); |                             builder.append(MINI_MESSAGE.deserialize(online, resolver)); | ||||||
|                             } else if (uuidMapping.username().equalsIgnoreCase("unknown")) { |                             } else if (uuidMapping.username().equalsIgnoreCase("unknown")) { | ||||||
|                                 TagResolver unknownResolver = TagResolver.resolver( |                                 TagResolver unknownResolver = TagResolver.resolver( | ||||||
|                                         "info.unknown", |                                         "info.unknown", | ||||||
|   | |||||||
| @@ -56,7 +56,7 @@ public class Music extends SubCommand { | |||||||
|             .asList("music_disc_13", "music_disc_cat", "music_disc_blocks", "music_disc_chirp", |             .asList("music_disc_13", "music_disc_cat", "music_disc_blocks", "music_disc_chirp", | ||||||
|                     "music_disc_far", "music_disc_mall", "music_disc_mellohi", "music_disc_stal", |                     "music_disc_far", "music_disc_mall", "music_disc_mellohi", "music_disc_stal", | ||||||
|                     "music_disc_strad", "music_disc_ward", "music_disc_11", "music_disc_wait", "music_disc_otherside", |                     "music_disc_strad", "music_disc_ward", "music_disc_11", "music_disc_wait", "music_disc_otherside", | ||||||
|                     "music_disc_pigstep", "music_disc_5", "music_disc_relic" |                     "music_disc_pigstep", "music_disc_5" | ||||||
|             ); |             ); | ||||||
|  |  | ||||||
|     private final InventoryUtil inventoryUtil; |     private final InventoryUtil inventoryUtil; | ||||||
|   | |||||||
| @@ -221,8 +221,7 @@ public class Purge extends SubCommand { | |||||||
|                                 ids.add(plot.temp); |                                 ids.add(plot.temp); | ||||||
|                                 if (finalClear) { |                                 if (finalClear) { | ||||||
|                                     plot.getPlotModificationManager().clear(false, true, player, |                                     plot.getPlotModificationManager().clear(false, true, player, | ||||||
|                                             () -> LOGGER.info("Plot {} cleared by purge", plot.getId()) |                                             () -> LOGGER.info("Plot {} cleared by purge", plot.getId())); | ||||||
|                                     ); |  | ||||||
|                                 } else { |                                 } else { | ||||||
|                                     plot.getPlotModificationManager().removeSign(); |                                     plot.getPlotModificationManager().removeSign(); | ||||||
|                                 } |                                 } | ||||||
|   | |||||||
| @@ -49,8 +49,7 @@ public record ComponentPreset( | |||||||
|     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 in components.yml needs a valid target component, got: " + map.get( |                         new IllegalArgumentException("The preset in components.yml needs a valid target component, got: " + map.get("component"))); | ||||||
|                                 "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(); | ||||||
|   | |||||||
| @@ -42,6 +42,32 @@ public class Config { | |||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + Config.class.getSimpleName()); |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + Config.class.getSimpleName()); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the value for a node<br> | ||||||
|  |      * Probably throws some error if you try to get a non existent key | ||||||
|  |      * | ||||||
|  |      * @param key  configuration key | ||||||
|  |      * @param root configuration class | ||||||
|  |      * @param <T>  value type | ||||||
|  |      * @return value | ||||||
|  |      */ | ||||||
|  |     @SuppressWarnings("unchecked") | ||||||
|  |     public static <T> T get(String key, Class<?> root) { | ||||||
|  |         String[] split = key.split("\\."); | ||||||
|  |         Object instance = getInstance(split, root); | ||||||
|  |         if (instance != null) { | ||||||
|  |             Field field = getField(split, instance); | ||||||
|  |             if (field != null) { | ||||||
|  |                 try { | ||||||
|  |                     return (T) field.get(instance); | ||||||
|  |                 } catch (IllegalAccessException e) { | ||||||
|  |                     e.printStackTrace(); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Set the value of a specific node<br> |      * Set the value of a specific node<br> | ||||||
|      * Probably throws some error if you supply non existing keys or invalid values |      * Probably throws some error if you supply non existing keys or invalid values | ||||||
| @@ -233,6 +259,7 @@ 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 { | ||||||
| @@ -418,6 +445,10 @@ public class Config { | |||||||
|             return INSTANCES.values(); |             return INSTANCES.values(); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         public Collection<String> getSections() { | ||||||
|  |             return INSTANCES.keySet(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         private Map<String, T> getRaw() { |         private Map<String, T> getRaw() { | ||||||
|             return INSTANCES; |             return INSTANCES; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -40,7 +40,7 @@ public interface Caption { | |||||||
|      * |      * | ||||||
|      * @param localeHolder Locale holder |      * @param localeHolder Locale holder | ||||||
|      * @return {@link ComponentLike} |      * @return {@link ComponentLike} | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     @NonNull Component toComponent(@NonNull LocaleHolder localeHolder); |     @NonNull Component toComponent(@NonNull LocaleHolder localeHolder); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -51,7 +51,7 @@ public class CaptionHolder { | |||||||
|      * Get the {@link TagResolver}s to use when resolving tags in the {@link Caption}. |      * Get the {@link TagResolver}s to use when resolving tags in the {@link Caption}. | ||||||
|      * |      * | ||||||
|      * @return The tag resolvers to use. |      * @return The tag resolvers to use. | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public TagResolver[] getTagResolvers() { |     public TagResolver[] getTagResolvers() { | ||||||
|         return this.tagResolvers; |         return this.tagResolvers; | ||||||
| @@ -61,7 +61,7 @@ public class CaptionHolder { | |||||||
|      * Set the {@link TagResolver}s to use when resolving tags in the {@link Caption}. |      * Set the {@link TagResolver}s to use when resolving tags in the {@link Caption}. | ||||||
|      * |      * | ||||||
|      * @param tagResolvers The tag resolvers to use. |      * @param tagResolvers The tag resolvers to use. | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public void setTagResolvers(TagResolver... tagResolvers) { |     public void setTagResolvers(TagResolver... tagResolvers) { | ||||||
|         this.tagResolvers = tagResolvers; |         this.tagResolvers = tagResolvers; | ||||||
|   | |||||||
| @@ -28,20 +28,16 @@ import com.plotsquared.core.plot.flag.implementations.PlotTitleFlag; | |||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.event.ClickEvent; | import net.kyori.adventure.text.event.ClickEvent; | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; | import net.kyori.adventure.text.minimessage.MiniMessage; | ||||||
| import net.kyori.adventure.text.minimessage.ParsingException; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.regex.Pattern; |  | ||||||
|  |  | ||||||
| import static com.plotsquared.core.configuration.caption.ComponentTransform.nested; | import static com.plotsquared.core.configuration.caption.ComponentTransform.nested; | ||||||
| import static com.plotsquared.core.configuration.caption.ComponentTransform.stripClicks; | import static com.plotsquared.core.configuration.caption.ComponentTransform.stripClicks; | ||||||
|  |  | ||||||
| public class CaptionUtility { | public class CaptionUtility { | ||||||
|  |  | ||||||
|     private static final Pattern LEGACY_FORMATTING = Pattern.compile("§[a-gklmnor0-9]"); |  | ||||||
|  |  | ||||||
|     // flags which values are parsed by minimessage |     // flags which values are parsed by minimessage | ||||||
|     private static final Set<Class<? extends PlotFlag<?, ?>>> MINI_MESSAGE_FLAGS = Set.of( |     private static final Set<Class<? extends PlotFlag<?, ?>>> MINI_MESSAGE_FLAGS = Set.of( | ||||||
|             GreetingFlag.class, |             GreetingFlag.class, | ||||||
| @@ -104,14 +100,7 @@ public class CaptionUtility { | |||||||
|      */ |      */ | ||||||
|     public static String stripClickEvents(final @NonNull String miniMessageString) { |     public static String stripClickEvents(final @NonNull String miniMessageString) { | ||||||
|         // parse, transform and serialize again |         // parse, transform and serialize again | ||||||
|         Component component; |         Component component = MiniMessage.miniMessage().deserialize(miniMessageString); | ||||||
|         try { |  | ||||||
|             component = MiniMessage.miniMessage().deserialize(miniMessageString); |  | ||||||
|         } catch (ParsingException e) { |  | ||||||
|             // if the String cannot be parsed, we try stripping legacy colors |  | ||||||
|             String legacyStripped = LEGACY_FORMATTING.matcher(miniMessageString).replaceAll(""); |  | ||||||
|             component = MiniMessage.miniMessage().deserialize(legacyStripped); |  | ||||||
|         } |  | ||||||
|         component = CLICK_STRIP_TRANSFORM.transform(component); |         component = CLICK_STRIP_TRANSFORM.transform(component); | ||||||
|         return MiniMessage.miniMessage().serialize(component); |         return MiniMessage.miniMessage().serialize(component); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -225,7 +225,7 @@ public final class CaptionLoader { | |||||||
|      */ |      */ | ||||||
|     public @NonNull CaptionMap loadOrCreateSingle(final @NonNull Path file) throws IOException { |     public @NonNull CaptionMap loadOrCreateSingle(final @NonNull Path file) throws IOException { | ||||||
|         final Locale locale = this.localeExtractor.apply(file); |         final Locale locale = this.localeExtractor.apply(file); | ||||||
|         if (!Files.exists(file)) { |         if (!Files.exists(file) ) { | ||||||
|             Map<String, String> map = new LinkedHashMap<>(); |             Map<String, String> map = new LinkedHashMap<>(); | ||||||
|             patch(map, locale); |             patch(map, locale); | ||||||
|             save(file, map); |             save(file, map); | ||||||
|   | |||||||
| @@ -56,8 +56,7 @@ final class ClassLoaderCaptionProvider implements DefaultCaptionProvider { | |||||||
|                 LOGGER.info("No resource for locale '{}' found in the plugin file." + |                 LOGGER.info("No resource for locale '{}' found in the plugin file." + | ||||||
|                                 "Please ensure you have placed the latest version of the file messages_{}.json in the 'lang' folder." + |                                 "Please ensure you have placed the latest version of the file messages_{}.json in the 'lang' folder." + | ||||||
|                                 "You may be able to find completed translations at https://intellectualsites.crowdin.com/plotsquared", |                                 "You may be able to find completed translations at https://intellectualsites.crowdin.com/plotsquared", | ||||||
|                         locale, locale |                         locale, locale); | ||||||
|                 ); |  | ||||||
|                 return null; |                 return null; | ||||||
|             } |             } | ||||||
|             try (final BufferedReader reader = new BufferedReader(new InputStreamReader(stream))) { |             try (final BufferedReader reader = new BufferedReader(new InputStreamReader(stream))) { | ||||||
|   | |||||||
| @@ -19,7 +19,6 @@ | |||||||
| package com.plotsquared.core.configuration.file; | package com.plotsquared.core.configuration.file; | ||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.serialization.ConfigurationSerialization; | import com.plotsquared.core.configuration.serialization.ConfigurationSerialization; | ||||||
| import org.yaml.snakeyaml.LoaderOptions; |  | ||||||
| import org.yaml.snakeyaml.constructor.SafeConstructor; | import org.yaml.snakeyaml.constructor.SafeConstructor; | ||||||
| import org.yaml.snakeyaml.error.YAMLException; | import org.yaml.snakeyaml.error.YAMLException; | ||||||
| import org.yaml.snakeyaml.nodes.Node; | import org.yaml.snakeyaml.nodes.Node; | ||||||
| @@ -31,7 +30,6 @@ import java.util.Map; | |||||||
| public class YamlConstructor extends SafeConstructor { | public class YamlConstructor extends SafeConstructor { | ||||||
|  |  | ||||||
|     YamlConstructor() { |     YamlConstructor() { | ||||||
|         super(new LoaderOptions()); |  | ||||||
|         yamlConstructors.put(Tag.MAP, new ConstructCustomObject()); |         yamlConstructors.put(Tag.MAP, new ConstructCustomObject()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -21,7 +21,6 @@ package com.plotsquared.core.configuration.file; | |||||||
| import com.plotsquared.core.configuration.ConfigurationSection; | import com.plotsquared.core.configuration.ConfigurationSection; | ||||||
| import com.plotsquared.core.configuration.serialization.ConfigurationSerializable; | import com.plotsquared.core.configuration.serialization.ConfigurationSerializable; | ||||||
| import com.plotsquared.core.configuration.serialization.ConfigurationSerialization; | import com.plotsquared.core.configuration.serialization.ConfigurationSerialization; | ||||||
| import org.yaml.snakeyaml.DumperOptions; |  | ||||||
| import org.yaml.snakeyaml.nodes.Node; | import org.yaml.snakeyaml.nodes.Node; | ||||||
| import org.yaml.snakeyaml.representer.Representer; | import org.yaml.snakeyaml.representer.Representer; | ||||||
|  |  | ||||||
| @@ -31,7 +30,6 @@ import java.util.Map; | |||||||
| class YamlRepresenter extends Representer { | class YamlRepresenter extends Representer { | ||||||
|  |  | ||||||
|     YamlRepresenter() { |     YamlRepresenter() { | ||||||
|         super(new DumperOptions()); |  | ||||||
|         this.multiRepresenters.put(ConfigurationSection.class, new RepresentConfigurationSection()); |         this.multiRepresenters.put(ConfigurationSection.class, new RepresentConfigurationSection()); | ||||||
|         this.multiRepresenters |         this.multiRepresenters | ||||||
|                 .put(ConfigurationSerializable.class, new RepresentConfigurationSerializable()); |                 .put(ConfigurationSerializable.class, new RepresentConfigurationSerializable()); | ||||||
|   | |||||||
| @@ -22,7 +22,7 @@ import com.sk89q.worldedit.entity.Entity; | |||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * @since 6.11.1 |  * @since TODO | ||||||
|  */ |  */ | ||||||
| public abstract class EntityEvent { | public abstract class EntityEvent { | ||||||
|  |  | ||||||
| @@ -53,8 +53,7 @@ public abstract class EntityEvent { | |||||||
|      * @return the event class name |      * @return the event class name | ||||||
|      * @since 6.11.0 |      * @since 6.11.0 | ||||||
|      */ |      */ | ||||||
|     @NonNull |     @NonNull public String getEventName() { | ||||||
|     public String getEventName() { |  | ||||||
|         if (this.name == null) { |         if (this.name == null) { | ||||||
|             this.name = this.getClass().getSimpleName(); |             this.name = this.getClass().getSimpleName(); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -379,11 +379,10 @@ public class ClassicPlotManager extends SquarePlotManager { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         int yStart = classicPlotWorld.getMinBuildHeight() + (classicPlotWorld.PLOT_BEDROCK ? 1 : 0); |  | ||||||
|         if (!plot.isMerged(Direction.NORTH)) { |         if (!plot.isMerged(Direction.NORTH)) { | ||||||
|             int z = bot.getZ(); |             int z = bot.getZ(); | ||||||
|             for (int x = bot.getX(); x < top.getX(); x++) { |             for (int x = bot.getX(); x < top.getX(); x++) { | ||||||
|                 for (int y = yStart; y <= classicPlotWorld.WALL_HEIGHT; y++) { |                 for (int y = classicPlotWorld.getMinBuildHeight(); y <= classicPlotWorld.WALL_HEIGHT; y++) { | ||||||
|                     queue.setBlock(x, y, z, blocks); |                     queue.setBlock(x, y, z, blocks); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -391,7 +390,7 @@ public class ClassicPlotManager extends SquarePlotManager { | |||||||
|         if (!plot.isMerged(Direction.WEST)) { |         if (!plot.isMerged(Direction.WEST)) { | ||||||
|             int x = bot.getX(); |             int x = bot.getX(); | ||||||
|             for (int z = bot.getZ(); z < top.getZ(); z++) { |             for (int z = bot.getZ(); z < top.getZ(); z++) { | ||||||
|                 for (int y = yStart; y <= classicPlotWorld.WALL_HEIGHT; y++) { |                 for (int y = classicPlotWorld.getMinBuildHeight(); y <= classicPlotWorld.WALL_HEIGHT; y++) { | ||||||
|                     queue.setBlock(x, y, z, blocks); |                     queue.setBlock(x, y, z, blocks); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -399,7 +398,7 @@ public class ClassicPlotManager extends SquarePlotManager { | |||||||
|         if (!plot.isMerged(Direction.SOUTH)) { |         if (!plot.isMerged(Direction.SOUTH)) { | ||||||
|             int z = top.getZ(); |             int z = top.getZ(); | ||||||
|             for (int x = bot.getX(); x < top.getX() + (plot.isMerged(Direction.EAST) ? 0 : 1); x++) { |             for (int x = bot.getX(); x < top.getX() + (plot.isMerged(Direction.EAST) ? 0 : 1); x++) { | ||||||
|                 for (int y = yStart; y <= classicPlotWorld.WALL_HEIGHT; y++) { |                 for (int y = classicPlotWorld.getMinBuildHeight(); y <= classicPlotWorld.WALL_HEIGHT; y++) { | ||||||
|                     queue.setBlock(x, y, z, blocks); |                     queue.setBlock(x, y, z, blocks); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -407,7 +406,7 @@ public class ClassicPlotManager extends SquarePlotManager { | |||||||
|         if (!plot.isMerged(Direction.EAST)) { |         if (!plot.isMerged(Direction.EAST)) { | ||||||
|             int x = top.getX(); |             int x = top.getX(); | ||||||
|             for (int z = bot.getZ(); z < top.getZ() + (plot.isMerged(Direction.SOUTH) ? 0 : 1); z++) { |             for (int z = bot.getZ(); z < top.getZ() + (plot.isMerged(Direction.SOUTH) ? 0 : 1); z++) { | ||||||
|                 for (int y = yStart; y <= classicPlotWorld.WALL_HEIGHT; y++) { |                 for (int y = classicPlotWorld.getMinBuildHeight(); y <= classicPlotWorld.WALL_HEIGHT; y++) { | ||||||
|                     queue.setBlock(x, y, z, blocks); |                     queue.setBlock(x, y, z, blocks); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -38,7 +38,6 @@ import javax.annotation.Nullable; | |||||||
|  |  | ||||||
| @SuppressWarnings("WeakerAccess") | @SuppressWarnings("WeakerAccess") | ||||||
| public abstract class ClassicPlotWorld extends SquarePlotWorld { | public abstract class ClassicPlotWorld extends SquarePlotWorld { | ||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + ClassicPlotWorld.class.getSimpleName()); |     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + ClassicPlotWorld.class.getSimpleName()); | ||||||
|  |  | ||||||
|     public int ROAD_HEIGHT = 62; |     public int ROAD_HEIGHT = 62; | ||||||
| @@ -65,21 +64,6 @@ 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. | ||||||
|      * |      * | ||||||
| @@ -160,4 +144,19 @@ 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; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -69,8 +69,8 @@ public class HybridGen extends IndependentPlotGenerator { | |||||||
|             EnumSet<SchematicFeature> features |             EnumSet<SchematicFeature> features | ||||||
|     ) { |     ) { | ||||||
|         int minY; // Math.min(world.PLOT_HEIGHT, world.ROAD_HEIGHT); |         int minY; // Math.min(world.PLOT_HEIGHT, world.ROAD_HEIGHT); | ||||||
|         boolean isRoad = features.contains(SchematicFeature.ROAD); |         if ((features.contains(SchematicFeature.ROAD) && Settings.Schematics.PASTE_ROAD_ON_TOP) | ||||||
|         if ((isRoad && Settings.Schematics.PASTE_ROAD_ON_TOP) || (!isRoad && Settings.Schematics.PASTE_ON_TOP)) { |                 || (!features.contains(SchematicFeature.ROAD) && Settings.Schematics.PASTE_ON_TOP)) { | ||||||
|             minY = world.SCHEM_Y; |             minY = world.SCHEM_Y; | ||||||
|         } else { |         } else { | ||||||
|             minY = world.getMinBuildHeight(); |             minY = world.getMinBuildHeight(); | ||||||
| @@ -341,10 +341,7 @@ public class HybridGen extends IndependentPlotGenerator { | |||||||
|                 for (Entity entity : hybridPlotWorld.getPlotSchematicEntities()) { |                 for (Entity entity : hybridPlotWorld.getPlotSchematicEntities()) { | ||||||
|                     if (region.contains(entity.getLocation().toVector().toBlockPoint())) { |                     if (region.contains(entity.getLocation().toVector().toBlockPoint())) { | ||||||
|                         Vector3 pos = (entity.getLocation().toVector() |                         Vector3 pos = (entity.getLocation().toVector() | ||||||
|                                 .subtract(region |                                 .subtract(region.getMinimumPoint().withY(hybridPlotWorld.getPlotSchematicMinPoint().getY()).toVector3())) | ||||||
|                                         .getMinimumPoint() |  | ||||||
|                                         .withY(hybridPlotWorld.getPlotSchematicMinPoint().getY()) |  | ||||||
|                                         .toVector3())) |  | ||||||
|                                 .add(min.getBlockVector3().withY(hybridPlotWorld.SCHEM_Y).toVector3()); |                                 .add(min.getBlockVector3().withY(hybridPlotWorld.SCHEM_Y).toVector3()); | ||||||
|                         result.setEntity(new PopulatingEntity( |                         result.setEntity(new PopulatingEntity( | ||||||
|                                 entity, |                                 entity, | ||||||
| @@ -402,12 +399,6 @@ 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. | ||||||
| @@ -462,4 +453,10 @@ public class HybridGen extends IndependentPlotGenerator { | |||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     private enum SchematicFeature { | ||||||
|  |         BIOMES, | ||||||
|  |         ROAD, | ||||||
|  |         POPULATING | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -141,11 +141,7 @@ public class HybridPlotManager extends ClassicPlotManager { | |||||||
|                         (pos1.getX() + pos2.getX()) / 2, |                         (pos1.getX() + pos2.getX()) / 2, | ||||||
|                         (pos1.getZ() + pos2.getZ()) / 2 |                         (pos1.getZ() + pos2.getZ()) / 2 | ||||||
|                 ), biome)) { |                 ), biome)) { | ||||||
|             WorldUtil.setBiome( |             WorldUtil.setBiome(hybridPlotWorld.getWorldName(), new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3()), biome); | ||||||
|                     hybridPlotWorld.getWorldName(), |  | ||||||
|                     new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3()), |  | ||||||
|                     biome |  | ||||||
|             ); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -162,7 +158,6 @@ public class HybridPlotManager extends ClassicPlotManager { | |||||||
|         } else { |         } else { | ||||||
|             minY = hybridPlotWorld.getMinBuildHeight(); |             minY = hybridPlotWorld.getMinBuildHeight(); | ||||||
|         } |         } | ||||||
|         int schemYDiff = (isRoad ? hybridPlotWorld.getRoadYStart() : hybridPlotWorld.getPlotYStart()) - minY; |  | ||||||
|         BaseBlock airBlock = BlockTypes.AIR.getDefaultState().toBaseBlock(); |         BaseBlock airBlock = BlockTypes.AIR.getDefaultState().toBaseBlock(); | ||||||
|         for (int x = pos1.getX(); x <= pos2.getX(); x++) { |         for (int x = pos1.getX(); x <= pos2.getX(); x++) { | ||||||
|             short absX = (short) ((x - hybridPlotWorld.ROAD_OFFSET_X) % size); |             short absX = (short) ((x - hybridPlotWorld.ROAD_OFFSET_X) % size); | ||||||
| @@ -179,14 +174,10 @@ public class HybridPlotManager extends ClassicPlotManager { | |||||||
|                     for (int y = 0; y < blocks.length; y++) { |                     for (int y = 0; y < blocks.length; y++) { | ||||||
|                         if (blocks[y] != null) { |                         if (blocks[y] != null) { | ||||||
|                             queue.setBlock(x, minY + y, z, blocks[y]); |                             queue.setBlock(x, minY + y, z, blocks[y]); | ||||||
|                         } else if (y > schemYDiff) { |                         } else if (!isRoad) { | ||||||
|                             // This is necessary, otherwise any blocks not specified in the schematic will remain after a clear. |                             // This is necessary, otherwise any blocks not specified in the schematic will remain after a clear | ||||||
|                             // This should only be done where the schematic has actually "started" |                             //  Do not set air for road as this may cause cavernous roads when debugroadregen is used | ||||||
|                             queue.setBlock(x, minY + y, z, airBlock); |                             queue.setBlock(x, minY + y, z, airBlock); | ||||||
|                         } else if (isRoad) { |  | ||||||
|                             queue.setBlock(x, minY + y, z, hybridPlotWorld.ROAD_BLOCK.toPattern()); |  | ||||||
|                         } else { |  | ||||||
|                             queue.setBlock(x, minY + y, z, hybridPlotWorld.MAIN_BLOCK.toPattern()); |  | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -212,18 +203,8 @@ public class HybridPlotManager extends ClassicPlotManager { | |||||||
|         PlotId id2 = PlotId.of(id.getX(), id.getY() + 1); |         PlotId id2 = PlotId.of(id.getX(), id.getY() + 1); | ||||||
|         Location bot = getPlotBottomLocAbs(id2); |         Location bot = getPlotBottomLocAbs(id2); | ||||||
|         Location top = getPlotTopLocAbs(id); |         Location top = getPlotTopLocAbs(id); | ||||||
|         Location pos1 = Location.at( |         Location pos1 = Location.at(hybridPlotWorld.getWorldName(), bot.getX() - 1, hybridPlotWorld.getMinGenHeight(), top.getZ() + 1); | ||||||
|                 hybridPlotWorld.getWorldName(), |         Location pos2 = Location.at(hybridPlotWorld.getWorldName(), top.getX() + 1, hybridPlotWorld.getMaxGenHeight(), bot.getZ()); | ||||||
|                 bot.getX() - 1, |  | ||||||
|                 hybridPlotWorld.getMinGenHeight(), |  | ||||||
|                 top.getZ() + 1 |  | ||||||
|         ); |  | ||||||
|         Location pos2 = Location.at( |  | ||||||
|                 hybridPlotWorld.getWorldName(), |  | ||||||
|                 top.getX() + 1, |  | ||||||
|                 hybridPlotWorld.getMaxGenHeight(), |  | ||||||
|                 bot.getZ() |  | ||||||
|         ); |  | ||||||
|         this.resetBiome(hybridPlotWorld, pos1, pos2); |         this.resetBiome(hybridPlotWorld, pos1, pos2); | ||||||
|         if (!hybridPlotWorld.ROAD_SCHEMATIC_ENABLED) { |         if (!hybridPlotWorld.ROAD_SCHEMATIC_ENABLED) { | ||||||
|             return true; |             return true; | ||||||
| @@ -293,13 +274,6 @@ 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()), | ||||||
| @@ -317,13 +291,6 @@ 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())); | ||||||
|   | |||||||
| @@ -76,9 +76,6 @@ public class HybridPlotWorld extends ClassicPlotWorld { | |||||||
|      * The Y level at which schematic generation will start, lowest of either road or plot schematic generation. |      * The Y level at which schematic generation will start, lowest of either road or plot schematic generation. | ||||||
|      */ |      */ | ||||||
|     public int SCHEM_Y; |     public int SCHEM_Y; | ||||||
|  |  | ||||||
|     private int plotY; |  | ||||||
|     private int roadY; |  | ||||||
|     private Location SIGN_LOCATION; |     private Location SIGN_LOCATION; | ||||||
|     private File root = null; |     private File root = null; | ||||||
|     private int lastOverlayHeightError = Integer.MIN_VALUE; |     private int lastOverlayHeightError = Integer.MIN_VALUE; | ||||||
| @@ -255,13 +252,13 @@ public class HybridPlotWorld extends ClassicPlotWorld { | |||||||
|  |  | ||||||
|         SCHEM_Y = schematicStartHeight(); |         SCHEM_Y = schematicStartHeight(); | ||||||
|  |  | ||||||
|         // plotY and roadY are important to allow plot and/or road schematic "overflow" into each other |         // plotY and roadY are important to allow plot and/or road schematic "overflow" into each other without causing AIOOB | ||||||
|         // without causing AIOOB exceptions when attempting either to set blocks to, or get block from G_SCH |         //  exceptions when attempting either to set blocks to, or get block from G_SCH | ||||||
|         // Default plot schematic start height, normalized to the minimum height schematics are pasted from. |         // Default plot schematic start height, normalized to the minimum height schematics are pasted from. | ||||||
|         plotY = PLOT_HEIGHT - SCHEM_Y; |         int plotY = PLOT_HEIGHT - SCHEM_Y; | ||||||
|         int minRoadWall = Settings.Schematics.USE_WALL_IN_ROAD_SCHEM_HEIGHT ? Math.min(ROAD_HEIGHT, WALL_HEIGHT) : ROAD_HEIGHT; |         int minRoadWall = Settings.Schematics.USE_WALL_IN_ROAD_SCHEM_HEIGHT ? Math.min(ROAD_HEIGHT, WALL_HEIGHT) : ROAD_HEIGHT; | ||||||
|         // Default road schematic start height, normalized to the minimum height schematics are pasted from. |         // Default road schematic start height, normalized to the minimum height schematics are pasted from. | ||||||
|         roadY = minRoadWall - SCHEM_Y; |         int roadY = minRoadWall - SCHEM_Y; | ||||||
|  |  | ||||||
|         int worldGenHeight = getMaxGenHeight() - getMinGenHeight() + 1; |         int worldGenHeight = getMaxGenHeight() - getMinGenHeight() + 1; | ||||||
|  |  | ||||||
| @@ -270,15 +267,14 @@ public class HybridPlotWorld extends ClassicPlotWorld { | |||||||
|  |  | ||||||
|         // SCHEM_Y should be normalised to the plot "start" height |         // SCHEM_Y should be normalised to the plot "start" height | ||||||
|         if (schematic3 != null) { |         if (schematic3 != null) { | ||||||
|             plotSchemHeight = schematic3.getClipboard().getDimensions().getY(); |             plotSchemHeight = maxSchematicHeight = schematic3.getClipboard().getDimensions().getY(); | ||||||
|             if (plotSchemHeight == worldGenHeight) { |             if (maxSchematicHeight == worldGenHeight) { | ||||||
|                 SCHEM_Y = getMinGenHeight(); |                 SCHEM_Y = getMinGenHeight(); | ||||||
|                 plotY = 0; |                 plotY = 0; | ||||||
|             } else if (!Settings.Schematics.PASTE_ON_TOP) { |             } else if (!Settings.Schematics.PASTE_ON_TOP) { | ||||||
|                 SCHEM_Y = getMinGenHeight(); |                 SCHEM_Y = getMinBuildHeight(); | ||||||
|                 plotY = 0; |                 plotY = 0; | ||||||
|             } |             } | ||||||
|             maxSchematicHeight = plotY + plotSchemHeight; |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         int roadSchemHeight; |         int roadSchemHeight; | ||||||
| @@ -296,15 +292,20 @@ public class HybridPlotWorld extends ClassicPlotWorld { | |||||||
|                     // Road is the lowest schematic. Normalize plotY to it. |                     // Road is the lowest schematic. Normalize plotY to it. | ||||||
|                     if (Settings.Schematics.PASTE_ON_TOP) { |                     if (Settings.Schematics.PASTE_ON_TOP) { | ||||||
|                         plotY = PLOT_HEIGHT - getMinGenHeight(); |                         plotY = PLOT_HEIGHT - getMinGenHeight(); | ||||||
|  |                     } else { | ||||||
|  |                         plotY = getMinBuildHeight() - getMinGenHeight(); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } else if (!Settings.Schematics.PASTE_ROAD_ON_TOP) { |             } else if (!Settings.Schematics.PASTE_ROAD_ON_TOP) { | ||||||
|                 roadY = 0; |                 if (SCHEM_Y == getMinGenHeight()) { // Only possible if plot schematic is enabled | ||||||
|                 SCHEM_Y = getMinGenHeight(); |                     // Plot is still the lowest schematic, normalize roadY to it | ||||||
|                 if (schematic3 != null) { |                     roadY = getMinBuildHeight() - getMinGenHeight(); | ||||||
|  |                 } else if (schematic3 != null) { | ||||||
|  |                     SCHEM_Y = getMinBuildHeight(); | ||||||
|  |                     roadY = 0;// Road is the lowest schematic | ||||||
|                     if (Settings.Schematics.PASTE_ON_TOP) { |                     if (Settings.Schematics.PASTE_ON_TOP) { | ||||||
|                         // Road is the lowest schematic. Normalize plotY to it. |                         // Road is the lowest schematic. Normalize plotY to it. | ||||||
|                         plotY = PLOT_HEIGHT - SCHEM_Y; |                         plotY = PLOT_HEIGHT - getMinBuildHeight(); | ||||||
|                     } |                     } | ||||||
|                     maxSchematicHeight = Math.max(maxSchematicHeight, plotY + plotSchemHeight); |                     maxSchematicHeight = Math.max(maxSchematicHeight, plotY + plotSchemHeight); | ||||||
|                 } |                 } | ||||||
| @@ -322,7 +323,7 @@ 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 || l3 > PLOT_WIDTH) { |             if (w3 > PLOT_WIDTH || h3 > PLOT_WIDTH) { | ||||||
|                 this.ROAD_SCHEMATIC_ENABLED = true; |                 this.ROAD_SCHEMATIC_ENABLED = true; | ||||||
|             } |             } | ||||||
|             int centerShiftZ; |             int centerShiftZ; | ||||||
| @@ -377,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("- road schematic: false"); |                 LOGGER.info("- schematic: false"); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -543,6 +544,14 @@ 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()} | ||||||
| @@ -553,24 +562,4 @@ public class HybridPlotWorld extends ClassicPlotWorld { | |||||||
|         return this.root; |         return this.root; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Get the y value where the plot schematic should be pasted from. |  | ||||||
|      * |  | ||||||
|      * @return plot schematic y start value |  | ||||||
|      * @since TODO |  | ||||||
|      */ |  | ||||||
|     public int getPlotYStart() { |  | ||||||
|         return SCHEM_Y + plotY; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Get the y value where the road schematic should be pasted from. |  | ||||||
|      * |  | ||||||
|      * @return road schematic y start value |  | ||||||
|      * @since TODO |  | ||||||
|      */ |  | ||||||
|     public int getRoadYStart() { |  | ||||||
|         return SCHEM_Y + roadY; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -63,6 +63,7 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
| import java.io.File; | import java.io.File; | ||||||
| import java.util.ArrayDeque; | import java.util.ArrayDeque; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
|  | import java.util.Arrays; | ||||||
| import java.util.Collections; | import java.util.Collections; | ||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
| @@ -379,6 +380,22 @@ public class HybridUtils { | |||||||
|         run.run(); |         run.run(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public int checkModified(QueueCoordinator queue, int x1, int x2, int y1, int y2, int z1, int z2, BlockState[] blocks) { | ||||||
|  |         int count = 0; | ||||||
|  |         for (int y = y1; y <= y2; y++) { | ||||||
|  |             for (int x = x1; x <= x2; x++) { | ||||||
|  |                 for (int z = z1; z <= z2; z++) { | ||||||
|  |                     BlockState block = queue.getBlock(x, y, z); | ||||||
|  |                     boolean same = Arrays.stream(blocks).anyMatch(p -> this.worldUtil.isBlockSame(block, p)); | ||||||
|  |                     if (!same) { | ||||||
|  |                         count++; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return count; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public final ArrayList<BlockVector2> getChunks(BlockVector2 region) { |     public final ArrayList<BlockVector2> getChunks(BlockVector2 region) { | ||||||
|         ArrayList<BlockVector2> chunks = new ArrayList<>(); |         ArrayList<BlockVector2> chunks = new ArrayList<>(); | ||||||
|         int sx = region.getX() << 5; |         int sx = region.getX() << 5; | ||||||
| @@ -529,7 +546,7 @@ public class HybridUtils { | |||||||
|                 Math.min(plotworld.PLOT_HEIGHT, Math.min(plotworld.WALL_HEIGHT, plotworld.ROAD_HEIGHT)) : plotworld.ROAD_HEIGHT; |                 Math.min(plotworld.PLOT_HEIGHT, Math.min(plotworld.WALL_HEIGHT, plotworld.ROAD_HEIGHT)) : plotworld.ROAD_HEIGHT; | ||||||
|         int sx = bot.getX() - plotworld.ROAD_WIDTH + 1; |         int sx = bot.getX() - plotworld.ROAD_WIDTH + 1; | ||||||
|         int sz = bot.getZ() + 1; |         int sz = bot.getZ() + 1; | ||||||
|         int sy = Settings.Schematics.PASTE_ROAD_ON_TOP ? schemY : plot.getArea().getMinGenHeight(); |         int sy = Settings.Schematics.PASTE_ROAD_ON_TOP ? schemY : plot.getArea().getMinBuildHeight(); | ||||||
|         int ex = bot.getX(); |         int ex = bot.getX(); | ||||||
|         int ez = top.getZ(); |         int ez = top.getZ(); | ||||||
|         int ey = get_ey(plotworld, queue, sx, ex, sz, ez, sy); |         int ey = get_ey(plotworld, queue, sx, ex, sz, ez, sy); | ||||||
| @@ -668,7 +685,7 @@ public class HybridUtils { | |||||||
|                     } |                     } | ||||||
|                     if (condition) { |                     if (condition) { | ||||||
|                         BaseBlock[] blocks = plotWorld.G_SCH.get(MathMan.pair(absX, absZ)); |                         BaseBlock[] blocks = plotWorld.G_SCH.get(MathMan.pair(absX, absZ)); | ||||||
|                         int minY = plotWorld.getRoadYStart(); |                         int minY = Settings.Schematics.PASTE_ROAD_ON_TOP ? plotWorld.SCHEM_Y : area.getMinGenHeight() + 1; | ||||||
|                         int maxDy = Math.max(extend, blocks.length); |                         int maxDy = Math.max(extend, blocks.length); | ||||||
|                         for (int dy = 0; dy < maxDy; dy++) { |                         for (int dy = 0; dy < maxDy; dy++) { | ||||||
|                             if (dy > blocks.length - 1) { |                             if (dy > blocks.length - 1) { | ||||||
|   | |||||||
| @@ -46,7 +46,7 @@ public abstract class IndependentPlotGenerator { | |||||||
|      * @param result   Queue to write to |      * @param result   Queue to write to | ||||||
|      * @param settings PlotArea (settings) |      * @param settings PlotArea (settings) | ||||||
|      * @param biomes   If biomes should be generated |      * @param biomes   If biomes should be generated | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public abstract void generateChunk(ZeroedDelegateScopedQueueCoordinator result, PlotArea settings, boolean biomes); |     public abstract void generateChunk(ZeroedDelegateScopedQueueCoordinator result, PlotArea settings, boolean biomes); | ||||||
|  |  | ||||||
| @@ -55,10 +55,9 @@ public abstract class IndependentPlotGenerator { | |||||||
|      * |      * | ||||||
|      * @param result  Queue to write to |      * @param result  Queue to write to | ||||||
|      * @param setting PlotArea (settings) |      * @param setting PlotArea (settings) | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public void populateChunk(ZeroedDelegateScopedQueueCoordinator result, PlotArea setting) { |     public void populateChunk(ZeroedDelegateScopedQueueCoordinator result, PlotArea setting) {} | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Return a new PlotArea object. |      * Return a new PlotArea object. | ||||||
| @@ -104,11 +103,11 @@ public abstract class IndependentPlotGenerator { | |||||||
|      * Get the biome to be generated at a specific point |      * Get the biome to be generated at a specific point | ||||||
|      * |      * | ||||||
|      * @param settings PlotArea settings to provide biome |      * @param settings PlotArea settings to provide biome | ||||||
|      * @param x        World x position |      * @param x       World x position | ||||||
|      * @param y        World y position |      * @param y       World y position | ||||||
|      * @param z        World z position |      * @param z       World z position | ||||||
|      * @return Biome type to be generated |      * @return Biome type to be generated | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public abstract BiomeType getBiome(PlotArea settings, int x, int y, int z); |     public abstract BiomeType getBiome(PlotArea settings, int x, int y, int z); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -142,9 +142,7 @@ public class PlotListener { | |||||||
|                     Map.Entry<UUID, List<StatusEffect>> entry = iterator.next(); |                     Map.Entry<UUID, List<StatusEffect>> entry = iterator.next(); | ||||||
|                     List<StatusEffect> effects = entry.getValue(); |                     List<StatusEffect> effects = entry.getValue(); | ||||||
|                     effects.removeIf(effect -> currentTime > effect.expiresAt); |                     effects.removeIf(effect -> currentTime > effect.expiresAt); | ||||||
|                     if (effects.isEmpty()) { |                     if (effects.isEmpty()) iterator.remove(); | ||||||
|                         iterator.remove(); |  | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, TaskTime.seconds(1L)); |         }, TaskTime.seconds(1L)); | ||||||
| @@ -488,9 +486,8 @@ public class PlotListener { | |||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Marks an effect as a status effect that will be removed on leaving a plot |      * Marks an effect as a status effect that will be removed on leaving a plot | ||||||
|      * |      * @param uuid The uuid of the player the effect belongs to | ||||||
|      * @param uuid      The uuid of the player the effect belongs to |      * @param name The name of the status effect | ||||||
|      * @param name      The name of the status effect |  | ||||||
|      * @param expiresAt The time when the effect expires |      * @param expiresAt The time when the effect expires | ||||||
|      * @since 6.10.0 |      * @since 6.10.0 | ||||||
|      */ |      */ | ||||||
| @@ -521,10 +518,10 @@ 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) { |         private StatusEffect(@NonNull String name, long expiresAt) { | ||||||
|             this.name = name; |                 this.name = name; | ||||||
|             this.expiresAt = expiresAt; |                 this.expiresAt = expiresAt; | ||||||
|  |             } | ||||||
|  |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -51,6 +51,7 @@ public final class UncheckedWorldLocation extends Location { | |||||||
|      * @param y     Y coordinate |      * @param y     Y coordinate | ||||||
|      * @param z     Z coordinate |      * @param z     Z coordinate | ||||||
|      * @return New location |      * @return New location | ||||||
|  |      * | ||||||
|      * @since 6.9.0 |      * @since 6.9.0 | ||||||
|      */ |      */ | ||||||
|     @DoNotUse |     @DoNotUse | ||||||
|   | |||||||
| @@ -222,13 +222,13 @@ public final class BlockBucket implements ConfigurationSerializable { | |||||||
|     ) { |     ) { | ||||||
|  |  | ||||||
|         public int getWeight() { |         public int getWeight() { | ||||||
|             return max - min; |                 return max - min; | ||||||
|         } |             } | ||||||
|  |  | ||||||
|         public boolean isInRange(final int num) { |             public boolean isInRange(final int num) { | ||||||
|             return num <= max && num >= min; |                 return num <= max && num >= min; | ||||||
|         } |             } | ||||||
|  |  | ||||||
|     } |         } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ 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; | ||||||
| @@ -2417,6 +2418,7 @@ 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); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -657,11 +657,9 @@ public abstract class PlotArea implements ComponentLike { | |||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("height.height_limit"), |                     TranslatableCaption.of("height.height_limit"), | ||||||
|                     TagResolver.builder() |                     TagResolver.builder() | ||||||
|                             .tag("minheight", Tag.inserting(Component.text(minBuildHeight))) |                             .tag("minHeight", Tag.inserting(Component.text(minBuildHeight))) | ||||||
|                             .tag( |                             .tag("maxHeight", | ||||||
|                                     "maxheight", |                             Tag.inserting(Component.text(maxBuildHeight))).build() | ||||||
|                                     Tag.inserting(Component.text(maxBuildHeight)) |  | ||||||
|                             ).build() |  | ||||||
|             ); |             ); | ||||||
|             // Return true if "failed" as the method will always be inverted otherwise |             // Return true if "failed" as the method will always be inverted otherwise | ||||||
|             return true; |             return true; | ||||||
| @@ -1019,7 +1017,7 @@ public abstract class PlotArea implements ComponentLike { | |||||||
|      * |      * | ||||||
|      * @param plotIds     List of plot IDs to merge |      * @param plotIds     List of plot IDs to merge | ||||||
|      * @param removeRoads If the roads between plots should be removed |      * @param removeRoads If the roads between plots should be removed | ||||||
|      * @param whenDone    Task to run when any merge world changes are complete. Also runs if no changes were made. Does not |      * @param whenDone  Task to run when any merge world changes are complete. Also runs if no changes were made. Does not | ||||||
|      *                    run if there was an error or if too few plots IDs were supplied. |      *                    run if there was an error or if too few plots IDs were supplied. | ||||||
|      * @return if merges were completed successfully. |      * @return if merges were completed successfully. | ||||||
|      * @since 6.9.0 |      * @since 6.9.0 | ||||||
|   | |||||||
| @@ -100,7 +100,7 @@ public class PlotInventory { | |||||||
|      * Put an item into this inventory |      * Put an item into this inventory | ||||||
|      * |      * | ||||||
|      * @param index the index (= slot) where to place the item |      * @param index the index (= slot) where to place the item | ||||||
|      * @param item  the item to place |      * @param item the item to place | ||||||
|      * @see #setItemChecked(int, PlotItemStack) |      * @see #setItemChecked(int, PlotItemStack) | ||||||
|      */ |      */ | ||||||
|     public void setItem(int index, PlotItemStack item) { |     public void setItem(int index, PlotItemStack item) { | ||||||
|   | |||||||
| @@ -79,6 +79,14 @@ public class PlotSettings { | |||||||
|         this.ratings = ratings; |         this.ratings = ratings; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public boolean setMerged(int direction, boolean merged) { | ||||||
|  |         if (this.merged[direction] != merged) { | ||||||
|  |             this.merged[direction] = merged; | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public boolean setMerged(Direction direction, boolean merged) { |     public boolean setMerged(Direction direction, boolean merged) { | ||||||
|         if (Direction.ALL == direction) { |         if (Direction.ALL == direction) { | ||||||
|             throw new IllegalArgumentException("You cannot use Direction.ALL in this method!"); |             throw new IllegalArgumentException("You cannot use Direction.ALL in this method!"); | ||||||
|   | |||||||
| @@ -154,7 +154,6 @@ public class ExpiryTask { | |||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Returns {@code true} if this task respects unknown owners |      * Returns {@code true} if this task respects unknown owners | ||||||
|      * |  | ||||||
|      * @return {@code true} if unknown owners should be counted as never online |      * @return {@code true} if unknown owners should be counted as never online | ||||||
|      * @since 6.4.0 |      * @since 6.4.0 | ||||||
|      */ |      */ | ||||||
|   | |||||||
| @@ -91,7 +91,6 @@ import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.PveFlag; | import com.plotsquared.core.plot.flag.implementations.PveFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.PvpFlag; | import com.plotsquared.core.plot.flag.implementations.PvpFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.RedstoneFlag; | import com.plotsquared.core.plot.flag.implementations.RedstoneFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.SculkSensorInteractFlag; |  | ||||||
| import com.plotsquared.core.plot.flag.implementations.ServerPlotFlag; | import com.plotsquared.core.plot.flag.implementations.ServerPlotFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.SnowFormFlag; | import com.plotsquared.core.plot.flag.implementations.SnowFormFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.SnowMeltFlag; | import com.plotsquared.core.plot.flag.implementations.SnowMeltFlag; | ||||||
| @@ -173,7 +172,6 @@ public final class GlobalFlagContainer extends FlagContainer { | |||||||
|         this.addFlag(MobBreakFlag.MOB_BREAK_FALSE); |         this.addFlag(MobBreakFlag.MOB_BREAK_FALSE); | ||||||
|         this.addFlag(MobPlaceFlag.MOB_PLACE_FALSE); |         this.addFlag(MobPlaceFlag.MOB_PLACE_FALSE); | ||||||
|         this.addFlag(MiscInteractFlag.MISC_INTERACT_FALSE); |         this.addFlag(MiscInteractFlag.MISC_INTERACT_FALSE); | ||||||
|         this.addFlag(SculkSensorInteractFlag.SCULK_SENSOR_INTERACT_FALSE); |  | ||||||
|         this.addFlag(MiscPlaceFlag.MISC_PLACE_FALSE); |         this.addFlag(MiscPlaceFlag.MISC_PLACE_FALSE); | ||||||
|         this.addFlag(MycelGrowFlag.MYCEL_GROW_TRUE); |         this.addFlag(MycelGrowFlag.MYCEL_GROW_TRUE); | ||||||
|         this.addFlag(NotifyEnterFlag.NOTIFY_ENTER_FALSE); |         this.addFlag(NotifyEnterFlag.NOTIFY_ENTER_FALSE); | ||||||
|   | |||||||
| @@ -88,7 +88,7 @@ public abstract class PlotFlag<T, F extends PlotFlag<T, F>> { | |||||||
|      * Gets the flag name as a Kyori {@link Component} |      * Gets the flag name as a Kyori {@link Component} | ||||||
|      * |      * | ||||||
|      * @see #getFlagName(Class) |      * @see #getFlagName(Class) | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public static <T, F extends PlotFlag<T, F>> Component getFlagNameComponent(Class<F> flagClass) { |     public static <T, F extends PlotFlag<T, F>> Component getFlagNameComponent(Class<F> flagClass) { | ||||||
|         return Component.text(getFlagName(flagClass)); |         return Component.text(getFlagName(flagClass)); | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ public class BeaconEffectsFlag extends BooleanFlag<BeaconEffectsFlag> { | |||||||
|     public static final BeaconEffectsFlag BEACON_EFFECT_TRUE = new BeaconEffectsFlag(true); |     public static final BeaconEffectsFlag BEACON_EFFECT_TRUE = new BeaconEffectsFlag(true); | ||||||
|     public static final BeaconEffectsFlag BEACON_EFFECT_FALSE = new BeaconEffectsFlag(false); |     public static final BeaconEffectsFlag BEACON_EFFECT_FALSE = new BeaconEffectsFlag(false); | ||||||
|  |  | ||||||
|     private BeaconEffectsFlag(boolean value) { |     private BeaconEffectsFlag(boolean value){ | ||||||
|         super(value, TranslatableCaption.of("flags.flag_description_beacon_effect")); |         super(value, TranslatableCaption.of("flags.flag_description_beacon_effect")); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ public class ProjectilesFlag extends BooleanFlag<ProjectilesFlag> { | |||||||
|     public static final ProjectilesFlag PROJECTILES_TRUE = new ProjectilesFlag(true); |     public static final ProjectilesFlag PROJECTILES_TRUE = new ProjectilesFlag(true); | ||||||
|     public static final ProjectilesFlag PROJECTILES_FALSE = new ProjectilesFlag(false); |     public static final ProjectilesFlag PROJECTILES_FALSE = new ProjectilesFlag(false); | ||||||
|  |  | ||||||
|     private ProjectilesFlag(boolean value) { |     private ProjectilesFlag(boolean value){ | ||||||
|         super(value, TranslatableCaption.of("flags.flag_description_projectiles")); |         super(value, TranslatableCaption.of("flags.flag_description_projectiles")); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,39 +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.plot.flag.implementations; |  | ||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; |  | ||||||
| import com.plotsquared.core.plot.flag.types.BooleanFlag; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; |  | ||||||
|  |  | ||||||
| public class SculkSensorInteractFlag extends BooleanFlag<SculkSensorInteractFlag> { |  | ||||||
|  |  | ||||||
|     public static final SculkSensorInteractFlag SCULK_SENSOR_INTERACT_TRUE = new SculkSensorInteractFlag(true); |  | ||||||
|     public static final SculkSensorInteractFlag SCULK_SENSOR_INTERACT_FALSE = new SculkSensorInteractFlag(false); |  | ||||||
|  |  | ||||||
|     private SculkSensorInteractFlag(boolean value) { |  | ||||||
|         super(value, TranslatableCaption.of("flags.flag_description_sculk_sensor_interact")); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     protected SculkSensorInteractFlag flagOf(@NonNull Boolean value) { |  | ||||||
|         return value ? SCULK_SENSOR_INTERACT_TRUE : SCULK_SENSOR_INTERACT_FALSE; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @@ -82,10 +82,10 @@ public abstract class TimedFlag<T, F extends PlotFlag<TimedFlag.Timed<T>, F>> | |||||||
|     ) { |     ) { | ||||||
|  |  | ||||||
|         @Override |         @Override | ||||||
|         public String toString() { |             public String toString() { | ||||||
|             return String.format("%d %s", interval, value); |                 return String.format("%d %s", interval, value); | ||||||
|  |             } | ||||||
|  |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -29,17 +29,17 @@ import org.checkerframework.checker.nullness.qual.NonNull; | |||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
|  | import java.util.HashMap; | ||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Map; | import java.util.Map; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.concurrent.ConcurrentHashMap; |  | ||||||
|  |  | ||||||
| @Singleton | @Singleton | ||||||
| public class DefaultPlotAreaManager implements PlotAreaManager { | public class DefaultPlotAreaManager implements PlotAreaManager { | ||||||
|  |  | ||||||
|     final PlotArea[] noPlotAreas = new PlotArea[0]; |     final PlotArea[] noPlotAreas = new PlotArea[0]; | ||||||
|     private final Map<String, PlotWorld> plotWorlds = new ConcurrentHashMap<>(); |     private final Map<String, PlotWorld> plotWorlds = new HashMap<>(); | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull PlotArea[] getAllPlotAreas() { |     public @NonNull PlotArea[] getAllPlotAreas() { | ||||||
|   | |||||||
| @@ -111,7 +111,7 @@ public interface PlotAreaManager { | |||||||
|      * |      * | ||||||
|      * @param worldName Name of the world to add |      * @param worldName Name of the world to add | ||||||
|      * @return {@code true} if successful, {@code false} if world already existed |      * @return {@code true} if successful, {@code false} if world already existed | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     boolean addWorld(@NonNull String worldName); |     boolean addWorld(@NonNull String worldName); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -76,7 +76,6 @@ public class SinglePlotArea extends GridPlotWorld { | |||||||
|      * Returns true if the given string matches the naming system used to identify single plot worlds |      * Returns true if the given string matches the naming system used to identify single plot worlds | ||||||
|      * e.g. -1_5 represents plot id *;-1;5. "*" being the plot area name given to single plot world |      * e.g. -1_5 represents plot id *;-1;5. "*" being the plot area name given to single plot world | ||||||
|      * {@link com.plotsquared.core.plot.PlotArea}. |      * {@link com.plotsquared.core.plot.PlotArea}. | ||||||
|      * |  | ||||||
|      * @since 6.1.4 |      * @since 6.1.4 | ||||||
|      */ |      */ | ||||||
|     public static boolean isSinglePlotWorld(String worldName) { |     public static boolean isSinglePlotWorld(String worldName) { | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
|  * The min and max points of this queue are offset according to the minimum point given in the constructor, and the offsets set |  * The min and max points of this queue are offset according to the minimum point given in the constructor, and the offsets set | ||||||
|  * in {@link BlockArrayCacheScopedQueueCoordinator#setOffsetX(int)} and |  * in {@link BlockArrayCacheScopedQueueCoordinator#setOffsetX(int)} and | ||||||
|  * {@link BlockArrayCacheScopedQueueCoordinator#setOffsetZ(int)} |  * {@link BlockArrayCacheScopedQueueCoordinator#setOffsetZ(int)} | ||||||
|  * <p> |  * | ||||||
|  * Internal use only. Subject to change at any time and created for specific use cases. |  * Internal use only. Subject to change at any time and created for specific use cases. | ||||||
|  */ |  */ | ||||||
| @NotPublic | @NotPublic | ||||||
| @@ -54,7 +54,6 @@ public class BlockArrayCacheScopedQueueCoordinator extends ZeroedDelegateScopedQ | |||||||
|     private final int scopeMaxZ; |     private final int scopeMaxZ; | ||||||
|     private int offsetX = 0; |     private int offsetX = 0; | ||||||
|     private int offsetZ = 0; |     private int offsetZ = 0; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Construct a new instance |      * Construct a new instance | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -29,7 +29,6 @@ public abstract class ChunkCoordinator implements Runnable { | |||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Cancel the chunk coordinator. |      * Cancel the chunk coordinator. | ||||||
|      * |  | ||||||
|      * @since 6.0.10 |      * @since 6.0.10 | ||||||
|      */ |      */ | ||||||
|     public abstract void cancel(); |     public abstract void cancel(); | ||||||
|   | |||||||
| @@ -43,10 +43,11 @@ 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; | ||||||
| @@ -66,7 +67,7 @@ public abstract class QueueCoordinator { | |||||||
|      * @param x chunk x coordinate |      * @param x chunk x coordinate | ||||||
|      * @param z chunk z coordinate |      * @param z chunk z coordinate | ||||||
|      * @return a new {@link ZeroedDelegateScopedQueueCoordinator} |      * @return a new {@link ZeroedDelegateScopedQueueCoordinator} | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public ZeroedDelegateScopedQueueCoordinator getForChunk(int x, int z, int minY, int maxY) { |     public ZeroedDelegateScopedQueueCoordinator getForChunk(int x, int z, int minY, int maxY) { | ||||||
|         int bx = x << 4; |         int bx = x << 4; | ||||||
|   | |||||||
| @@ -32,7 +32,7 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
|  * zero in the x and z directions, i.e. starting from 0,0. An offset of the minimum point of the region will then be applied to |  * zero in the x and z directions, i.e. starting from 0,0. An offset of the minimum point of the region will then be applied to | ||||||
|  * x and z. |  * x and z. | ||||||
|  * |  * | ||||||
|  * @since 7.0.0 |  * @since TODO | ||||||
|  */ |  */ | ||||||
| public class ZeroedDelegateScopedQueueCoordinator extends DelegateQueueCoordinator { | public class ZeroedDelegateScopedQueueCoordinator extends DelegateQueueCoordinator { | ||||||
|  |  | ||||||
| @@ -50,7 +50,7 @@ public class ZeroedDelegateScopedQueueCoordinator extends DelegateQueueCoordinat | |||||||
|     /** |     /** | ||||||
|      * Create a new ScopedQueueCoordinator instance that delegates to a given QueueCoordinator. Locations are inclusive. |      * Create a new ScopedQueueCoordinator instance that delegates to a given QueueCoordinator. Locations are inclusive. | ||||||
|      * |      * | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public ZeroedDelegateScopedQueueCoordinator(@Nullable QueueCoordinator parent, @NonNull Location min, @NonNull Location max) { |     public ZeroedDelegateScopedQueueCoordinator(@Nullable QueueCoordinator parent, @NonNull Location min, @NonNull Location max) { | ||||||
|         super(parent); |         super(parent); | ||||||
|   | |||||||
| @@ -25,17 +25,11 @@ 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; | ||||||
| @@ -91,10 +85,8 @@ public class PlotAreaBuilder { | |||||||
|         return this.plotManager; |         return this.plotManager; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @NotNull |  | ||||||
|     @Contract(" -> !null") |  | ||||||
|     public PlotAreaType plotAreaType() { |     public PlotAreaType plotAreaType() { | ||||||
|         return Objects.requireNonNullElse(this.plotAreaType, PlotAreaType.NORMAL); |         return this.plotAreaType; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public PlotAreaTerrainType terrainType() { |     public PlotAreaTerrainType terrainType() { | ||||||
| @@ -135,8 +127,7 @@ public class PlotAreaBuilder { | |||||||
|         return this; |         return this; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public PlotAreaBuilder plotAreaType(@NotNull PlotAreaType plotAreaType) { |     public PlotAreaBuilder plotAreaType(PlotAreaType plotAreaType) { | ||||||
|         Objects.requireNonNull(plotAreaType, "PlotAreaType must not be null"); |  | ||||||
|         this.plotAreaType = plotAreaType; |         this.plotAreaType = plotAreaType; | ||||||
|         return this; |         return this; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -65,9 +65,9 @@ public final class LockRepository { | |||||||
|      * @param runnable Action to run when the lock is available |      * @param runnable Action to run when the lock is available | ||||||
|      */ |      */ | ||||||
|     public void useLock(final @NonNull LockKey key, final @NonNull Runnable runnable) { |     public void useLock(final @NonNull LockKey key, final @NonNull Runnable runnable) { | ||||||
|         try (LockAccess ignored = lock(key)) { |        try (LockAccess ignored = lock(key)) { | ||||||
|             runnable.run(); |            runnable.run(); | ||||||
|         } |        } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|   | |||||||
| @@ -31,6 +31,8 @@ import com.sk89q.worldedit.world.registry.LegacyMapper; | |||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
|  | import java.util.Map; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * {@link BlockState} related utility methods |  * {@link BlockState} related utility methods | ||||||
|  */ |  */ | ||||||
| @@ -107,4 +109,34 @@ public final class BlockUtil { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Parse a comma delimited list of block states | ||||||
|  |      * | ||||||
|  |      * @param commaDelimited List of block states | ||||||
|  |      * @return Parsed block states | ||||||
|  |      */ | ||||||
|  |     public static @NonNull BlockState[] parse(final @NonNull String commaDelimited) { | ||||||
|  |         final String[] split = commaDelimited.split(",(?![^\\(\\[]*[\\]\\)])"); | ||||||
|  |         final BlockState[] result = new BlockState[split.length]; | ||||||
|  |         for (int i = 0; i < split.length; i++) { | ||||||
|  |             result[i] = get(split[i]); | ||||||
|  |         } | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Deserialize a serialized {@link BlockState} | ||||||
|  |      * | ||||||
|  |      * @param map Serialized block state | ||||||
|  |      * @return Deserialized block state, or {@code null} if the map is | ||||||
|  |      *         not a properly serialized block state | ||||||
|  |      */ | ||||||
|  |     public static @Nullable BlockState deserialize(final @NonNull Map<String, Object> map) { | ||||||
|  |         if (map.containsKey("material")) { | ||||||
|  |             final Object object = map.get("material"); | ||||||
|  |             return get(object.toString()); | ||||||
|  |         } | ||||||
|  |         return null; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ public abstract class ChunkManager { | |||||||
|     private static final Map<BlockVector2, RunnableVal<ZeroedDelegateScopedQueueCoordinator>> addChunks = new ConcurrentHashMap<>(); |     private static final Map<BlockVector2, RunnableVal<ZeroedDelegateScopedQueueCoordinator>> addChunks = new ConcurrentHashMap<>(); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public static void setChunkInPlotArea( |     public static void setChunkInPlotArea( | ||||||
|             RunnableVal<ZeroedDelegateScopedQueueCoordinator> force, |             RunnableVal<ZeroedDelegateScopedQueueCoordinator> force, | ||||||
| @@ -76,7 +76,7 @@ public abstract class ChunkManager { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public static boolean preProcessChunk(BlockVector2 loc, ZeroedDelegateScopedQueueCoordinator queue) { |     public static boolean preProcessChunk(BlockVector2 loc, ZeroedDelegateScopedQueueCoordinator queue) { | ||||||
|         final RunnableVal<ZeroedDelegateScopedQueueCoordinator> forceChunk = forceChunks.get(loc); |         final RunnableVal<ZeroedDelegateScopedQueueCoordinator> forceChunk = forceChunks.get(loc); | ||||||
| @@ -89,7 +89,7 @@ public abstract class ChunkManager { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public static boolean postProcessChunk(BlockVector2 loc, ZeroedDelegateScopedQueueCoordinator queue) { |     public static boolean postProcessChunk(BlockVector2 loc, ZeroedDelegateScopedQueueCoordinator queue) { | ||||||
|         final RunnableVal<ZeroedDelegateScopedQueueCoordinator> addChunk = forceChunks.get(loc); |         final RunnableVal<ZeroedDelegateScopedQueueCoordinator> addChunk = forceChunks.get(loc); | ||||||
|   | |||||||
| @@ -18,6 +18,10 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.core.util; | package com.plotsquared.core.util; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
|  | import com.sk89q.worldedit.math.BlockVector2; | ||||||
|  | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * This cache is used for world generation and just saves a bit of calculation time when checking if something is in the plot area. |  * This cache is used for world generation and just saves a bit of calculation time when checking if something is in the plot area. | ||||||
|  */ |  */ | ||||||
| @@ -103,4 +107,22 @@ public class ChunkUtil { | |||||||
|         return z_loc[j]; |         return z_loc[j]; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Returns true if the region pos1-pos2 contains the chunk | ||||||
|  |      * | ||||||
|  |      * @param pos1  Region minimum point | ||||||
|  |      * @param pos2  Region maximum point | ||||||
|  |      * @param chunk BlockVector2 of chunk coordinates | ||||||
|  |      * @return {@code true} if the region pos1-pos2 contains the chunk | ||||||
|  |      */ | ||||||
|  |     public static boolean isWholeChunk(@NonNull Location pos1, @NonNull Location pos2, @NonNull BlockVector2 chunk) { | ||||||
|  |         int x1 = pos1.getX(); | ||||||
|  |         int z1 = pos1.getZ(); | ||||||
|  |         int x2 = pos2.getX(); | ||||||
|  |         int z2 = pos2.getZ(); | ||||||
|  |         int cx = chunk.getX() << 4; | ||||||
|  |         int cz = chunk.getZ() << 4; | ||||||
|  |         return cx > x1 && cz > z1 && cx < x2 && cz < z2; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ import java.util.Collection; | |||||||
| /** | /** | ||||||
|  * A utility class for modifying components. |  * A utility class for modifying components. | ||||||
|  * |  * | ||||||
|  * @since 7.0.0 |  * @since TODO | ||||||
|  */ |  */ | ||||||
| public class ComponentHelper { | public class ComponentHelper { | ||||||
|  |  | ||||||
| @@ -37,7 +37,7 @@ public class ComponentHelper { | |||||||
|      * @param components The components to join |      * @param components The components to join | ||||||
|      * @param delimiter  The delimiter to use between the components |      * @param delimiter  The delimiter to use between the components | ||||||
|      * @return The joined components |      * @return The joined components | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public static ComponentLike join(Collection<? extends ComponentLike> components, Component delimiter) { |     public static ComponentLike join(Collection<? extends ComponentLike> components, Component delimiter) { | ||||||
|         return join(components.toArray(ComponentLike[]::new), delimiter); |         return join(components.toArray(ComponentLike[]::new), delimiter); | ||||||
| @@ -49,7 +49,7 @@ public class ComponentHelper { | |||||||
|      * @param components The components to join |      * @param components The components to join | ||||||
|      * @param delimiter  The delimiter to use between the components |      * @param delimiter  The delimiter to use between the components | ||||||
|      * @return The joined components |      * @return The joined components | ||||||
|      * @since 7.0.0 |      * @since TODO | ||||||
|      */ |      */ | ||||||
|     public static Component join(ComponentLike[] components, Component delimiter) { |     public static Component join(ComponentLike[] components, Component delimiter) { | ||||||
|         TextComponent.Builder builder = Component.text(); |         TextComponent.Builder builder = Component.text(); | ||||||
|   | |||||||
| @@ -35,8 +35,8 @@ public abstract class InventoryUtil { | |||||||
|      * Attempts to set an item into a {@link PlotInventory} while also checking the existence of the material |      * Attempts to set an item into a {@link PlotInventory} while also checking the existence of the material | ||||||
|      * |      * | ||||||
|      * @param plotInventory The inventory where the item should be placed |      * @param plotInventory The inventory where the item should be placed | ||||||
|      * @param index         The index where to place the item |      * @param index The index where to place the item | ||||||
|      * @param item          The item to place into the inventory |      * @param item The item to place into the inventory | ||||||
|      * @return {@code true} if the item could be placed, {@code false} otherwise (e.g. item not available in current version) |      * @return {@code true} if the item could be placed, {@code false} otherwise (e.g. item not available in current version) | ||||||
|      * @since 6.5.0 |      * @since 6.5.0 | ||||||
|      */ |      */ | ||||||
| @@ -49,14 +49,12 @@ public abstract class InventoryUtil { | |||||||
|      * Attempts to set an item into a {@link PlotInventory} |      * Attempts to set an item into a {@link PlotInventory} | ||||||
|      * |      * | ||||||
|      * @param plotInventory The inventory where the item should be placed |      * @param plotInventory The inventory where the item should be placed | ||||||
|      * @param index         The index where to place the item |      * @param index The index where to place the item | ||||||
|      * @param item          The item to place into the inventory |      * @param item The item to place into the inventory | ||||||
|      * @see #setItemChecked(PlotInventory, int, PlotItemStack) |      * @see #setItemChecked(PlotInventory, int, PlotItemStack) | ||||||
|      */ |      */ | ||||||
|     public void setItem( |     public void setItem(final PlotInventory plotInventory, final int index, | ||||||
|             final PlotInventory plotInventory, final int index, |                         final PlotItemStack item) { | ||||||
|             final PlotItemStack item |  | ||||||
|     ) { |  | ||||||
|         setItemChecked(plotInventory, index, item); |         setItemChecked(plotInventory, index, item); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -70,6 +70,103 @@ public class MathMan { | |||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static long pairInt(int x, int y) { | ||||||
|  |         return (((long) x) << 32) | (y & 0xffffffffL); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static int unpairIntX(long pair) { | ||||||
|  |         return (int) (pair >> 32); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static int unpairIntY(long pair) { | ||||||
|  |         return (int) pair; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static byte pair16(byte x, byte y) { | ||||||
|  |         return (byte) (x + (y << 4)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static byte unpair16x(byte value) { | ||||||
|  |         return (byte) (value & 0xF); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static byte unpair16y(byte value) { | ||||||
|  |         return (byte) ((value >> 4) & 0xF); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static long inverseRound(double val) { | ||||||
|  |         long round = Math.round(val); | ||||||
|  |         return (long) (round + Math.signum(val - round)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static int sqrt(int x) { | ||||||
|  |         int xn; | ||||||
|  |  | ||||||
|  |         if (x >= 0x10000) { | ||||||
|  |             if (x >= 0x1000000) { | ||||||
|  |                 if (x >= 0x10000000) { | ||||||
|  |                     if (x >= 0x40000000) { | ||||||
|  |                         xn = table[x >> 24] << 8; | ||||||
|  |                     } else { | ||||||
|  |                         xn = table[x >> 22] << 7; | ||||||
|  |                     } | ||||||
|  |                 } else { | ||||||
|  |                     if (x >= 0x4000000) { | ||||||
|  |                         xn = table[x >> 20] << 6; | ||||||
|  |                     } else { | ||||||
|  |                         xn = table[x >> 18] << 5; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 xn = (xn + 1 + (x / xn)) >> 1; | ||||||
|  |                 xn = (xn + 1 + (x / xn)) >> 1; | ||||||
|  |                 return ((xn * xn) > x) ? --xn : xn; | ||||||
|  |             } else { | ||||||
|  |                 if (x >= 0x100000) { | ||||||
|  |                     if (x >= 0x400000) { | ||||||
|  |                         xn = table[x >> 16] << 4; | ||||||
|  |                     } else { | ||||||
|  |                         xn = table[x >> 14] << 3; | ||||||
|  |                     } | ||||||
|  |                 } else { | ||||||
|  |                     if (x >= 0x40000) { | ||||||
|  |                         xn = table[x >> 12] << 2; | ||||||
|  |                     } else { | ||||||
|  |                         xn = table[x >> 10] << 1; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 xn = (xn + 1 + (x / xn)) >> 1; | ||||||
|  |  | ||||||
|  |                 return ((xn * xn) > x) ? --xn : xn; | ||||||
|  |             } | ||||||
|  |         } else { | ||||||
|  |             if (x >= 0x100) { | ||||||
|  |                 if (x >= 0x1000) { | ||||||
|  |                     if (x >= 0x4000) { | ||||||
|  |                         xn = (table[x >> 8]) + 1; | ||||||
|  |                     } else { | ||||||
|  |                         xn = (table[x >> 6] >> 1) + 1; | ||||||
|  |                     } | ||||||
|  |                 } else { | ||||||
|  |                     if (x >= 0x400) { | ||||||
|  |                         xn = (table[x >> 4] >> 2) + 1; | ||||||
|  |                     } else { | ||||||
|  |                         xn = (table[x >> 2] >> 3) + 1; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |  | ||||||
|  |                 return ((xn * xn) > x) ? --xn : xn; | ||||||
|  |             } else { | ||||||
|  |                 if (x >= 0) { | ||||||
|  |                     return table[x] >> 4; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         throw new IllegalArgumentException("Invalid number:" + x); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     public static double getMean(int[] array) { |     public static double getMean(int[] array) { | ||||||
|         double count = 0; |         double count = 0; | ||||||
|         for (int i : array) { |         for (int i : array) { | ||||||
| @@ -78,6 +175,14 @@ public class MathMan { | |||||||
|         return count / array.length; |         return count / array.length; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static double getMean(double[] array) { | ||||||
|  |         double count = 0; | ||||||
|  |         for (double i : array) { | ||||||
|  |             count += i; | ||||||
|  |         } | ||||||
|  |         return count / array.length; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static int pair(short x, short y) { |     public static int pair(short x, short y) { | ||||||
|         return (x << 16) | (y & 0xFFFF); |         return (x << 16) | (y & 0xFFFF); | ||||||
|     } |     } | ||||||
| @@ -86,10 +191,105 @@ public class MathMan { | |||||||
|         return (a & b) + (a ^ b) / 2; |         return (a & b) + (a ^ b) / 2; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static short unpairX(int hash) { | ||||||
|  |         return (short) (hash >> 16); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static short unpairY(int hash) { | ||||||
|  |         return (short) (hash & 0xFFFF); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * get the x,y,z unit vector from pitch and yaw specified | ||||||
|  |      * | ||||||
|  |      * @param yaw   yaw | ||||||
|  |      * @param pitch pitch | ||||||
|  |      * @return x, y, z unit vector | ||||||
|  |      */ | ||||||
|  |     public static float[] getDirection(float yaw, float pitch) { | ||||||
|  |         double pitch_sin = Math.sin(pitch); | ||||||
|  |         return new float[]{(float) (pitch_sin * Math.cos(yaw)), | ||||||
|  |                 (float) (pitch_sin * Math.sin(yaw)), (float) Math.cos(pitch)}; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static int floorMod(int x, int y) { | ||||||
|  |         int i = x % y; | ||||||
|  |         if (i < 0) { | ||||||
|  |             i += y; | ||||||
|  |         } | ||||||
|  |         return i; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static int roundInt(double value) { |     public static int roundInt(double value) { | ||||||
|         return (int) (value < 0 ? (value == (int) value) ? value : value - 1 : value); |         return (int) (value < 0 ? (value == (int) value) ? value : value - 1 : value); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Returns [ pitch, yaw ] | ||||||
|  |      * | ||||||
|  |      * @param x x | ||||||
|  |      * @param y y | ||||||
|  |      * @param z z | ||||||
|  |      * @return pitch and yaw of x,y,z from 0,0,0 | ||||||
|  |      */ | ||||||
|  |     public static float[] getPitchAndYaw(float x, float y, float z) { | ||||||
|  |         float distance = sqrtApprox((z * z) + (x * x)); | ||||||
|  |         return new float[]{atan2(y, distance), atan2(x, z)}; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static final float atan2(float y, float x) { | ||||||
|  |         float add; | ||||||
|  |         float mul; | ||||||
|  |  | ||||||
|  |         if (x < 0.0f) { | ||||||
|  |             if (y < 0.0f) { | ||||||
|  |                 x = -x; | ||||||
|  |                 y = -y; | ||||||
|  |  | ||||||
|  |                 mul = 1.0f; | ||||||
|  |             } else { | ||||||
|  |                 x = -x; | ||||||
|  |                 mul = -1.0f; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             add = -3.141592653f; | ||||||
|  |         } else { | ||||||
|  |             if (y < 0.0f) { | ||||||
|  |                 y = -y; | ||||||
|  |                 mul = -1.0f; | ||||||
|  |             } else { | ||||||
|  |                 mul = 1.0f; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             add = 0.0f; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         float invDiv = 1.0f / (((x < y) ? y : x) * INV_ATAN2_DIM_MINUS_1); | ||||||
|  |  | ||||||
|  |         int xi = (int) (x * invDiv); | ||||||
|  |         int yi = (int) (y * invDiv); | ||||||
|  |  | ||||||
|  |         return (atan2[(yi * ATAN2_DIM) + xi] + add) * mul; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static float sqrtApprox(float f) { | ||||||
|  |         return f * Float.intBitsToFloat(0x5f375a86 - (Float.floatToIntBits(f) >> 1)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static double sqrtApprox(double d) { | ||||||
|  |         return Double | ||||||
|  |                 .longBitsToDouble(((Double.doubleToLongBits(d) - (1L << 52)) >> 1) + (1L << 61)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static float invSqrt(float x) { | ||||||
|  |         float xhalf = 0.5f * x; | ||||||
|  |         int i = Float.floatToIntBits(x); | ||||||
|  |         i = 0x5f3759df - (i >> 1); | ||||||
|  |         x = Float.intBitsToFloat(i); | ||||||
|  |         x = x * (1.5f - (xhalf * x * x)); | ||||||
|  |         return x; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static int getPositiveId(int i) { |     public static int getPositiveId(int i) { | ||||||
|         if (i < 0) { |         if (i < 0) { | ||||||
|             return (-i * 2) - 1; |             return (-i * 2) - 1; | ||||||
| @@ -121,6 +321,14 @@ public class MathMan { | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static double getSD(double[] array, double av) { | ||||||
|  |         double sd = 0; | ||||||
|  |         for (double element : array) { | ||||||
|  |             sd += Math.pow(Math.abs(element - av), 2); | ||||||
|  |         } | ||||||
|  |         return Math.sqrt(sd / array.length); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static double getSD(int[] array, double av) { |     public static double getSD(int[] array, double av) { | ||||||
|         double sd = 0; |         double sd = 0; | ||||||
|         for (int element : array) { |         for (int element : array) { | ||||||
| @@ -129,4 +337,22 @@ public class MathMan { | |||||||
|         return Math.sqrt(sd / array.length); |         return Math.sqrt(sd / array.length); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static int mod(int x, int y) { | ||||||
|  |         if (isPowerOfTwo(y)) { | ||||||
|  |             return x & (y - 1); | ||||||
|  |         } | ||||||
|  |         return x % y; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static int unsignedmod(int x, int y) { | ||||||
|  |         if (isPowerOfTwo(y)) { | ||||||
|  |             return x & (y - 1); | ||||||
|  |         } | ||||||
|  |         return x % y; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static boolean isPowerOfTwo(int number) { | ||||||
|  |         return (number & (number - 1)) == 0; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -272,8 +272,7 @@ public abstract class RegionManager { | |||||||
|         fromQueue1.addReadChunks(new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3()).getChunks()); |         fromQueue1.addReadChunks(new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3()).getChunks()); | ||||||
|         fromQueue2.addReadChunks(new CuboidRegion( |         fromQueue2.addReadChunks(new CuboidRegion( | ||||||
|                 swapPos.getBlockVector3(), |                 swapPos.getBlockVector3(), | ||||||
|                 BlockVector3.at( |                 BlockVector3.at(swapPos.getX() + pos2.getX() - pos1.getX(), | ||||||
|                         swapPos.getX() + pos2.getX() - pos1.getX(), |  | ||||||
|                         pos1.getY(), |                         pos1.getY(), | ||||||
|                         swapPos.getZ() + pos2.getZ() - pos1.getZ() |                         swapPos.getZ() + pos2.getZ() - pos1.getZ() | ||||||
|                 ) |                 ) | ||||||
|   | |||||||
| @@ -19,10 +19,12 @@ | |||||||
| package com.plotsquared.core.util; | package com.plotsquared.core.util; | ||||||
|  |  | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
|  | import com.sk89q.worldedit.math.BlockVector2; | ||||||
| import com.sk89q.worldedit.math.BlockVector3; | import com.sk89q.worldedit.math.BlockVector3; | ||||||
| import com.sk89q.worldedit.regions.CuboidRegion; | import com.sk89q.worldedit.regions.CuboidRegion; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  | import java.awt.geom.Rectangle2D; | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
|  |  | ||||||
| @@ -88,6 +90,12 @@ public class RegionUtil { | |||||||
|                 .getY() && y <= max.getY(); |                 .getY() && y <= max.getY(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static @NonNull Rectangle2D toRectangle(final @NonNull CuboidRegion region) { | ||||||
|  |         final BlockVector2 min = region.getMinimumPoint().toBlockVector2(); | ||||||
|  |         final BlockVector2 max = region.getMaximumPoint().toBlockVector2(); | ||||||
|  |         return new Rectangle2D.Double(min.getX(), min.getZ(), max.getX(), max.getZ()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     // Because WorldEdit (not FastAsyncWorldEdit) lack this for CuboidRegion |     // Because WorldEdit (not FastAsyncWorldEdit) lack this for CuboidRegion | ||||||
|     public static boolean intersects(CuboidRegion region, CuboidRegion other) { |     public static boolean intersects(CuboidRegion region, CuboidRegion other) { | ||||||
|         BlockVector3 regionMin = region.getMinimumPoint(); |         BlockVector3 regionMin = region.getMinimumPoint(); | ||||||
|   | |||||||
| @@ -18,13 +18,19 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.core.util; | package com.plotsquared.core.util; | ||||||
|  |  | ||||||
|  | import com.plotsquared.core.PlotSquared; | ||||||
|  | import com.plotsquared.core.configuration.caption.Caption; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
|  | import java.lang.reflect.Array; | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| import java.util.Collection; | import java.util.Collection; | ||||||
| import java.util.Comparator; | import java.util.Comparator; | ||||||
|  | import java.util.Iterator; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  | import java.util.Map; | ||||||
|  | import java.util.Map.Entry; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.regex.Pattern; | import java.util.regex.Pattern; | ||||||
|  |  | ||||||
| @@ -33,6 +39,27 @@ public class StringMan { | |||||||
|     // Stolen from https://stackoverflow.com/a/366532/12620913 | Debug: https://regex101.com/r/DudJLb/1 |     // Stolen from https://stackoverflow.com/a/366532/12620913 | Debug: https://regex101.com/r/DudJLb/1 | ||||||
|     private static final Pattern STRING_SPLIT_PATTERN = Pattern.compile("[^\\s\"]+|\"([^\"]*)\""); |     private static final Pattern STRING_SPLIT_PATTERN = Pattern.compile("[^\\s\"]+|\"([^\"]*)\""); | ||||||
|  |  | ||||||
|  |     public static String replaceFromMap(String string, Map<String, String> replacements) { | ||||||
|  |         StringBuilder sb = new StringBuilder(string); | ||||||
|  |         int size = string.length(); | ||||||
|  |         for (Entry<String, String> entry : replacements.entrySet()) { | ||||||
|  |             if (size == 0) { | ||||||
|  |                 break; | ||||||
|  |             } | ||||||
|  |             String key = entry.getKey(); | ||||||
|  |             String value = entry.getValue(); | ||||||
|  |             int start = sb.indexOf(key, 0); | ||||||
|  |             while (start > -1) { | ||||||
|  |                 int end = start + key.length(); | ||||||
|  |                 int nextSearchStart = start + value.length(); | ||||||
|  |                 sb.replace(start, end, value); | ||||||
|  |                 size -= end - start; | ||||||
|  |                 start = sb.indexOf(key, nextSearchStart); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return sb.toString(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static int intersection(Set<String> options, String[] toCheck) { |     public static int intersection(Set<String> options, String[] toCheck) { | ||||||
|         int count = 0; |         int count = 0; | ||||||
|         for (String check : toCheck) { |         for (String check : toCheck) { | ||||||
| @@ -43,6 +70,91 @@ public class StringMan { | |||||||
|         return count; |         return count; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static String getString(Object obj) { | ||||||
|  |         if (obj == null) { | ||||||
|  |             return "null"; | ||||||
|  |         } | ||||||
|  |         if (obj instanceof String) { | ||||||
|  |             return (String) obj; | ||||||
|  |         } | ||||||
|  |         if (obj instanceof Caption) { | ||||||
|  |             return ((Caption) obj).getComponent(PlotSquared.platform()); | ||||||
|  |         } | ||||||
|  |         if (obj.getClass().isArray()) { | ||||||
|  |             StringBuilder result = new StringBuilder(); | ||||||
|  |             String prefix = ""; | ||||||
|  |  | ||||||
|  |             for (int i = 0; i < Array.getLength(obj); i++) { | ||||||
|  |                 result.append(prefix).append(getString(Array.get(obj, i))); | ||||||
|  |                 prefix = ","; | ||||||
|  |             } | ||||||
|  |             return "( " + result + " )"; | ||||||
|  |         } else if (obj instanceof Collection<?>) { | ||||||
|  |             StringBuilder result = new StringBuilder(); | ||||||
|  |             String prefix = ""; | ||||||
|  |             for (Object element : (Collection<?>) obj) { | ||||||
|  |                 result.append(prefix).append(getString(element)); | ||||||
|  |                 prefix = ","; | ||||||
|  |             } | ||||||
|  |             return "[ " + result + " ]"; | ||||||
|  |         } else { | ||||||
|  |             return obj.toString(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static String replaceFirst(char c, String s) { | ||||||
|  |         if (s == null) { | ||||||
|  |             return ""; | ||||||
|  |         } | ||||||
|  |         if (s.isEmpty()) { | ||||||
|  |             return s; | ||||||
|  |         } | ||||||
|  |         char[] chars = s.toCharArray(); | ||||||
|  |         char[] newChars = new char[chars.length]; | ||||||
|  |         int used = 0; | ||||||
|  |         boolean found = false; | ||||||
|  |         for (char cc : chars) { | ||||||
|  |             if (!found && (c == cc)) { | ||||||
|  |                 found = true; | ||||||
|  |             } else { | ||||||
|  |                 newChars[used++] = cc; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (found) { | ||||||
|  |             chars = new char[newChars.length - 1]; | ||||||
|  |             System.arraycopy(newChars, 0, chars, 0, chars.length); | ||||||
|  |             return String.valueOf(chars); | ||||||
|  |         } | ||||||
|  |         return s; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static String replaceAll(String string, Object... pairs) { | ||||||
|  |         StringBuilder sb = new StringBuilder(string); | ||||||
|  |         for (int i = 0; i < pairs.length; i += 2) { | ||||||
|  |             String key = pairs[i] + ""; | ||||||
|  |             String value = pairs[i + 1] + ""; | ||||||
|  |             int start = sb.indexOf(key, 0); | ||||||
|  |             while (start > -1) { | ||||||
|  |                 int end = start + key.length(); | ||||||
|  |                 int nextSearchStart = start + value.length(); | ||||||
|  |                 sb.replace(start, end, value); | ||||||
|  |                 start = sb.indexOf(key, nextSearchStart); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return sb.toString(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static boolean isAlphanumeric(String str) { | ||||||
|  |         for (int i = 0; i < str.length(); i++) { | ||||||
|  |             char c = str.charAt(i); | ||||||
|  |             if ((c < 0x30) || ((c >= 0x3a) && (c <= 0x40)) || ((c > 0x5a) && (c <= 0x60)) || (c | ||||||
|  |                     > 0x7a)) { | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static boolean isAlphanumericUnd(String str) { |     public static boolean isAlphanumericUnd(String str) { | ||||||
|         for (int i = 0; i < str.length(); i++) { |         for (int i = 0; i < str.length(); i++) { | ||||||
|             char c = str.charAt(i); |             char c = str.charAt(i); | ||||||
| @@ -53,6 +165,16 @@ public class StringMan { | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static boolean isAlpha(String str) { | ||||||
|  |         for (int i = 0; i < str.length(); i++) { | ||||||
|  |             char c = str.charAt(i); | ||||||
|  |             if ((c <= 0x40) || ((c > 0x5a) && (c <= 0x60)) || (c > 0x7a)) { | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static String join(Collection<?> collection, String delimiter) { |     public static String join(Collection<?> collection, String delimiter) { | ||||||
|         return join(collection.toArray(), delimiter); |         return join(collection.toArray(), delimiter); | ||||||
|     } |     } | ||||||
| @@ -63,6 +185,23 @@ public class StringMan { | |||||||
|         return join(array, delimiter); |         return join(array, delimiter); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static String join(Collection<?> collection, char delimiter) { | ||||||
|  |         return join(collection.toArray(), delimiter + ""); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static boolean isAsciiPrintable(char c) { | ||||||
|  |         return (c >= ' ') && (c < ''); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static boolean isAsciiPrintable(String s) { | ||||||
|  |         for (char c : s.toCharArray()) { | ||||||
|  |             if (!isAsciiPrintable(c)) { | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static int getLevenshteinDistance(String s, String t) { |     public static int getLevenshteinDistance(String s, String t) { | ||||||
|         int n = s.length(); |         int n = s.length(); | ||||||
|         int m = t.length(); |         int m = t.length(); | ||||||
| @@ -110,6 +249,23 @@ public class StringMan { | |||||||
|         return result.toString(); |         return result.toString(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static String join(int[] array, String delimiter) { | ||||||
|  |         Integer[] wrapped = new Integer[array.length]; | ||||||
|  |         for (int i = 0; i < array.length; i++) { | ||||||
|  |             wrapped[i] = array[i]; | ||||||
|  |         } | ||||||
|  |         return join(wrapped, delimiter); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static boolean isEqualToAny(String a, String... args) { | ||||||
|  |         for (String arg : args) { | ||||||
|  |             if (StringMan.isEqual(a, arg)) { | ||||||
|  |                 return true; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static boolean isEqualIgnoreCaseToAny(@NonNull String a, String... args) { |     public static boolean isEqualIgnoreCaseToAny(@NonNull String a, String... args) { | ||||||
|         for (String arg : args) { |         for (String arg : args) { | ||||||
|             if (a.equalsIgnoreCase(arg)) { |             if (a.equalsIgnoreCase(arg)) { | ||||||
| @@ -128,12 +284,41 @@ public class StringMan { | |||||||
|         return a.equals(b); |         return a.equals(b); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static boolean isEqualIgnoreCase(String a, String b) { | ||||||
|  |         return a.equals(b) || ((a != null) && (b != null) && (a.length() == b.length()) && a | ||||||
|  |                 .equalsIgnoreCase(b)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static String repeat(String s, int n) { |     public static String repeat(String s, int n) { | ||||||
|         StringBuilder sb = new StringBuilder(); |         StringBuilder sb = new StringBuilder(); | ||||||
|         sb.append(String.valueOf(s).repeat(Math.max(0, n))); |         sb.append(String.valueOf(s).repeat(Math.max(0, n))); | ||||||
|         return sb.toString(); |         return sb.toString(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static boolean contains(String name, char c) { | ||||||
|  |         for (char current : name.toCharArray()) { | ||||||
|  |             if (c == current) { | ||||||
|  |                 return true; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public <T> Collection<T> match(Collection<T> col, String startsWith) { | ||||||
|  |         if (col == null) { | ||||||
|  |             return null; | ||||||
|  |         } | ||||||
|  |         startsWith = startsWith.toLowerCase(); | ||||||
|  |         Iterator<?> iterator = col.iterator(); | ||||||
|  |         while (iterator.hasNext()) { | ||||||
|  |             Object item = iterator.next(); | ||||||
|  |             if (item == null || !item.toString().toLowerCase().startsWith(startsWith)) { | ||||||
|  |                 iterator.remove(); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return col; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * @param message an input string |      * @param message an input string | ||||||
|      * @return a list of strings |      * @return a list of strings | ||||||
|   | |||||||
| @@ -58,6 +58,29 @@ public class WEManager { | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static boolean maskContains(Set<CuboidRegion> mask, double dx, double dy, double dz) { | ||||||
|  |         int x = Math.toIntExact(Math.round(dx >= 0 ? dx - 0.5 : dx + 0.5)); | ||||||
|  |         int y = Math.toIntExact(Math.round(dy - 0.5)); | ||||||
|  |         int z = Math.toIntExact(Math.round(dz >= 0 ? dz - 0.5 : dz + 0.5)); | ||||||
|  |         for (CuboidRegion region : mask) { | ||||||
|  |             if (RegionUtil.contains(region, x, y, z)) { | ||||||
|  |                 return true; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static boolean maskContains(Set<CuboidRegion> mask, double dx, double dz) { | ||||||
|  |         int x = Math.toIntExact(Math.round(dx >= 0 ? dx - 0.5 : dx + 0.5)); | ||||||
|  |         int z = Math.toIntExact(Math.round(dz >= 0 ? dz - 0.5 : dz + 0.5)); | ||||||
|  |         for (CuboidRegion region : mask) { | ||||||
|  |             if (RegionUtil.contains(region, x, z)) { | ||||||
|  |                 return true; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     public static HashSet<CuboidRegion> getMask(PlotPlayer<?> player) { |     public static HashSet<CuboidRegion> getMask(PlotPlayer<?> player) { | ||||||
|         HashSet<CuboidRegion> regions = new HashSet<>(); |         HashSet<CuboidRegion> regions = new HashSet<>(); | ||||||
|         UUID uuid = player.getUUID(); |         UUID uuid = player.getUUID(); | ||||||
| @@ -93,4 +116,17 @@ public class WEManager { | |||||||
|         return regions; |         return regions; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public static boolean intersects(CuboidRegion region1, CuboidRegion region2) { | ||||||
|  |         return RegionUtil.intersects(region1, region2); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static boolean regionContains(CuboidRegion selection, HashSet<CuboidRegion> mask) { | ||||||
|  |         for (CuboidRegion region : mask) { | ||||||
|  |             if (intersects(region, selection)) { | ||||||
|  |                 return true; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -285,8 +285,7 @@ public abstract class WorldUtil { | |||||||
|                         int trz = top.getZ() >> 9; |                         int trz = top.getZ() >> 9; | ||||||
|                         Set<BlockVector2> files = getChunkChunks(bot.getWorldName()); |                         Set<BlockVector2> files = getChunkChunks(bot.getWorldName()); | ||||||
|                         for (BlockVector2 mca : files) { |                         for (BlockVector2 mca : files) { | ||||||
|                             if (mca.getX() >= brx && mca.getX() <= trx && mca.getZ() >= brz && mca.getZ() <= trz && !added.contains( |                             if (mca.getX() >= brx && mca.getX() <= trx && mca.getZ() >= brz && mca.getZ() <= trz && !added.contains(mca)) { | ||||||
|                                     mca)) { |  | ||||||
|                                 final File file = getMcr(plot.getWorldName(), mca.getX(), mca.getZ()); |                                 final File file = getMcr(plot.getWorldName(), mca.getX(), mca.getZ()); | ||||||
|                                 if (file != null) { |                                 if (file != null) { | ||||||
|                                     //final String name = "r." + (x - cx) + "." + (z - cz) + ".mca"; |                                     //final String name = "r." + (x - cx) + "." + (z - cz) + ".mca"; | ||||||
|   | |||||||
| @@ -102,7 +102,7 @@ public final class PlaceholderRegistry { | |||||||
|             return plot.getAlias(); |             return plot.getAlias(); | ||||||
|         }); |         }); | ||||||
|         this.createPlaceholder("currentplot_owner", (player, plot) -> { |         this.createPlaceholder("currentplot_owner", (player, plot) -> { | ||||||
|             if (plot.getFlag(ServerPlotFlag.class)) { |             if (plot.getFlag(ServerPlotFlag.class)){ | ||||||
|                 return legacyComponent(TranslatableCaption.of("info.server"), player); |                 return legacyComponent(TranslatableCaption.of("info.server"), player); | ||||||
|             } |             } | ||||||
|             final UUID plotOwner = plot.getOwnerAbs(); |             final UUID plotOwner = plot.getOwnerAbs(); | ||||||
| @@ -298,8 +298,8 @@ 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( |     public record PlaceholderAddedEvent( | ||||||
|             Placeholder placeholder |             Placeholder placeholder | ||||||
|     ) { |     ) { | ||||||
|   | |||||||
| @@ -41,7 +41,7 @@ | |||||||
|   "cluster.cluster_deleted": "<prefix><dark_aqua>Successfully deleted the cluster </dark_aqua><gold><cluster></gold><dark_aqua>.</dark_aqua>", |   "cluster.cluster_deleted": "<prefix><dark_aqua>Successfully deleted the cluster </dark_aqua><gold><cluster></gold><dark_aqua>.</dark_aqua>", | ||||||
|   "cluster.cluster_resized": "<prefix><dark_aqua>Successfully resized the cluster.</dark_aqua>", |   "cluster.cluster_resized": "<prefix><dark_aqua>Successfully resized the cluster.</dark_aqua>", | ||||||
|   "cluster.cluster_added_user": "<prefix><dark_aqua>Successfully added user to the cluster.</dark_aqua>", |   "cluster.cluster_added_user": "<prefix><dark_aqua>Successfully added user to the cluster.</dark_aqua>", | ||||||
|   "cluster.cannot_kick_player": "<prefix><red>You cannot kick the player <gray><name></gray>.</red>", |   "cluster.cannot_kick_player": "<prefix><red>You cannot kick that player: </red><gray><name></gray>", | ||||||
|   "cluster.cluster_invited": "<prefix><gold>You have been invited to the following cluster: </gold><gray><cluster>.</gray>", |   "cluster.cluster_invited": "<prefix><gold>You have been invited to the following cluster: </gold><gray><cluster>.</gray>", | ||||||
|   "cluster.cluster_removed": "<prefix><gold>You have been removed from cluster: </gold><gray><cluster>.</gray>", |   "cluster.cluster_removed": "<prefix><gold>You have been removed from cluster: </gold><gray><cluster>.</gray>", | ||||||
|   "cluster.cluster_kicked_user": "<prefix><dark_aqua>Successfully kicked the user from the cluster.</dark_aqua>", |   "cluster.cluster_kicked_user": "<prefix><dark_aqua>Successfully kicked the user from the cluster.</dark_aqua>", | ||||||
| @@ -411,8 +411,6 @@ | |||||||
|   "deny.no_enter": "<prefix><red>You are denied from the plot <red><gold><plot></gold><red> and therefore not allowed to enter.</red>", |   "deny.no_enter": "<prefix><red>You are denied from the plot <red><gold><plot></gold><red> and therefore not allowed to enter.</red>", | ||||||
|   "deny.you_got_denied": "<prefix><red>You are denied from the plot you were previously on, and got teleported to spawn.</red>", |   "deny.you_got_denied": "<prefix><red>You are denied from the plot you were previously on, and got teleported to spawn.</red>", | ||||||
|   "deny.cant_remove_owner": "<prefix><red>You can't remove the plot owner.</red>", |   "deny.cant_remove_owner": "<prefix><red>You can't remove the plot owner.</red>", | ||||||
|   "kick.player_not_in_plot": "<prefix><red>The player <gray><player></gray> is not on this plot.</red>", |  | ||||||
|   "kick.cannot_kick_player": "<prefix><red>You cannot kick the player <gray><player></gray>.</red>", |  | ||||||
|   "kick.you_got_kicked": "<prefix><dark_aqua>You got kicked from the plot!</dark_aqua>", |   "kick.you_got_kicked": "<prefix><dark_aqua>You got kicked from the plot!</dark_aqua>", | ||||||
|   "trusted.trusted_added": "<prefix><dark_aqua>You successfully trusted a user to the plot.</dark_aqua>", |   "trusted.trusted_added": "<prefix><dark_aqua>You successfully trusted a user to the plot.</dark_aqua>", | ||||||
|   "trusted.plot_removed_user": "<prefix><red>Plot <plot> of which you were added to has been deleted due to owner inactivity.</red>", |   "trusted.plot_removed_user": "<prefix><red>Plot <plot> of which you were added to has been deleted due to owner inactivity.</red>", | ||||||
| @@ -488,7 +486,7 @@ | |||||||
|   "single.get_position": "<prefix><gold>Go to the first corner and use: <gray><command> to create position 1.</gold>", |   "single.get_position": "<prefix><gold>Go to the first corner and use: <gray><command> to create position 1.</gold>", | ||||||
|   "single.delete_world_region": "<prefix><red>Stop the server and delete: <world>/region.</red>", |   "single.delete_world_region": "<prefix><red>Stop the server and delete: <world>/region.</red>", | ||||||
|   "single.regeneration_complete": "<prefix><gold>Regeneration complete.</gold>", |   "single.regeneration_complete": "<prefix><gold>Regeneration complete.</gold>", | ||||||
|   "single.worldcreation_location": "<prefix><gold>World creation settings may be stored in multiple locations:</gold>\n<dark_gray> - </dark_gray><gray>bukkit.yml in your server's root folder.</gray>\n<dark_gray> - </dark_gray><gray>PlotSquared's worlds.yml</gray>\n<dark_gray> - </dark_gray><gray>Hyperverse's worlds.yml (or any world management plugin)</gray>\n<dark_gray> - </dark_gray><red>Stop the server and delete it from these locations.</red>", |   "single.worldcreation_location": "<prefix><gold>World creation settings may be stored in multiple locations:</gold>\n<dark_gray> - </dark_gray><gray>bukkit.yml in your server's root folder.</gray>\n<dark_gray> - </dark_gray><gray>PlotSquared's settings.yml</gray>\n<dark_gray> - </dark_gray><gray>Hyperverse's worlds.yml (or any world management plugin)</gray>\n<dark_gray> - </dark_gray><red>Stop the server and delete it from these locations.</red>", | ||||||
|   "legacyconfig.legacy_config_found": "<prefix><green>A legacy configuration file was detected. Conversion will be attempted.</green>", |   "legacyconfig.legacy_config_found": "<prefix><green>A legacy configuration file was detected. Conversion will be attempted.</green>", | ||||||
|   "legacyconfig.legacy_config_backup": "<prefix><gold>A copy of worlds.yml has been saved in the file worlds.yml.old</gold>.", |   "legacyconfig.legacy_config_backup": "<prefix><gold>A copy of worlds.yml has been saved in the file worlds.yml.old</gold>.", | ||||||
|   "legacyconfig.legacy_config_replaced": "<prefix><gray><value1> has been replaced with <value2></gray>", |   "legacyconfig.legacy_config_replaced": "<prefix><gray><value1> has been replaced with <value2></gray>", | ||||||
| @@ -574,7 +572,6 @@ | |||||||
|   "flags.flag_description_misc_break": "<gray>Set to `true` to allow guests to break miscellaneous items.</gray>", |   "flags.flag_description_misc_break": "<gray>Set to `true` to allow guests to break miscellaneous items.</gray>", | ||||||
|   "flags.flag_description_misc_cap": "<gray>Set to an integer value to limit the amount of miscellaneous entities on the plot.</gray>", |   "flags.flag_description_misc_cap": "<gray>Set to an integer value to limit the amount of miscellaneous entities on the plot.</gray>", | ||||||
|   "flags.flag_description_misc_interact": "<gray>Set to `true` to allow guests to interact with miscellaneous items.</gray>", |   "flags.flag_description_misc_interact": "<gray>Set to `true` to allow guests to interact with miscellaneous items.</gray>", | ||||||
|   "flags.flag_description_sculk_sensor_interact": "<gray>Set to `true` to allow guests to interact with sculk sensors.</gray>", |  | ||||||
|   "flags.flag_description_misc_place": "<gray>Set to `true` to allow guests to place miscellaneous items.</gray>", |   "flags.flag_description_misc_place": "<gray>Set to `true` to allow guests to place miscellaneous items.</gray>", | ||||||
|   "flags.flag_description_mob_break": "<gray>Set to `true` to allow mobs to break blocks within the plot.</gray>", |   "flags.flag_description_mob_break": "<gray>Set to `true` to allow mobs to break blocks within the plot.</gray>", | ||||||
|   "flags.flag_description_mob_cap": "<gray>Set to an integer value to limit the amount of mobs on the plot.</gray>", |   "flags.flag_description_mob_cap": "<gray>Set to an integer value to limit the amount of mobs on the plot.</gray>", | ||||||
|   | |||||||
| @@ -128,5 +128,4 @@ public class FlagTest { | |||||||
|                 ((TranslatableCaption) exception.getErrorMessage()).getKey() |                 ((TranslatableCaption) exception.getErrorMessage()).getKey() | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -107,5 +107,4 @@ public class PlotRangeIteratorTest { | |||||||
|         Assertions.assertFalse(range.hasNext()); |         Assertions.assertFalse(range.hasNext()); | ||||||
|         Assertions.assertThrows(NoSuchElementException.class, range::next); |         Assertions.assertThrows(NoSuchElementException.class, range::next); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -51,5 +51,4 @@ class LockRepositoryTest { | |||||||
|         })); |         })); | ||||||
|         Assertions.assertFalse(lock.isLocked()); |         Assertions.assertFalse(lock.isLocked()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -33,10 +33,8 @@ public class StringManTest { | |||||||
|                 new Message("title \"sub title\"", List.of("title", "sub title")), |                 new Message("title \"sub title\"", List.of("title", "sub title")), | ||||||
|                 new Message("\"a title\" subtitle", List.of("a title", "subtitle")), |                 new Message("\"a title\" subtitle", List.of("a title", "subtitle")), | ||||||
|                 new Message("\"title\" \"subtitle\"", List.of("title", "subtitle")), |                 new Message("\"title\" \"subtitle\"", List.of("title", "subtitle")), | ||||||
|                 new Message( |                 new Message("\"How <bold>bold</bold> of you\" \"to assume I like <rainbow>rainbows</rainbow>\"", | ||||||
|                         "\"How <bold>bold</bold> of you\" \"to assume I like <rainbow>rainbows</rainbow>\"", |                         List.of("How <bold>bold</bold> of you", "to assume I like <rainbow>rainbows</rainbow>")) | ||||||
|                         List.of("How <bold>bold</bold> of you", "to assume I like <rainbow>rainbows</rainbow>") |  | ||||||
|                 ) |  | ||||||
|         ); |         ); | ||||||
|  |  | ||||||
|         for (Message message : messages) { |         for (Message message : messages) { | ||||||
| @@ -55,5 +53,4 @@ public class StringManTest { | |||||||
|     private record Message(String input, List<String> expected) { |     private record Message(String input, List<String> expected) { | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user