mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-11-04 03:03:43 +01:00 
			
		
		
		
	Compare commits
	
		
			56 Commits
		
	
	
		
			fix/plot-c
			...
			fix/add-mi
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					c90e681aab | ||
| 
						 | 
					59eefd6865 | ||
| 
						 | 
					587a286d05 | ||
| 
						 | 
					e10caf6aa0 | ||
| 
						 | 
					08b325e37d | ||
| 
						 | 
					c394108ba6 | ||
| 
						 | 
					31e89019f1 | ||
| 
						 | 
					3a7075e28d | ||
| 
						 | 
					8373b7874e | ||
| 
						 | 
					fe13882b97 | ||
| 
						 | 
					f45064c4c4 | ||
| 
						 | 
					af32399dd2 | ||
| 
						 | 
					f3c03348d9 | ||
| 
						 | 
					a53330e39b | ||
| 
						 | 
					e2ba93dab9 | ||
| 
						 | 
					9d43434e40 | ||
| 
						 | 
					4f421167d1 | ||
| 
						 | 
					94f4619c2c | ||
| 
						 | 
					9885d3e506 | ||
| 
						 | 
					a54276d3b2 | ||
| 
						 | 
					cbb284b0fd | ||
| 
						 | 
					ed22b22e9c | ||
| 
						 | 
					444ccda807 | ||
| 
						 | 
					db361cc420 | ||
| 
						 | 
					079dc02cfe | ||
| 
						 | 
					e98791c865 | ||
| 
						 | 
					7c3112f30f | ||
| 
						 | 
					c01f5f5c7d | ||
| 
						 | 
					95caa19505 | ||
| 
						 | 
					b8055201df | ||
| 
						 | 
					81daefae4a | ||
| 
						 | 
					02437a8c72 | ||
| 
						 | 
					958c66b28f | ||
| 
						 | 
					c656190e14 | ||
| 
						 | 
					e914cb210e | ||
| 
						 | 
					94c6af74d2 | ||
| 
						 | 
					ebb82bd66d | ||
| 
						 | 
					66f907eb5d | ||
| 
						 | 
					9ffede2c5c | ||
| 
						 | 
					97172df0dc | ||
| 
						 | 
					c9746b182c | ||
| 
						 | 
					10a2b80ffc | ||
| 
						 | 
					ca0f38255d | ||
| 
						 | 
					0484ac73af | ||
| 
						 | 
					1a712ad3c1 | ||
| 
						 | 
					2d1f483469 | ||
| 
						 | 
					91830e233b | ||
| 
						 | 
					561edb83bf | ||
| 
						 | 
					0e09cf223a | ||
| 
						 | 
					d78360d6eb | ||
| 
						 | 
					1464804c11 | ||
| 
						 | 
					8629eae5fc | ||
| 
						 | 
					7b8ba7c3ac | ||
| 
						 | 
					77c7466c17 | ||
| 
						 | 
					82fe76fd37 | ||
| 
						 | 
					3f81ea4ef8 | 
							
								
								
									
										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://forms.gle/btgdRn9yhGtzEiGW8) form!
 | 
					        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!
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  - type: dropdown
 | 
					  - type: dropdown
 | 
				
			||||||
    attributes:
 | 
					    attributes:
 | 
				
			||||||
@@ -27,6 +27,9 @@ 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'
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										5
									
								
								renovate.json → .github/renovate.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								renovate.json → .github/renovate.json
									
									
									
									
										vendored
									
									
								
							@@ -4,11 +4,10 @@
 | 
				
			|||||||
    "config:base",
 | 
					    "config:base",
 | 
				
			||||||
    ":semanticCommitsDisabled"
 | 
					    ":semanticCommitsDisabled"
 | 
				
			||||||
  ],
 | 
					  ],
 | 
				
			||||||
 | 
					  "automerge": true,
 | 
				
			||||||
  "labels": [
 | 
					  "labels": [
 | 
				
			||||||
    "dependencies"
 | 
					    "dependencies"
 | 
				
			||||||
  ],
 | 
					  ],
 | 
				
			||||||
  "rebaseWhen": "conflicted",
 | 
					  "rebaseWhen": "conflicted",
 | 
				
			||||||
  "schedule": [
 | 
					  "schedule": ["on the first day of the month"]
 | 
				
			||||||
    "on the first day of the week"
 | 
					 | 
				
			||||||
  ]
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -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@08d9328877d6954120eef2b07abbc79249bb6210 # ratchet:Ilshidur/action-discord@0.3.2
 | 
					        uses: Ilshidur/action-discord@0.3.2
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          args: |
 | 
					          args: |
 | 
				
			||||||
            "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>"
 | 
					            "<@&525015541815967744> <@&679322738552471574> <@&699293353862496266>"
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										2
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							@@ -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@55e685c48d84285a5b0418cd094606e199cca3b6 # v1
 | 
					        uses: gradle/wrapper-validation-action@v1
 | 
				
			||||||
      - name: Setup Java
 | 
					      - name: Setup Java
 | 
				
			||||||
        uses: actions/setup-java@v3
 | 
					        uses: actions/setup-java@v3
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										10
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							@@ -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@55e685c48d84285a5b0418cd094606e199cca3b6 # v1
 | 
					        uses: gradle/wrapper-validation-action@v1
 | 
				
			||||||
      - name: Setup Java
 | 
					      - name: Setup Java
 | 
				
			||||||
        uses: actions/setup-java@v3
 | 
					        uses: actions/setup-java@v3
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
@@ -42,8 +42,8 @@ jobs:
 | 
				
			|||||||
          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'}}
 | 
					       # if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}}
 | 
				
			||||||
        uses: cpina/github-action-push-to-another-repository@0a14457bb28b04dfa1652e0ffdfda866d2845c73
 | 
					        uses: cpina/github-action-push-to-another-repository@main
 | 
				
			||||||
        env:
 | 
					        env:
 | 
				
			||||||
          SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }}
 | 
					          SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }}
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
@@ -54,8 +54,8 @@ jobs:
 | 
				
			|||||||
          target-branch: main
 | 
					          target-branch: main
 | 
				
			||||||
          target-directory: v7/core
 | 
					          target-directory: v7/core
 | 
				
			||||||
      - name: Publish bukkit javadoc
 | 
					      - name: Publish bukkit javadoc
 | 
				
			||||||
        if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}}
 | 
					      #  if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/main'}}
 | 
				
			||||||
        uses: cpina/github-action-push-to-another-repository@0a14457bb28b04dfa1652e0ffdfda866d2845c73 # main
 | 
					        uses: cpina/github-action-push-to-another-repository@main
 | 
				
			||||||
        env:
 | 
					        env:
 | 
				
			||||||
          SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }}
 | 
					          SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }}
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										11
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							@@ -21,11 +21,16 @@ jobs:
 | 
				
			|||||||
    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@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2
 | 
					        uses: github/codeql-action/init@v2
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          languages: ${{ matrix.language }}
 | 
					          languages: ${{ matrix.language }}
 | 
				
			||||||
      - name: Autobuild
 | 
					      - name: Autobuild
 | 
				
			||||||
        uses: github/codeql-action/autobuild@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2
 | 
					        uses: github/codeql-action/autobuild@v2
 | 
				
			||||||
      - name: Perform CodeQL Analysis
 | 
					      - name: Perform CodeQL Analysis
 | 
				
			||||||
        uses: github/codeql-action/analyze@32dc499307d133bb5085bae78498c0ac2cf762d5 # v2
 | 
					        uses: github/codeql-action/analyze@v2
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							@@ -137,3 +137,7 @@ docs/
 | 
				
			|||||||
build/
 | 
					build/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
.DS_Store
 | 
					.DS_Store
 | 
				
			||||||
 | 
					# Ignore run folders
 | 
				
			||||||
 | 
					run-[0-0].[0-9]/
 | 
				
			||||||
 | 
					run-[0-0].[0-9].[0-9]/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										154
									
								
								.idea/icon.svg
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										154
									
								
								.idea/icon.svg
									
									
									
										generated
									
									
									
								
							@@ -1,48 +1,144 @@
 | 
				
			|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
 | 
					<?xml version="1.0" encoding="UTF-8" standalone="no"?>
 | 
				
			||||||
