mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-25 23:53:44 +02:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			fix/v6/imp
			...
			build/mast
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 576ee735a5 | 
							
								
								
									
										7
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.github/ISSUE_TEMPLATE/bug_report.yml
									
									
									
									
										vendored
									
									
								
							| @@ -27,13 +27,14 @@ 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.19.2' |  | ||||||
|         - '1.19.1' |  | ||||||
|         - '1.19' |  | ||||||
|         - '1.18.2' |         - '1.18.2' | ||||||
|         - '1.18.1' |         - '1.18.1' | ||||||
|  |         - '1.18' | ||||||
|         - '1.17.1' |         - '1.17.1' | ||||||
|         - '1.16.5' |         - '1.16.5' | ||||||
|  |         - '1.15.2' | ||||||
|  |         - '1.14.4' | ||||||
|  |         - '1.13.2' | ||||||
|     validations: |     validations: | ||||||
|       required: true |       required: true | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										24
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										24
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -40,27 +40,3 @@ jobs: | |||||||
|         env: |         env: | ||||||
|           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} |           ORG_GRADLE_PROJECT_sonatypeUsername: ${{ secrets.SONATYPE_USERNAME }} | ||||||
|           ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} |           ORG_GRADLE_PROJECT_sonatypePassword: ${{ secrets.SONATYPE_PASSWORD }} | ||||||
|       - name: Publish core javadoc |  | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} |  | ||||||
|         uses: cpina/github-action-push-to-another-repository@main |  | ||||||
|         env: |  | ||||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} |  | ||||||
|         with: |  | ||||||
|           source-directory: 'Core/build/docs/javadoc' |  | ||||||
|           destination-github-username: 'IntellectualSites' |  | ||||||
|           destination-repository-name: 'plotsquared-javadocs' |  | ||||||
|           user-email: ${{ secrets.USER_EMAIL }} |  | ||||||
|           target-branch: main |  | ||||||
|           target-directory: core |  | ||||||
|       - name: Publish bukkit javadoc |  | ||||||
|         if: ${{ runner.os == 'Linux' && env.STATUS == 'release' && github.event_name == 'push' && github.ref == 'refs/heads/v6'}} |  | ||||||
|         uses: cpina/github-action-push-to-another-repository@main |  | ||||||
|         env: |  | ||||||
|           SSH_DEPLOY_KEY: ${{ secrets.SSH_DEPLOY_KEY }} |  | ||||||
|         with: |  | ||||||
|           source-directory: 'Bukkit/build/docs/javadoc' |  | ||||||
|           destination-github-username: 'IntellectualSites' |  | ||||||
|           destination-repository-name: 'plotsquared-javadocs' |  | ||||||
|           user-email: ${{ secrets.USER_EMAIL }} |  | ||||||
|           target-branch: main |  | ||||||
|           target-directory: bukkit |  | ||||||
|   | |||||||
| @@ -21,20 +21,20 @@ dependencies { | |||||||
|     api(projects.plotSquaredCore) |     api(projects.plotSquaredCore) | ||||||
|  |  | ||||||
|     // Metrics |     // Metrics | ||||||
|     implementation("org.bstats:bstats-bukkit") |     implementation(libs.bstats) | ||||||
|  |  | ||||||
|     // Paper |     // Paper | ||||||
|     compileOnly(libs.paper) |     compileOnly(libs.paper) | ||||||
|     implementation("io.papermc:paperlib") |     implementation(libs.paperlib) | ||||||
|  |  | ||||||
|     // Plugins |     // Plugins | ||||||
|     compileOnly(libs.worldeditBukkit) { |     compileOnly(libs.worldeditBukkit) { | ||||||
|         exclude(group = "org.bukkit") |         exclude(group = "org.bukkit") | ||||||
|         exclude(group = "org.spigotmc") |         exclude(group = "org.spigotmc") | ||||||
|     } |     } | ||||||
|     compileOnly("com.fastasyncworldedit:FastAsyncWorldEdit-Bukkit") { isTransitive = false } |     compileOnly(libs.fastasyncworldeditBukkit) { isTransitive = false } | ||||||
|     testImplementation("com.fastasyncworldedit:FastAsyncWorldEdit-Bukkit") { isTransitive = false } |     testImplementation(libs.fastasyncworldeditBukkit) { isTransitive = false } | ||||||
|     compileOnly("com.github.MilkBowl:VaultAPI") { |     compileOnly(libs.vault) { | ||||||
|         exclude(group = "org.bukkit") |         exclude(group = "org.bukkit") | ||||||
|     } |     } | ||||||
|     compileOnly(libs.placeholderapi) |     compileOnly(libs.placeholderapi) | ||||||
| @@ -44,16 +44,15 @@ dependencies { | |||||||
|  |  | ||||||
|     // Other libraries |     // Other libraries | ||||||
|     implementation(libs.squirrelid) { isTransitive = false } |     implementation(libs.squirrelid) { isTransitive = false } | ||||||
|     implementation("dev.notmyfault.serverlib:ServerLib") |     implementation(libs.serverlib) | ||||||
|  |  | ||||||
|     // Our libraries |     // Our libraries | ||||||
|     implementation(libs.arkitektonika) |     implementation(libs.arkitektonika) | ||||||
|     implementation(libs.http4j) |     implementation(libs.http4j) | ||||||
|     implementation("com.intellectualsites.paster:Paster") |     implementation(libs.paster) | ||||||
|     implementation("com.intellectualsites.informative-annotations:informative-annotations") |  | ||||||
|  |  | ||||||
|     // Adventure |     // Adventure | ||||||
|     implementation("net.kyori:adventure-platform-bukkit") |     implementation(libs.adventurePlatformBukkit) | ||||||
| } | } | ||||||
|  |  | ||||||
| tasks.processResources { | tasks.processResources { | ||||||
| @@ -88,7 +87,6 @@ tasks.named<ShadowJar>("shadowJar") { | |||||||
|     relocate("javax.inject", "com.plotsquared.core.annotation.inject") |     relocate("javax.inject", "com.plotsquared.core.annotation.inject") | ||||||
|     relocate("net.jcip", "com.plotsquared.core.annotations.jcip") |     relocate("net.jcip", "com.plotsquared.core.annotations.jcip") | ||||||
|     relocate("edu.umd.cs.findbugs", "com.plotsquared.core.annotations.findbugs") |     relocate("edu.umd.cs.findbugs", "com.plotsquared.core.annotations.findbugs") | ||||||
|     relocate("com.intellectualsites.informative-annotations", "com.plotsquared.core.annotation.informative") |  | ||||||
|  |  | ||||||
|     // Get rid of all the libs which are 100% unused. |     // Get rid of all the libs which are 100% unused. | ||||||
|     minimize() |     minimize() | ||||||
| @@ -99,12 +97,11 @@ tasks.named<ShadowJar>("shadowJar") { | |||||||
| tasks { | tasks { | ||||||
|     withType<Javadoc> { |     withType<Javadoc> { | ||||||
|         val opt = options as StandardJavadocDocletOptions |         val opt = options as StandardJavadocDocletOptions | ||||||
|         opt.links("https://jd.papermc.io/paper/1.18/") |         opt.links("https://papermc.io/javadocs/paper/1.18/") | ||||||
|         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://javadoc.io/doc/com.plotsquared/PlotSquared-Core/latest/") | ||||||
|         opt.links("https://jd.adventure.kyori.net/api/4.9.3/") |         opt.links("https://jd.adventure.kyori.net/api/" + libs.adventure.get().versionConstraint.toString()) | ||||||
|         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.encoding("UTF-8") |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -41,7 +48,6 @@ import com.plotsquared.bukkit.listener.PlayerEventListener; | |||||||
| import com.plotsquared.bukkit.listener.ProjectileEventListener; | import com.plotsquared.bukkit.listener.ProjectileEventListener; | ||||||
| import com.plotsquared.bukkit.listener.ServerListener; | import com.plotsquared.bukkit.listener.ServerListener; | ||||||
| import com.plotsquared.bukkit.listener.SingleWorldListener; | import com.plotsquared.bukkit.listener.SingleWorldListener; | ||||||
| import com.plotsquared.bukkit.listener.SpigotListener; |  | ||||||
| import com.plotsquared.bukkit.listener.WorldEvents; | import com.plotsquared.bukkit.listener.WorldEvents; | ||||||
| import com.plotsquared.bukkit.placeholder.PAPIPlaceholders; | import com.plotsquared.bukkit.placeholder.PAPIPlaceholders; | ||||||
| import com.plotsquared.bukkit.placeholder.PlaceholderFormatter; | import com.plotsquared.bukkit.placeholder.PlaceholderFormatter; | ||||||
| @@ -264,7 +270,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|  |  | ||||||
|         final PlotSquared plotSquared = new PlotSquared(this, "Bukkit"); |         final PlotSquared plotSquared = new PlotSquared(this, "Bukkit"); | ||||||
|  |  | ||||||
|         // FastAsyncWorldEdit |         // FAWE | ||||||
|         if (Settings.FAWE_Components.FAWE_HOOK) { |         if (Settings.FAWE_Components.FAWE_HOOK) { | ||||||
|             Plugin fawe = getServer().getPluginManager().getPlugin("FastAsyncWorldEdit"); |             Plugin fawe = getServer().getPluginManager().getPlugin("FastAsyncWorldEdit"); | ||||||
|             if (fawe != null) { |             if (fawe != null) { | ||||||
| @@ -272,7 +278,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                     Class.forName("com.fastasyncworldedit.bukkit.regions.plotsquared.FaweQueueCoordinator"); |                     Class.forName("com.fastasyncworldedit.bukkit.regions.plotsquared.FaweQueueCoordinator"); | ||||||
|                     faweHook = true; |                     faweHook = true; | ||||||
|                 } catch (Exception ignored) { |                 } catch (Exception ignored) { | ||||||
|                     LOGGER.error("Incompatible version of FastAsyncWorldEdit to enable hook, please upgrade: https://ci.athion" + |                     LOGGER.error("Incompatible version of FAWE to enable hook, please upgrade: https://ci.athion" + | ||||||
|                             ".net/job/FastAsyncWorldEdit/"); |                             ".net/job/FastAsyncWorldEdit/"); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -361,8 +367,6 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|                 } else { |                 } else { | ||||||
|                     getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener.class), this); |                     getServer().getPluginManager().registerEvents(injector().getInstance(PaperListener.class), this); | ||||||
|                 } |                 } | ||||||
|             } else { |  | ||||||
|                 getServer().getPluginManager().registerEvents(injector().getInstance(SpigotListener.class), this); |  | ||||||
|             } |             } | ||||||
|             this.plotListener.startRunnable(); |             this.plotListener.startRunnable(); | ||||||
|         } |         } | ||||||
| @@ -428,7 +432,7 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|  |  | ||||||
|         plotSquared.startExpiryTasks(); |         plotSquared.startExpiryTasks(); | ||||||
|  |  | ||||||
|         // Once the server has loaded force updating all generators known to PlotSquared |         // Once the server has loaded force updating all generators known to P2 | ||||||
|         TaskManager.runTaskLater(() -> PlotSquared.platform().setupUtils().updateGenerators(true), TaskTime.ticks(1L)); |         TaskManager.runTaskLater(() -> PlotSquared.platform().setupUtils().updateGenerators(true), TaskTime.ticks(1L)); | ||||||
|  |  | ||||||
|         // Services are accessed in order |         // Services are accessed in order | ||||||
| @@ -659,15 +663,20 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|             final @NonNull SQLiteUUIDService sqLiteUUIDService, |             final @NonNull SQLiteUUIDService sqLiteUUIDService, | ||||||
|             final @NonNull CacheUUIDService cacheUUIDService |             final @NonNull CacheUUIDService cacheUUIDService | ||||||
|     ) { |     ) { | ||||||
|         // Record all unique UUID's and put them into a queue |         // Load all uuids into a big chunky boi queue | ||||||
|         final Set<UUID> uuidSet = new HashSet<>(); |         final Queue<UUID> uuidQueue = new LinkedBlockingQueue<>(); | ||||||
|         PlotSquared.get().forEachPlotRaw(plot -> { |         PlotSquared.get().forEachPlotRaw(plot -> { | ||||||
|             uuidSet.add(plot.getOwnerAbs()); |             final Set<UUID> uuids = new HashSet<>(); | ||||||
|             uuidSet.addAll(plot.getMembers()); |             uuids.add(plot.getOwnerAbs()); | ||||||
|             uuidSet.addAll(plot.getTrusted()); |             uuids.addAll(plot.getMembers()); | ||||||
|             uuidSet.addAll(plot.getDenied()); |             uuids.addAll(plot.getTrusted()); | ||||||
|  |             uuids.addAll(plot.getDenied()); | ||||||
|  |             for (final UUID uuid : uuids) { | ||||||
|  |                 if (!uuidQueue.contains(uuid)) { | ||||||
|  |                     uuidQueue.add(uuid); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|         }); |         }); | ||||||
|         final Queue<UUID> uuidQueue = new LinkedBlockingQueue<>(uuidSet); |  | ||||||
|  |  | ||||||
|         LOGGER.info("(UUID) {} UUIDs will be cached", uuidQueue.size()); |         LOGGER.info("(UUID) {} UUIDs will be cached", uuidQueue.size()); | ||||||
|  |  | ||||||
| @@ -730,11 +739,6 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|         this.getServer().getPluginManager().disablePlugin(this); |         this.getServer().getPluginManager().disablePlugin(this); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void shutdownServer() { |  | ||||||
|         getServer().shutdown(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private void registerCommands() { |     private void registerCommands() { | ||||||
|         final BukkitCommand bukkitCommand = new BukkitCommand(); |         final BukkitCommand bukkitCommand = new BukkitCommand(); | ||||||
|         final PluginCommand plotCommand = getCommand("plots"); |         final PluginCommand plotCommand = getCommand("plots"); | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -18,18 +25,17 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.bukkit.generator; | package com.plotsquared.bukkit.generator; | ||||||
|  |  | ||||||
| import com.plotsquared.bukkit.queue.LimitedRegionWrapperQueue; | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.generator.HybridPlotWorld; |  | ||||||
| import com.plotsquared.core.generator.IndependentPlotGenerator; | import com.plotsquared.core.generator.IndependentPlotGenerator; | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.ChunkWrapper; | ||||||
| import com.plotsquared.core.location.UncheckedWorldLocation; |  | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.plot.world.SinglePlotArea; | import com.plotsquared.core.queue.QueueCoordinator; | ||||||
| import com.plotsquared.core.queue.ScopedQueueCoordinator; | import com.plotsquared.core.queue.ScopedQueueCoordinator; | ||||||
|  | import com.sk89q.worldedit.bukkit.BukkitWorld; | ||||||
|  | import org.bukkit.Chunk; | ||||||
|  | import org.bukkit.World; | ||||||
| import org.bukkit.generator.BlockPopulator; | import org.bukkit.generator.BlockPopulator; | ||||||
| import org.bukkit.generator.LimitedRegion; |  | ||||||
| import org.bukkit.generator.WorldInfo; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Random; | import java.util.Random; | ||||||
| @@ -37,51 +43,35 @@ import java.util.Random; | |||||||
| final class BlockStatePopulator extends BlockPopulator { | final class BlockStatePopulator extends BlockPopulator { | ||||||
|  |  | ||||||
|     private final IndependentPlotGenerator plotGenerator; |     private final IndependentPlotGenerator plotGenerator; | ||||||
|  |     private final PlotAreaManager plotAreaManager; | ||||||
|  |  | ||||||
|     /** |     private QueueCoordinator queue; | ||||||
|      * @since 6.9.0 |  | ||||||
|      */ |  | ||||||
|     public BlockStatePopulator( |  | ||||||
|             final @NonNull IndependentPlotGenerator plotGenerator |  | ||||||
|     ) { |  | ||||||
|         this.plotGenerator = plotGenerator; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * @deprecated Use {@link BlockStatePopulator#BlockStatePopulator(IndependentPlotGenerator)} as plotAreManager is unused |  | ||||||
|      */ |  | ||||||
|     @Deprecated(forRemoval = true, since = "6.9.0") |  | ||||||
|     public BlockStatePopulator( |     public BlockStatePopulator( | ||||||
|             final @NonNull IndependentPlotGenerator plotGenerator, |             final @NonNull IndependentPlotGenerator plotGenerator, | ||||||
|             final @NonNull PlotAreaManager plotAreaManager |             final @NonNull PlotAreaManager plotAreaManager | ||||||
|     ) { |     ) { | ||||||
|         this.plotGenerator = plotGenerator; |         this.plotGenerator = plotGenerator; | ||||||
|  |         this.plotAreaManager = plotAreaManager; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void populate( |     public void populate(final @NonNull World world, final @NonNull Random random, final @NonNull Chunk source) { | ||||||
|             @NonNull final WorldInfo worldInfo, |         if (this.queue == null) { | ||||||
|             @NonNull final Random random, |             this.queue = PlotSquared.platform().globalBlockQueue().getNewQueue(new BukkitWorld(world)); | ||||||
|             final int chunkX, |         } | ||||||
|             final int chunkZ, |         final PlotArea area = this.plotAreaManager.getPlotArea(world.getName(), null); | ||||||
|             @NonNull final LimitedRegion limitedRegion |         if (area == null) { | ||||||
|     ) { |  | ||||||
|         PlotArea area = UncheckedWorldLocation.at(worldInfo.getName(), chunkX << 4, 0, chunkZ << 4).getPlotArea(); |  | ||||||
|         if (area == null || (area instanceof HybridPlotWorld hpw && !hpw.populationNeeded()) || area instanceof SinglePlotArea) { |  | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         LimitedRegionWrapperQueue wrapped = new LimitedRegionWrapperQueue(limitedRegion); |         final ChunkWrapper wrap = new ChunkWrapper(area.getWorldName(), source.getX(), source.getZ()); | ||||||
|         // It is possible for the region to be larger than the chunk, but there is no reason for P2 to need to populate |         final ScopedQueueCoordinator chunk = this.queue.getForChunk(wrap.x, wrap.z, | ||||||
|         // outside of the actual chunk area. |                 com.plotsquared.bukkit.util.BukkitWorld.getMinWorldHeight(world), | ||||||
|         Location min = UncheckedWorldLocation.at(worldInfo.getName(), chunkX << 4, worldInfo.getMinHeight(), chunkZ << 4); |                 com.plotsquared.bukkit.util.BukkitWorld.getMaxWorldHeight(world) - 1 | ||||||
|         Location max = UncheckedWorldLocation.at( |  | ||||||
|                 worldInfo.getName(), |  | ||||||
|                 (chunkX << 4) + 15, |  | ||||||
|                 worldInfo.getMaxHeight(), |  | ||||||
|                 (chunkZ << 4) + 15 |  | ||||||
|         ); |         ); | ||||||
|         ScopedQueueCoordinator offsetChunkQueue = new ScopedQueueCoordinator(wrapped, min, max); |         if (this.plotGenerator.populateChunk(chunk, area)) { | ||||||
|         this.plotGenerator.populateChunk(offsetChunkQueue, area); |             this.queue.enqueue(); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -42,7 +49,8 @@ import java.util.List; | |||||||
| import java.util.Random; | import java.util.Random; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
|  |  | ||||||
| public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrapper<ChunkGenerator> { | public class BukkitPlotGenerator extends ChunkGenerator | ||||||
|  |         implements GeneratorWrapper<ChunkGenerator> { | ||||||
|  |  | ||||||
|     @SuppressWarnings("unused") |     @SuppressWarnings("unused") | ||||||
|     public final boolean PAPER_ASYNC_SAFE = true; |     public final boolean PAPER_ASYNC_SAFE = true; | ||||||
| @@ -65,12 +73,7 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         this.plotGenerator = generator; |         this.plotGenerator = generator; | ||||||
|         this.platformGenerator = this; |         this.platformGenerator = this; | ||||||
|         this.populators = new ArrayList<>(); |         this.populators = new ArrayList<>(); | ||||||
|         int minecraftMinorVersion = PlotSquared.platform().serverVersion()[1]; |         this.populators.add(new BlockStatePopulator(this.plotGenerator, this.plotAreaManager)); | ||||||
|         if (minecraftMinorVersion >= 17) { |  | ||||||
|             this.populators.add(new BlockStatePopulator(this.plotGenerator)); |  | ||||||
|         } else { |  | ||||||
|             this.populators.add(new LegacyBlockStatePopulator(this.plotGenerator)); |  | ||||||
|         } |  | ||||||
|         this.full = true; |         this.full = true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -109,7 +112,30 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|     @Override |     @Override | ||||||
|     public @NonNull List<BlockPopulator> getDefaultPopulators(@NonNull World world) { |     public @NonNull List<BlockPopulator> getDefaultPopulators(@NonNull World world) { | ||||||
|         try { |         try { | ||||||
|             checkLoaded(world); |             if (!this.loaded) { | ||||||
|  |                 String name = world.getName(); | ||||||
|  |                 PlotSquared.get().loadWorld(name, this); | ||||||
|  |                 final Set<PlotArea> areas = this.plotAreaManager.getPlotAreasSet(name); | ||||||
|  |                 if (!areas.isEmpty()) { | ||||||
|  |                     PlotArea area = areas.iterator().next(); | ||||||
|  |                     if (!area.isMobSpawning()) { | ||||||
|  |                         if (!area.isSpawnEggs()) { | ||||||
|  |                             world.setSpawnFlags(false, false); | ||||||
|  |                         } | ||||||
|  |                         world.setAmbientSpawnLimit(0); | ||||||
|  |                         world.setAnimalSpawnLimit(0); | ||||||
|  |                         world.setMonsterSpawnLimit(0); | ||||||
|  |                         world.setWaterAnimalSpawnLimit(0); | ||||||
|  |                     } else { | ||||||
|  |                         world.setSpawnFlags(true, true); | ||||||
|  |                         world.setAmbientSpawnLimit(-1); | ||||||
|  |                         world.setAnimalSpawnLimit(-1); | ||||||
|  |                         world.setMonsterSpawnLimit(-1); | ||||||
|  |                         world.setWaterAnimalSpawnLimit(-1); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 this.loaded = true; | ||||||
|  |             } | ||||||
|         } catch (Exception e) { |         } catch (Exception e) { | ||||||
|             e.printStackTrace(); |             e.printStackTrace(); | ||||||
|         } |         } | ||||||
| @@ -128,44 +154,12 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|         return toAdd; |         return toAdd; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private synchronized void checkLoaded(@NonNull World world) { |  | ||||||
|         // Do not attempt to load configurations until WorldEdit has a platform ready. |  | ||||||
|         if (!PlotSquared.get().isWeInitialised()) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         if (!this.loaded) { |  | ||||||
|             String name = world.getName(); |  | ||||||
|             PlotSquared.get().loadWorld(name, this); |  | ||||||
|             final Set<PlotArea> areas = this.plotAreaManager.getPlotAreasSet(name); |  | ||||||
|             if (!areas.isEmpty()) { |  | ||||||
|                 PlotArea area = areas.iterator().next(); |  | ||||||
|                 if (!area.isMobSpawning()) { |  | ||||||
|                     if (!area.isSpawnEggs()) { |  | ||||||
|                         world.setSpawnFlags(false, false); |  | ||||||
|                     } |  | ||||||
|                     setSpawnLimits(world, 0); |  | ||||||
|                 } else { |  | ||||||
|                     world.setSpawnFlags(true, true); |  | ||||||
|                     setSpawnLimits(world, -1); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             this.loaded = true; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @SuppressWarnings("deprecation") |  | ||||||
|     private void setSpawnLimits(@NonNull World world, int limit) { |  | ||||||
|         world.setAmbientSpawnLimit(limit); |  | ||||||
|         world.setAnimalSpawnLimit(limit); |  | ||||||
|         world.setMonsterSpawnLimit(limit); |  | ||||||
|         world.setWaterAnimalSpawnLimit(limit); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull ChunkData generateChunkData( |     public @NonNull ChunkData generateChunkData( | ||||||
|             @NonNull World world, @NonNull Random random, int x, int z, |             @NonNull World world, @NonNull Random random, int x, int z, | ||||||
|             @NonNull BiomeGrid biome |             @NonNull BiomeGrid biome | ||||||
|     ) { |     ) { | ||||||
|  |  | ||||||
|         int minY = BukkitWorld.getMinWorldHeight(world); |         int minY = BukkitWorld.getMinWorldHeight(world); | ||||||
|         int maxY = BukkitWorld.getMaxWorldHeight(world); |         int maxY = BukkitWorld.getMaxWorldHeight(world); | ||||||
|         GenChunk result = new GenChunk(minY, maxY); |         GenChunk result = new GenChunk(minY, maxY); | ||||||
| @@ -207,7 +201,9 @@ public class BukkitPlotGenerator extends ChunkGenerator implements GeneratorWrap | |||||||
|     private void generate(BlockVector2 loc, World world, ScopedQueueCoordinator result) { |     private void generate(BlockVector2 loc, World world, ScopedQueueCoordinator result) { | ||||||
|         // Load if improperly loaded |         // Load if improperly loaded | ||||||
|         if (!this.loaded) { |         if (!this.loaded) { | ||||||
|             checkLoaded(world); |             String name = world.getName(); | ||||||
|  |             PlotSquared.get().loadWorld(name, this); | ||||||
|  |             this.loaded = true; | ||||||
|         } |         } | ||||||
|         // Process the chunk |         // Process the chunk | ||||||
|         if (ChunkManager.preProcessChunk(loc, result)) { |         if (ChunkManager.preProcessChunk(loc, result)) { | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,74 +0,0 @@ | |||||||
| /* |  | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  | ||||||
|  * |  | ||||||
|  * This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU General Public License |  | ||||||
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>. |  | ||||||
|  */ |  | ||||||
| package com.plotsquared.bukkit.generator; |  | ||||||
|  |  | ||||||
| import com.plotsquared.core.PlotSquared; |  | ||||||
| import com.plotsquared.core.generator.HybridPlotWorld; |  | ||||||
| import com.plotsquared.core.generator.IndependentPlotGenerator; |  | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.location.UncheckedWorldLocation; |  | ||||||
| import com.plotsquared.core.plot.PlotArea; |  | ||||||
| import com.plotsquared.core.plot.world.SinglePlotArea; |  | ||||||
| import com.plotsquared.core.queue.QueueCoordinator; |  | ||||||
| import com.plotsquared.core.queue.ScopedQueueCoordinator; |  | ||||||
| import com.sk89q.worldedit.bukkit.BukkitWorld; |  | ||||||
| import com.sk89q.worldedit.util.SideEffectSet; |  | ||||||
| import org.bukkit.Chunk; |  | ||||||
| import org.bukkit.World; |  | ||||||
| import org.bukkit.generator.BlockPopulator; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; |  | ||||||
| import org.jetbrains.annotations.NotNull; |  | ||||||
|  |  | ||||||
| import java.util.Random; |  | ||||||
|  |  | ||||||
| final class LegacyBlockStatePopulator extends BlockPopulator { |  | ||||||
|  |  | ||||||
|     private final IndependentPlotGenerator plotGenerator; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * @since 6.9.0 |  | ||||||
|      */ |  | ||||||
|     public LegacyBlockStatePopulator( |  | ||||||
|             final @NonNull IndependentPlotGenerator plotGenerator |  | ||||||
|     ) { |  | ||||||
|         this.plotGenerator = plotGenerator; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void populate(@NotNull final World world, @NotNull final Random random, @NotNull final Chunk source) { |  | ||||||
|         int chunkMinX = source.getX() << 4; |  | ||||||
|         int chunkMinZ = source.getZ() << 4; |  | ||||||
|         PlotArea area = Location.at(world.getName(), chunkMinX, 0, chunkMinZ).getPlotArea(); |  | ||||||
|         if (area == null || (area instanceof HybridPlotWorld hpw && !hpw.populationNeeded()) || area instanceof SinglePlotArea) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         QueueCoordinator queue = PlotSquared.platform().globalBlockQueue().getNewQueue(new BukkitWorld(world)); |  | ||||||
|         queue.setForceSync(true); |  | ||||||
|         queue.setSideEffectSet(SideEffectSet.none()); |  | ||||||
|         queue.setBiomesEnabled(false); |  | ||||||
|         queue.setChunkObject(source); |  | ||||||
|         Location min = UncheckedWorldLocation.at(world.getName(), chunkMinX, world.getMinHeight(), chunkMinZ); |  | ||||||
|         Location max = UncheckedWorldLocation.at(world.getName(), chunkMinX + 15, world.getMaxHeight(), chunkMinZ + 15); |  | ||||||
|         ScopedQueueCoordinator offsetChunkQueue = new ScopedQueueCoordinator(queue, min, max); |  | ||||||
|         this.plotGenerator.populateChunk(offsetChunkQueue, area); |  | ||||||
|         queue.enqueue(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -65,7 +72,6 @@ import net.kyori.adventure.text.minimessage.Template; | |||||||
| import org.bukkit.Bukkit; | import org.bukkit.Bukkit; | ||||||
| import org.bukkit.GameMode; | import org.bukkit.GameMode; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
| import org.bukkit.Tag; |  | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.BlockFace; | import org.bukkit.block.BlockFace; | ||||||
| import org.bukkit.block.BlockState; | import org.bukkit.block.BlockState; | ||||||
| @@ -107,27 +113,11 @@ import org.checkerframework.checker.nullness.qual.NonNull; | |||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
| import java.util.Set; |  | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
| import java.util.stream.Collectors; |  | ||||||
| import java.util.stream.Stream; |  | ||||||
|  |  | ||||||
| @SuppressWarnings("unused") | @SuppressWarnings("unused") | ||||||
| public class BlockEventListener implements Listener { | public class BlockEventListener implements Listener { | ||||||
|  |  | ||||||
|     private static final Set<Material> PISTONS = Set.of( |  | ||||||
|             Material.PISTON, |  | ||||||
|             Material.STICKY_PISTON |  | ||||||
|     ); |  | ||||||
|     private static final Set<Material> PHYSICS_BLOCKS = Set.of( |  | ||||||
|             Material.TURTLE_EGG, |  | ||||||
|             Material.TURTLE_SPAWN_EGG |  | ||||||
|     ); |  | ||||||
|     private static final Set<Material> SNOW = Stream.of(Material.values()) // needed as Tag.SNOW isn't present in 1.16.5 |  | ||||||
|             .filter(material -> material.name().contains("SNOW")) |  | ||||||
|             .filter(Material::isBlock) |  | ||||||
|             .collect(Collectors.toUnmodifiableSet()); |  | ||||||
|  |  | ||||||
|     private final PlotAreaManager plotAreaManager; |     private final PlotAreaManager plotAreaManager; | ||||||
|     private final WorldEdit worldEdit; |     private final WorldEdit worldEdit; | ||||||
|  |  | ||||||
| @@ -233,33 +223,50 @@ public class BlockEventListener implements Listener { | |||||||
|             plot.debug("Prevented block physics and resent block change because disable-physics = true"); |             plot.debug("Prevented block physics and resent block change because disable-physics = true"); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (event.getChangedType() == Material.COMPARATOR) { |         switch (event.getChangedType()) { | ||||||
|  |             case COMPARATOR: { | ||||||
|                 if (!plot.getFlag(RedstoneFlag.class)) { |                 if (!plot.getFlag(RedstoneFlag.class)) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     plot.debug("Prevented comparator update because redstone = false"); |                     plot.debug("Prevented comparator update because redstone = false"); | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|         if (PHYSICS_BLOCKS.contains(event.getChangedType())) { |             case ANVIL: | ||||||
|  |             case DRAGON_EGG: | ||||||
|  |             case GRAVEL: | ||||||
|  |             case SAND: | ||||||
|  |             case TURTLE_EGG: | ||||||
|  |             case TURTLE_HELMET: | ||||||
|  |             case TURTLE_SPAWN_EGG: { | ||||||
|                 if (plot.getFlag(DisablePhysicsFlag.class)) { |                 if (plot.getFlag(DisablePhysicsFlag.class)) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     plot.debug("Prevented block physics because disable-physics = true"); |                     plot.debug("Prevented block physics because disable-physics = true"); | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |             default: | ||||||
|                 if (Settings.Redstone.DETECT_INVALID_EDGE_PISTONS) { |                 if (Settings.Redstone.DETECT_INVALID_EDGE_PISTONS) { | ||||||
|             if (PISTONS.contains(block.getType())) { |                     switch (block.getType()) { | ||||||
|  |                         case PISTON, STICKY_PISTON -> { | ||||||
|                             org.bukkit.block.data.Directional piston = (org.bukkit.block.data.Directional) block.getBlockData(); |                             org.bukkit.block.data.Directional piston = (org.bukkit.block.data.Directional) block.getBlockData(); | ||||||
|                 final BlockFace facing = piston.getFacing(); |                             switch (piston.getFacing()) { | ||||||
|                 location = location.add(facing.getModX(), facing.getModY(), facing.getModZ()); |                                 case EAST -> location = location.add(1, 0, 0); | ||||||
|  |                                 case SOUTH -> location = location.add(-1, 0, 0); | ||||||
|  |                                 case WEST -> location = location.add(0, 0, 1); | ||||||
|  |                                 case NORTH -> location = location.add(0, 0, -1); | ||||||
|  |                             } | ||||||
|                             Plot newPlot = area.getOwnedPlotAbs(location); |                             Plot newPlot = area.getOwnedPlotAbs(location); | ||||||
|                             if (!plot.equals(newPlot)) { |                             if (!plot.equals(newPlot)) { | ||||||
|                                 event.setCancelled(true); |                                 event.setCancelled(true); | ||||||
|                                 plot.debug("Prevented piston update because of invalid edge piston detection"); |                                 plot.debug("Prevented piston update because of invalid edge piston detection"); | ||||||
|  |                                 return; | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|  |                 break; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void blockCreate(BlockPlaceEvent event) { |     public void blockCreate(BlockPlaceEvent event) { | ||||||
| @@ -272,9 +279,15 @@ public class BlockEventListener implements Listener { | |||||||
|         BukkitPlayer pp = BukkitUtil.adapt(player); |         BukkitPlayer pp = BukkitUtil.adapt(player); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         if (plot != null) { |         if (plot != null) { | ||||||
|             if (area.notifyIfOutsideBuildArea(pp, location.getY())) { |             if ((location.getY() >= area.getMaxBuildHeight() || location.getY() < area | ||||||
|  |                     .getMinBuildHeight()) && !Permissions | ||||||
|  |                     .hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_HEIGHT_LIMIT)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 pp.sendMessage( | ||||||
|  |                         TranslatableCaption.of("height.height_limit"), | ||||||
|  |                         Template.of("minHeight", String.valueOf(area.getMinBuildHeight())), | ||||||
|  |                         Template.of("maxHeight", String.valueOf(area.getMaxBuildHeight())) | ||||||
|  |                 ); | ||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_UNOWNED)) { | ||||||
| @@ -352,9 +365,15 @@ public class BlockEventListener implements Listener { | |||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } else if (area.notifyIfOutsideBuildArea(plotPlayer, location.getY())) { |             } else if ((location.getY() >= area.getMaxBuildHeight() || location.getY() < area | ||||||
|  |                     .getMinBuildHeight()) && !Permissions | ||||||
|  |                     .hasPermission(plotPlayer, Permission.PERMISSION_ADMIN_BUILD_HEIGHT_LIMIT)) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 plotPlayer.sendMessage( | ||||||
|  |                         TranslatableCaption.of("height.height_limit"), | ||||||
|  |                         Template.of("minHeight", String.valueOf(area.getMinBuildHeight())), | ||||||
|  |                         Template.of("maxHeight", String.valueOf(area.getMaxBuildHeight())) | ||||||
|  |                 ); | ||||||
|             } |             } | ||||||
|             if (!plot.hasOwner()) { |             if (!plot.hasOwner()) { | ||||||
|                 if (!Permissions |                 if (!Permissions | ||||||
| @@ -442,7 +461,6 @@ public class BlockEventListener implements Listener { | |||||||
|             case "TWISTING_VINES": |             case "TWISTING_VINES": | ||||||
|             case "CAVE_VINES": |             case "CAVE_VINES": | ||||||
|             case "VINE": |             case "VINE": | ||||||
|             case "GLOW_BERRIES": |  | ||||||
|                 if (!plot.getFlag(VineGrowFlag.class)) { |                 if (!plot.getFlag(VineGrowFlag.class)) { | ||||||
|                     plot.debug("Vine could not grow because vine-grow = false"); |                     plot.debug("Vine could not grow because vine-grow = false"); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
| @@ -533,18 +551,17 @@ public class BlockEventListener implements Listener { | |||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (!area.buildRangeContainsY(location.getY())) { |         switch (event.getNewState().getType()) { | ||||||
|             event.setCancelled(true); |             case SNOW: | ||||||
|             return; |             case SNOW_BLOCK: | ||||||
|         } |  | ||||||
|         if (SNOW.contains(event.getNewState().getType())) { |  | ||||||
|                 if (!plot.getFlag(SnowFormFlag.class)) { |                 if (!plot.getFlag(SnowFormFlag.class)) { | ||||||
|                     plot.debug("Snow could not form because snow-form = false"); |                     plot.debug("Snow could not form because snow-form = false"); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|                 return; |                 return; | ||||||
|         } |             case ICE: | ||||||
|         if (Tag.ICE.isTagged(event.getNewState().getType())) { |             case FROSTED_ICE: | ||||||
|  |             case PACKED_ICE: | ||||||
|                 if (!plot.getFlag(IceFormFlag.class)) { |                 if (!plot.getFlag(IceFormFlag.class)) { | ||||||
|                     plot.debug("Ice could not form because ice-form = false"); |                     plot.debug("Ice could not form because ice-form = false"); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
| @@ -569,12 +586,18 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Class<? extends BooleanFlag<?>> flag; |         Class<? extends BooleanFlag<?>> flag; | ||||||
|         if (SNOW.contains(event.getNewState().getType())) { |         switch (event.getNewState().getType()) { | ||||||
|  |             case SNOW: | ||||||
|  |             case SNOW_BLOCK: | ||||||
|                 flag = SnowFormFlag.class; |                 flag = SnowFormFlag.class; | ||||||
|         } else if (Tag.ICE.isTagged(event.getNewState().getType())) { |                 break; | ||||||
|  |             case ICE: | ||||||
|  |             case FROSTED_ICE: | ||||||
|  |             case PACKED_ICE: | ||||||
|                 flag = IceFormFlag.class; |                 flag = IceFormFlag.class; | ||||||
|         } else { |                 break; | ||||||
|             return; |             default: | ||||||
|  |                 return; // other blocks are ignored by this event | ||||||
|         } |         } | ||||||
|         boolean allowed = plot.getFlag(flag); |         boolean allowed = plot.getFlag(flag); | ||||||
|         Entity entity = event.getEntity(); |         Entity entity = event.getEntity(); | ||||||
| @@ -678,98 +701,111 @@ public class BlockEventListener implements Listener { | |||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Material blockType = block.getType(); |         switch (block.getType()) { | ||||||
|         if (Tag.ICE.isTagged(blockType)) { |             case ICE: | ||||||
|                 if (!plot.getFlag(IceMeltFlag.class)) { |                 if (!plot.getFlag(IceMeltFlag.class)) { | ||||||
|                     plot.debug("Ice could not melt because ice-melt = false"); |                     plot.debug("Ice could not melt because ice-melt = false"); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             return; |                 break; | ||||||
|         } |             case SNOW: | ||||||
|         if (SNOW.contains(blockType)) { |  | ||||||
|                 if (!plot.getFlag(SnowMeltFlag.class)) { |                 if (!plot.getFlag(SnowMeltFlag.class)) { | ||||||
|                     plot.debug("Snow could not melt because snow-melt = false"); |                     plot.debug("Snow could not melt because snow-melt = false"); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             return; |                 break; | ||||||
|         } |             case FARMLAND: | ||||||
|         if (blockType == Material.FARMLAND) { |  | ||||||
|                 if (!plot.getFlag(SoilDryFlag.class)) { |                 if (!plot.getFlag(SoilDryFlag.class)) { | ||||||
|                     plot.debug("Soil could not dry because soil-dry = false"); |                     plot.debug("Soil could not dry because soil-dry = false"); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             return; |                 break; | ||||||
|         } |             case TUBE_CORAL_BLOCK: | ||||||
|         if (Tag.CORAL_BLOCKS.isTagged(blockType) || Tag.CORALS.isTagged(blockType) || Tag.WALL_CORALS.isTagged(blockType)) { |             case BRAIN_CORAL_BLOCK: | ||||||
|  |             case BUBBLE_CORAL_BLOCK: | ||||||
|  |             case FIRE_CORAL_BLOCK: | ||||||
|  |             case HORN_CORAL_BLOCK: | ||||||
|  |             case TUBE_CORAL: | ||||||
|  |             case BRAIN_CORAL: | ||||||
|  |             case BUBBLE_CORAL: | ||||||
|  |             case FIRE_CORAL: | ||||||
|  |             case HORN_CORAL: | ||||||
|  |             case TUBE_CORAL_FAN: | ||||||
|  |             case BRAIN_CORAL_FAN: | ||||||
|  |             case BUBBLE_CORAL_FAN: | ||||||
|  |             case FIRE_CORAL_FAN: | ||||||
|  |             case HORN_CORAL_FAN: | ||||||
|  |             case BRAIN_CORAL_WALL_FAN: | ||||||
|  |             case BUBBLE_CORAL_WALL_FAN: | ||||||
|  |             case FIRE_CORAL_WALL_FAN: | ||||||
|  |             case HORN_CORAL_WALL_FAN: | ||||||
|  |             case TUBE_CORAL_WALL_FAN: | ||||||
|                 if (!plot.getFlag(CoralDryFlag.class)) { |                 if (!plot.getFlag(CoralDryFlag.class)) { | ||||||
|                     plot.debug("Coral could not dry because coral-dry = false"); |                     plot.debug("Coral could not dry because coral-dry = false"); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|  |                 break; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onChange(BlockFromToEvent event) { |     public void onChange(BlockFromToEvent event) { | ||||||
|         Block fromBlock = event.getBlock(); |         Block from = event.getBlock(); | ||||||
|  |  | ||||||
|         // Check liquid flow flag inside of origin plot too |         // Check liquid flow flag inside of origin plot too | ||||||
|         final Location fromLocation = BukkitUtil.adapt(fromBlock.getLocation()); |         final Location fLocation = BukkitUtil.adapt(from.getLocation()); | ||||||
|         final PlotArea fromArea = fromLocation.getPlotArea(); |         final PlotArea fromArea = fLocation.getPlotArea(); | ||||||
|         if (fromArea != null) { |         if (fromArea != null) { | ||||||
|             final Plot fromPlot = fromArea.getOwnedPlot(fromLocation); |             final Plot plot = fromArea.getOwnedPlot(fLocation); | ||||||
|             if (fromPlot != null && fromPlot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.DISABLED && event |             if (plot != null && plot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.DISABLED && event | ||||||
|                     .getBlock() |                     .getBlock() | ||||||
|                     .isLiquid()) { |                     .isLiquid()) { | ||||||
|                 fromPlot.debug("Liquid could not flow because liquid-flow = disabled"); |                 plot.debug("Liquid could not flow because liquid-flow = disabled"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         Block toBlock = event.getToBlock(); |         Block to = event.getToBlock(); | ||||||
|         Location toLocation = BukkitUtil.adapt(toBlock.getLocation()); |         Location tLocation = BukkitUtil.adapt(to.getLocation()); | ||||||
|         PlotArea toArea = toLocation.getPlotArea(); |         PlotArea area = tLocation.getPlotArea(); | ||||||
|         if (toArea == null) { |         if (area == null) { | ||||||
|             if (fromBlock.getType() == Material.DRAGON_EGG && fromArea != null) { |             if (from.getType() == Material.DRAGON_EGG && fromArea != null) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (!toArea.buildRangeContainsY(toLocation.getY())) { |         Plot plot = area.getOwnedPlot(tLocation); | ||||||
|             event.setCancelled(true); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         Plot toPlot = toArea.getOwnedPlot(toLocation); |  | ||||||
|  |  | ||||||
|         if (fromBlock.getType() == Material.DRAGON_EGG && fromArea != null) { |         if (from.getType() == Material.DRAGON_EGG && fromArea != null) { | ||||||
|             final Plot fromPlot = fromArea.getOwnedPlot(fromLocation); |             final Plot fromPlot = fromArea.getOwnedPlot(fLocation); | ||||||
|  |  | ||||||
|             if (fromPlot != null || toPlot != null) { |             if (fromPlot != null || plot != null) { | ||||||
|                 if ((fromPlot == null || !fromPlot.equals(toPlot)) && (toPlot == null || !toPlot.equals(fromPlot))) { |                 if ((fromPlot == null || !fromPlot.equals(plot)) && (plot == null || !plot.equals(fromPlot))) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (toPlot != null) { |         if (plot != null) { | ||||||
|             if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals(toPlot, toArea.getOwnedPlot(fromLocation))) { |             if (!area.contains(fLocation.getX(), fLocation.getZ()) || !Objects.equals(plot, area.getOwnedPlot(fLocation))) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (toPlot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.ENABLED && event.getBlock().isLiquid()) { |             if (plot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.ENABLED && event.getBlock().isLiquid()) { | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (toPlot.getFlag(DisablePhysicsFlag.class)) { |             if (plot.getFlag(DisablePhysicsFlag.class)) { | ||||||
|                 toPlot.debug(event.getBlock().getType() + " could not update because disable-physics = true"); |                 plot.debug(event.getBlock().getType() + " could not update because disable-physics = true"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (toPlot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.DISABLED && event.getBlock().isLiquid()) { |             if (plot.getFlag(LiquidFlowFlag.class) == LiquidFlowFlag.FlowStatus.DISABLED && event.getBlock().isLiquid()) { | ||||||
|                 toPlot.debug("Liquid could not flow because liquid-flow = disabled"); |                 plot.debug("Liquid could not flow because liquid-flow = disabled"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } else if (!toArea.contains(fromLocation.getX(), fromLocation.getZ()) || !Objects.equals(null, toArea.getOwnedPlot(fromLocation))) { |         } else if (!area.contains(fLocation.getX(), fLocation.getZ()) || !Objects.equals(null, area.getOwnedPlot(fLocation))) { | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } else if (event.getBlock().isLiquid()) { |         } else if (event.getBlock().isLiquid()) { | ||||||
|             final org.bukkit.Location location = event.getBlock().getLocation(); |             final org.bukkit.Location location = event.getBlock().getLocation(); | ||||||
| @@ -809,11 +845,6 @@ public class BlockEventListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         if (!area.buildRangeContainsY(location.getY())) { |  | ||||||
|             event.setCancelled(true); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null || !plot.getFlag(CropGrowFlag.class)) { |         if (plot == null || !plot.getFlag(CropGrowFlag.class)) { | ||||||
|             if (plot != null) { |             if (plot != null) { | ||||||
| @@ -857,16 +888,15 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         for (Block block1 : event.getBlocks()) { |         for (Block block1 : event.getBlocks()) { | ||||||
|             Location bloc = BukkitUtil.adapt(block1.getLocation()); |             Location bloc = BukkitUtil.adapt(block1.getLocation()); | ||||||
|             Location newLoc = bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()); |             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains( | ||||||
|             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains(newLoc)) { |                     bloc.getX() + relative.getBlockX(), | ||||||
|  |                     bloc.getZ() + relative.getBlockZ() | ||||||
|  |             )) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot.equals(area.getOwnedPlot(newLoc))) { |             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot | ||||||
|                 event.setCancelled(true); |                     .equals(area.getOwnedPlot(bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ())))) { | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             if (!area.buildRangeContainsY(bloc.getY()) || !area.buildRangeContainsY(newLoc.getY())) { |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -892,8 +922,9 @@ public class BlockEventListener implements Listener { | |||||||
|             } |             } | ||||||
|             for (Block block1 : event.getBlocks()) { |             for (Block block1 : event.getBlocks()) { | ||||||
|                 Location bloc = BukkitUtil.adapt(block1.getLocation()); |                 Location bloc = BukkitUtil.adapt(block1.getLocation()); | ||||||
|                 Location newLoc = bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()); |                 if (bloc.isPlotArea() || bloc | ||||||
|                 if (bloc.isPlotArea() || newLoc.isPlotArea()) { |                         .add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()) | ||||||
|  |                         .isPlotArea()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
| @@ -907,16 +938,15 @@ public class BlockEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         for (Block block1 : event.getBlocks()) { |         for (Block block1 : event.getBlocks()) { | ||||||
|             Location bloc = BukkitUtil.adapt(block1.getLocation()); |             Location bloc = BukkitUtil.adapt(block1.getLocation()); | ||||||
|             Location newLoc = bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ()); |             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains( | ||||||
|             if (!area.contains(bloc.getX(), bloc.getZ()) || !area.contains(newLoc)) { |                     bloc.getX() + relative.getBlockX(), | ||||||
|  |                     bloc.getZ() + relative.getBlockZ() | ||||||
|  |             )) { | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot.equals(area.getOwnedPlot(newLoc))) { |             if (!plot.equals(area.getOwnedPlot(bloc)) || !plot | ||||||
|                 event.setCancelled(true); |                     .equals(area.getOwnedPlot(bloc.add(relative.getBlockX(), relative.getBlockY(), relative.getBlockZ())))) { | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             if (!area.buildRangeContainsY(bloc.getY()) || !area.buildRangeContainsY(newLoc.getY())) { |  | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @@ -927,12 +957,7 @@ public class BlockEventListener implements Listener { | |||||||
|     public void onBlockDispense(BlockDispenseEvent event) { |     public void onBlockDispense(BlockDispenseEvent event) { | ||||||
|         Material type = event.getItem().getType(); |         Material type = event.getItem().getType(); | ||||||
|         switch (type.toString()) { |         switch (type.toString()) { | ||||||
|             case "SHULKER_BOX", "WHITE_SHULKER_BOX", "ORANGE_SHULKER_BOX", "MAGENTA_SHULKER_BOX", "LIGHT_BLUE_SHULKER_BOX", |             case "SHULKER_BOX", "WHITE_SHULKER_BOX", "ORANGE_SHULKER_BOX", "MAGENTA_SHULKER_BOX", "LIGHT_BLUE_SHULKER_BOX", "YELLOW_SHULKER_BOX", "LIME_SHULKER_BOX", "PINK_SHULKER_BOX", "GRAY_SHULKER_BOX", "LIGHT_GRAY_SHULKER_BOX", "CYAN_SHULKER_BOX", "PURPLE_SHULKER_BOX", "BLUE_SHULKER_BOX", "BROWN_SHULKER_BOX", "GREEN_SHULKER_BOX", "RED_SHULKER_BOX", "BLACK_SHULKER_BOX", "CARVED_PUMPKIN", "WITHER_SKELETON_SKULL", "FLINT_AND_STEEL", "BONE_MEAL", "SHEARS", "GLASS_BOTTLE", "GLOWSTONE", "COD_BUCKET", "PUFFERFISH_BUCKET", "SALMON_BUCKET", "TROPICAL_FISH_BUCKET", "AXOLOTL_BUCKET", "BUCKET", "WATER_BUCKET", "LAVA_BUCKET" -> { | ||||||
|                     "YELLOW_SHULKER_BOX", "LIME_SHULKER_BOX", "PINK_SHULKER_BOX", "GRAY_SHULKER_BOX", "LIGHT_GRAY_SHULKER_BOX", |  | ||||||
|                     "CYAN_SHULKER_BOX", "PURPLE_SHULKER_BOX", "BLUE_SHULKER_BOX", "BROWN_SHULKER_BOX", "GREEN_SHULKER_BOX", |  | ||||||
|                     "RED_SHULKER_BOX", "BLACK_SHULKER_BOX", "CARVED_PUMPKIN", "WITHER_SKELETON_SKULL", "FLINT_AND_STEEL", |  | ||||||
|                     "BONE_MEAL", "SHEARS", "GLASS_BOTTLE", "GLOWSTONE", "COD_BUCKET", "PUFFERFISH_BUCKET", "SALMON_BUCKET", |  | ||||||
|                     "TROPICAL_FISH_BUCKET", "AXOLOTL_BUCKET", "BUCKET", "WATER_BUCKET", "LAVA_BUCKET", "TADPOLE_BUCKET" -> { |  | ||||||
|                 if (event.getBlock().getType() == Material.DROPPER) { |                 if (event.getBlock().getType() == Material.DROPPER) { | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
| @@ -940,11 +965,6 @@ public class BlockEventListener implements Listener { | |||||||
|                 Location location = BukkitUtil.adapt(event.getBlock().getRelative(targetFace).getLocation()); |                 Location location = BukkitUtil.adapt(event.getBlock().getRelative(targetFace).getLocation()); | ||||||
|                 if (location.isPlotRoad()) { |                 if (location.isPlotRoad()) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                     return; |  | ||||||
|                 } |  | ||||||
|                 PlotArea area = location.getPlotArea(); |  | ||||||
|                 if (area != null && !area.buildRangeContainsY(location.getY())) { |  | ||||||
|                     event.setCancelled(true); |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -984,10 +1004,6 @@ public class BlockEventListener implements Listener { | |||||||
|                 Plot plot = area.getOwnedPlot(location); |                 Plot plot = area.getOwnedPlot(location); | ||||||
|                 if (!Objects.equals(plot, origin)) { |                 if (!Objects.equals(plot, origin)) { | ||||||
|                     event.getBlocks().remove(i); |                     event.getBlocks().remove(i); | ||||||
|                     continue; |  | ||||||
|                 } |  | ||||||
|                 if (!area.buildRangeContainsY(location.getY())) { |  | ||||||
|                     event.getBlocks().remove(i); |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -1079,10 +1095,6 @@ public class BlockEventListener implements Listener { | |||||||
|         Plot plot = area.getOwnedPlot(location1); |         Plot plot = area.getOwnedPlot(location1); | ||||||
|         if (player != null) { |         if (player != null) { | ||||||
|             BukkitPlayer pp = BukkitUtil.adapt(player); |             BukkitPlayer pp = BukkitUtil.adapt(player); | ||||||
|             if (area.notifyIfOutsideBuildArea(pp, location1.getY())) { |  | ||||||
|                 event.setCancelled(true); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|                     pp.sendMessage( |                     pp.sendMessage( | ||||||
| @@ -1190,10 +1202,7 @@ public class BlockEventListener implements Listener { | |||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
|                 Plot plot = area.getOwnedPlot(blockLocation); |                 Plot plot = area.getOwnedPlot(blockLocation); | ||||||
|                 if (!Objects.equals(plot, origin)) { |                 return !Objects.equals(plot, origin); | ||||||
|                     return true; |  | ||||||
|                 } |  | ||||||
|                 return !area.buildRangeContainsY(location.getY()); |  | ||||||
|             }); |             }); | ||||||
|         } |         } | ||||||
|         if (blocks.isEmpty()) { |         if (blocks.isEmpty()) { | ||||||
| @@ -1235,7 +1244,15 @@ public class BlockEventListener implements Listener { | |||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|             if (area.notifyIfOutsideBuildArea(pp, currentLocation.getY())) { |             if (Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_BUILD_HEIGHT_LIMIT)) { | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             if (currentLocation.getY() >= area.getMaxBuildHeight() || currentLocation.getY() < area.getMinBuildHeight()) { | ||||||
|  |                 pp.sendMessage( | ||||||
|  |                         TranslatableCaption.of("height.height_limit"), | ||||||
|  |                         Template.of("minHeight", String.valueOf(area.getMinBuildHeight())), | ||||||
|  |                         Template.of("maxHeight", String.valueOf(area.getMaxBuildHeight())) | ||||||
|  |                 ); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -26,7 +33,6 @@ import com.plotsquared.core.plot.Plot; | |||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.flag.implementations.CopperOxideFlag; | import com.plotsquared.core.plot.flag.implementations.CopperOxideFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.MiscInteractFlag; | import com.plotsquared.core.plot.flag.implementations.MiscInteractFlag; | ||||||
| import org.bukkit.Material; |  | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.Item; | import org.bukkit.entity.Item; | ||||||
| @@ -40,31 +46,11 @@ import org.bukkit.event.block.BlockReceiveGameEvent; | |||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
| import java.util.Set; |  | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  |  | ||||||
| @SuppressWarnings("unused") | @SuppressWarnings("unused") | ||||||
| public class BlockEventListener117 implements Listener { | public class BlockEventListener117 implements Listener { | ||||||
|  |  | ||||||
|     private static final Set<Material> COPPER_OXIDIZING = Set.of( |  | ||||||
|             Material.COPPER_BLOCK, |  | ||||||
|             Material.EXPOSED_COPPER, |  | ||||||
|             Material.WEATHERED_COPPER, |  | ||||||
|             Material.OXIDIZED_COPPER, |  | ||||||
|             Material.CUT_COPPER, |  | ||||||
|             Material.EXPOSED_CUT_COPPER, |  | ||||||
|             Material.WEATHERED_CUT_COPPER, |  | ||||||
|             Material.OXIDIZED_CUT_COPPER, |  | ||||||
|             Material.CUT_COPPER_STAIRS, |  | ||||||
|             Material.EXPOSED_CUT_COPPER_STAIRS, |  | ||||||
|             Material.WEATHERED_CUT_COPPER_STAIRS, |  | ||||||
|             Material.OXIDIZED_CUT_COPPER_STAIRS, |  | ||||||
|             Material.CUT_COPPER_SLAB, |  | ||||||
|             Material.EXPOSED_CUT_COPPER_SLAB, |  | ||||||
|             Material.WEATHERED_CUT_COPPER_SLAB, |  | ||||||
|             Material.OXIDIZED_CUT_COPPER_SLAB |  | ||||||
|     ); |  | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
|     public BlockEventListener117() { |     public BlockEventListener117() { | ||||||
|     } |     } | ||||||
| @@ -80,19 +66,10 @@ public class BlockEventListener117 implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         BukkitPlayer plotPlayer = null; |  | ||||||
|  |  | ||||||
|         if (entity instanceof Player player) { |  | ||||||
|             plotPlayer = BukkitUtil.adapt(player); |  | ||||||
|             if (area.notifyIfOutsideBuildArea(plotPlayer, location.getY())) { |  | ||||||
|                 event.setCancelled(true); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         Plot plot = location.getOwnedPlot(); |         Plot plot = location.getOwnedPlot(); | ||||||
|         if (plot == null || !plot.getFlag(MiscInteractFlag.class)) { |         if (plot == null || !plot.getFlag(MiscInteractFlag.class)) { | ||||||
|             if (plotPlayer != null) { |             if (entity instanceof Player player) { | ||||||
|  |                 BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|                 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 misc-interact = false"); | ||||||
| @@ -124,12 +101,12 @@ public class BlockEventListener117 implements Listener { | |||||||
|         PlotArea area = location.getPlotArea(); |         PlotArea area = location.getPlotArea(); | ||||||
|         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 = BukkitUtil.adapt(blocks.get(i).getLocation()); | ||||||
|                 blockLocation = BukkitUtil.adapt(blocks.get(i).getLocation()); |                 if (location.isPlotArea()) { | ||||||
|                 if (blockLocation.isPlotArea()) { |  | ||||||
|                     blocks.remove(i); |                     blocks.remove(i); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |             return; | ||||||
|         } else { |         } else { | ||||||
|             Plot origin = area.getOwnedPlot(location); |             Plot origin = area.getOwnedPlot(location); | ||||||
|             if (origin == null) { |             if (origin == null) { | ||||||
| @@ -137,22 +114,30 @@ public class BlockEventListener117 implements Listener { | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             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 = BukkitUtil.adapt(blocks.get(i).getLocation()); | ||||||
|                 if (!area.contains(blockLocation.getX(), blockLocation.getZ())) { |                 if (!area.contains(location.getX(), location.getZ())) { | ||||||
|                     blocks.remove(i); |                     blocks.remove(i); | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|                 Plot plot = area.getOwnedPlot(blockLocation); |                 Plot plot = area.getOwnedPlot(location); | ||||||
|                 if (!Objects.equals(plot, origin)) { |                 if (!Objects.equals(plot, origin)) { | ||||||
|                     event.getBlocks().remove(i); |                     event.getBlocks().remove(i); | ||||||
|                     continue; |  | ||||||
|                 } |                 } | ||||||
|                 if (!area.buildRangeContainsY(location.getY())) { |             } | ||||||
|  |         } | ||||||
|  |         Plot origin = area.getPlot(location); | ||||||
|  |         if (origin == null) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         for (int i = blocks.size() - 1; i >= 0; i--) { | ||||||
|  |             location = BukkitUtil.adapt(blocks.get(i).getLocation()); | ||||||
|  |             Plot plot = area.getOwnedPlot(location); | ||||||
|  |             if (!Objects.equals(plot, origin) && (!plot.isMerged() && !origin.isMerged())) { | ||||||
|                 event.getBlocks().remove(i); |                 event.getBlocks().remove(i); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onBlockForm(BlockFormEvent event) { |     public void onBlockForm(BlockFormEvent event) { | ||||||
| @@ -170,7 +155,23 @@ public class BlockEventListener117 implements Listener { | |||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (COPPER_OXIDIZING.contains(event.getNewState().getType())) { |         switch (event.getNewState().getType()) { | ||||||
|  |             case COPPER_BLOCK: | ||||||
|  |             case EXPOSED_COPPER: | ||||||
|  |             case WEATHERED_COPPER: | ||||||
|  |             case OXIDIZED_COPPER: | ||||||
|  |             case CUT_COPPER: | ||||||
|  |             case EXPOSED_CUT_COPPER: | ||||||
|  |             case WEATHERED_CUT_COPPER: | ||||||
|  |             case OXIDIZED_CUT_COPPER: | ||||||
|  |             case CUT_COPPER_STAIRS: | ||||||
|  |             case EXPOSED_CUT_COPPER_STAIRS: | ||||||
|  |             case WEATHERED_CUT_COPPER_STAIRS: | ||||||
|  |             case OXIDIZED_CUT_COPPER_STAIRS: | ||||||
|  |             case CUT_COPPER_SLAB: | ||||||
|  |             case EXPOSED_CUT_COPPER_SLAB: | ||||||
|  |             case WEATHERED_CUT_COPPER_SLAB: | ||||||
|  |             case OXIDIZED_CUT_COPPER_SLAB: | ||||||
|                 if (!plot.getFlag(CopperOxideFlag.class)) { |                 if (!plot.getFlag(CopperOxideFlag.class)) { | ||||||
|                     plot.debug("Copper could not oxide because copper-oxide = false"); |                     plot.debug("Copper could not oxide because copper-oxide = false"); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -201,7 +208,7 @@ public class EntityEventListener implements Listener { | |||||||
|             } |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (BukkitEntityUtil.checkEntity(entity, plot.getBasePlot(false))) { |         if (BukkitEntityUtil.checkEntity(entity, plot)) { | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -124,16 +131,16 @@ public class EntitySpawnListener implements Listener { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Plot plot = location.getOwnedPlotAbs(); |         Plot plot = location.getOwnedPlotAbs(); | ||||||
|         EntityType type = entity.getType(); |  | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (type == EntityType.DROPPED_ITEM) { |             EntityType type = entity.getType(); | ||||||
|  |             if (!area.isMobSpawning()) { | ||||||
|  |                 switch (type) { | ||||||
|  |                     case DROPPED_ITEM: | ||||||
|                         if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { |                         if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { | ||||||
|                             event.setCancelled(true); |                             event.setCancelled(true); | ||||||
|                 } |  | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|             if (!area.isMobSpawning()) { |                     case PLAYER: | ||||||
|                 if (type == EntityType.PLAYER) { |  | ||||||
|                         return; |                         return; | ||||||
|                 } |                 } | ||||||
|                 if (type.isAlive()) { |                 if (type.isAlive()) { | ||||||
| @@ -148,13 +155,12 @@ public class EntitySpawnListener implements Listener { | |||||||
|         if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { |         if (Settings.Done.RESTRICT_BUILDING && DoneFlag.isDone(plot)) { | ||||||
|             event.setCancelled(true); |             event.setCancelled(true); | ||||||
|         } |         } | ||||||
|         if (type == EntityType.ENDER_CRYSTAL) { |         switch (entity.getType()) { | ||||||
|  |             case ENDER_CRYSTAL: | ||||||
|                 if (BukkitEntityUtil.checkEntity(entity, plot)) { |                 if (BukkitEntityUtil.checkEntity(entity, plot)) { | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|             return; |             case SHULKER: | ||||||
|         } |  | ||||||
|         if (type == EntityType.SHULKER) { |  | ||||||
|                 if (!entity.hasMetadata("shulkerPlot")) { |                 if (!entity.hasMetadata("shulkerPlot")) { | ||||||
|                     entity.setMetadata("shulkerPlot", new FixedMetadataValue((Plugin) PlotSquared.platform(), plot.getId())); |                     entity.setMetadata("shulkerPlot", new FixedMetadataValue((Plugin) PlotSquared.platform(), plot.getId())); | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -18,7 +25,6 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.bukkit.listener; | package com.plotsquared.bukkit.listener; | ||||||
|  |  | ||||||
| import com.destroystokyo.paper.event.block.BeaconEffectEvent; |  | ||||||
| import com.destroystokyo.paper.event.entity.EntityPathfindEvent; | import com.destroystokyo.paper.event.entity.EntityPathfindEvent; | ||||||
| import com.destroystokyo.paper.event.entity.PlayerNaturallySpawnCreaturesEvent; | import com.destroystokyo.paper.event.entity.PlayerNaturallySpawnCreaturesEvent; | ||||||
| import com.destroystokyo.paper.event.entity.PreCreatureSpawnEvent; | import com.destroystokyo.paper.event.entity.PreCreatureSpawnEvent; | ||||||
| @@ -37,11 +43,8 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
| import com.plotsquared.core.plot.flag.FlagContainer; |  | ||||||
| import com.plotsquared.core.plot.flag.implementations.BeaconEffectsFlag; |  | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | import com.plotsquared.core.plot.flag.implementations.ProjectilesFlag; | ||||||
| import com.plotsquared.core.plot.flag.types.BooleanFlag; |  | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.Permissions; | import com.plotsquared.core.util.Permissions; | ||||||
| import net.kyori.adventure.text.minimessage.Template; | import net.kyori.adventure.text.minimessage.Template; | ||||||
| @@ -233,15 +236,15 @@ public class PaperListener implements Listener { | |||||||
|         Plot plot = location.getOwnedPlotAbs(); |         Plot plot = location.getOwnedPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             EntityType type = event.getType(); |             EntityType type = event.getType(); | ||||||
|             // PreCreatureSpawnEvent **should** not be called for DROPPED_ITEM, just for the sake of consistency |             if (!area.isMobSpawning()) { | ||||||
|             if (type == EntityType.DROPPED_ITEM) { |                 switch (type) { | ||||||
|  |                     case DROPPED_ITEM: | ||||||
|                         if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { |                         if (Settings.Enabled_Components.KILL_ROAD_ITEMS) { | ||||||
|  |                             event.setShouldAbortSpawn(true); | ||||||
|                             event.setCancelled(true); |                             event.setCancelled(true); | ||||||
|                 } |  | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|             if (!area.isMobSpawning()) { |                     case PLAYER: | ||||||
|                 if (type == EntityType.PLAYER) { |  | ||||||
|                         return; |                         return; | ||||||
|                 } |                 } | ||||||
|                 if (type.isAlive()) { |                 if (type.isAlive()) { | ||||||
| @@ -404,50 +407,4 @@ public class PaperListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(ignoreCancelled = true) |  | ||||||
|     public void onBeaconEffect(final BeaconEffectEvent event) { |  | ||||||
|         Block block = event.getBlock(); |  | ||||||
|         Location beaconLocation = BukkitUtil.adapt(block.getLocation()); |  | ||||||
|         Plot beaconPlot = beaconLocation.getPlot(); |  | ||||||
|  |  | ||||||
|         PlotArea area = beaconLocation.getPlotArea(); |  | ||||||
|         if (area == null) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         Player player = event.getPlayer(); |  | ||||||
|         Location playerLocation = BukkitUtil.adapt(player.getLocation()); |  | ||||||
|  |  | ||||||
|         PlotPlayer<Player> plotPlayer = BukkitUtil.adapt(player); |  | ||||||
|         Plot playerStandingPlot = playerLocation.getPlot(); |  | ||||||
|         if (playerStandingPlot == null) { |  | ||||||
|             FlagContainer container = area.getRoadFlagContainer(); |  | ||||||
|             if (!getBooleanFlagValue(container, BeaconEffectsFlag.class, true) || |  | ||||||
|                     (beaconPlot != null && Settings.Enabled_Components.DISABLE_BEACON_EFFECT_OVERFLOW)) { |  | ||||||
|                 event.setCancelled(true); |  | ||||||
|             } |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         FlagContainer container = playerStandingPlot.getFlagContainer(); |  | ||||||
|         boolean plotBeaconEffects = getBooleanFlagValue(container, BeaconEffectsFlag.class, true); |  | ||||||
|         if (playerStandingPlot.equals(beaconPlot)) { |  | ||||||
|             if (!plotBeaconEffects) { |  | ||||||
|                 event.setCancelled(true); |  | ||||||
|             } |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         if (!plotBeaconEffects || Settings.Enabled_Components.DISABLE_BEACON_EFFECT_OVERFLOW) { |  | ||||||
|             event.setCancelled(true); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private boolean getBooleanFlagValue(@NonNull FlagContainer container, |  | ||||||
|                                         @NonNull Class<? extends BooleanFlag<?>> flagClass, |  | ||||||
|                                         boolean defaultValue) { |  | ||||||
|         BooleanFlag<?> flag = container.getFlag(flagClass); |  | ||||||
|         return flag == null ? defaultValue : flag.getValue(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -82,7 +89,6 @@ import org.bukkit.Bukkit; | |||||||
| import org.bukkit.ChatColor; | import org.bukkit.ChatColor; | ||||||
| import org.bukkit.FluidCollisionMode; | import org.bukkit.FluidCollisionMode; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
| import org.bukkit.Tag; |  | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.BlockFace; | import org.bukkit.block.BlockFace; | ||||||
| import org.bukkit.block.BlockState; | import org.bukkit.block.BlockState; | ||||||
| @@ -106,7 +112,6 @@ import org.bukkit.event.Listener; | |||||||
| import org.bukkit.event.block.Action; | import org.bukkit.event.block.Action; | ||||||
| import org.bukkit.event.entity.EntityPickupItemEvent; | import org.bukkit.event.entity.EntityPickupItemEvent; | ||||||
| import org.bukkit.event.entity.EntityPlaceEvent; | import org.bukkit.event.entity.EntityPlaceEvent; | ||||||
| import org.bukkit.event.entity.EntityPotionEffectEvent; |  | ||||||
| import org.bukkit.event.entity.PlayerDeathEvent; | import org.bukkit.event.entity.PlayerDeathEvent; | ||||||
| import org.bukkit.event.hanging.HangingBreakByEntityEvent; | import org.bukkit.event.hanging.HangingBreakByEntityEvent; | ||||||
| import org.bukkit.event.hanging.HangingPlaceEvent; | import org.bukkit.event.hanging.HangingPlaceEvent; | ||||||
| @@ -143,41 +148,27 @@ import org.bukkit.inventory.meta.ItemMeta; | |||||||
| import org.bukkit.metadata.FixedMetadataValue; | import org.bukkit.metadata.FixedMetadataValue; | ||||||
| import org.bukkit.metadata.MetadataValue; | import org.bukkit.metadata.MetadataValue; | ||||||
| import org.bukkit.plugin.Plugin; | import org.bukkit.plugin.Plugin; | ||||||
| import org.bukkit.potion.PotionEffect; |  | ||||||
| import org.bukkit.util.Vector; | import org.bukkit.util.Vector; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.lang.reflect.Field; | import java.lang.reflect.Field; | ||||||
|  | import java.util.ArrayList; | ||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Locale; | import java.util.Locale; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  | import java.util.regex.Pattern; | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * Player Events involving plots. |  * Player Events involving plots. | ||||||
|  */ |  */ | ||||||
| @SuppressWarnings("unused") | @SuppressWarnings("unused") | ||||||
| public class PlayerEventListener implements Listener { | public class PlayerEventListener extends PlotListener implements Listener { | ||||||
|  |  | ||||||
|     private static final Set<Material> MINECARTS = Set.of( |  | ||||||
|             Material.MINECART, |  | ||||||
|             Material.TNT_MINECART, |  | ||||||
|             Material.CHEST_MINECART, |  | ||||||
|             Material.COMMAND_BLOCK_MINECART, |  | ||||||
|             Material.FURNACE_MINECART, |  | ||||||
|             Material.HOPPER_MINECART |  | ||||||
|     ); |  | ||||||
|     private static final Set<Material> BOOKS = Set.of( |  | ||||||
|             Material.BOOK, |  | ||||||
|             Material.KNOWLEDGE_BOOK, |  | ||||||
|             Material.WRITABLE_BOOK, |  | ||||||
|             Material.WRITTEN_BOOK |  | ||||||
|     ); |  | ||||||
|     private final EventDispatcher eventDispatcher; |     private final EventDispatcher eventDispatcher; | ||||||
|     private final WorldEdit worldEdit; |     private final WorldEdit worldEdit; | ||||||
|     private final PlotAreaManager plotAreaManager; |     private final PlotAreaManager plotAreaManager; | ||||||
|     private final PlotListener plotListener; |  | ||||||
|     // To prevent recursion |     // To prevent recursion | ||||||
|     private boolean tmpTeleport = true; |     private boolean tmpTeleport = true; | ||||||
|     private Field fieldPlayer; |     private Field fieldPlayer; | ||||||
| @@ -197,36 +188,12 @@ public class PlayerEventListener implements Listener { | |||||||
|     public PlayerEventListener( |     public PlayerEventListener( | ||||||
|             final @NonNull PlotAreaManager plotAreaManager, |             final @NonNull PlotAreaManager plotAreaManager, | ||||||
|             final @NonNull EventDispatcher eventDispatcher, |             final @NonNull EventDispatcher eventDispatcher, | ||||||
|             final @NonNull WorldEdit worldEdit, |             final @NonNull WorldEdit worldEdit | ||||||
|             final @NonNull PlotListener plotListener |  | ||||||
|     ) { |     ) { | ||||||
|  |         super(eventDispatcher); | ||||||
|         this.eventDispatcher = eventDispatcher; |         this.eventDispatcher = eventDispatcher; | ||||||
|         this.worldEdit = worldEdit; |         this.worldEdit = worldEdit; | ||||||
|         this.plotAreaManager = plotAreaManager; |         this.plotAreaManager = plotAreaManager; | ||||||
|         this.plotListener = plotListener; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @EventHandler(ignoreCancelled = true) |  | ||||||
|     public void onEffect(@NonNull EntityPotionEffectEvent event) { |  | ||||||
|         if (Settings.Enabled_Components.DISABLE_BEACON_EFFECT_OVERFLOW || |  | ||||||
|                 event.getCause() != EntityPotionEffectEvent.Cause.BEACON || |  | ||||||
|                 !(event.getEntity() instanceof Player player)) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         UUID uuid = player.getUniqueId(); |  | ||||||
|         PotionEffect effect = event.getNewEffect(); |  | ||||||
|         if (effect == null) { |  | ||||||
|             PotionEffect oldEffect = event.getOldEffect(); |  | ||||||
|             if (oldEffect != null) { |  | ||||||
|                 String name = oldEffect.getType().getName(); |  | ||||||
|                 plotListener.addEffect(uuid, name, -1); |  | ||||||
|             } |  | ||||||
|         } else { |  | ||||||
|             long expiresAt = System.currentTimeMillis() + effect.getDuration() * 50L; //Convert ticks to milliseconds |  | ||||||
|             String name = effect.getType().getName(); |  | ||||||
|             plotListener.addEffect(uuid, name, expiresAt); |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler | ||||||
| @@ -379,7 +346,7 @@ public class PlayerEventListener implements Listener { | |||||||
|         if (area != null) { |         if (area != null) { | ||||||
|             Plot plot = area.getPlot(location); |             Plot plot = area.getPlot(location); | ||||||
|             if (plot != null) { |             if (plot != null) { | ||||||
|                 plotListener.plotEntry(pp, plot); |                 plotEntry(pp, plot); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         // Delayed |         // Delayed | ||||||
| @@ -431,7 +398,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                 PlotArea area = location.getPlotArea(); |                 PlotArea area = location.getPlotArea(); | ||||||
|                 if (area == null) { |                 if (area == null) { | ||||||
|                     if (lastPlot != null) { |                     if (lastPlot != null) { | ||||||
|                         plotListener.plotExit(pp, lastPlot); |                         plotExit(pp, lastPlot); | ||||||
|                         lastPlotAccess.remove(); |                         lastPlotAccess.remove(); | ||||||
|                     } |                     } | ||||||
|                     try (final MetaDataAccess<Location> lastLocationAccess = |                     try (final MetaDataAccess<Location> lastLocationAccess = | ||||||
| @@ -565,7 +532,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             if (now == null) { |             if (now == null) { | ||||||
|                 try (final MetaDataAccess<Boolean> kickAccess = |                 try (final MetaDataAccess<Boolean> kickAccess = | ||||||
|                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { |                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { | ||||||
|                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { |                     if (lastPlot != null && !plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_EXIT_DENIED)) |                                 Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_EXIT_DENIED)) | ||||||
| @@ -583,7 +550,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                 } |                 } | ||||||
|             } else if (now.equals(lastPlot)) { |             } else if (now.equals(lastPlot)) { | ||||||
|                 ForceFieldListener.handleForcefield(player, pp, now); |                 ForceFieldListener.handleForcefield(player, pp, now); | ||||||
|             } else if (!plotListener.plotEntry(pp, now) && this.tmpTeleport) { |             } else if (!plotEntry(pp, now) && this.tmpTeleport) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("deny.no_enter"), |                         TranslatableCaption.of("deny.no_enter"), | ||||||
|                         Template.of("plot", now.toString()) |                         Template.of("plot", now.toString()) | ||||||
| @@ -655,7 +622,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 try (final MetaDataAccess<Boolean> kickAccess = |                 try (final MetaDataAccess<Boolean> kickAccess = | ||||||
|                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { |                              pp.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_KICK)) { | ||||||
|                     if (lastPlot != null && !plotListener.plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { |                     if (lastPlot != null && !plotExit(pp, lastPlot) && this.tmpTeleport && !kickAccess.get().orElse(false)) { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("permission.no_permission_event"), |                                 TranslatableCaption.of("permission.no_permission_event"), | ||||||
|                                 Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_EXIT_DENIED)) |                                 Template.of("node", String.valueOf(Permission.PERMISSION_ADMIN_EXIT_DENIED)) | ||||||
| @@ -673,7 +640,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                 } |                 } | ||||||
|             } else if (plot.equals(lastPlot)) { |             } else if (plot.equals(lastPlot)) { | ||||||
|                 ForceFieldListener.handleForcefield(player, pp, plot); |                 ForceFieldListener.handleForcefield(player, pp, plot); | ||||||
|             } else if (!plotListener.plotEntry(pp, plot) && this.tmpTeleport) { |             } else if (!plotEntry(pp, plot) && this.tmpTeleport) { | ||||||
|                 pp.sendMessage( |                 pp.sendMessage( | ||||||
|                         TranslatableCaption.of("deny.no_enter"), |                         TranslatableCaption.of("deny.no_enter"), | ||||||
|                         Template.of("plot", plot.toString()) |                         Template.of("plot", plot.toString()) | ||||||
| @@ -820,7 +787,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             lastLocationAccess.remove(); |             lastLocationAccess.remove(); | ||||||
|         } |         } | ||||||
|         if (plot != null) { |         if (plot != null) { | ||||||
|             plotListener.plotExit(pp, plot); |             plotExit(pp, plot); | ||||||
|         } |         } | ||||||
|         if (this.worldEdit != null) { |         if (this.worldEdit != null) { | ||||||
|             if (!Permissions.hasPermission(pp, Permission.PERMISSION_WORLDEDIT_BYPASS)) { |             if (!Permissions.hasPermission(pp, Permission.PERMISSION_WORLDEDIT_BYPASS)) { | ||||||
| @@ -834,7 +801,7 @@ public class PlayerEventListener implements Listener { | |||||||
|         if (location.isPlotArea()) { |         if (location.isPlotArea()) { | ||||||
|             plot = location.getPlot(); |             plot = location.getPlot(); | ||||||
|             if (plot != null) { |             if (plot != null) { | ||||||
|                 plotListener.plotEntry(pp, plot); |                 plotEntry(pp, plot); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -870,10 +837,10 @@ public class PlayerEventListener implements Listener { | |||||||
|         if ((slot > 8) || !event.getEventName().equals("InventoryCreativeEvent")) { |         if ((slot > 8) || !event.getEventName().equals("InventoryCreativeEvent")) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         ItemStack oldItem = inv.getItemInHand(); |         ItemStack current = inv.getItemInHand(); | ||||||
|         ItemMeta oldMeta = oldItem.getItemMeta(); |  | ||||||
|         ItemStack newItem = event.getCursor(); |         ItemStack newItem = event.getCursor(); | ||||||
|         ItemMeta newMeta = newItem.getItemMeta(); |         ItemMeta newMeta = newItem.getItemMeta(); | ||||||
|  |         ItemMeta oldMeta = newItem.getItemMeta(); | ||||||
|  |  | ||||||
|         if (event.getClick() == ClickType.CREATIVE) { |         if (event.getClick() == ClickType.CREATIVE) { | ||||||
|             final Plot plot = pp.getCurrentPlot(); |             final Plot plot = pp.getCurrentPlot(); | ||||||
| @@ -913,25 +880,33 @@ public class PlayerEventListener implements Listener { | |||||||
|                 oldLore = lore.toString(); |                 oldLore = lore.toString(); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         Material itemType = newItem.getType(); |         if (!"[(+NBT)]".equals(newLore) || (current.equals(newItem) && newLore.equals(oldLore))) { | ||||||
|         if (!"[(+NBT)]".equals(newLore) || (oldItem.equals(newItem) && newLore.equals(oldLore))) { |             switch (newItem.getType()) { | ||||||
|             if (newMeta == null || (itemType != Material.LEGACY_BANNER && itemType != Material.PLAYER_HEAD)) { |                 case LEGACY_BANNER: | ||||||
|  |                 case PLAYER_HEAD: | ||||||
|  |                     if (newMeta != null) { | ||||||
|  |                         break; | ||||||
|  |                     } | ||||||
|  |                 default: | ||||||
|                     return; |                     return; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         Block block = player.getTargetBlock(null, 7); |         Block block = player.getTargetBlock(null, 7); | ||||||
|         org.bukkit.block.BlockState state = block.getState(); |         org.bukkit.block.BlockState state = block.getState(); | ||||||
|         Material stateType = state.getType(); |         Material stateType = state.getType(); | ||||||
|  |         Material itemType = newItem.getType(); | ||||||
|         if (stateType != itemType) { |         if (stateType != itemType) { | ||||||
|             if (stateType == Material.LEGACY_WALL_BANNER || stateType == Material.LEGACY_STANDING_BANNER) { |             switch (stateType) { | ||||||
|                 if (itemType != Material.LEGACY_BANNER) { |                 case LEGACY_STANDING_BANNER: | ||||||
|                     return; |                 case LEGACY_WALL_BANNER: | ||||||
|  |                     if (itemType == Material.LEGACY_BANNER) { | ||||||
|  |                         break; | ||||||
|                     } |                     } | ||||||
|             } else if (stateType == Material.LEGACY_SKULL) { |                 case LEGACY_SKULL: | ||||||
|                 if (itemType != Material.LEGACY_SKULL_ITEM) { |                     if (itemType == Material.LEGACY_SKULL_ITEM) { | ||||||
|                     return; |                         break; | ||||||
|                     } |                     } | ||||||
|             } else { |                 default: | ||||||
|                     return; |                     return; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -971,7 +946,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (cancelled) { |         if (cancelled) { | ||||||
|             if ((oldItem.getType() == newItem.getType()) && (oldItem.getDurability() == newItem |             if ((current.getType() == newItem.getType()) && (current.getDurability() == newItem | ||||||
|                     .getDurability())) { |                     .getDurability())) { | ||||||
|                 event.setCursor( |                 event.setCursor( | ||||||
|                         new ItemStack(newItem.getType(), newItem.getAmount(), newItem.getDurability())); |                         new ItemStack(newItem.getType(), newItem.getAmount(), newItem.getDurability())); | ||||||
| @@ -1158,21 +1133,14 @@ public class PlayerEventListener implements Listener { | |||||||
|                     //Allow all players to eat while also allowing the block place event ot be fired |                     //Allow all players to eat while also allowing the block place event ot be fired | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|                 if (type == Material.ARMOR_STAND) { |                 switch (type) { | ||||||
|  |                     case ACACIA_BOAT, BIRCH_BOAT, CHEST_MINECART, COMMAND_BLOCK_MINECART, DARK_OAK_BOAT, FURNACE_MINECART, HOPPER_MINECART, JUNGLE_BOAT, MINECART, OAK_BOAT, SPRUCE_BOAT, TNT_MINECART -> eventType = PlayerBlockEventType.PLACE_VEHICLE; | ||||||
|  |                     case FIREWORK_ROCKET, FIREWORK_STAR -> eventType = PlayerBlockEventType.SPAWN_MOB; | ||||||
|  |                     case BOOK, KNOWLEDGE_BOOK, WRITABLE_BOOK, WRITTEN_BOOK -> eventType = PlayerBlockEventType.READ; | ||||||
|  |                     case ARMOR_STAND -> { | ||||||
|                         location = BukkitUtil.adapt(block.getRelative(event.getBlockFace()).getLocation()); |                         location = BukkitUtil.adapt(block.getRelative(event.getBlockFace()).getLocation()); | ||||||
|                         eventType = PlayerBlockEventType.PLACE_MISC; |                         eventType = PlayerBlockEventType.PLACE_MISC; | ||||||
|                     } |                     } | ||||||
|                 if (Tag.ITEMS_BOATS.isTagged(type) || MINECARTS.contains(type)) { |  | ||||||
|                     eventType = PlayerBlockEventType.PLACE_VEHICLE; |  | ||||||
|                     break; |  | ||||||
|                 } |  | ||||||
|                 if (type == Material.FIREWORK_ROCKET || type == Material.FIREWORK_STAR) { |  | ||||||
|                     eventType = PlayerBlockEventType.SPAWN_MOB; |  | ||||||
|                     break; |  | ||||||
|                 } |  | ||||||
|                 if (BOOKS.contains(type)) { |  | ||||||
|                     eventType = PlayerBlockEventType.READ; |  | ||||||
|                     break; |  | ||||||
|                 } |                 } | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
| @@ -1307,7 +1275,7 @@ public class PlayerEventListener implements Listener { | |||||||
|         TaskManager.removeFromTeleportQueue(event.getPlayer().getName()); |         TaskManager.removeFromTeleportQueue(event.getPlayer().getName()); | ||||||
|         BukkitPlayer pp = BukkitUtil.adapt(event.getPlayer()); |         BukkitPlayer pp = BukkitUtil.adapt(event.getPlayer()); | ||||||
|         pp.unregister(); |         pp.unregister(); | ||||||
|         plotListener.logout(pp.getUUID()); |         this.logout(pp.getUUID()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
| @@ -1744,7 +1712,6 @@ public class PlayerEventListener implements Listener { | |||||||
|         if (PlotSquared.get().getPlotAreaManager().getPlotAreasSet(world).size() == 0) { |         if (PlotSquared.get().getPlotAreaManager().getPlotAreasSet(world).size() == 0) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         BukkitPlayer pp = (event.getEntity() instanceof Player player) ? BukkitUtil.adapt(player) : null; |  | ||||||
|         int minX = Integer.MAX_VALUE; |         int minX = Integer.MAX_VALUE; | ||||||
|         int maxX = Integer.MIN_VALUE; |         int maxX = Integer.MIN_VALUE; | ||||||
|         int minZ = Integer.MAX_VALUE; |         int minZ = Integer.MAX_VALUE; | ||||||
| @@ -1766,10 +1733,6 @@ public class PlayerEventListener implements Listener { | |||||||
|             if (area == null) { |             if (area == null) { | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             if (area.notifyIfOutsideBuildArea(pp, location.getY())) { |  | ||||||
|                 event.setCancelled(true); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             Plot plot = location.getOwnedPlot(); |             Plot plot = location.getOwnedPlot(); | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (area.isRoadFlags() && area.getRoadFlag(DenyPortalsFlag.class)) { |                 if (area.isRoadFlags() && area.getRoadFlag(DenyPortalsFlag.class)) { | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -89,7 +96,7 @@ public class ProjectileEventListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @EventHandler(ignoreCancelled = true) |     @EventHandler | ||||||
|     public void onProjectileLaunch(ProjectileLaunchEvent event) { |     public void onProjectileLaunch(ProjectileLaunchEvent event) { | ||||||
|         Projectile entity = event.getEntity(); |         Projectile entity = event.getEntity(); | ||||||
|         ProjectileSource shooter = entity.getShooter(); |         ProjectileSource shooter = entity.getShooter(); | ||||||
| @@ -149,18 +156,6 @@ public class ProjectileEventListener implements Listener { | |||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         ProjectileSource shooter = entity.getShooter(); |         ProjectileSource shooter = entity.getShooter(); | ||||||
|         if (shooter instanceof Player) { |         if (shooter instanceof Player) { | ||||||
|             if (!((Player) shooter).isOnline()) { |  | ||||||
|                 if (plot != null) { |  | ||||||
|                     if (plot.isAdded(((Player) shooter).getUniqueId()) || plot.getFlag(ProjectilesFlag.class)) { |  | ||||||
|                         return; |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 entity.remove(); |  | ||||||
|                 event.setCancelled(true); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); |             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { |                 if (!Permissions.hasPermission(pp, Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED)) { | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,57 +0,0 @@ | |||||||
| /* |  | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  | ||||||
|  * |  | ||||||
|  * This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU General Public License |  | ||||||
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>. |  | ||||||
|  */ |  | ||||||
| package com.plotsquared.bukkit.listener; |  | ||||||
|  |  | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; |  | ||||||
| import com.plotsquared.core.location.Location; |  | ||||||
| import com.plotsquared.core.plot.Plot; |  | ||||||
| import com.plotsquared.core.plot.flag.FlagContainer; |  | ||||||
| import com.plotsquared.core.plot.flag.implementations.BeaconEffectsFlag; |  | ||||||
| import org.bukkit.entity.Entity; |  | ||||||
| import org.bukkit.event.EventHandler; |  | ||||||
| import org.bukkit.event.Listener; |  | ||||||
| import org.bukkit.event.entity.EntityPotionEffectEvent; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Fallback listener for paper events on spigot |  | ||||||
|  */ |  | ||||||
| public class SpigotListener implements Listener { |  | ||||||
|  |  | ||||||
|     @EventHandler(ignoreCancelled = true) |  | ||||||
|     public void onEffect(@NonNull EntityPotionEffectEvent event) { |  | ||||||
|         if (event.getCause() != EntityPotionEffectEvent.Cause.BEACON) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         Entity entity = event.getEntity(); |  | ||||||
|         Location location = BukkitUtil.adapt(entity.getLocation()); |  | ||||||
|         Plot plot = location.getPlot(); |  | ||||||
|         if (plot == null) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         FlagContainer container = plot.getFlagContainer(); |  | ||||||
|         BeaconEffectsFlag effectsEnabled = container.getFlag(BeaconEffectsFlag.class); |  | ||||||
|         if (effectsEnabled != null && !effectsEnabled.getValue()) { |  | ||||||
|             event.setCancelled(true); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -47,13 +54,13 @@ import org.bukkit.event.EventException; | |||||||
| import org.bukkit.event.player.PlayerTeleportEvent; | import org.bukkit.event.player.PlayerTeleportEvent; | ||||||
| import org.bukkit.permissions.PermissionAttachmentInfo; | import org.bukkit.permissions.PermissionAttachmentInfo; | ||||||
| import org.bukkit.plugin.RegisteredListener; | import org.bukkit.plugin.RegisteredListener; | ||||||
| import org.bukkit.potion.PotionEffectType; |  | ||||||
| import org.checkerframework.checker.index.qual.NonNegative; | import org.checkerframework.checker.index.qual.NonNegative; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
| import static com.sk89q.worldedit.world.gamemode.GameModes.ADVENTURE; | import static com.sk89q.worldedit.world.gamemode.GameModes.ADVENTURE; | ||||||
| import static com.sk89q.worldedit.world.gamemode.GameModes.CREATIVE; | import static com.sk89q.worldedit.world.gamemode.GameModes.CREATIVE; | ||||||
| @@ -348,14 +355,6 @@ public class BukkitPlayer extends PlotPlayer<Player> { | |||||||
|         return BukkitUtil.BUKKIT_AUDIENCES.player(this.player); |         return BukkitUtil.BUKKIT_AUDIENCES.player(this.player); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public void removeEffect(@NonNull String name) { |  | ||||||
|         PotionEffectType type = PotionEffectType.getByName(name); |  | ||||||
|         if (type != null) { |  | ||||||
|             player.removePotionEffect(type); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean canSee(final PlotPlayer<?> other) { |     public boolean canSee(final PlotPlayer<?> other) { | ||||||
|         if (other instanceof ConsolePlayer) { |         if (other instanceof ConsolePlayer) { | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -85,9 +92,9 @@ public final class BukkitChunkCoordinator extends ChunkCoordinator { | |||||||
|             @Assisted final @NonNull Collection<BlockVector2> requestedChunks, |             @Assisted final @NonNull Collection<BlockVector2> requestedChunks, | ||||||
|             @Assisted final @NonNull Runnable whenDone, |             @Assisted final @NonNull Runnable whenDone, | ||||||
|             @Assisted final @NonNull Consumer<Throwable> throwableConsumer, |             @Assisted final @NonNull Consumer<Throwable> throwableConsumer, | ||||||
|             @Assisted("unloadAfter") final boolean unloadAfter, |             @Assisted final boolean unloadAfter, | ||||||
|             @Assisted final @NonNull Collection<ProgressSubscriber> progressSubscribers, |             @Assisted final @NonNull Collection<ProgressSubscriber> progressSubscribers, | ||||||
|             @Assisted("forceSync") final boolean forceSync |             @Assisted final boolean forceSync | ||||||
|     ) { |     ) { | ||||||
|         this.requestedChunks = new LinkedBlockingQueue<>(requestedChunks); |         this.requestedChunks = new LinkedBlockingQueue<>(requestedChunks); | ||||||
|         this.availableChunks = new LinkedBlockingQueue<>(); |         this.availableChunks = new LinkedBlockingQueue<>(); | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -228,7 +235,6 @@ public class BukkitQueueCoordinator extends BasicQueueCoordinator { | |||||||
|                         .withConsumer(consumer) |                         .withConsumer(consumer) | ||||||
|                         .unloadAfter(isUnloadAfter()) |                         .unloadAfter(isUnloadAfter()) | ||||||
|                         .withProgressSubscribers(getProgressSubscribers()) |                         .withProgressSubscribers(getProgressSubscribers()) | ||||||
|                         .forceSync(isForceSync()) |  | ||||||
|                         .build(); |                         .build(); | ||||||
|         return super.enqueue(); |         return super.enqueue(); | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -19,12 +26,12 @@ | |||||||
| package com.plotsquared.bukkit.queue; | package com.plotsquared.bukkit.queue; | ||||||
|  |  | ||||||
| import com.google.common.base.Preconditions; | import com.google.common.base.Preconditions; | ||||||
| import com.intellectualsites.annotations.DoNotUse; |  | ||||||
| import com.plotsquared.bukkit.util.BukkitBlockUtil; | import com.plotsquared.bukkit.util.BukkitBlockUtil; | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
| import com.plotsquared.core.location.ChunkWrapper; | import com.plotsquared.core.location.ChunkWrapper; | ||||||
| import com.plotsquared.core.location.Location; | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.queue.ScopedQueueCoordinator; | import com.plotsquared.core.queue.ScopedQueueCoordinator; | ||||||
|  | import com.plotsquared.core.util.AnnotationHelper; | ||||||
| import com.plotsquared.core.util.ChunkUtil; | import com.plotsquared.core.util.ChunkUtil; | ||||||
| import com.plotsquared.core.util.PatternUtil; | import com.plotsquared.core.util.PatternUtil; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| @@ -44,7 +51,7 @@ import org.checkerframework.checker.nullness.qual.Nullable; | |||||||
|  |  | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
|  |  | ||||||
| @DoNotUse | @AnnotationHelper.ApiDescription(info = "Internal use only. Subject to changes at any time.") | ||||||
| public class GenChunk extends ScopedQueueCoordinator { | public class GenChunk extends ScopedQueueCoordinator { | ||||||
|  |  | ||||||
|     public final Biome[] biomes; |     public final Biome[] biomes; | ||||||
| @@ -103,7 +110,7 @@ public class GenChunk extends ScopedQueueCoordinator { | |||||||
|     /** |     /** | ||||||
|      * Set the world and XZ of the chunk being represented via {@link ChunkWrapper} |      * Set the world and XZ of the chunk being represented via {@link ChunkWrapper} | ||||||
|      * |      * | ||||||
|      * @param wrap PlotSquared ChunkWrapper |      * @param wrap P2 ChunkWrapper | ||||||
|      */ |      */ | ||||||
|     public void setChunk(@NonNull ChunkWrapper wrap) { |     public void setChunk(@NonNull ChunkWrapper wrap) { | ||||||
|         chunk = null; |         chunk = null; | ||||||
|   | |||||||
| @@ -1,121 +0,0 @@ | |||||||
| /* |  | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  | ||||||
|  * |  | ||||||
|  * This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU General Public License |  | ||||||
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>. |  | ||||||
|  */ |  | ||||||
| package com.plotsquared.bukkit.queue; |  | ||||||
|  |  | ||||||
| import com.plotsquared.bukkit.schematic.StateWrapper; |  | ||||||
| import com.plotsquared.core.queue.DelegateQueueCoordinator; |  | ||||||
| import com.sk89q.jnbt.CompoundTag; |  | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; |  | ||||||
| import com.sk89q.worldedit.entity.Entity; |  | ||||||
| import com.sk89q.worldedit.function.pattern.Pattern; |  | ||||||
| import com.sk89q.worldedit.math.BlockVector3; |  | ||||||
| import com.sk89q.worldedit.world.block.BaseBlock; |  | ||||||
| import com.sk89q.worldedit.world.block.BlockState; |  | ||||||
| import org.apache.logging.log4j.LogManager; |  | ||||||
| import org.apache.logging.log4j.Logger; |  | ||||||
| import org.bukkit.Location; |  | ||||||
| import org.bukkit.entity.EntityType; |  | ||||||
| import org.bukkit.generator.LimitedRegion; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Wraps a {@link LimitedRegion} inside a {@link com.plotsquared.core.queue.QueueCoordinator} so it can be written to. |  | ||||||
|  * |  | ||||||
|  * @since 6.9.0 |  | ||||||
|  */ |  | ||||||
| public class LimitedRegionWrapperQueue extends DelegateQueueCoordinator { |  | ||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + LimitedRegionWrapperQueue.class.getSimpleName()); |  | ||||||
|  |  | ||||||
|     private final LimitedRegion limitedRegion; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * @since 6.9.0 |  | ||||||
|      */ |  | ||||||
|     public LimitedRegionWrapperQueue(LimitedRegion limitedRegion) { |  | ||||||
|         super(null); |  | ||||||
|         this.limitedRegion = limitedRegion; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean setBlock(final int x, final int y, final int z, @NonNull final Pattern pattern) { |  | ||||||
|         return setBlock(x, y, z, pattern.applyBlock(BlockVector3.at(x, y, z))); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean setBlock(final int x, final int y, final int z, @NonNull final BaseBlock id) { |  | ||||||
|         boolean result = setBlock(x, y, z, id.toImmutableState()); |  | ||||||
|         if (result && id.hasNbtData()) { |  | ||||||
|             CompoundTag tag = id.getNbtData(); |  | ||||||
|             StateWrapper sw = new StateWrapper(tag); |  | ||||||
|             try { |  | ||||||
|                 sw.restoreTag(limitedRegion.getBlockState(x, y, z).getBlock()); |  | ||||||
|             } catch (IllegalArgumentException e) { |  | ||||||
|                 LOGGER.error("Error attempting to populate tile entity into the world at location {},{},{}", x, y, z, e); |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean setBlock(final int x, final int y, final int z, @NonNull final BlockState id) { |  | ||||||
|         try { |  | ||||||
|             limitedRegion.setType(x, y, z, BukkitAdapter.adapt(id.getBlockType())); |  | ||||||
|             limitedRegion.setBlockData(x, y, z, BukkitAdapter.adapt(id)); |  | ||||||
|         } catch (IllegalArgumentException e) { |  | ||||||
|             LOGGER.error("Error attempting to populate block into the world at location {},{},{}", x, y, z, e); |  | ||||||
|             return false; |  | ||||||
|         } |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean setEntity(@NonNull final Entity entity) { |  | ||||||
|         EntityType type = BukkitAdapter.adapt(entity.getState().getType()); |  | ||||||
|         double x = entity.getLocation().getX(); |  | ||||||
|         double y = entity.getLocation().getY(); |  | ||||||
|         double z = entity.getLocation().getZ(); |  | ||||||
|         Location location = new Location(limitedRegion.getWorld(), x, y, z); |  | ||||||
|         try { |  | ||||||
|             limitedRegion.spawnEntity(location, type); |  | ||||||
|         } catch (IllegalArgumentException e) { |  | ||||||
|             LOGGER.error("Error attempting to populate entity into the world at location {},{},{}", (int) x, (int) y, (int) z, e); |  | ||||||
|             return false; |  | ||||||
|         } |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean setTile(final int x, final int y, final int z, @NonNull final CompoundTag tag) { |  | ||||||
|         StateWrapper sw = new StateWrapper(tag); |  | ||||||
|         try { |  | ||||||
|             return sw.restoreTag(limitedRegion.getBlockState(x, y, z).getBlock()); |  | ||||||
|         } catch (IllegalArgumentException e) { |  | ||||||
|             LOGGER.error("Error attempting to populate tile entity into the world at location {},{},{}", x, y, z, e); |  | ||||||
|             return false; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public boolean isSettingTiles() { |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -28,13 +35,11 @@ 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 org.bukkit.Bukkit; |  | ||||||
| import org.bukkit.ChatColor; | import org.bukkit.ChatColor; | ||||||
| import org.bukkit.World; | import org.bukkit.World; | ||||||
| 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.enchantments.Enchantment; | import org.bukkit.enchantments.Enchantment; | ||||||
| import org.bukkit.inventory.Inventory; | import org.bukkit.inventory.Inventory; | ||||||
| import org.bukkit.inventory.InventoryHolder; | import org.bukkit.inventory.InventoryHolder; | ||||||
| @@ -52,11 +57,6 @@ public class StateWrapper { | |||||||
|     public org.bukkit.block.BlockState state = null; |     public org.bukkit.block.BlockState state = null; | ||||||
|     public CompoundTag tag = null; |     public CompoundTag tag = null; | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * @deprecated in favour of using WE methods for obtaining NBT, specifically by obtaining a |  | ||||||
|      *         {@link com.sk89q.worldedit.world.block.BaseBlock} and then using {@link com.sk89q.worldedit.world.block.BaseBlock#getNbtData()} |  | ||||||
|      */ |  | ||||||
|     @Deprecated(forRemoval = true, since = "6.9.0") |  | ||||||
|     public StateWrapper(org.bukkit.block.BlockState state) { |     public StateWrapper(org.bukkit.block.BlockState state) { | ||||||
|         this.state = state; |         this.state = state; | ||||||
|     } |     } | ||||||
| @@ -230,37 +230,10 @@ public class StateWrapper { | |||||||
|                 } |                 } | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|             case "skull" -> { |  | ||||||
|                 if (state instanceof Skull skull) { |  | ||||||
|                     CompoundTag skullOwner = ((CompoundTag) this.tag.getValue().get("SkullOwner")); |  | ||||||
|                     if (skullOwner == null) { |  | ||||||
|                         return true; |  | ||||||
|                     } |  | ||||||
|                     String player = skullOwner.getString("Name"); |  | ||||||
|                     if (player == null || player.isEmpty()) { |  | ||||||
|                         return false; |  | ||||||
|                     } |  | ||||||
|                     try { |  | ||||||
|                         skull.setOwningPlayer(Bukkit.getOfflinePlayer(player)); |  | ||||||
|                         skull.update(true); |  | ||||||
|                     } catch (Exception e) { |  | ||||||
|                         e.printStackTrace(); |  | ||||||
|                     } |  | ||||||
|                     return true; |  | ||||||
|                 } |  | ||||||
|                 return false; |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Get a CompoundTag of the contents of a block's inventory (chest, furnace, etc.). |  | ||||||
|      * |  | ||||||
|      * @deprecated in favour of using WorldEdit methods for obtaining NBT, specifically by obtaining a |  | ||||||
|      *         {@link com.sk89q.worldedit.world.block.BaseBlock} and then using {@link com.sk89q.worldedit.world.block.BaseBlock#getNbtData()} |  | ||||||
|      */ |  | ||||||
|     @Deprecated(forRemoval = true, since = "6.9.0") |  | ||||||
|     public CompoundTag getTag() { |     public CompoundTag getTag() { | ||||||
|         if (this.tag != null) { |         if (this.tag != null) { | ||||||
|             return this.tag; |             return this.tag; | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -58,7 +65,6 @@ import org.bukkit.block.BlockFace; | |||||||
| import org.bukkit.block.Sign; | import org.bukkit.block.Sign; | ||||||
| import org.bukkit.block.data.Directional; | import org.bukkit.block.data.Directional; | ||||||
| import org.bukkit.block.data.type.WallSign; | import org.bukkit.block.data.type.WallSign; | ||||||
| import org.bukkit.entity.Allay; |  | ||||||
| import org.bukkit.entity.Ambient; | import org.bukkit.entity.Ambient; | ||||||
| import org.bukkit.entity.Animals; | import org.bukkit.entity.Animals; | ||||||
| import org.bukkit.entity.AreaEffectCloud; | import org.bukkit.entity.AreaEffectCloud; | ||||||
| @@ -438,9 +444,6 @@ public class BukkitUtil extends WorldUtil { | |||||||
|                 allowedInterfaces.add(Animals.class); |                 allowedInterfaces.add(Animals.class); | ||||||
|                 allowedInterfaces.add(WaterMob.class); |                 allowedInterfaces.add(WaterMob.class); | ||||||
|                 allowedInterfaces.add(Ambient.class); |                 allowedInterfaces.add(Ambient.class); | ||||||
|                 if (PlotSquared.platform().serverVersion()[1] >= 19) { |  | ||||||
|                     allowedInterfaces.add(Allay.class); |  | ||||||
|                 } |  | ||||||
|             } |             } | ||||||
|             case "tameable" -> allowedInterfaces.add(Tameable.class); |             case "tameable" -> allowedInterfaces.add(Tameable.class); | ||||||
|             case "vehicle" -> allowedInterfaces.add(Vehicle.class); |             case "vehicle" -> allowedInterfaces.add(Vehicle.class); | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -55,7 +55,7 @@ further defined and clarified by project maintainers. | |||||||
| ## Enforcement | ## Enforcement | ||||||
|  |  | ||||||
| Instances of abusive, harassing, or otherwise unacceptable behavior may be | Instances of abusive, harassing, or otherwise unacceptable behavior may be | ||||||
| reported by contacting the project team at contact@intellectualsites.com. All | reported by contacting the project team at contact@alexander-soderberg.com. All | ||||||
| complaints will be reviewed and investigated and will result in a response that | complaints will be reviewed and investigated and will result in a response that | ||||||
| is deemed necessary and appropriate to the circumstances. The project team is | is deemed necessary and appropriate to the circumstances. The project team is | ||||||
| obligated to maintain confidentiality with regard to the reporter of an incident. | obligated to maintain confidentiality with regard to the reporter of an incident. | ||||||
|   | |||||||
| @@ -2,18 +2,18 @@ import java.time.format.DateTimeFormatter | |||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|     // Expected everywhere. |     // Expected everywhere. | ||||||
|     compileOnlyApi("org.checkerframework:checker-qual") |     compileOnlyApi(libs.checkerqual) | ||||||
|  |  | ||||||
|     // Minecraft expectations |     // Minecraft expectations | ||||||
|     compileOnlyApi("com.google.code.gson:gson") |     compileOnlyApi(libs.gson) | ||||||
|     compileOnly("com.google.guava:guava") |     compileOnly(libs.guava) | ||||||
|  |  | ||||||
|     // Platform expectations |     // Platform expectations | ||||||
|     compileOnlyApi("org.yaml:snakeyaml") |     compileOnlyApi(libs.snakeyaml) | ||||||
|  |  | ||||||
|     // Adventure |     // Adventure | ||||||
|     api("net.kyori:adventure-api") |     api(libs.adventure) | ||||||
|     api("net.kyori:adventure-text-minimessage") |     api(libs.minimessage) | ||||||
|  |  | ||||||
|     // Guice |     // Guice | ||||||
|     api(libs.guice) { |     api(libs.guice) { | ||||||
| @@ -31,19 +31,18 @@ dependencies { | |||||||
|         exclude(group = "dummypermscompat") |         exclude(group = "dummypermscompat") | ||||||
|     } |     } | ||||||
|     testImplementation(libs.worldeditCore) |     testImplementation(libs.worldeditCore) | ||||||
|     compileOnly("com.fastasyncworldedit:FastAsyncWorldEdit-Core") { isTransitive = false } |     compileOnly(libs.fastasyncworldeditCore) { isTransitive = false } | ||||||
|     testImplementation("com.fastasyncworldedit:FastAsyncWorldEdit-Core") { isTransitive = false } |     testImplementation(libs.fastasyncworldeditCore) { isTransitive = false } | ||||||
|  |  | ||||||
|     // Logging |     // Logging | ||||||
|     compileOnlyApi("org.apache.logging.log4j:log4j-api") |     compileOnlyApi(libs.log4j) | ||||||
|  |  | ||||||
|     // Other libraries |     // Other libraries | ||||||
|     api(libs.prtree) |     api(libs.prtree) | ||||||
|     api(libs.aopalliance) |     api(libs.aopalliance) | ||||||
|     api(libs.cloudServices) |     api(libs.cloudServices) | ||||||
|     api(libs.arkitektonika) |     api(libs.arkitektonika) | ||||||
|     api("com.intellectualsites.paster:Paster") |     api(libs.paster) | ||||||
|     api("com.intellectualsites.informative-annotations:informative-annotations") |  | ||||||
| } | } | ||||||
|  |  | ||||||
| tasks.processResources { | tasks.processResources { | ||||||
| @@ -60,10 +59,8 @@ tasks { | |||||||
|     withType<Javadoc> { |     withType<Javadoc> { | ||||||
|         val opt = options as StandardJavadocDocletOptions |         val opt = options as StandardJavadocDocletOptions | ||||||
|         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-core/" + libs.worldeditCore.get().versionConstraint.toString()) |         opt.links("https://docs.enginehub.org/javadoc/com.sk89q.worldedit/worldedit-core/" + libs.worldeditCore.get().versionConstraint.toString()) | ||||||
|         opt.links("https://jd.adventure.kyori.net/api/4.9.3/") |         opt.links("https://jd.adventure.kyori.net/api/" + libs.adventure.get().versionConstraint.toString()) | ||||||
|         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.encoding("UTF-8") |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -22,7 +29,6 @@ import cloud.commandframework.services.ServicePipeline; | |||||||
| import com.google.inject.Injector; | import com.google.inject.Injector; | ||||||
| import com.google.inject.Key; | import com.google.inject.Key; | ||||||
| import com.google.inject.TypeLiteral; | import com.google.inject.TypeLiteral; | ||||||
| import com.intellectualsites.annotations.DoNotUse; |  | ||||||
| import com.plotsquared.core.backup.BackupManager; | import com.plotsquared.core.backup.BackupManager; | ||||||
| import com.plotsquared.core.configuration.caption.LocaleHolder; | import com.plotsquared.core.configuration.caption.LocaleHolder; | ||||||
| import com.plotsquared.core.generator.GeneratorWrapper; | import com.plotsquared.core.generator.GeneratorWrapper; | ||||||
| @@ -34,6 +40,7 @@ import com.plotsquared.core.permissions.PermissionHandler; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.queue.GlobalBlockQueue; | import com.plotsquared.core.queue.GlobalBlockQueue; | ||||||
|  | import com.plotsquared.core.util.AnnotationHelper; | ||||||
| import com.plotsquared.core.util.ChunkManager; | import com.plotsquared.core.util.ChunkManager; | ||||||
| import com.plotsquared.core.util.EconHandler; | import com.plotsquared.core.util.EconHandler; | ||||||
| import com.plotsquared.core.util.PlatformWorldManager; | import com.plotsquared.core.util.PlatformWorldManager; | ||||||
| @@ -75,11 +82,6 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|      */ |      */ | ||||||
|     void shutdown(); |     void shutdown(); | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Completely shuts down the server. |  | ||||||
|      */ |  | ||||||
|     void shutdownServer(); |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Get the name of the plugin |      * Get the name of the plugin | ||||||
|      * |      * | ||||||
| @@ -313,7 +315,7 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|      * @return worldedit implementations |      * @return worldedit implementations | ||||||
|      * @since 6.3.0 |      * @since 6.3.0 | ||||||
|      */ |      */ | ||||||
|     @DoNotUse |     @AnnotationHelper.ApiDescription(info = "Internal use only") | ||||||
|     @NonNull String worldEditImplementations(); |     @NonNull String worldEditImplementations(); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
| @@ -357,9 +359,9 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|     @NonNull String toLegacyPlatformString(@NonNull Component component); |     @NonNull String toLegacyPlatformString(@NonNull Component component); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Returns if the FastAsyncWorldEdit-PlotSquared hook is active/enabled |      * Returns if the FAWE-P2 hook is active/enabled | ||||||
|      * |      * | ||||||
|      * @return status of FastAsyncWorldEdit-PlotSquared hook |      * @return status of FAWE-P2 hook | ||||||
|      */ |      */ | ||||||
|     default boolean isFaweHooking() { |     default boolean isFaweHooking() { | ||||||
|         return false; |         return false; | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
| @@ -65,10 +72,7 @@ import com.plotsquared.core.util.ReflectionUtils; | |||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import com.plotsquared.core.uuid.UUIDPipeline; | import com.plotsquared.core.uuid.UUIDPipeline; | ||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
| import com.sk89q.worldedit.event.platform.PlatformReadyEvent; |  | ||||||
| import com.sk89q.worldedit.math.BlockVector2; | import com.sk89q.worldedit.math.BlockVector2; | ||||||
| import com.sk89q.worldedit.util.eventbus.EventHandler; |  | ||||||
| import com.sk89q.worldedit.util.eventbus.Subscribe; |  | ||||||
| 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.checkerframework.checker.nullness.qual.MonotonicNonNull; | import org.checkerframework.checker.nullness.qual.MonotonicNonNull; | ||||||
| @@ -149,8 +153,6 @@ public class PlotSquared { | |||||||
|     private EventDispatcher eventDispatcher; |     private EventDispatcher eventDispatcher; | ||||||
|     private PlotListener plotListener; |     private PlotListener plotListener; | ||||||
|  |  | ||||||
|     private boolean weInitialised; |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Initialize PlotSquared with the desired Implementation class. |      * Initialize PlotSquared with the desired Implementation class. | ||||||
|      * |      * | ||||||
| @@ -197,9 +199,6 @@ public class PlotSquared { | |||||||
|             this.loadCaptionMap(); |             this.loadCaptionMap(); | ||||||
|         } catch (final Exception e) { |         } catch (final Exception e) { | ||||||
|             LOGGER.error("Failed to load caption map", e); |             LOGGER.error("Failed to load caption map", e); | ||||||
|             LOGGER.error("Shutting down server to prevent further issues"); |  | ||||||
|             this.platform.shutdownServer(); |  | ||||||
|             throw new RuntimeException("Abort loading PlotSquared"); |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // Setup the global flag container |         // Setup the global flag container | ||||||
| @@ -224,7 +223,6 @@ public class PlotSquared { | |||||||
|             } |             } | ||||||
|  |  | ||||||
|             this.worldedit = WorldEdit.getInstance(); |             this.worldedit = WorldEdit.getInstance(); | ||||||
|             WorldEdit.getInstance().getEventBus().register(new WEPlatformReadyListener()); |  | ||||||
|  |  | ||||||
|             // Create Event utility class |             // Create Event utility class | ||||||
|             this.eventDispatcher = new EventDispatcher(this.worldedit); |             this.eventDispatcher = new EventDispatcher(this.worldedit); | ||||||
| @@ -270,7 +268,7 @@ public class PlotSquared { | |||||||
|             captionMap = this.captionLoader.loadAll(this.platform.getDirectory().toPath().resolve("lang")); |             captionMap = this.captionLoader.loadAll(this.platform.getDirectory().toPath().resolve("lang")); | ||||||
|         } else { |         } else { | ||||||
|             String fileName = "messages_" + Settings.Enabled_Components.DEFAULT_LOCALE + ".json"; |             String fileName = "messages_" + Settings.Enabled_Components.DEFAULT_LOCALE + ".json"; | ||||||
|             captionMap = this.captionLoader.loadOrCreateSingle(this.platform.getDirectory().toPath().resolve("lang").resolve(fileName)); |             captionMap = this.captionLoader.loadSingle(this.platform.getDirectory().toPath().resolve("lang").resolve(fileName)); | ||||||
|         } |         } | ||||||
|         this.captionMaps.put(TranslatableCaption.DEFAULT_NAMESPACE, captionMap); |         this.captionMaps.put(TranslatableCaption.DEFAULT_NAMESPACE, captionMap); | ||||||
|         LOGGER.info( |         LOGGER.info( | ||||||
| @@ -1576,13 +1574,6 @@ public class PlotSquared { | |||||||
|         return this.plotListener; |         return this.plotListener; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Get if the {@link PlatformReadyEvent} has been sent by WorldEdit. There is no way to query this within WorldEdit itself. |  | ||||||
|      */ |  | ||||||
|     public boolean isWeInitialised() { |  | ||||||
|         return weInitialised; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Different ways of sorting {@link Plot plots} |      * Different ways of sorting {@link Plot plots} | ||||||
|      */ |      */ | ||||||
| @@ -1605,15 +1596,4 @@ public class PlotSquared { | |||||||
|         DISTANCE_FROM_ORIGIN |         DISTANCE_FROM_ORIGIN | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private final class WEPlatformReadyListener { |  | ||||||
|  |  | ||||||
|         @SuppressWarnings("unused") |  | ||||||
|         @Subscribe(priority = EventHandler.Priority.VERY_EARLY) |  | ||||||
|         public void onPlatformReady(PlatformReadyEvent event) { |  | ||||||
|             weInitialised = true; |  | ||||||
|             WorldEdit.getInstance().getEventBus().unregister(WEPlatformReadyListener.this); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| /* | /* | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  *       _____  _       _    _____                                _ | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  *      |  __ \| |     | |  / ____|                              | | | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  *      | |__) | | ___ | |_| (___   __ _ _   _  __ _ _ __ ___  __| | | ||||||
|  |  *      |  ___/| |/ _ \| __|\___ \ / _` | | | |/ _` | '__/ _ \/ _` | | ||||||
|  |  *      | |    | | (_) | |_ ____) | (_| | |_| | (_| | | |  __/ (_| | | ||||||
|  |  *      |_|    |_|\___/ \__|_____/ \__, |\__,_|\__,_|_|  \___|\__,_| | ||||||
|  |  *                                    | | | ||||||
|  |  *                                    |_| | ||||||
|  |  *            PlotSquared plot management system for Minecraft | ||||||
|  |  *               Copyright (C) 2014 - 2022 IntellectualSites | ||||||
|  * |  * | ||||||
|  *     This program is free software: you can redistribute it and/or modify |  *     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 |  *     it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user