<svg xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:cc="http://creativecommons.org/ns#" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:svg="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" version="1.1" id="svg2" xml:space="preserve" width="4000" height="3333.3333" viewBox="0 0 4000 3333.3333" sodipodi:docname="PlotSquared.ai">
 | 
					<svg
 | 
				
			||||||
		<metadata id="metadata8">
 | 
					   version="1.1"
 | 
				
			||||||
 | 
					   id="svg2"
 | 
				
			||||||
 | 
					   xml:space="preserve"
 | 
				
			||||||
 | 
					   width="512"
 | 
				
			||||||
 | 
					   height="512"
 | 
				
			||||||
 | 
					   viewBox="0 0 512 512.00001"
 | 
				
			||||||
 | 
					   sodipodi:docname="icon.svg"
 | 
				
			||||||
 | 
					   inkscape:version="1.1.2 (b8e25be8, 2022-02-05)"
 | 
				
			||||||
 | 
					   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
 | 
				
			||||||
 | 
					   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
 | 
				
			||||||
 | 
					   xmlns="http://www.w3.org/2000/svg"
 | 
				
			||||||
 | 
					   xmlns:svg="http://www.w3.org/2000/svg"
 | 
				
			||||||
 | 
					   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
 | 
				
			||||||
 | 
					   xmlns:cc="http://creativecommons.org/ns#"
 | 
				
			||||||
 | 
					   xmlns:dc="http://purl.org/dc/elements/1.1/">
 | 
				
			||||||
 | 
							<metadata
 | 
				
			||||||
 | 
					   id="metadata8">
 | 
				
			||||||
			<rdf:RDF>
 | 
								<rdf:RDF>
 | 
				
			||||||
				<cc:Work rdf:about="">
 | 
									<cc:Work
 | 
				
			||||||
 | 
					   rdf:about="">
 | 
				
			||||||
					<dc:format>image/svg+xml</dc:format>
 | 
										<dc:format>image/svg+xml</dc:format>
 | 
				
			||||||
                    <dc:type rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
 | 
					                    <dc:type
 | 
				
			||||||
 | 
					   rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
 | 
				
			||||||
				</cc:Work>
 | 
									</cc:Work>
 | 
				
			||||||
			</rdf:RDF>
 | 
								</rdf:RDF>
 | 
				
			||||||
		</metadata>
 | 
							</metadata>
 | 
				
			||||||
    <defs id="defs6">
 | 
					    <defs
 | 
				
			||||||
			<clipPath clipPathUnits="userSpaceOnUse" id="clipPath18">
 | 
					   id="defs6">
 | 
				
			||||||
				<path d="M 0,2500 H 3000 V 0 H 0 Z" id="path16" />
 | 
								<clipPath
 | 
				
			||||||
 | 
					   clipPathUnits="userSpaceOnUse"
 | 
				
			||||||
 | 
					   id="clipPath18">
 | 
				
			||||||
 | 
									<path
 | 
				
			||||||
 | 
					   d="M 0,2500 H 3000 V 0 H 0 Z"
 | 
				
			||||||
 | 
					   id="path16" />
 | 
				
			||||||
			</clipPath>
 | 
								</clipPath>
 | 
				
			||||||
		</defs>
 | 
							</defs>
 | 
				
			||||||
    <sodipodi:namedview pagecolor="#ffffff" bordercolor="#666666" borderopacity="1" objecttolerance="10" gridtolerance="10" guidetolerance="10" inkscape:pageopacity="0" inkscape:pageshadow="2" inkscape:window-width="640" inkscape:window-height="480" id="namedview4" />
 | 
					    <sodipodi:namedview
 | 
				
			||||||
    <g id="g10" inkscape:groupmode="layer" inkscape:label="PlotSquared" transform="matrix(1.3333333,0,0,-1.3333333,0,3333.3333)">
 | 
					   pagecolor="#ffffff"
 | 
				
			||||||
			<g id="g12">
 | 
					   bordercolor="#666666"
 | 
				
			||||||
				<g id="g14" clip-path="url(#clipPath18)">
 | 
					   borderopacity="1"
 | 
				
			||||||
					<g id="g20" transform="translate(1486.1511,2242.6453)">
 | 
					   objecttolerance="10"
 | 
				
			||||||
						<path d="m 0,0 c 16.533,10.846 33.211,21.453 50.104,31.699 78.972,-48.281 153.985,-102.704 227.269,-159.144 148.61,-115.422 287.884,-243.01 414.393,-382.333 111.39,-122.861 212.751,-255.152 298.898,-396.971 52.744,-87.322 100.544,-177.884 139.514,-272.214 -11.638,-3.551 -23.108,-7.655 -34.362,-12.286 l -0.24,0.288 c -11.135,12.982 -24.141,24.212 -34.915,37.506 -22.557,23.013 -45.425,45.737 -68.03,68.678 -19.725,20.253 -40.601,39.45 -58.958,60.974 -36.355,36.451 -72.517,73.093 -108.944,109.471 -22.628,26.013 -48.064,49.385 -71.965,74.197 -19.029,19.485 -38.706,38.346 -57.519,57.999 -12.166,14.998 -26.684,27.716 -39.93,41.658 -27.668,27.524 -54.903,55.479 -82.571,82.979 -23.924,27.956 -51.664,52.264 -76.692,79.164 -4.68,4.487 -8.855,10.774 -15.886,11.326 -22.34,34.027 -58.311,57.327 -97.377,67.502 -104.312,99.153 -215.487,191.202 -332.661,274.782 -117.942,-83.94 -229.476,-176.781 -334.484,-276.39 -26.684,-0.024 -53.368,0.024 -80.076,-0.024 0.024,-26.564 0.048,-53.104 0,-79.668 -72.229,-73.021 -139.491,-150.937 -202.385,-232.092 -63.758,-82.619 -121.973,-169.51 -173.541,-260.264 131.932,-69.061 257.864,-149.521 375.926,-240.275 0.096,-26.444 -0.12,-52.888 0.096,-79.332 l 0.744,-0.984 c 20.109,-24.14 43.409,-45.233 65.126,-67.861 15.118,-15.382 30.571,-30.404 45.569,-45.881 17.565,-20.733 37.698,-39.042 56.607,-58.503 19.917,-20.781 41.25,-40.218 59.967,-62.151 29.156,-29.299 58.167,-58.815 87.515,-87.922 29.155,-33.043 61.502,-63.111 92.169,-94.738 13.726,-12.67 25.124,-27.571 38.634,-40.457 25.029,-25.365 50.129,-50.657 75.325,-75.853 -37.914,-51.208 -73.741,-103.952 -107.192,-158.183 -167.83,273.317 -397.235,507.305 -662.37,687.158 -81.875,55.335 -167.23,105.584 -255.681,149.641 -52.815,26.276 -106.831,50.248 -162.239,70.381 99.393,233.628 242.795,446.715 410.289,636.79 93.562,106.088 194.634,205.433 301.466,298.13 C -217.335,-155.808 -111.439,-73.789 0,0" style="fill:#062f4c;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path22" />
 | 
					   gridtolerance="10"
 | 
				
			||||||
 | 
					   guidetolerance="10"
 | 
				
			||||||
 | 
					   inkscape:pageopacity="0"
 | 
				
			||||||
 | 
					   inkscape:pageshadow="2"
 | 
				
			||||||
 | 
					   inkscape:window-width="1440"
 | 
				
			||||||
 | 
					   inkscape:window-height="900"
 | 
				
			||||||
 | 
					   id="namedview4"
 | 
				
			||||||
 | 
					   inkscape:pagecheckerboard="0"
 | 
				
			||||||
 | 
					   showgrid="false"
 | 
				
			||||||
 | 
					   inkscape:zoom="0.1632"
 | 
				
			||||||
 | 
					   inkscape:cx="1087.6225"
 | 
				
			||||||
 | 
					   inkscape:cy="1666.6666"
 | 
				
			||||||
 | 
					   inkscape:window-x="0"
 | 
				
			||||||
 | 
					   inkscape:window-y="0"
 | 
				
			||||||
 | 
					   inkscape:window-maximized="0"
 | 
				
			||||||
 | 
					   inkscape:current-layer="g10" />
 | 
				
			||||||
 | 
					    <g
 | 
				
			||||||
 | 
					   id="g10"
 | 
				
			||||||
 | 
					   inkscape:groupmode="layer"
 | 
				
			||||||
 | 
					   inkscape:label="PlotSquared"
 | 
				
			||||||
 | 
					   transform="matrix(1.3333333,0,0,-1.3333333,0,3333.3333)">
 | 
				
			||||||
 | 
								<g
 | 
				
			||||||
 | 
					   id="g12"
 | 
				
			||||||
 | 
					   transform="matrix(0.16955078,0,0,0.16955078,-68.456969,2101.8529)">
 | 
				
			||||||
 | 
									<g
 | 
				
			||||||
 | 
					   id="g14"
 | 
				
			||||||
 | 
					   clip-path="url(#clipPath18)">
 | 
				
			||||||
 | 
										<g
 | 
				
			||||||
 | 
					   id="g20"
 | 
				
			||||||
 | 
					   transform="translate(1486.1511,2242.6453)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 16.533,10.846 33.211,21.453 50.104,31.699 78.972,-48.281 153.985,-102.704 227.269,-159.144 148.61,-115.422 287.884,-243.01 414.393,-382.333 111.39,-122.861 212.751,-255.152 298.898,-396.971 52.744,-87.322 100.544,-177.884 139.514,-272.214 -11.638,-3.551 -23.108,-7.655 -34.362,-12.286 l -0.24,0.288 c -11.135,12.982 -24.141,24.212 -34.915,37.506 -22.557,23.013 -45.425,45.737 -68.03,68.678 -19.725,20.253 -40.601,39.45 -58.958,60.974 -36.355,36.451 -72.517,73.093 -108.944,109.471 -22.628,26.013 -48.064,49.385 -71.965,74.197 -19.029,19.485 -38.706,38.346 -57.519,57.999 -12.166,14.998 -26.684,27.716 -39.93,41.658 -27.668,27.524 -54.903,55.479 -82.571,82.979 -23.924,27.956 -51.664,52.264 -76.692,79.164 -4.68,4.487 -8.855,10.774 -15.886,11.326 -22.34,34.027 -58.311,57.327 -97.377,67.502 -104.312,99.153 -215.487,191.202 -332.661,274.782 -117.942,-83.94 -229.476,-176.781 -334.484,-276.39 -26.684,-0.024 -53.368,0.024 -80.076,-0.024 0.024,-26.564 0.048,-53.104 0,-79.668 -72.229,-73.021 -139.491,-150.937 -202.385,-232.092 -63.758,-82.619 -121.973,-169.51 -173.541,-260.264 131.932,-69.061 257.864,-149.521 375.926,-240.275 0.096,-26.444 -0.12,-52.888 0.096,-79.332 l 0.744,-0.984 c 20.109,-24.14 43.409,-45.233 65.126,-67.861 15.118,-15.382 30.571,-30.404 45.569,-45.881 17.565,-20.733 37.698,-39.042 56.607,-58.503 19.917,-20.781 41.25,-40.218 59.967,-62.151 29.156,-29.299 58.167,-58.815 87.515,-87.922 29.155,-33.043 61.502,-63.111 92.169,-94.738 13.726,-12.67 25.124,-27.571 38.634,-40.457 25.029,-25.365 50.129,-50.657 75.325,-75.853 -37.914,-51.208 -73.741,-103.952 -107.192,-158.183 -167.83,273.317 -397.235,507.305 -662.37,687.158 -81.875,55.335 -167.23,105.584 -255.681,149.641 -52.815,26.276 -106.831,50.248 -162.239,70.381 99.393,233.628 242.795,446.715 410.289,636.79 93.562,106.088 194.634,205.433 301.466,298.13 C -217.335,-155.808 -111.439,-73.789 0,0"
 | 
				
			||||||
 | 
					   style="fill:#062f4c;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path22" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g24" transform="translate(1201.7948,1741.5303)">
 | 
					                    <g
 | 
				
			||||||
						<path d="M 0,0 C 105.008,99.609 216.543,192.45 334.485,276.39 451.659,192.81 562.833,100.76 667.146,1.608 c -34.987,8.83 -71.51,9.718 -107.264,6.431 -41.202,-4.296 -82.907,-19.077 -112.543,-48.953 -33.019,-32.155 -49.456,-77.604 -55.311,-122.501 -28.124,27.908 -56.104,55.983 -84.035,84.083 -2.976,2.976 -6.839,4.823 -10.391,6.911 -19.029,26.348 -45.953,46.673 -76.62,57.495 C 187.555,-2.472 151.513,-0.12 116.166,0 Z" style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path26" />
 | 
					   id="g24"
 | 
				
			||||||
 | 
					   transform="translate(1201.7948,1741.5303)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="M 0,0 C 105.008,99.609 216.543,192.45 334.485,276.39 451.659,192.81 562.833,100.76 667.146,1.608 c -34.987,8.83 -71.51,9.718 -107.264,6.431 -41.202,-4.296 -82.907,-19.077 -112.543,-48.953 -33.019,-32.155 -49.456,-77.604 -55.311,-122.501 -28.124,27.908 -56.104,55.983 -84.035,84.083 -2.976,2.976 -6.839,4.823 -10.391,6.911 -19.029,26.348 -45.953,46.673 -76.62,57.495 C 187.555,-2.472 151.513,-0.12 116.166,0 Z"
 | 
				
			||||||
 | 
					   style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path26" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g28" transform="translate(919.3342,1429.7462)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 c 62.894,81.156 130.156,159.072 202.385,232.092 0.048,-244.21 0.024,-488.421 0,-732.631 C 84.323,-409.785 -41.61,-329.325 -173.541,-260.264 -121.973,-169.51 -63.758,-82.619 0,0" style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path30" />
 | 
					   id="g28"
 | 
				
			||||||
 | 
					   transform="translate(919.3342,1429.7462)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 62.894,81.156 130.156,159.072 202.385,232.092 0.048,-244.21 0.024,-488.421 0,-732.631 C 84.323,-409.785 -41.61,-329.325 -173.541,-260.264 -121.973,-169.51 -63.758,-82.619 0,0"
 | 
				
			||||||
 | 
					   style="fill:#4c8fcc;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path30" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g32" transform="translate(1649.134,1700.6166)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 c 29.635,29.875 71.341,44.657 112.543,48.952 35.754,3.288 72.277,2.4 107.263,-6.431 39.066,-10.174 75.037,-33.474 97.377,-67.501 11.879,-17.661 20.181,-37.411 26.42,-57.687 10.871,-38.802 11.95,-79.356 11.446,-119.358 -44.345,-0.072 -88.69,0.048 -133.035,-0.072 -1.032,30.907 3.263,63.686 -10.175,92.626 -9.526,20.325 -32.107,31.243 -53.751,32.131 -21.453,1.44 -45.065,-4.32 -59.175,-21.597 -12.79,-15.861 -15.382,-37.002 -16.558,-56.655 -1.295,-29.132 3.696,-59.031 17.518,-84.923 16.821,-30.619 39.378,-57.783 64.526,-81.9 31.387,-32.634 67.501,-60.374 97.857,-94.041 27.332,-28.988 51.256,-61.479 68.005,-97.785 20.541,-41.13 26.972,-87.827 25.82,-133.372 -0.912,-32.107 -5.231,-64.406 -16.149,-94.737 -11.59,-31.699 -31.123,-61.047 -58.335,-81.371 -25.124,-19.125 -55.696,-29.852 -86.651,-34.771 -49.552,-6.743 -101.888,-4.847 -148.465,14.854 -35.227,14.829 -64.238,42.689 -81.708,76.548 -20.996,40.242 -27.115,86.339 -27.259,131.212 0.048,17.829 0,35.658 0.048,53.463 44.345,0.048 88.69,-0.023 133.059,0.048 1.728,-35.538 -4.055,-72.06 5.663,-106.807 5.783,-22.173 26.204,-37.794 48.185,-41.754 20.733,-3.431 43.577,-2.015 61.622,9.791 15.502,9.43 23.949,26.78 26.78,44.225 5.903,35.922 1.872,74.293 -15.381,106.688 -16.918,30.595 -39.474,57.711 -64.55,81.899 -33.187,34.099 -71.173,63.254 -102.585,99.081 -26.756,28.867 -49.408,61.646 -65.486,97.641 -24.572,52.48 -26.731,112.422 -20.18,169.102 C -49.456,-77.604 -33.019,-32.155 0,0" style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path34" />
 | 
					   id="g32"
 | 
				
			||||||
 | 
					   transform="translate(1649.134,1700.6166)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 29.635,29.875 71.341,44.657 112.543,48.952 35.754,3.288 72.277,2.4 107.263,-6.431 39.066,-10.174 75.037,-33.474 97.377,-67.501 11.879,-17.661 20.181,-37.411 26.42,-57.687 10.871,-38.802 11.95,-79.356 11.446,-119.358 -44.345,-0.072 -88.69,0.048 -133.035,-0.072 -1.032,30.907 3.263,63.686 -10.175,92.626 -9.526,20.325 -32.107,31.243 -53.751,32.131 -21.453,1.44 -45.065,-4.32 -59.175,-21.597 -12.79,-15.861 -15.382,-37.002 -16.558,-56.655 -1.295,-29.132 3.696,-59.031 17.518,-84.923 16.821,-30.619 39.378,-57.783 64.526,-81.9 31.387,-32.634 67.501,-60.374 97.857,-94.041 27.332,-28.988 51.256,-61.479 68.005,-97.785 20.541,-41.13 26.972,-87.827 25.82,-133.372 -0.912,-32.107 -5.231,-64.406 -16.149,-94.737 -11.59,-31.699 -31.123,-61.047 -58.335,-81.371 -25.124,-19.125 -55.696,-29.852 -86.651,-34.771 -49.552,-6.743 -101.888,-4.847 -148.465,14.854 -35.227,14.829 -64.238,42.689 -81.708,76.548 -20.996,40.242 -27.115,86.339 -27.259,131.212 0.048,17.829 0,35.658 0.048,53.463 44.345,0.048 88.69,-0.023 133.059,0.048 1.728,-35.538 -4.055,-72.06 5.663,-106.807 5.783,-22.173 26.204,-37.794 48.185,-41.754 20.733,-3.431 43.577,-2.015 61.622,9.791 15.502,9.43 23.949,26.78 26.78,44.225 5.903,35.922 1.872,74.293 -15.381,106.688 -16.918,30.595 -39.474,57.711 -64.55,81.899 -33.187,34.099 -71.173,63.254 -102.585,99.081 -26.756,28.867 -49.408,61.646 -65.486,97.641 -24.572,52.48 -26.731,112.422 -20.18,169.102 C -49.456,-77.604 -33.019,-32.155 0,0"
 | 
				
			||||||
 | 
					   style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path34" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g36" transform="translate(1262.7214,1613.126)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 v -301.13 c 23.204,0.024 46.409,-0.048 69.613,0.024 18.525,0.288 38.202,6.575 50.153,21.429 12.43,17.277 13.917,39.522 14.613,60.111 0.024,43.985 -0.048,87.994 0.024,131.979 -0.48,23.637 -0.983,50.369 -17.277,69.23 C 104.864,-5.711 86.867,-0.24 69.589,0 46.385,0.048 23.204,0.024 0,0 m -141.002,128.38 c 26.708,0.048 53.392,0 80.075,0.024 H 55.24 c 35.346,-0.12 71.389,-2.471 104.815,-14.925 30.668,-10.823 57.592,-31.148 76.621,-57.496 26.852,-39.09 36.69,-87.202 38.058,-133.947 0.024,-48.833 0.096,-97.689 -0.024,-146.521 -1.728,-47.993 -11.974,-97.953 -41.514,-136.971 -22.748,-30.644 -57.495,-50.801 -94.281,-59.583 -45.377,-11.878 -92.578,-6.791 -138.891,-7.847 -0.072,-111.799 0,-223.574 -0.024,-335.373 -13.942,0 -27.86,0.024 -41.778,-0.024 -32.802,0.072 -65.605,0 -98.384,0.048 l -0.744,0.984 c -0.216,26.444 0,52.888 -0.096,79.332 0.024,244.211 0.048,488.421 0,732.632 0.048,26.563 0.024,53.103 0,79.667" style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path38" />
 | 
					   id="g36"
 | 
				
			||||||
 | 
					   transform="translate(1262.7214,1613.126)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 v -301.13 c 23.204,0.024 46.409,-0.048 69.613,0.024 18.525,0.288 38.202,6.575 50.153,21.429 12.43,17.277 13.917,39.522 14.613,60.111 0.024,43.985 -0.048,87.994 0.024,131.979 -0.48,23.637 -0.983,50.369 -17.277,69.23 C 104.864,-5.711 86.867,-0.24 69.589,0 46.385,0.048 23.204,0.024 0,0 m -141.002,128.38 c 26.708,0.048 53.392,0 80.075,0.024 H 55.24 c 35.346,-0.12 71.389,-2.471 104.815,-14.925 30.668,-10.823 57.592,-31.148 76.621,-57.496 26.852,-39.09 36.69,-87.202 38.058,-133.947 0.024,-48.833 0.096,-97.689 -0.024,-146.521 -1.728,-47.993 -11.974,-97.953 -41.514,-136.971 -22.748,-30.644 -57.495,-50.801 -94.281,-59.583 -45.377,-11.878 -92.578,-6.791 -138.891,-7.847 -0.072,-111.799 0,-223.574 -0.024,-335.373 -13.942,0 -27.86,0.024 -41.778,-0.024 -32.802,0.072 -65.605,0 -98.384,0.048 l -0.744,0.984 c -0.216,26.444 0,52.888 -0.096,79.332 0.024,244.211 0.048,488.421 0,732.632 0.048,26.563 0.024,53.103 0,79.667"
 | 
				
			||||||
 | 
					   style="fill:#feeeee;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path38" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g40" transform="translate(1966.3174,1675.6364)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 c 7.031,-0.552 11.206,-6.839 15.885,-11.326 25.029,-26.9 52.768,-51.208 76.693,-79.164 27.667,-27.5 54.903,-55.456 82.571,-82.979 13.246,-13.942 27.764,-26.66 39.93,-41.658 18.813,-19.653 38.49,-38.514 57.519,-57.999 23.9,-24.812 49.337,-48.185 71.965,-74.197 36.427,-36.378 72.589,-73.02 108.943,-109.471 18.358,-21.524 39.234,-40.722 58.959,-60.974 22.605,-22.941 45.473,-45.665 68.03,-68.678 10.774,-13.294 23.78,-24.524 34.914,-37.506 -103.904,-41.97 -203.488,-94.114 -298.922,-152.761 -246.994,-152.28 -466.224,-350.298 -639.333,-583.398 -25.197,25.196 -50.297,50.488 -75.325,75.852 -13.51,12.886 -24.908,27.788 -38.634,40.458 -30.667,31.627 -63.014,61.695 -92.17,94.738 -29.347,29.107 -58.359,58.623 -87.514,87.922 -18.717,21.933 -40.05,41.37 -59.967,62.151 -18.909,19.461 -39.042,37.77 -56.607,58.503 -14.998,15.477 -30.452,30.499 -45.569,45.88 -21.717,22.629 -45.017,43.722 -65.126,67.862 32.779,-0.048 65.582,0.024 98.384,-0.048 114.391,-98.097 220.407,-205.984 315.384,-322.99 92.914,114.318 196.242,220.022 307.753,316.271 30.955,4.919 61.526,15.646 86.65,34.771 27.212,20.325 46.745,49.672 58.335,81.371 107.312,77.988 219.327,149.929 337.509,210.376 -35.299,64.67 -75.829,126.437 -118.254,186.643 C 176.253,-228.037 104.24,-140.115 26.42,-57.687 20.181,-37.41 11.878,-17.661 0,0" style="fill:#042338;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path42" />
 | 
					   id="g40"
 | 
				
			||||||
 | 
					   transform="translate(1966.3174,1675.6364)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 7.031,-0.552 11.206,-6.839 15.885,-11.326 25.029,-26.9 52.768,-51.208 76.693,-79.164 27.667,-27.5 54.903,-55.456 82.571,-82.979 13.246,-13.942 27.764,-26.66 39.93,-41.658 18.813,-19.653 38.49,-38.514 57.519,-57.999 23.9,-24.812 49.337,-48.185 71.965,-74.197 36.427,-36.378 72.589,-73.02 108.943,-109.471 18.358,-21.524 39.234,-40.722 58.959,-60.974 22.605,-22.941 45.473,-45.665 68.03,-68.678 10.774,-13.294 23.78,-24.524 34.914,-37.506 -103.904,-41.97 -203.488,-94.114 -298.922,-152.761 -246.994,-152.28 -466.224,-350.298 -639.333,-583.398 -25.197,25.196 -50.297,50.488 -75.325,75.852 -13.51,12.886 -24.908,27.788 -38.634,40.458 -30.667,31.627 -63.014,61.695 -92.17,94.738 -29.347,29.107 -58.359,58.623 -87.514,87.922 -18.717,21.933 -40.05,41.37 -59.967,62.151 -18.909,19.461 -39.042,37.77 -56.607,58.503 -14.998,15.477 -30.452,30.499 -45.569,45.88 -21.717,22.629 -45.017,43.722 -65.126,67.862 32.779,-0.048 65.582,0.024 98.384,-0.048 114.391,-98.097 220.407,-205.984 315.384,-322.99 92.914,114.318 196.242,220.022 307.753,316.271 30.955,4.919 61.526,15.646 86.65,34.771 27.212,20.325 46.745,49.672 58.335,81.371 107.312,77.988 219.327,149.929 337.509,210.376 -35.299,64.67 -75.829,126.437 -118.254,186.643 C 176.253,-228.037 104.24,-140.115 26.42,-57.687 20.181,-37.41 11.878,-17.661 0,0"
 | 
				
			||||||
 | 
					   style="fill:#042338;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path42" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g44" transform="translate(1499.3971,1669.1094)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 c 3.551,-2.088 7.415,-3.935 10.39,-6.911 27.932,-28.1 55.912,-56.175 84.036,-84.083 -6.551,-56.679 -4.392,-116.622 20.18,-169.102 16.078,-35.994 38.73,-68.774 65.486,-97.641 31.412,-35.826 69.398,-64.982 102.585,-99.081 25.076,-24.188 47.632,-51.304 64.55,-81.899 17.253,-32.395 21.284,-70.765 15.381,-106.688 -2.831,-17.445 -11.278,-34.794 -26.78,-44.225 -18.045,-11.806 -40.889,-13.222 -61.622,-9.79 -21.981,3.959 -42.402,19.58 -48.185,41.753 -9.718,34.747 -3.935,71.269 -5.663,106.808 -44.369,-0.072 -88.714,0 -133.059,-0.048 -0.048,-17.806 0,-35.635 -0.048,-53.464 0.144,-44.873 6.263,-90.97 27.259,-131.212 17.47,-33.859 46.481,-61.718 81.708,-76.548 46.577,-19.701 98.913,-21.597 148.465,-14.854 -111.511,-96.249 -214.839,-201.953 -307.753,-316.271 -94.977,117.006 -200.993,224.893 -315.383,322.99 13.918,0.048 27.836,0.024 41.777,0.024 0.024,111.799 -0.048,223.574 0.024,335.372 46.313,1.056 93.514,-4.031 138.891,7.847 36.786,8.783 71.533,28.94 94.282,59.583 29.539,39.018 39.785,88.978 41.513,136.971 0.12,48.833 0.048,97.689 0.024,146.522 C 36.69,-87.203 26.852,-39.09 0,0" style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path46" />
 | 
					   id="g44"
 | 
				
			||||||
 | 
					   transform="translate(1499.3971,1669.1094)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 3.551,-2.088 7.415,-3.935 10.39,-6.911 27.932,-28.1 55.912,-56.175 84.036,-84.083 -6.551,-56.679 -4.392,-116.622 20.18,-169.102 16.078,-35.994 38.73,-68.774 65.486,-97.641 31.412,-35.826 69.398,-64.982 102.585,-99.081 25.076,-24.188 47.632,-51.304 64.55,-81.899 17.253,-32.395 21.284,-70.765 15.381,-106.688 -2.831,-17.445 -11.278,-34.794 -26.78,-44.225 -18.045,-11.806 -40.889,-13.222 -61.622,-9.79 -21.981,3.959 -42.402,19.58 -48.185,41.753 -9.718,34.747 -3.935,71.269 -5.663,106.808 -44.369,-0.072 -88.714,0 -133.059,-0.048 -0.048,-17.806 0,-35.635 -0.048,-53.464 0.144,-44.873 6.263,-90.97 27.259,-131.212 17.47,-33.859 46.481,-61.718 81.708,-76.548 46.577,-19.701 98.913,-21.597 148.465,-14.854 -111.511,-96.249 -214.839,-201.953 -307.753,-316.271 -94.977,117.006 -200.993,224.893 -315.383,322.99 13.918,0.048 27.836,0.024 41.777,0.024 0.024,111.799 -0.048,223.574 0.024,335.372 46.313,1.056 93.514,-4.031 138.891,7.847 36.786,8.783 71.533,28.94 94.282,59.583 29.539,39.018 39.785,88.978 41.513,136.971 0.12,48.833 0.048,97.689 0.024,146.522 C 36.69,-87.203 26.852,-39.09 0,0"
 | 
				
			||||||
 | 
					   style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path46" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g48" transform="translate(1748.0469,1601.6797)">
 | 
					                    <g
 | 
				
			||||||
						<path d="M 0,0 C 14.11,17.277 37.722,23.036 59.175,21.597 80.82,20.709 103.4,9.791 112.927,-10.534 c 13.438,-28.94 9.142,-61.719 10.174,-92.626 44.345,0.12 88.691,0 133.036,0.072 0.504,40.002 -0.576,80.556 -11.447,119.358 77.82,-82.428 149.833,-170.35 215.583,-262.664 42.426,-60.207 82.956,-121.973 118.254,-186.643 -118.182,-60.447 -230.196,-132.388 -337.508,-210.376 10.918,30.331 15.238,62.63 16.149,94.737 1.152,45.545 -5.279,92.242 -25.82,133.372 -16.749,36.306 -40.673,68.797 -68.005,97.785 -30.355,33.667 -66.47,61.406 -97.857,94.041 -25.148,24.117 -47.705,51.28 -64.526,81.9 -13.822,25.892 -18.813,55.791 -17.517,84.923 C -15.382,-37.002 -12.79,-15.862 0,0" style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path50" />
 | 
					   id="g48"
 | 
				
			||||||
 | 
					   transform="translate(1748.0469,1601.6797)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="M 0,0 C 14.11,17.277 37.722,23.036 59.175,21.597 80.82,20.709 103.4,9.791 112.927,-10.534 c 13.438,-28.94 9.142,-61.719 10.174,-92.626 44.345,0.12 88.691,0 133.036,0.072 0.504,40.002 -0.576,80.556 -11.447,119.358 77.82,-82.428 149.833,-170.35 215.583,-262.664 42.426,-60.207 82.956,-121.973 118.254,-186.643 -118.182,-60.447 -230.196,-132.388 -337.508,-210.376 10.918,30.331 15.238,62.63 16.149,94.737 1.152,45.545 -5.279,92.242 -25.82,133.372 -16.749,36.306 -40.673,68.797 -68.005,97.785 -30.355,33.667 -66.47,61.406 -97.857,94.041 -25.148,24.117 -47.705,51.28 -64.526,81.9 -13.822,25.892 -18.813,55.791 -17.517,84.923 C -15.382,-37.002 -12.79,-15.862 0,0"
 | 
				
			||||||
 | 
					   style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path50" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
                    <g id="g52" transform="translate(1262.7214,1613.126)">
 | 
					                    <g
 | 
				
			||||||
						<path d="m 0,0 c 23.204,0.024 46.385,0.048 69.589,0 17.278,-0.24 35.275,-5.711 47.537,-18.357 16.294,-18.861 16.797,-45.593 17.277,-69.23 -0.072,-43.985 0,-87.994 -0.024,-131.979 -0.696,-20.589 -2.183,-42.834 -14.613,-60.111 -11.951,-14.854 -31.628,-21.141 -50.153,-21.429 -23.204,-0.072 -46.409,0 -69.613,-0.024 z" style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none" id="path54" />
 | 
					   id="g52"
 | 
				
			||||||
 | 
					   transform="translate(1262.7214,1613.126)">
 | 
				
			||||||
 | 
											<path
 | 
				
			||||||
 | 
					   d="m 0,0 c 23.204,0.024 46.385,0.048 69.589,0 17.278,-0.24 35.275,-5.711 47.537,-18.357 16.294,-18.861 16.797,-45.593 17.277,-69.23 -0.072,-43.985 0,-87.994 -0.024,-131.979 -0.696,-20.589 -2.183,-42.834 -14.613,-60.111 -11.951,-14.854 -31.628,-21.141 -50.153,-21.429 -23.204,-0.072 -46.409,0 -69.613,-0.024 z"
 | 
				
			||||||
 | 
					   style="fill:#1c72ba;fill-opacity:1;fill-rule:nonzero;stroke:none"
 | 
				
			||||||
 | 
					   id="path54" />
 | 
				
			||||||
					</g>
 | 
										</g>
 | 
				
			||||||
				</g>
 | 
									</g>
 | 
				
			||||||
			</g>
 | 
								</g>
 | 
				
			||||||
 
 | 
				
			|||||||
| 
		 Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 12 KiB  | 
@@ -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,6 +62,7 @@ tasks.processResources {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
tasks.named<ShadowJar>("shadowJar") {
 | 
					tasks.named<ShadowJar>("shadowJar") {
 | 
				
			||||||
 | 
					    dependsOn(":plotsquared-core:shadowJar")
 | 
				
			||||||
    dependencies {
 | 
					    dependencies {
 | 
				
			||||||
        exclude(dependency("org.checkerframework:"))
 | 
					        exclude(dependency("org.checkerframework:"))
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -102,7 +103,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.12.0/")
 | 
					        opt.links("https://jd.advntr.dev/api/4.14.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
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -50,7 +50,6 @@ 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.TranslationUpdateManager;
 | 
					import com.plotsquared.bukkit.util.TranslationUpdateManager;
 | 
				
			||||||
import com.plotsquared.bukkit.util.UpdateUtility;
 | 
					 | 
				
			||||||
import com.plotsquared.bukkit.util.task.BukkitTaskManager;
 | 
					import com.plotsquared.bukkit.util.task.BukkitTaskManager;
 | 
				
			||||||
import com.plotsquared.bukkit.util.task.PaperTimeConverter;
 | 
					import com.plotsquared.bukkit.util.task.PaperTimeConverter;
 | 
				
			||||||
import com.plotsquared.bukkit.util.task.SpigotTimeConverter;
 | 
					import com.plotsquared.bukkit.util.task.SpigotTimeConverter;
 | 
				
			||||||
@@ -303,9 +302,11 @@ 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());
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -34,9 +34,12 @@ 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;
 | 
				
			||||||
@@ -48,10 +51,14 @@ 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());
 | 
				
			||||||
@@ -284,7 +291,7 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    @SuppressWarnings("deprecation") // The entire method is deprecated, but kept for compatibility with <=1.16.2
 | 
					    @SuppressWarnings("deprecation") // The entire method is deprecated, but kept for compatibility with <=1.16.2
 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
    @Deprecated(since = "TODO")
 | 
					    @Deprecated(since = "7.0.0")
 | 
				
			||||||
    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
 | 
				
			||||||
    ) {
 | 
					    ) {
 | 
				
			||||||
@@ -414,7 +421,11 @@ 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;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        PlotArea area = UncheckedWorldLocation.at(name, chunkX << 4, 0, chunkZ << 4).getPlotArea();
 | 
					        BlockVector3 loc = BlockVector3.at(chunkX << 4, 0, chunkZ << 4);
 | 
				
			||||||
 | 
					        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",
 | 
				
			||||||
@@ -434,9 +445,16 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap
 | 
				
			|||||||
        private static final List<Biome> BIOMES;
 | 
					        private static final List<Biome> BIOMES;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        static {
 | 
					        static {
 | 
				
			||||||
            ArrayList<Biome> biomes = new ArrayList<>(List.of(Biome.values()));
 | 
					            Set<Biome> disabledBiomes = EnumSet.of(Biome.CUSTOM);
 | 
				
			||||||
            biomes.remove(Biome.CUSTOM);
 | 
					            if (PlotSquared.platform().serverVersion()[1] <= 19) {
 | 
				
			||||||
            BIOMES = List.copyOf(biomes);
 | 
					                final Biome cherryGrove = Registry.BIOME.get(NamespacedKey.minecraft("cherry_grove"));
 | 
				
			||||||
 | 
					                if (cherryGrove != null) {
 | 
				
			||||||
 | 
					                    disabledBiomes.add(cherryGrove);
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            BIOMES = Arrays.stream(Biome.values())
 | 
				
			||||||
 | 
					                    .filter(not(disabledBiomes::contains))
 | 
				
			||||||
 | 
					                    .toList();
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        @Override
 | 
					        @Override
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1116,6 +1116,7 @@ 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,6 +26,7 @@ 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;
 | 
				
			||||||
@@ -96,12 +97,12 @@ public class BlockEventListener117 implements Listener {
 | 
				
			|||||||
                area,
 | 
					                area,
 | 
				
			||||||
                MiscInteractFlag.class,
 | 
					                MiscInteractFlag.class,
 | 
				
			||||||
                true
 | 
					                true
 | 
				
			||||||
        ) || plot != null && !plot.getFlag(
 | 
					        ) || plot != null && (!plot.getFlag(MiscInteractFlag.class) || !plot.getFlag(SculkSensorInteractFlag.class))) {
 | 
				
			||||||
                MiscInteractFlag.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 misc-interact = false");
 | 
					                        plot.debug(plotPlayer.getName() + " couldn't trigger sculk sensors because both " +
 | 
				
			||||||
 | 
					                                "sculk-sensor-interact and misc-interact = false");
 | 
				
			||||||
                        event.setCancelled(true);
 | 
					                        event.setCancelled(true);
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
@@ -112,13 +113,15 @@ 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 misc-interact = false and the item's owner could not be resolved.");
 | 
					                                "A thrown item couldn't trigger sculk sensors because both sculk-sensor-interact and " +
 | 
				
			||||||
 | 
					                                        "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 misc-interact = false");
 | 
					                            plot.debug("A thrown item couldn't trigger sculk sensors because both sculk-sensor-interact and " +
 | 
				
			||||||
 | 
					                                    "misc-interact = false");
 | 
				
			||||||
                            event.setCancelled(true);
 | 
					                            event.setCancelled(true);
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
@@ -137,7 +140,6 @@ 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);
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -152,7 +152,8 @@ public class EntityEventListener implements Listener {
 | 
				
			|||||||
                }
 | 
					                }
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL",
 | 
					            case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL",
 | 
				
			||||||
                    "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN" -> {
 | 
					                    "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN", "NETHER_PORTAL", "DEFAULT",
 | 
				
			||||||
 | 
					                    "DUPLICATION", "FROZEN", "SPELL" -> {
 | 
				
			||||||
                if (!area.isMobSpawning()) {
 | 
					                if (!area.isMobSpawning()) {
 | 
				
			||||||
                    event.setCancelled(true);
 | 
					                    event.setCancelled(true);
 | 
				
			||||||
                    return;
 | 
					                    return;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -176,6 +176,10 @@ public class BukkitPlayer extends PlotPlayer<Player> {
 | 
				
			|||||||
            final Set<PermissionAttachmentInfo> effective = player.getEffectivePermissions();
 | 
					            final Set<PermissionAttachmentInfo> effective = player.getEffectivePermissions();
 | 
				
			||||||
            if (!effective.isEmpty()) {
 | 
					            if (!effective.isEmpty()) {
 | 
				
			||||||
                for (PermissionAttachmentInfo attach : effective) {
 | 
					                for (PermissionAttachmentInfo attach : effective) {
 | 
				
			||||||
 | 
					                    // Ignore all "false" permissions
 | 
				
			||||||
 | 
					                    if (!attach.getValue()) {
 | 
				
			||||||
 | 
					                        continue;
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
                    String permStr = attach.getPermission();
 | 
					                    String permStr = attach.getPermission();
 | 
				
			||||||
                    if (permStr.startsWith(stubPlus)) {
 | 
					                    if (permStr.startsWith(stubPlus)) {
 | 
				
			||||||
                        hasAny = true;
 | 
					                        hasAny = true;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -18,6 +18,8 @@
 | 
				
			|||||||
 */
 | 
					 */
 | 
				
			||||||
package com.plotsquared.bukkit.schematic;
 | 
					package com.plotsquared.bukkit.schematic;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import com.destroystokyo.paper.profile.PlayerProfile;
 | 
				
			||||||
 | 
					import com.destroystokyo.paper.profile.ProfileProperty;
 | 
				
			||||||
import com.plotsquared.bukkit.util.BukkitUtil;
 | 
					import com.plotsquared.bukkit.util.BukkitUtil;
 | 
				
			||||||
import com.sk89q.jnbt.ByteTag;
 | 
					import com.sk89q.jnbt.ByteTag;
 | 
				
			||||||
import com.sk89q.jnbt.CompoundTag;
 | 
					import com.sk89q.jnbt.CompoundTag;
 | 
				
			||||||
@@ -28,13 +30,20 @@ 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;
 | 
				
			||||||
@@ -45,11 +54,15 @@ import java.util.HashMap;
 | 
				
			|||||||
import java.util.List;
 | 
					import java.util.List;
 | 
				
			||||||
import java.util.Map;
 | 
					import java.util.Map;
 | 
				
			||||||
import java.util.Map.Entry;
 | 
					import java.util.Map.Entry;
 | 
				
			||||||
 | 
					import java.util.Objects;
 | 
				
			||||||
 | 
					import java.util.UUID;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public class StateWrapper {
 | 
					public class StateWrapper {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public org.bukkit.block.BlockState state = null;
 | 
					    public CompoundTag tag;
 | 
				
			||||||
    public CompoundTag tag = null;
 | 
					
 | 
				
			||||||
 | 
					    private boolean paperErrorTextureSent = false;
 | 
				
			||||||
 | 
					    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;
 | 
				
			||||||
@@ -227,9 +240,8 @@ public class StateWrapper {
 | 
				
			|||||||
                        return true;
 | 
					                        return true;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                    String player = skullOwner.getString("Name");
 | 
					                    String player = skullOwner.getString("Name");
 | 
				
			||||||
                    if (player == null || player.isEmpty()) {
 | 
					
 | 
				
			||||||
                        return false;
 | 
					                    if (player != null && !player.isEmpty()) {
 | 
				
			||||||
                    }
 | 
					 | 
				
			||||||
                        try {
 | 
					                        try {
 | 
				
			||||||
                            skull.setOwningPlayer(Bukkit.getOfflinePlayer(player));
 | 
					                            skull.setOwningPlayer(Bukkit.getOfflinePlayer(player));
 | 
				
			||||||
                            skull.update(true);
 | 
					                            skull.update(true);
 | 
				
			||||||
@@ -238,6 +250,56 @@ public class StateWrapper {
 | 
				
			|||||||
                        }
 | 
					                        }
 | 
				
			||||||
                        return true;
 | 
					                        return true;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                    final CompoundTag properties = (CompoundTag) skullOwner.getValue().get("Properties");
 | 
				
			||||||
 | 
					                    if (properties == null) {
 | 
				
			||||||
 | 
					                        return false;
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
 | 
					                    final ListTag textures = properties.getListTag("textures");
 | 
				
			||||||
 | 
					                    if (textures.getValue().isEmpty()) {
 | 
				
			||||||
 | 
					                        return false;
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
 | 
					                    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 false;
 | 
					                return false;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -28,24 +28,32 @@ import java.nio.file.Paths;
 | 
				
			|||||||
import java.util.stream.Stream;
 | 
					import java.util.stream.Stream;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * This is a helper class which replaces occurrences of 'suggest_command' with 'run_command' in messages_%.json.
 | 
					 * This is a helper class which replaces older syntax no longer supported by MiniMessage with replacements 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 TODO
 | 
					 * @since 7.0.0
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
@NotPublic
 | 
					@NotPublic
 | 
				
			||||||
public class TranslationUpdateManager {
 | 
					public class TranslationUpdateManager {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public static void upgradeTranslationFile() throws IOException {
 | 
					    public static void upgradeTranslationFile() throws IOException {
 | 
				
			||||||
        String searchText = "suggest_command";
 | 
					        String suggestCommand = "suggest_command";
 | 
				
			||||||
        String replacementText = "run_command";
 | 
					        String suggestCommandReplacement = "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 -> replaceInFile(p, searchText, replacementText));
 | 
					                    .forEach(p -> {
 | 
				
			||||||
 | 
					                        replaceInFile(p, suggestCommand, suggestCommandReplacement);
 | 
				
			||||||
 | 
					                        replaceInFile(p, minHeight, minheightReplacement);
 | 
				
			||||||
 | 
					                        replaceInFile(p, maxHeight, maxheightReplacement);
 | 
				
			||||||
 | 
					                    });
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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.12.0/")
 | 
					        opt.links("https://jd.advntr.dev/api/4.14.0/")
 | 
				
			||||||
        opt.links("https://jd.advntr.dev/text-minimessage/4.12.0/")
 | 
					        opt.links("https://jd.advntr.dev/text-minimessage/4.14.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/")
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -296,10 +296,13 @@ 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 = (sizeX * sizeZ) * cost;
 | 
					            cost = size * cost + mergeCost;
 | 
				
			||||||
            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"));
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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);
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
            });
 | 
					            });
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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("errors.invalid_player"),
 | 
					                                TranslatableCaption.of("kick.player_not_in_plot"),
 | 
				
			||||||
                                TagResolver.resolver("value", Tag.inserting(Component.text(args[0])))
 | 
					                                TagResolver.resolver("player", Tag.inserting(Component.text(player2.getName())))
 | 
				
			||||||
                        );
 | 
					                        );
 | 
				
			||||||
                        return;
 | 
					                        return;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                    if (player2.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_DENIED)) {
 | 
					                    if (player2.hasPermission(Permission.PERMISSION_ADMIN_ENTRY_DENIED)) {
 | 
				
			||||||
                        player.sendMessage(
 | 
					                        player.sendMessage(
 | 
				
			||||||
                                TranslatableCaption.of("cluster.cannot_kick_player"),
 | 
					                                TranslatableCaption.of("kick.cannot_kick_player"),
 | 
				
			||||||
                                TagResolver.resolver("name", Tag.inserting(Component.text(player2.getName())))
 | 
					                                TagResolver.resolver("player", Tag.inserting(Component.text(player2.getName())))
 | 
				
			||||||
                        );
 | 
					                        );
 | 
				
			||||||
                        return;
 | 
					                        return;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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_pigstep", "music_disc_5", "music_disc_relic"
 | 
				
			||||||
            );
 | 
					            );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private final InventoryUtil inventoryUtil;
 | 
					    private final InventoryUtil inventoryUtil;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -40,7 +40,7 @@ public interface Caption {
 | 
				
			|||||||
     *
 | 
					     *
 | 
				
			||||||
     * @param localeHolder Locale holder
 | 
					     * @param localeHolder Locale holder
 | 
				
			||||||
     * @return {@link ComponentLike}
 | 
					     * @return {@link ComponentLike}
 | 
				
			||||||
     * @since TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    @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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public void setTagResolvers(TagResolver... tagResolvers) {
 | 
					    public void setTagResolvers(TagResolver... tagResolvers) {
 | 
				
			||||||
        this.tagResolvers = tagResolvers;
 | 
					        this.tagResolvers = tagResolvers;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -28,16 +28,20 @@ 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,
 | 
				
			||||||
@@ -100,7 +104,14 @@ 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 = MiniMessage.miniMessage().deserialize(miniMessageString);
 | 
					        Component component;
 | 
				
			||||||
 | 
					        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);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -19,6 +19,7 @@
 | 
				
			|||||||
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;
 | 
				
			||||||
@@ -30,6 +31,7 @@ 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,6 +21,7 @@ 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;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -30,6 +31,7 @@ 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());
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -379,10 +379,11 @@ 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 = classicPlotWorld.getMinBuildHeight(); y <= classicPlotWorld.WALL_HEIGHT; y++) {
 | 
					                for (int y = yStart; y <= classicPlotWorld.WALL_HEIGHT; y++) {
 | 
				
			||||||
                    queue.setBlock(x, y, z, blocks);
 | 
					                    queue.setBlock(x, y, z, blocks);
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
@@ -390,7 +391,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 = classicPlotWorld.getMinBuildHeight(); y <= classicPlotWorld.WALL_HEIGHT; y++) {
 | 
					                for (int y = yStart; y <= classicPlotWorld.WALL_HEIGHT; y++) {
 | 
				
			||||||
                    queue.setBlock(x, y, z, blocks);
 | 
					                    queue.setBlock(x, y, z, blocks);
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
@@ -398,7 +399,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 = classicPlotWorld.getMinBuildHeight(); y <= classicPlotWorld.WALL_HEIGHT; y++) {
 | 
					                for (int y = yStart; y <= classicPlotWorld.WALL_HEIGHT; y++) {
 | 
				
			||||||
                    queue.setBlock(x, y, z, blocks);
 | 
					                    queue.setBlock(x, y, z, blocks);
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
@@ -406,7 +407,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 = classicPlotWorld.getMinBuildHeight(); y <= classicPlotWorld.WALL_HEIGHT; y++) {
 | 
					                for (int y = yStart; y <= classicPlotWorld.WALL_HEIGHT; y++) {
 | 
				
			||||||
                    queue.setBlock(x, y, z, blocks);
 | 
					                    queue.setBlock(x, y, z, blocks);
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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);
 | 
				
			||||||
        if ((features.contains(SchematicFeature.ROAD) && Settings.Schematics.PASTE_ROAD_ON_TOP)
 | 
					        boolean isRoad = features.contains(SchematicFeature.ROAD);
 | 
				
			||||||
                || (!features.contains(SchematicFeature.ROAD) && Settings.Schematics.PASTE_ON_TOP)) {
 | 
					        if ((isRoad && Settings.Schematics.PASTE_ROAD_ON_TOP) || (!isRoad && Settings.Schematics.PASTE_ON_TOP)) {
 | 
				
			||||||
            minY = world.SCHEM_Y;
 | 
					            minY = world.SCHEM_Y;
 | 
				
			||||||
        } else {
 | 
					        } else {
 | 
				
			||||||
            minY = world.getMinBuildHeight();
 | 
					            minY = world.getMinBuildHeight();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -162,6 +162,7 @@ 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);
 | 
				
			||||||
@@ -178,10 +179,14 @@ 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 (!isRoad) {
 | 
					                        } else if (y > schemYDiff) {
 | 
				
			||||||
                            // 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.
 | 
				
			||||||
                            //  Do not set air for road as this may cause cavernous roads when debugroadregen is used
 | 
					                            // This should only be done where the schematic has actually "started"
 | 
				
			||||||
                            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());
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -76,6 +76,9 @@ 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;
 | 
				
			||||||
@@ -252,13 +255,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 without causing AIOOB
 | 
					        // plotY and roadY are important to allow plot and/or road schematic "overflow" into each other
 | 
				
			||||||
        //  exceptions when attempting either to set blocks to, or get block from G_SCH
 | 
					        // without causing AIOOB 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.
 | 
				
			||||||
        int plotY = PLOT_HEIGHT - SCHEM_Y;
 | 
					        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.
 | 
				
			||||||
        int roadY = minRoadWall - SCHEM_Y;
 | 
					        roadY = minRoadWall - SCHEM_Y;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        int worldGenHeight = getMaxGenHeight() - getMinGenHeight() + 1;
 | 
					        int worldGenHeight = getMaxGenHeight() - getMinGenHeight() + 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -267,14 +270,15 @@ 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 = maxSchematicHeight = schematic3.getClipboard().getDimensions().getY();
 | 
					            plotSchemHeight = schematic3.getClipboard().getDimensions().getY();
 | 
				
			||||||
            if (maxSchematicHeight == worldGenHeight) {
 | 
					            if (plotSchemHeight == 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 = getMinBuildHeight();
 | 
					                SCHEM_Y = getMinBuildHeight();
 | 
				
			||||||
                plotY = 0;
 | 
					                plotY = 0;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					            maxSchematicHeight = plotY + plotSchemHeight;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        int roadSchemHeight;
 | 
					        int roadSchemHeight;
 | 
				
			||||||
@@ -323,7 +327,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 || h3 > PLOT_WIDTH) {
 | 
					            if (w3 > PLOT_WIDTH || l3 > PLOT_WIDTH) {
 | 
				
			||||||
                this.ROAD_SCHEMATIC_ENABLED = true;
 | 
					                this.ROAD_SCHEMATIC_ENABLED = true;
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            int centerShiftZ;
 | 
					            int centerShiftZ;
 | 
				
			||||||
@@ -378,7 +382,7 @@ public class HybridPlotWorld extends ClassicPlotWorld {
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
        if ((schematic1 == null && schematic2 == null) || this.ROAD_WIDTH == 0) {
 | 
					        if ((schematic1 == null && schematic2 == null) || this.ROAD_WIDTH == 0) {
 | 
				
			||||||
            if (Settings.DEBUG) {
 | 
					            if (Settings.DEBUG) {
 | 
				
			||||||
                LOGGER.info("- schematic: false");
 | 
					                LOGGER.info("- road schematic: false");
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
@@ -554,4 +558,24 @@ 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;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -668,7 +668,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 = Settings.Schematics.PASTE_ROAD_ON_TOP ? plotWorld.SCHEM_Y : area.getMinGenHeight() + 1;
 | 
					                        int minY = plotWorld.getRoadYStart();
 | 
				
			||||||
                        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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public abstract void generateChunk(ZeroedDelegateScopedQueueCoordinator result, PlotArea settings, boolean biomes);
 | 
					    public abstract void generateChunk(ZeroedDelegateScopedQueueCoordinator result, PlotArea settings, boolean biomes);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -55,7 +55,7 @@ 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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public void populateChunk(ZeroedDelegateScopedQueueCoordinator result, PlotArea setting) {
 | 
					    public void populateChunk(ZeroedDelegateScopedQueueCoordinator result, PlotArea setting) {
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -108,7 +108,7 @@ public abstract class IndependentPlotGenerator {
 | 
				
			|||||||
     * @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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public abstract BiomeType getBiome(PlotArea settings, int x, int y, int z);
 | 
					    public abstract BiomeType getBiome(PlotArea settings, int x, int y, int z);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,7 +20,6 @@ package com.plotsquared.core.plot;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import com.google.common.collect.ImmutableSet;
 | 
					import com.google.common.collect.ImmutableSet;
 | 
				
			||||||
import com.google.common.collect.Lists;
 | 
					import com.google.common.collect.Lists;
 | 
				
			||||||
import com.google.common.collect.Sets;
 | 
					 | 
				
			||||||
import com.google.inject.Inject;
 | 
					import com.google.inject.Inject;
 | 
				
			||||||
import com.plotsquared.core.PlotSquared;
 | 
					import com.plotsquared.core.PlotSquared;
 | 
				
			||||||
import com.plotsquared.core.command.Like;
 | 
					import com.plotsquared.core.command.Like;
 | 
				
			||||||
@@ -2418,7 +2417,6 @@ public class Plot {
 | 
				
			|||||||
        if (!this.isMerged()) {
 | 
					        if (!this.isMerged()) {
 | 
				
			||||||
            Location pos1 = this.getBottomAbs().withY(getArea().getMinBuildHeight());
 | 
					            Location pos1 = this.getBottomAbs().withY(getArea().getMinBuildHeight());
 | 
				
			||||||
            Location pos2 = this.getTopAbs().withY(getArea().getMaxBuildHeight());
 | 
					            Location pos2 = this.getTopAbs().withY(getArea().getMaxBuildHeight());
 | 
				
			||||||
            this.connectedCache = Sets.newHashSet(this);
 | 
					 | 
				
			||||||
            CuboidRegion rg = new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3());
 | 
					            CuboidRegion rg = new CuboidRegion(pos1.getBlockVector3(), pos2.getBlockVector3());
 | 
				
			||||||
            return Collections.singleton(rg);
 | 
					            return Collections.singleton(rg);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -657,9 +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))
 | 
					                                    Tag.inserting(Component.text(maxBuildHeight))
 | 
				
			||||||
                            ).build()
 | 
					                            ).build()
 | 
				
			||||||
            );
 | 
					            );
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -91,6 +91,7 @@ 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;
 | 
				
			||||||
@@ -172,6 +173,7 @@ 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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    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));
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -0,0 +1,39 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * 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;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -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 HashMap<>();
 | 
					    private final Map<String, PlotWorld> plotWorlds = new ConcurrentHashMap<>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    boolean addWorld(@NonNull String worldName);
 | 
					    boolean addWorld(@NonNull String worldName);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -66,7 +66,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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    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 TODO
 | 
					 * @since 7.0.0
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    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,11 +25,17 @@ import com.plotsquared.core.plot.PlotAreaTerrainType;
 | 
				
			|||||||
import com.plotsquared.core.plot.PlotAreaType;
 | 
					import com.plotsquared.core.plot.PlotAreaType;
 | 
				
			||||||
import com.plotsquared.core.plot.PlotId;
 | 
					import com.plotsquared.core.plot.PlotId;
 | 
				
			||||||
import com.plotsquared.core.util.SetupUtils;
 | 
					import com.plotsquared.core.util.SetupUtils;
 | 
				
			||||||
 | 
					import org.jetbrains.annotations.Contract;
 | 
				
			||||||
 | 
					import org.jetbrains.annotations.NotNull;
 | 
				
			||||||
 | 
					import org.jetbrains.annotations.Nullable;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import java.util.Objects;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public class PlotAreaBuilder {
 | 
					public class PlotAreaBuilder {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    private String generatorName;
 | 
					    private String generatorName;
 | 
				
			||||||
    private String plotManager;
 | 
					    private String plotManager;
 | 
				
			||||||
 | 
					    @Nullable
 | 
				
			||||||
    private PlotAreaType plotAreaType;
 | 
					    private PlotAreaType plotAreaType;
 | 
				
			||||||
    private PlotAreaTerrainType terrainType;
 | 
					    private PlotAreaTerrainType terrainType;
 | 
				
			||||||
    private String worldName;
 | 
					    private String worldName;
 | 
				
			||||||
@@ -85,8 +91,10 @@ public class PlotAreaBuilder {
 | 
				
			|||||||
        return this.plotManager;
 | 
					        return this.plotManager;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @NotNull
 | 
				
			||||||
 | 
					    @Contract(" -> !null")
 | 
				
			||||||
    public PlotAreaType plotAreaType() {
 | 
					    public PlotAreaType plotAreaType() {
 | 
				
			||||||
        return this.plotAreaType;
 | 
					        return Objects.requireNonNullElse(this.plotAreaType, PlotAreaType.NORMAL);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public PlotAreaTerrainType terrainType() {
 | 
					    public PlotAreaTerrainType terrainType() {
 | 
				
			||||||
@@ -127,7 +135,8 @@ public class PlotAreaBuilder {
 | 
				
			|||||||
        return this;
 | 
					        return this;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public PlotAreaBuilder plotAreaType(PlotAreaType plotAreaType) {
 | 
					    public PlotAreaBuilder plotAreaType(@NotNull PlotAreaType plotAreaType) {
 | 
				
			||||||
 | 
					        Objects.requireNonNull(plotAreaType, "PlotAreaType must not be null");
 | 
				
			||||||
        this.plotAreaType = plotAreaType;
 | 
					        this.plotAreaType = plotAreaType;
 | 
				
			||||||
        return this;
 | 
					        return this;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    public static void setChunkInPlotArea(
 | 
					    public static void setChunkInPlotArea(
 | 
				
			||||||
            RunnableVal<ZeroedDelegateScopedQueueCoordinator> force,
 | 
					            RunnableVal<ZeroedDelegateScopedQueueCoordinator> force,
 | 
				
			||||||
@@ -76,7 +76,7 @@ public abstract class ChunkManager {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /**
 | 
					    /**
 | 
				
			||||||
     * @since TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    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);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -27,7 +27,7 @@ import java.util.Collection;
 | 
				
			|||||||
/**
 | 
					/**
 | 
				
			||||||
 * A utility class for modifying components.
 | 
					 * A utility class for modifying components.
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * @since TODO
 | 
					 * @since 7.0.0
 | 
				
			||||||
 */
 | 
					 */
 | 
				
			||||||
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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    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 TODO
 | 
					     * @since 7.0.0
 | 
				
			||||||
     */
 | 
					     */
 | 
				
			||||||
    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();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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 that player: </red><gray><name></gray>",
 | 
					  "cluster.cannot_kick_player": "<prefix><red>You cannot kick the player <gray><name></gray>.</red>",
 | 
				
			||||||
  "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,6 +411,8 @@
 | 
				
			|||||||
  "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>",
 | 
				
			||||||
@@ -486,7 +488,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 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>",
 | 
					  "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>",
 | 
				
			||||||
  "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>",
 | 
				
			||||||
@@ -572,6 +574,7 @@
 | 
				
			|||||||
  "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>",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,7 @@
 | 
				
			|||||||
import com.diffplug.gradle.spotless.SpotlessPlugin
 | 
					import com.diffplug.gradle.spotless.SpotlessPlugin
 | 
				
			||||||
import com.github.jengelman.gradle.plugins.shadow.ShadowPlugin
 | 
					import com.github.jengelman.gradle.plugins.shadow.ShadowPlugin
 | 
				
			||||||
import java.net.URI
 | 
					import java.net.URI
 | 
				
			||||||
 | 
					import xyz.jpenilla.runpaper.task.RunServer
 | 
				
			||||||
 | 
					
 | 
				
			||||||
plugins {
 | 
					plugins {
 | 
				
			||||||
    java
 | 
					    java
 | 
				
			||||||
@@ -15,9 +16,11 @@ plugins {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    eclipse
 | 
					    eclipse
 | 
				
			||||||
    idea
 | 
					    idea
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    id("xyz.jpenilla.run-paper") version "2.1.0"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
group = "com.plotsquared"
 | 
					group = "com.intellectualsites.plotsquared"
 | 
				
			||||||
version = "7.0.0-SNAPSHOT"
 | 
					version = "7.0.0-SNAPSHOT"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if (!File("$rootDir/.git").exists()) {
 | 
					if (!File("$rootDir/.git").exists()) {
 | 
				
			||||||
@@ -74,12 +77,12 @@ subprojects {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    dependencies {
 | 
					    dependencies {
 | 
				
			||||||
        implementation(platform("com.intellectualsites.bom:bom-newest:1.24"))
 | 
					        implementation(platform("com.intellectualsites.bom:bom-newest:1.31"))
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    dependencies {
 | 
					    dependencies {
 | 
				
			||||||
        // Tests
 | 
					        // Tests
 | 
				
			||||||
        testImplementation("org.junit.jupiter:junit-jupiter:5.9.2")
 | 
					        testImplementation("org.junit.jupiter:junit-jupiter:5.9.3")
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    plugins.withId("java") {
 | 
					    plugins.withId("java") {
 | 
				
			||||||
@@ -207,7 +210,7 @@ subprojects {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
nexusPublishing {
 | 
					nexusPublishing {
 | 
				
			||||||
    repositories {
 | 
					    this.repositories {
 | 
				
			||||||
        sonatype {
 | 
					        sonatype {
 | 
				
			||||||
            nexusUrl.set(URI.create("https://s01.oss.sonatype.org/service/local/"))
 | 
					            nexusUrl.set(URI.create("https://s01.oss.sonatype.org/service/local/"))
 | 
				
			||||||
            snapshotRepositoryUrl.set(URI.create("https://s01.oss.sonatype.org/content/repositories/snapshots/"))
 | 
					            snapshotRepositoryUrl.set(URI.create("https://s01.oss.sonatype.org/content/repositories/snapshots/"))
 | 
				
			||||||
@@ -218,3 +221,17 @@ nexusPublishing {
 | 
				
			|||||||
tasks.getByName<Jar>("jar") {
 | 
					tasks.getByName<Jar>("jar") {
 | 
				
			||||||
    enabled = false
 | 
					    enabled = false
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					val supportedVersions = listOf("1.16.5", "1.17", "1.17.1", "1.18.2", "1.19", "1.19.1", "1.19.2", "1.19.3", "1.19.4", "1.20")
 | 
				
			||||||
 | 
					tasks {
 | 
				
			||||||
 | 
					    supportedVersions.forEach {
 | 
				
			||||||
 | 
					        register<RunServer>("runServer-$it") {
 | 
				
			||||||
 | 
					            minecraftVersion(it)
 | 
				
			||||||
 | 
					            pluginJars(*project(":plotsquared-bukkit").getTasksByName("shadowJar", false).map { (it as Jar).archiveFile }
 | 
				
			||||||
 | 
					                    .toTypedArray())
 | 
				
			||||||
 | 
					            jvmArgs("-DPaper.IgnoreJavaVersion=true", "-Dcom.mojang.eula.agree=true")
 | 
				
			||||||
 | 
					            group = "run paper"
 | 
				
			||||||
 | 
					            runDirectory.set(file("run-$it"))
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,26 +1,26 @@
 | 
				
			|||||||
[versions]
 | 
					[versions]
 | 
				
			||||||
# Platform expectations
 | 
					# Platform expectations
 | 
				
			||||||
guice = "5.1.0"
 | 
					guice = "7.0.0"
 | 
				
			||||||
spotbugs = "4.7.3"
 | 
					spotbugs = "4.7.3"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Plugins
 | 
					# Plugins
 | 
				
			||||||
worldedit = "7.2.13"
 | 
					worldedit = "7.2.15"
 | 
				
			||||||
placeholderapi = "2.11.2"
 | 
					placeholderapi = "2.11.3"
 | 
				
			||||||
luckperms = "5.4"
 | 
					luckperms = "5.4"
 | 
				
			||||||
essentialsx = "2.19.7"
 | 
					essentialsx = "2.20.0"
 | 
				
			||||||
mvdwapi = "3.1.1"
 | 
					mvdwapi = "3.1.1"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Third party
 | 
					# Third party
 | 
				
			||||||
prtree = "2.0.1"
 | 
					prtree = "2.0.1"
 | 
				
			||||||
aopalliance = "1.0"
 | 
					aopalliance = "1.0"
 | 
				
			||||||
cloud-services = "1.8.2"
 | 
					cloud-services = "1.8.3"
 | 
				
			||||||
arkitektonika = "2.1.2"
 | 
					arkitektonika = "2.1.2"
 | 
				
			||||||
squirrelid = "0.3.1"
 | 
					squirrelid = "0.3.2"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Gradle plugins
 | 
					# Gradle plugins
 | 
				
			||||||
shadow = "7.1.2"
 | 
					shadow = "8.1.1"
 | 
				
			||||||
grgit = "4.1.1"
 | 
					grgit = "4.1.1"
 | 
				
			||||||
spotless = "6.16.0"
 | 
					spotless = "6.19.0"
 | 
				
			||||||
nexus = "1.3.0"
 | 
					nexus = "1.3.0"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[libraries]
 | 
					[libraries]
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										3
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							@@ -1,6 +1,7 @@
 | 
				
			|||||||
distributionBase=GRADLE_USER_HOME
 | 
					distributionBase=GRADLE_USER_HOME
 | 
				
			||||||
distributionPath=wrapper/dists
 | 
					distributionPath=wrapper/dists
 | 
				
			||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.6.1-bin.zip
 | 
					distributionUrl=https\://services.gradle.org/distributions/gradle-8.2-bin.zip
 | 
				
			||||||
networkTimeout=10000
 | 
					networkTimeout=10000
 | 
				
			||||||
 | 
					validateDistributionUrl=true
 | 
				
			||||||
zipStoreBase=GRADLE_USER_HOME
 | 
					zipStoreBase=GRADLE_USER_HOME
 | 
				
			||||||
zipStorePath=wrapper/dists
 | 
					zipStorePath=wrapper/dists
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										12
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							@@ -85,9 +85,6 @@ done
 | 
				
			|||||||
APP_BASE_NAME=${0##*/}
 | 
					APP_BASE_NAME=${0##*/}
 | 
				
			||||||
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
 | 
					APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
 | 
					 | 
				
			||||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Use the maximum available, or set MAX_FD != -1 to use that value.
 | 
					# Use the maximum available, or set MAX_FD != -1 to use that value.
 | 
				
			||||||
MAX_FD=maximum
 | 
					MAX_FD=maximum
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -133,10 +130,13 @@ location of your Java installation."
 | 
				
			|||||||
    fi
 | 
					    fi
 | 
				
			||||||
else
 | 
					else
 | 
				
			||||||
    JAVACMD=java
 | 
					    JAVACMD=java
 | 
				
			||||||
    which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
 | 
					    if ! command -v java >/dev/null 2>&1
 | 
				
			||||||
 | 
					    then
 | 
				
			||||||
 | 
					        die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Please set the JAVA_HOME variable in your environment to match the
 | 
					Please set the JAVA_HOME variable in your environment to match the
 | 
				
			||||||
location of your Java installation."
 | 
					location of your Java installation."
 | 
				
			||||||
 | 
					    fi
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Increase the maximum file descriptors if we can.
 | 
					# Increase the maximum file descriptors if we can.
 | 
				
			||||||
@@ -197,6 +197,10 @@ if "$cygwin" || "$msys" ; then
 | 
				
			|||||||
    done
 | 
					    done
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
 | 
				
			||||||
 | 
					DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Collect all arguments for the java command;
 | 
					# Collect all arguments for the java command;
 | 
				
			||||||
#   * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of
 | 
					#   * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of
 | 
				
			||||||
#     shell script including quotes and variable substitutions, so put them in
 | 
					#     shell script including quotes and variable substitutions, so put them in
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2,7 +2,7 @@ rootProject.name = "PlotSquared"
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
include("Core", "Bukkit")
 | 
					include("Core", "Bukkit")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
project(":Core").name = "PlotSquared-Core"
 | 
					project(":Core").name = "plotsquared-core"
 | 
				
			||||||
project(":Bukkit").name = "PlotSquared-Bukkit"
 | 
					project(":Bukkit").name = "plotsquared-bukkit"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
enableFeaturePreview("TYPESAFE_PROJECT_ACCESSORS")
 | 
					enableFeaturePreview("TYPESAFE_PROJECT_ACCESSORS")
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user