mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-25 23:53:44 +02:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			renovate/w
			...
			fix/v7/faw
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 22974d6478 | ||
|   | 4924ffe03b | 
							
								
								
									
										6
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							| @@ -9,11 +9,11 @@ jobs: | |||||||
|         os: [ ubuntu-latest, windows-latest, macos-latest ] |         os: [ ubuntu-latest, windows-latest, macos-latest ] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout Repository |       - name: Checkout Repository | ||||||
|         uses: actions/checkout@v5 |         uses: actions/checkout@v4 | ||||||
|       - name: Validate Gradle Wrapper |       - name: Validate Gradle Wrapper | ||||||
|         uses: gradle/actions/wrapper-validation@v5 |         uses: gradle/actions/wrapper-validation@v4 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v5 |         uses: actions/setup-java@v4 | ||||||
|         with: |         with: | ||||||
|           distribution: temurin |           distribution: temurin | ||||||
|           java-version: 21 |           java-version: 21 | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -9,11 +9,11 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout Repository |       - name: Checkout Repository | ||||||
|         uses: actions/checkout@v5 |         uses: actions/checkout@v4 | ||||||
|       - name: Validate Gradle Wrapper |       - name: Validate Gradle Wrapper | ||||||
|         uses: gradle/actions/wrapper-validation@v5 |         uses: gradle/actions/wrapper-validation@v4 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v5 |         uses: actions/setup-java@v4 | ||||||
|         with: |         with: | ||||||
|           distribution: temurin |           distribution: temurin | ||||||
|           java-version: 21 |           java-version: 21 | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -20,17 +20,17 @@ jobs: | |||||||
|         language: [ 'java' ] |         language: [ 'java' ] | ||||||
|     steps: |     steps: | ||||||
|       - name: Checkout repository |       - name: Checkout repository | ||||||
|         uses: actions/checkout@v5 |         uses: actions/checkout@v4 | ||||||
|       - name: Setup Java |       - name: Setup Java | ||||||
|         uses: actions/setup-java@v5 |         uses: actions/setup-java@v4 | ||||||
|         with: |         with: | ||||||
|           distribution: temurin |           distribution: temurin | ||||||
|           java-version: 21 |           java-version: 21 | ||||||
|       - name: Initialize CodeQL |       - name: Initialize CodeQL | ||||||
|         uses: github/codeql-action/init@v4 |         uses: github/codeql-action/init@v3 | ||||||
|         with: |         with: | ||||||
|           languages: ${{ matrix.language }} |           languages: ${{ matrix.language }} | ||||||
|       - name: Autobuild |       - name: Autobuild | ||||||
|         uses: github/codeql-action/autobuild@v4 |         uses: github/codeql-action/autobuild@v3 | ||||||
|       - name: Perform CodeQL Analysis |       - name: Perform CodeQL Analysis | ||||||
|         uses: github/codeql-action/analyze@v4 |         uses: github/codeql-action/analyze@v3 | ||||||
|   | |||||||
| @@ -17,19 +17,6 @@ repositories { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| // Make sure we control the exact version of paper being included, while dropping spigot + bukkit |  | ||||||
| configurations.all { |  | ||||||
|     exclude("org.bukkit") |  | ||||||
|     exclude("org.spigotmc") |  | ||||||
|  |  | ||||||
|     resolutionStrategy.eachDependency { |  | ||||||
|         if (requested.group == "io.papermc.paper" && requested.name == "paper-api") { |  | ||||||
|             useVersion(checkNotNull(libs.paper.orNull?.version)) |  | ||||||
|             because("specific paper version is required to prevent binary incompatibilities on older versions") |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| dependencies { | dependencies { | ||||||
|     api(projects.plotsquaredCore) |     api(projects.plotsquaredCore) | ||||||
|  |  | ||||||
| @@ -41,13 +28,20 @@ dependencies { | |||||||
|     implementation(libs.paperlib) |     implementation(libs.paperlib) | ||||||
|  |  | ||||||
|     // Plugins |     // Plugins | ||||||
|     compileOnly(libs.worldeditBukkit) |     compileOnly(libs.worldeditBukkit) { | ||||||
|  |         exclude(group = "org.bukkit") | ||||||
|  |         exclude(group = "org.spigotmc") | ||||||
|  |     } | ||||||
|     compileOnly(libs.faweBukkit) { isTransitive = false } |     compileOnly(libs.faweBukkit) { isTransitive = false } | ||||||
|     testImplementation(libs.faweBukkit) { isTransitive = false } |     testImplementation(libs.faweBukkit) { isTransitive = false } | ||||||
|     compileOnly(libs.vault) |     compileOnly(libs.vault) { | ||||||
|  |         exclude(group = "org.bukkit") | ||||||
|  |     } | ||||||
|     compileOnly(libs.placeholderapi) |     compileOnly(libs.placeholderapi) | ||||||
|     compileOnly(libs.luckperms) |     compileOnly(libs.luckperms) | ||||||
|     compileOnly(libs.essentialsx) |     compileOnly(libs.essentialsx) { | ||||||
|  |         exclude(group = "org.spigotmc") | ||||||
|  |     } | ||||||
|     compileOnly(libs.mvdwapi) { isTransitive = false } |     compileOnly(libs.mvdwapi) { isTransitive = false } | ||||||
|  |  | ||||||
|     // Other libraries |     // Other libraries | ||||||
|   | |||||||
| @@ -160,7 +160,7 @@ public class EntityEventListener implements Listener { | |||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SILVERFISH_BLOCK", "ENDER_PEARL", |             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL", | ||||||
|                  "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN", "NETHER_PORTAL", |                  "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN", "NETHER_PORTAL", | ||||||
|                  "FROZEN", "SPELL", "DEFAULT" -> { |                  "FROZEN", "SPELL", "DEFAULT" -> { | ||||||
|                 if (!area.isMobSpawning()) { |                 if (!area.isMobSpawning()) { | ||||||
|   | |||||||
| @@ -202,7 +202,7 @@ public class PaperListener implements Listener { | |||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SILVERFISH_BLOCK", "ENDER_PEARL", "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN" -> { |             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL", "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN" -> { | ||||||
|                 if (!area.isMobSpawning()) { |                 if (!area.isMobSpawning()) { | ||||||
|                     event.setShouldAbortSpawn(true); |                     event.setShouldAbortSpawn(true); | ||||||
|                     event.setCancelled(true); |                     event.setCancelled(true); | ||||||
|   | |||||||
| @@ -47,7 +47,6 @@ import org.bukkit.event.entity.LingeringPotionSplashEvent; | |||||||
| import org.bukkit.event.entity.PotionSplashEvent; | import org.bukkit.event.entity.PotionSplashEvent; | ||||||
| import org.bukkit.event.entity.ProjectileHitEvent; | import org.bukkit.event.entity.ProjectileHitEvent; | ||||||
| import org.bukkit.event.entity.ProjectileLaunchEvent; | import org.bukkit.event.entity.ProjectileLaunchEvent; | ||||||
| import org.bukkit.event.player.PlayerEggThrowEvent; |  | ||||||
| import org.bukkit.projectiles.BlockProjectileSource; | import org.bukkit.projectiles.BlockProjectileSource; | ||||||
| import org.bukkit.projectiles.ProjectileSource; | import org.bukkit.projectiles.ProjectileSource; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| @@ -158,26 +157,14 @@ public class ProjectileEventListener implements Listener { | |||||||
|  |  | ||||||
|     @EventHandler |     @EventHandler | ||||||
|     public void onProjectileHit(ProjectileHitEvent event) { |     public void onProjectileHit(ProjectileHitEvent event) { | ||||||
|         if (cancelProjectileHit(event.getEntity())) { |         Projectile entity = event.getEntity(); | ||||||
|             event.setCancelled(true); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @EventHandler |  | ||||||
|     public void onPlayerEggThrow(PlayerEggThrowEvent event) { |  | ||||||
|         if (cancelProjectileHit(event.getEgg())) { |  | ||||||
|             event.setHatching(false); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private boolean cancelProjectileHit(Projectile entity) { |  | ||||||
|         Location location = BukkitUtil.adapt(entity.getLocation()); |         Location location = BukkitUtil.adapt(entity.getLocation()); | ||||||
|         if (!this.plotAreaManager.hasPlotArea(location.getWorldName())) { |         if (!this.plotAreaManager.hasPlotArea(location.getWorldName())) { | ||||||
|             return false; |             return; | ||||||
|         } |         } | ||||||
|         PlotArea area = location.getPlotArea(); |         PlotArea area = location.getPlotArea(); | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             return false; |             return; | ||||||
|         } |         } | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|         ProjectileSource shooter = entity.getShooter(); |         ProjectileSource shooter = entity.getShooter(); | ||||||
| @@ -185,14 +172,15 @@ public class ProjectileEventListener implements Listener { | |||||||
|             if (!((Player) shooter).isOnline()) { |             if (!((Player) shooter).isOnline()) { | ||||||
|                 if (plot != null) { |                 if (plot != null) { | ||||||
|                     if (plot.isAdded(((Player) shooter).getUniqueId()) || plot.getFlag(ProjectilesFlag.class)) { |                     if (plot.isAdded(((Player) shooter).getUniqueId()) || plot.getFlag(ProjectilesFlag.class)) { | ||||||
|                         return false; |                         return; | ||||||
|                     } |                     } | ||||||
|                 } else if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true)) { |                 } else if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, ProjectilesFlag.class, true)) { | ||||||
|                     return false; |                     return; | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 return true; |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); |             PlotPlayer<?> pp = BukkitUtil.adapt((Player) shooter); | ||||||
| @@ -201,36 +189,38 @@ public class ProjectileEventListener implements Listener { | |||||||
|                         Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED |                         Permission.PERMISSION_ADMIN_PROJECTILE_UNOWNED | ||||||
|                 )) { |                 )) { | ||||||
|                     entity.remove(); |                     entity.remove(); | ||||||
|                     return true; |                     event.setCancelled(true); | ||||||
|                 } |                 } | ||||||
|                 return false; |                 return; | ||||||
|             } |             } | ||||||
|             if (plot.isAdded(pp.getUUID()) || pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) || plot.getFlag( |             if (plot.isAdded(pp.getUUID()) || pp.hasPermission(Permission.PERMISSION_ADMIN_PROJECTILE_OTHER) || plot.getFlag( | ||||||
|                     ProjectilesFlag.class) || (entity instanceof FishHook && plot.getFlag( |                     ProjectilesFlag.class) || (entity instanceof FishHook && plot.getFlag( | ||||||
|                     FishingFlag.class))) { |                     FishingFlag.class))) { | ||||||
|                 return false; |                 return; | ||||||
|             } |             } | ||||||
|             entity.remove(); |             entity.remove(); | ||||||
|             return true; |             event.setCancelled(true); | ||||||
|  |             return; | ||||||
|         } |         } | ||||||
|         if (!(shooter instanceof Entity) && shooter != null) { |         if (!(shooter instanceof Entity) && shooter != null) { | ||||||
|             if (plot == null) { |             if (plot == null) { | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 return true; |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|             } |             } | ||||||
|             Location sLoc = |             Location sLoc = | ||||||
|                     BukkitUtil.adapt(((BlockProjectileSource) shooter).getBlock().getLocation()); |                     BukkitUtil.adapt(((BlockProjectileSource) shooter).getBlock().getLocation()); | ||||||
|             if (!area.contains(sLoc.getX(), sLoc.getZ())) { |             if (!area.contains(sLoc.getX(), sLoc.getZ())) { | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 return true; |                 event.setCancelled(true); | ||||||
|  |                 return; | ||||||
|             } |             } | ||||||
|             Plot sPlot = area.getOwnedPlotAbs(sLoc); |             Plot sPlot = area.getOwnedPlotAbs(sLoc); | ||||||
|             if (sPlot == null || !PlotHandler.sameOwners(plot, sPlot)) { |             if (sPlot == null || !PlotHandler.sameOwners(plot, sPlot)) { | ||||||
|                 entity.remove(); |                 entity.remove(); | ||||||
|                 return true; |                 event.setCancelled(true); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         return false; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -18,8 +18,6 @@ | |||||||
|  */ |  */ | ||||||
| package com.plotsquared.core.backup; | package com.plotsquared.core.backup; | ||||||
|  |  | ||||||
| import org.apache.logging.log4j.LogManager; |  | ||||||
| import org.apache.logging.log4j.Logger; |  | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| import java.io.IOException; | import java.io.IOException; | ||||||
| @@ -32,14 +30,12 @@ import java.nio.file.Path; | |||||||
|  */ |  */ | ||||||
| public class Backup { | public class Backup { | ||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + Backup.class.getSimpleName()); |  | ||||||
|  |  | ||||||
|     private final BackupProfile owner; |     private final BackupProfile owner; | ||||||
|     private final long creationTime; |     private final long creationTime; | ||||||
|     @Nullable |     @Nullable | ||||||
|     private final Path file; |     private final Path file; | ||||||
|  |  | ||||||
|     Backup(final BackupProfile owner, final long creationTime, @Nullable final Path file) { |     Backup(final BackupProfile owner, final long creationTime, final Path file) { | ||||||
|         this.owner = owner; |         this.owner = owner; | ||||||
|         this.creationTime = creationTime; |         this.creationTime = creationTime; | ||||||
|         this.file = file; |         this.file = file; | ||||||
| @@ -53,7 +49,7 @@ public class Backup { | |||||||
|             try { |             try { | ||||||
|                 Files.deleteIfExists(file); |                 Files.deleteIfExists(file); | ||||||
|             } catch (final IOException e) { |             } catch (final IOException e) { | ||||||
|                 LOGGER.error("Error deleting backup at {}", file, e); |                 e.printStackTrace(); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -21,15 +21,14 @@ package com.plotsquared.core.backup; | |||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.google.inject.assistedinject.Assisted; | import com.google.inject.assistedinject.Assisted; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.exception.PlotSquaredException; | import com.plotsquared.core.player.ConsolePlayer; | ||||||
| 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.schematic.Schematic; | import com.plotsquared.core.plot.schematic.Schematic; | ||||||
| import com.plotsquared.core.util.SchematicHandler; | import com.plotsquared.core.util.SchematicHandler; | ||||||
| import com.plotsquared.core.util.task.RunnableVal; | import com.plotsquared.core.util.task.RunnableVal; | ||||||
| import com.plotsquared.core.util.task.TaskManager; | import com.plotsquared.core.util.task.TaskManager; | ||||||
| import org.apache.logging.log4j.LogManager; | import net.kyori.adventure.text.minimessage.MiniMessage; | ||||||
| import org.apache.logging.log4j.Logger; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| @@ -52,7 +51,7 @@ import java.util.concurrent.CompletableFuture; | |||||||
|  */ |  */ | ||||||
| public class PlayerBackupProfile implements BackupProfile { | public class PlayerBackupProfile implements BackupProfile { | ||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + PlayerBackupProfile.class.getSimpleName()); |     static final MiniMessage MINI_MESSAGE = MiniMessage.builder().build(); | ||||||
|  |  | ||||||
|     private final UUID owner; |     private final UUID owner; | ||||||
|     private final Plot plot; |     private final Plot plot; | ||||||
| @@ -88,7 +87,7 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                 Files.createDirectory(path); |                 Files.createDirectory(path); | ||||||
|             } |             } | ||||||
|         } catch (final Exception e) { |         } catch (final Exception e) { | ||||||
|             LOGGER.error("Error resolving {} from {}", child, parent, e); |             e.printStackTrace(); | ||||||
|         } |         } | ||||||
|         return path; |         return path; | ||||||
|     } |     } | ||||||
| @@ -105,7 +104,7 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                     try { |                     try { | ||||||
|                         Files.createDirectories(path); |                         Files.createDirectories(path); | ||||||
|                     } catch (IOException e) { |                     } catch (IOException e) { | ||||||
|                         LOGGER.error("Error creating directory {}", path, e); |                         e.printStackTrace(); | ||||||
|                         return Collections.emptyList(); |                         return Collections.emptyList(); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -118,11 +117,11 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                             backups.add( |                             backups.add( | ||||||
|                                     new Backup(this, basicFileAttributes.creationTime().toMillis(), file)); |                                     new Backup(this, basicFileAttributes.creationTime().toMillis(), file)); | ||||||
|                         } catch (IOException e) { |                         } catch (IOException e) { | ||||||
|                             LOGGER.error("Error getting attributes for file {} to create backup", file, e); |                             e.printStackTrace(); | ||||||
|                         } |                         } | ||||||
|                     }); |                     }); | ||||||
|                 } catch (IOException e) { |                 } catch (IOException e) { | ||||||
|                     LOGGER.error("Error walking files from {}", path, e); |                     e.printStackTrace(); | ||||||
|                 } |                 } | ||||||
|                 backups.sort(Comparator.comparingLong(Backup::getCreationTime).reversed()); |                 backups.sort(Comparator.comparingLong(Backup::getCreationTime).reversed()); | ||||||
|                 return (this.backupCache = backups); |                 return (this.backupCache = backups); | ||||||
| @@ -134,7 +133,7 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|     public void destroy() { |     public void destroy() { | ||||||
|         this.listBackups().whenCompleteAsync((backups, error) -> { |         this.listBackups().whenCompleteAsync((backups, error) -> { | ||||||
|             if (error != null) { |             if (error != null) { | ||||||
|                 LOGGER.error("Error while listing backups", error); |                 error.printStackTrace(); | ||||||
|             } |             } | ||||||
|             backups.forEach(Backup::delete); |             backups.forEach(Backup::delete); | ||||||
|             this.backupCache = null; |             this.backupCache = null; | ||||||
| @@ -142,12 +141,10 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public @NonNull Path getBackupDirectory() { |     public @NonNull Path getBackupDirectory() { | ||||||
|         return resolve( |         return resolve(resolve( | ||||||
|                 resolve( |  | ||||||
|                 resolve(backupManager.getBackupPath(), Objects.requireNonNull(plot.getArea().toString(), "plot area id")), |                 resolve(backupManager.getBackupPath(), Objects.requireNonNull(plot.getArea().toString(), "plot area id")), | ||||||
|                 Objects.requireNonNull(plot.getId().toDashSeparatedString(), "plot id") |                 Objects.requireNonNull(plot.getId().toDashSeparatedString(), "plot id") | ||||||
|                 ), Objects.requireNonNull(owner.toString(), "owner") |         ), Objects.requireNonNull(owner.toString(), "owner")); | ||||||
|         ); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
| @@ -159,8 +156,7 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                     backups.get(backups.size() - 1).delete(); |                     backups.get(backups.size() - 1).delete(); | ||||||
|                 } |                 } | ||||||
|                 final List<Plot> plots = Collections.singletonList(plot); |                 final List<Plot> plots = Collections.singletonList(plot); | ||||||
|                 final boolean result = this.schematicHandler.exportAll( |                 final boolean result = this.schematicHandler.exportAll(plots, getBackupDirectory().toFile(), | ||||||
|                         plots, getBackupDirectory().toFile(), |  | ||||||
|                         "%world%-%id%-" + System.currentTimeMillis(), () -> |                         "%world%-%id%-" + System.currentTimeMillis(), () -> | ||||||
|                                 future.complete(new Backup(this, System.currentTimeMillis(), null)) |                                 future.complete(new Backup(this, System.currentTimeMillis(), null)) | ||||||
|                 ); |                 ); | ||||||
| @@ -184,7 +180,7 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                 try { |                 try { | ||||||
|                     schematic = this.schematicHandler.getSchematic(backup.getFile().toFile()); |                     schematic = this.schematicHandler.getSchematic(backup.getFile().toFile()); | ||||||
|                 } catch (SchematicHandler.UnsupportedFormatException e) { |                 } catch (SchematicHandler.UnsupportedFormatException e) { | ||||||
|                     LOGGER.error("Unsupported format for backup {}", backup.getFile(), e); |                     e.printStackTrace(); | ||||||
|                 } |                 } | ||||||
|                 if (schematic == null) { |                 if (schematic == null) { | ||||||
|                     future.completeExceptionally(new IllegalArgumentException( |                     future.completeExceptionally(new IllegalArgumentException( | ||||||
| @@ -204,9 +200,10 @@ public class PlayerBackupProfile implements BackupProfile { | |||||||
|                                     if (value) { |                                     if (value) { | ||||||
|                                         future.complete(null); |                                         future.complete(null); | ||||||
|                                     } else { |                                     } else { | ||||||
|                                         future.completeExceptionally(new PlotSquaredException( |                                         future.completeExceptionally(new RuntimeException(MINI_MESSAGE.escapeTags( | ||||||
|                                                 TranslatableCaption |                                                 TranslatableCaption | ||||||
|                                                         .of("schematics.schematic_paste_failed"))); |                                                         .of("schematics.schematic_paste_failed") | ||||||
|  |                                                         .getComponent(ConsolePlayer.getConsole())))); | ||||||
|                                     } |                                     } | ||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
|   | |||||||
| @@ -32,8 +32,6 @@ import com.plotsquared.core.util.task.TaskManager; | |||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.apache.logging.log4j.LogManager; |  | ||||||
| import org.apache.logging.log4j.Logger; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.checkerframework.checker.nullness.qual.Nullable; | import org.checkerframework.checker.nullness.qual.Nullable; | ||||||
|  |  | ||||||
| @@ -49,7 +47,6 @@ import java.util.concurrent.TimeUnit; | |||||||
| @Singleton | @Singleton | ||||||
| public class SimpleBackupManager implements BackupManager { | public class SimpleBackupManager implements BackupManager { | ||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + SimpleBackupManager.class.getSimpleName()); |  | ||||||
|     private final Path backupPath; |     private final Path backupPath; | ||||||
|     private final boolean automaticBackup; |     private final boolean automaticBackup; | ||||||
|     private final int backupLimit; |     private final int backupLimit; | ||||||
| @@ -115,12 +112,7 @@ public class SimpleBackupManager implements BackupManager { | |||||||
|                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) |                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) | ||||||
|                         ); |                         ); | ||||||
|                     } |                     } | ||||||
|                     LOGGER.error( |                     throwable.printStackTrace(); | ||||||
|                             "Error creating backup for plot {};{} and player {}", |  | ||||||
|                             plot.getArea(), |  | ||||||
|                             plot.getId(), |  | ||||||
|                             player == null ? "null" : player.getName(), throwable |  | ||||||
|                     ); |  | ||||||
|                 } else { |                 } else { | ||||||
|                     if (player != null) { |                     if (player != null) { | ||||||
|                         player.sendMessage(TranslatableCaption.of("backups.backup_automatic_finished")); |                         player.sendMessage(TranslatableCaption.of("backups.backup_automatic_finished")); | ||||||
| @@ -136,7 +128,6 @@ public class SimpleBackupManager implements BackupManager { | |||||||
|         return this.automaticBackup; |         return this.automaticBackup; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @NonNull |  | ||||||
|     public Path getBackupPath() { |     public Path getBackupPath() { | ||||||
|         return this.backupPath; |         return this.backupPath; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -21,6 +21,7 @@ package com.plotsquared.core.command; | |||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -57,7 +58,8 @@ public class Alias extends SubCommand { | |||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -24,7 +24,6 @@ import com.plotsquared.core.backup.BackupProfile; | |||||||
| import com.plotsquared.core.backup.NullBackupProfile; | import com.plotsquared.core.backup.NullBackupProfile; | ||||||
| import com.plotsquared.core.backup.PlayerBackupProfile; | import com.plotsquared.core.backup.PlayerBackupProfile; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.exception.PlotSquaredException; |  | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -33,8 +32,6 @@ import com.plotsquared.core.util.task.RunnableVal3; | |||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.apache.logging.log4j.LogManager; |  | ||||||
| import org.apache.logging.log4j.Logger; |  | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.nio.file.Files; | import java.nio.file.Files; | ||||||
| @@ -60,8 +57,6 @@ import java.util.stream.Stream; | |||||||
|         permission = "plots.backup") |         permission = "plots.backup") | ||||||
| public final class Backup extends Command { | public final class Backup extends Command { | ||||||
|  |  | ||||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + Backup.class.getSimpleName()); |  | ||||||
|  |  | ||||||
|     private final BackupManager backupManager; |     private final BackupManager backupManager; | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
| @@ -331,28 +326,19 @@ public final class Backup extends Command { | |||||||
|             if (backupProfile instanceof NullBackupProfile) { |             if (backupProfile instanceof NullBackupProfile) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("backups.backup_impossible"), |                         TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver("plot", Tag.inserting( | ||||||
|                                 "plot", Tag.inserting( |  | ||||||
|                                 TranslatableCaption.of("generic.generic_other").toComponent(player) |                                 TranslatableCaption.of("generic.generic_other").toComponent(player) | ||||||
|                                 ) |                         )) | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|                 backupProfile.listBackups().whenComplete((backups, throwable) -> { |                 backupProfile.listBackups().whenComplete((backups, throwable) -> { | ||||||
|                     if (throwable != null) { |                     if (throwable != null) { | ||||||
|                         Component reason; |  | ||||||
|                         if (throwable instanceof PlotSquaredException pe) { |  | ||||||
|                             reason = pe.getCaption().toComponent(player); |  | ||||||
|                         } else { |  | ||||||
|                             reason = Component.text(throwable.getMessage()); |  | ||||||
|                         } |  | ||||||
|                         player.sendMessage( |                         player.sendMessage( | ||||||
|                                 TranslatableCaption.of("backups.backup_load_failure"), |                                 TranslatableCaption.of("backups.backup_load_failure"), | ||||||
|                                 TagResolver.resolver("reason", Tag.inserting(reason)) |                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) | ||||||
|                         ); |                         ); | ||||||
|                         LOGGER.error("Error loading player ({}) backup", player.getName(), throwable); |                         throwable.printStackTrace(); | ||||||
|                         return; |                     } else { | ||||||
|                     } |  | ||||||
|                         if (number < 1 || number > backups.size()) { |                         if (number < 1 || number > backups.size()) { | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("backups.backup_impossible"), |                                     TranslatableCaption.of("backups.backup_impossible"), | ||||||
| @@ -378,8 +364,7 @@ public final class Backup extends Command { | |||||||
|                                         ) |                                         ) | ||||||
|                                 ); |                                 ); | ||||||
|                             } else { |                             } else { | ||||||
|                             CmdConfirm.addPending( |                                 CmdConfirm.addPending(player, "/plot backup load " + number, | ||||||
|                                     player, "/plot backup load " + number, |  | ||||||
|                                         () -> backupProfile.restoreBackup(backup, player) |                                         () -> backupProfile.restoreBackup(backup, player) | ||||||
|                                                 .whenComplete((n, error) -> { |                                                 .whenComplete((n, error) -> { | ||||||
|                                                     if (error != null) { |                                                     if (error != null) { | ||||||
| @@ -397,6 +382,7 @@ public final class Backup extends Command { | |||||||
|                                 ); |                                 ); | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|  |                     } | ||||||
|                 }); |                 }); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -20,7 +20,6 @@ package com.plotsquared.core.command; | |||||||
|  |  | ||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.PlotSquared; | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.configuration.Settings; |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.PlayerBuyPlotEvent; | import com.plotsquared.core.events.PlayerBuyPlotEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| @@ -85,9 +84,8 @@ public class Buy extends Command { | |||||||
|         checkTrue(plot.hasOwner(), TranslatableCaption.of("info.plot_unowned")); |         checkTrue(plot.hasOwner(), TranslatableCaption.of("info.plot_unowned")); | ||||||
|         checkTrue(!plot.isOwner(player.getUUID()), TranslatableCaption.of("economy.cannot_buy_own")); |         checkTrue(!plot.isOwner(player.getUUID()), TranslatableCaption.of("economy.cannot_buy_own")); | ||||||
|         Set<Plot> plots = plot.getConnectedPlots(); |         Set<Plot> plots = plot.getConnectedPlots(); | ||||||
|         int plotCount = Settings.Limit.GLOBAL ? player.getPlotCount() : player.getPlotCount(plot.getWorldName()); |  | ||||||
|         checkTrue( |         checkTrue( | ||||||
|                 plotCount + plots.size() <= player.getAllowedPlots(), |                 player.getPlotCount() + plots.size() <= player.getAllowedPlots(), | ||||||
|                 TranslatableCaption.of("permission.cant_claim_more_plots"), |                 TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                 TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) |                 TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) | ||||||
|         ); |         ); | ||||||
|   | |||||||
| @@ -26,6 +26,7 @@ import com.plotsquared.core.events.PlayerClaimPlotEvent; | |||||||
| import com.plotsquared.core.events.PlotMergeEvent; | import com.plotsquared.core.events.PlotMergeEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.location.Direction; | import com.plotsquared.core.location.Direction; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.MetaDataAccess; | import com.plotsquared.core.player.MetaDataAccess; | ||||||
| import com.plotsquared.core.player.PlayerMetaDataKeys; | import com.plotsquared.core.player.PlayerMetaDataKeys; | ||||||
| @@ -71,7 +72,8 @@ public class Claim extends SubCommand { | |||||||
|         if (args.length >= 1) { |         if (args.length >= 1) { | ||||||
|             schematic = args[0]; |             schematic = args[0]; | ||||||
|         } |         } | ||||||
|         Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -88,7 +90,7 @@ public class Claim extends SubCommand { | |||||||
|         boolean force = event.getEventResult() == Result.FORCE; |         boolean force = event.getEventResult() == Result.FORCE; | ||||||
|         int currentPlots = Settings.Limit.GLOBAL ? |         int currentPlots = Settings.Limit.GLOBAL ? | ||||||
|                 player.getPlotCount() : |                 player.getPlotCount() : | ||||||
|                 player.getPlotCount(plot.getWorldName()); |                 player.getPlotCount(location.getWorldName()); | ||||||
|  |  | ||||||
|         final PlotArea area = plot.getArea(); |         final PlotArea area = plot.getArea(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -68,8 +68,8 @@ public class Continue extends SubCommand { | |||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         int size = plot.getConnectedPlots().size(); |         int size = plot.getConnectedPlots().size(); | ||||||
|         int plotCount = Settings.Limit.GLOBAL ? player.getPlotCount() : player.getPlotCount(plot.getWorldName()); |         if (!Settings.Done.COUNTS_TOWARDS_LIMIT && (player.getAllowedPlots() | ||||||
|         if (!Settings.Done.COUNTS_TOWARDS_LIMIT && (player.getAllowedPlots() < plotCount + size)) { |                 < player.getPlotCount() + size)) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("permission.cant_claim_more_plots"), |                     TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||||
|                     TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) |                     TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
| package com.plotsquared.core.command; | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -36,7 +37,8 @@ public class Copy extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||||
|         Plot plot1 = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot1 = location.getPlotAbs(); | ||||||
|         if (plot1 == null) { |         if (plot1 == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -22,6 +22,7 @@ import com.google.inject.Inject; | |||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.generator.HybridPlotWorld; | import com.plotsquared.core.generator.HybridPlotWorld; | ||||||
| import com.plotsquared.core.generator.HybridUtils; | import com.plotsquared.core.generator.HybridUtils; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| 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 net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| @@ -46,7 +47,8 @@ public class CreateRoadSchematic extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -55,7 +57,7 @@ public class CreateRoadSchematic extends SubCommand { | |||||||
|             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); |             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         if (!(plot.getArea() instanceof HybridPlotWorld)) { |         if (!(location.getPlotArea() instanceof HybridPlotWorld)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|         } |         } | ||||||
|         this.hybridUtils.setupRoadSchematic(plot); |         this.hybridUtils.setupRoadSchematic(plot); | ||||||
|   | |||||||
| @@ -22,6 +22,7 @@ import com.google.inject.Inject; | |||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.generator.HybridPlotManager; | import com.plotsquared.core.generator.HybridPlotManager; | ||||||
| import com.plotsquared.core.generator.HybridUtils; | import com.plotsquared.core.generator.HybridUtils; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| 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; | ||||||
| @@ -56,7 +57,8 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot = location.getPlotAbs(); | ||||||
|         if (args.length < 1) { |         if (args.length < 1) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
| @@ -90,7 +92,8 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public boolean regenPlot(PlotPlayer<?> player) { |     public boolean regenPlot(PlotPlayer<?> player) { | ||||||
|         PlotArea area = player.getContextualPlotArea(); |         Location location = player.getLocation(); | ||||||
|  |         PlotArea area = location.getPlotArea(); | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|             return false; |             return false; | ||||||
| @@ -145,10 +148,10 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         PlotArea area = player.getContextualPlotArea(); |         Location location = player.getLocation(); | ||||||
|  |         PlotArea area = location.getPlotArea(); | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|             return false; |  | ||||||
|         } |         } | ||||||
|         Plot plot = player.getCurrentPlot(); |         Plot plot = player.getCurrentPlot(); | ||||||
|         PlotManager manager = area.getPlotManager(); |         PlotManager manager = area.getPlotManager(); | ||||||
|   | |||||||
| @@ -23,6 +23,7 @@ import com.plotsquared.core.configuration.Settings; | |||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.events.TeleportCause; | import com.plotsquared.core.events.TeleportCause; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -60,7 +61,8 @@ public class Delete extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||||
|         final Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         final Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -90,7 +92,7 @@ public class Delete extends SubCommand { | |||||||
|         final java.util.Set<Plot> plots = plot.getConnectedPlots(); |         final java.util.Set<Plot> plots = plot.getConnectedPlots(); | ||||||
|         final int currentPlots = Settings.Limit.GLOBAL ? |         final int currentPlots = Settings.Limit.GLOBAL ? | ||||||
|                 player.getPlotCount() : |                 player.getPlotCount() : | ||||||
|                 player.getPlotCount(plot.getWorldName()); |                 player.getPlotCount(location.getWorldName()); | ||||||
|         Runnable run = () -> { |         Runnable run = () -> { | ||||||
|             if (plot.getRunning() > 0) { |             if (plot.getRunning() > 0) { | ||||||
|                 player.sendMessage(TranslatableCaption.of("errors.wait_for_timer")); |                 player.sendMessage(TranslatableCaption.of("errors.wait_for_timer")); | ||||||
|   | |||||||
| @@ -70,7 +70,8 @@ public class Deny extends SubCommand { | |||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|  |  | ||||||
|         final Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         final Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -26,6 +26,7 @@ import com.plotsquared.core.events.PlotDoneEvent; | |||||||
| import com.plotsquared.core.events.PlotFlagAddEvent; | import com.plotsquared.core.events.PlotFlagAddEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
| import com.plotsquared.core.generator.HybridUtils; | import com.plotsquared.core.generator.HybridUtils; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -60,7 +61,8 @@ public class Done extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||||
|         final Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         final Plot plot = location.getPlotAbs(); | ||||||
|         if ((plot == null) || !plot.hasOwner()) { |         if ((plot == null) || !plot.hasOwner()) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -73,7 +73,7 @@ public class Download extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||||
|         String world = player.getCurrentPlot().getWorldName(); |         String world = player.getLocation().getWorldName(); | ||||||
|         if (!this.plotAreaManager.hasPlotArea(world)) { |         if (!this.plotAreaManager.hasPlotArea(world)) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -27,6 +27,7 @@ import com.plotsquared.core.configuration.caption.TranslatableCaption; | |||||||
| import com.plotsquared.core.events.PlotFlagAddEvent; | import com.plotsquared.core.events.PlotFlagAddEvent; | ||||||
| import com.plotsquared.core.events.PlotFlagRemoveEvent; | import com.plotsquared.core.events.PlotFlagRemoveEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -178,7 +179,8 @@ public final class FlagCommand extends Command { | |||||||
|      * @return {@code true} if the player is allowed to modify the flags at their current location |      * @return {@code true} if the player is allowed to modify the flags at their current location | ||||||
|      */ |      */ | ||||||
|     private static boolean checkRequirements(final @NonNull PlotPlayer<?> player) { |     private static boolean checkRequirements(final @NonNull PlotPlayer<?> player) { | ||||||
|         final Plot plot = player.getCurrentPlot(); |         final Location location = player.getLocation(); | ||||||
|  |         final Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -342,7 +344,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (plotFlag == null) { |         if (plotFlag == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Plot plot = player.getCurrentPlot(); |         Plot plot = player.getLocation().getPlotAbs(); | ||||||
|         PlotFlagAddEvent event = eventDispatcher.callFlagAdd(plotFlag, plot); |         PlotFlagAddEvent event = eventDispatcher.callFlagAdd(plotFlag, plot); | ||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
| @@ -407,7 +409,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (plotFlag == null) { |         if (plotFlag == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         Plot plot = player.getCurrentPlot(); |         Plot plot = player.getLocation().getPlotAbs(); | ||||||
|         PlotFlagAddEvent event = eventDispatcher.callFlagAdd(plotFlag, plot); |         PlotFlagAddEvent event = eventDispatcher.callFlagAdd(plotFlag, plot); | ||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
| @@ -417,7 +419,7 @@ public final class FlagCommand extends Command { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         boolean force = event.getEventResult() == Result.FORCE; |         boolean force = event.getEventResult() == Result.FORCE; | ||||||
|         final PlotFlag localFlag = player.getCurrentPlot().getFlagContainer() |         final PlotFlag localFlag = player.getLocation().getPlotAbs().getFlagContainer() | ||||||
|                 .getFlag(event.getFlag().getClass()); |                 .getFlag(event.getFlag().getClass()); | ||||||
|         if (!force) { |         if (!force) { | ||||||
|             for (String entry : args[1].split(",")) { |             for (String entry : args[1].split(",")) { | ||||||
| @@ -442,7 +444,7 @@ public final class FlagCommand extends Command { | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         boolean result = |         boolean result = | ||||||
|                 player.getCurrentPlot().setFlag(localFlag.merge(parsed.getValue())); |                 player.getLocation().getPlotAbs().setFlag(localFlag.merge(parsed.getValue())); | ||||||
|         if (!result) { |         if (!result) { | ||||||
|             player.sendMessage(TranslatableCaption.of("flag.flag_not_added")); |             player.sendMessage(TranslatableCaption.of("flag.flag_not_added")); | ||||||
|             return; |             return; | ||||||
| @@ -482,7 +484,7 @@ public final class FlagCommand extends Command { | |||||||
|         if (flag == null) { |         if (flag == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         final Plot plot = player.getCurrentPlot(); |         final Plot plot = player.getLocation().getPlotAbs(); | ||||||
|         final PlotFlag<?, ?> flagWithOldValue = plot.getFlagContainer().getFlag(flag.getClass()); |         final PlotFlag<?, ?> flagWithOldValue = plot.getFlagContainer().getFlag(flag.getClass()); | ||||||
|         PlotFlagRemoveEvent event = eventDispatcher.callFlagRemove(flag, plot); |         PlotFlagRemoveEvent event = eventDispatcher.callFlagRemove(flag, plot); | ||||||
|         if (event.getEventResult() == Result.DENY) { |         if (event.getEventResult() == Result.DENY) { | ||||||
| @@ -685,7 +687,7 @@ public final class FlagCommand extends Command { | |||||||
|                             .build() |                             .build() | ||||||
|             ); |             ); | ||||||
|             // Default value |             // Default value | ||||||
|             final String defaultValue = player.getCurrentPlot().getArea().getFlagContainer() |             final String defaultValue = player.getLocation().getPlotArea().getFlagContainer() | ||||||
|                     .getFlagErased(plotFlag.getClass()).toString(); |                     .getFlagErased(plotFlag.getClass()).toString(); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("flag.flag_info_default_value"), |                     TranslatableCaption.of("flag.flag_info_default_value"), | ||||||
|   | |||||||
| @@ -65,7 +65,8 @@ public class Kick extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot = location.getPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -123,7 +124,7 @@ public class Kick extends SubCommand { | |||||||
|                         ); |                         ); | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     Location spawn = this.worldUtil.getSpawn(plot.getWorldName()); |                     Location spawn = this.worldUtil.getSpawn(location.getWorldName()); | ||||||
|                     player2.sendMessage(TranslatableCaption.of("kick.you_got_kicked")); |                     player2.sendMessage(TranslatableCaption.of("kick.you_got_kicked")); | ||||||
|                     if (plot.equals(spawn.getPlot())) { |                     if (plot.equals(spawn.getPlot())) { | ||||||
|                         Location newSpawn = this.worldUtil.getSpawn(this.plotAreaManager.getAllWorlds()[0]); |                         Location newSpawn = this.worldUtil.getSpawn(this.plotAreaManager.getAllWorlds()[0]); | ||||||
| @@ -147,7 +148,8 @@ public class Kick extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             return Collections.emptyList(); |             return Collections.emptyList(); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -150,8 +150,8 @@ public class ListCmd extends SubCommand { | |||||||
|             page = 0; |             page = 0; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         PlotArea area = player.getContextualPlotArea(); |         String world = player.getLocation().getWorldName(); | ||||||
|         String world = area != null ? area.getWorldName() : ""; |         PlotArea area = player.getApplicablePlotArea(); | ||||||
|         String arg = args[0].toLowerCase(); |         String arg = args[0].toLowerCase(); | ||||||
|         final boolean[] sort = new boolean[]{true}; |         final boolean[] sort = new boolean[]{true}; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -68,6 +68,11 @@ public class Load extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, final String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, final String[] args) { | ||||||
|  |         final String world = player.getLocation().getWorldName(); | ||||||
|  |         if (!this.plotAreaManager.hasPlotArea(world)) { | ||||||
|  |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|         final Plot plot = player.getCurrentPlot(); |         final Plot plot = player.getCurrentPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ package com.plotsquared.core.command; | |||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.TeleportCause; | import com.plotsquared.core.events.TeleportCause; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
|  |  | ||||||
| @@ -35,7 +36,8 @@ public class Middle extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] arguments) { |     public boolean onCommand(PlotPlayer<?> player, String[] arguments) { | ||||||
|         Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot = location.getPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ package com.plotsquared.core.command; | |||||||
|  |  | ||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -54,7 +55,8 @@ public class Move extends SubCommand { | |||||||
|             RunnableVal3<Command, Runnable, Runnable> confirm, |             RunnableVal3<Command, Runnable, Runnable> confirm, | ||||||
|             RunnableVal2<Command, CommandResult> whenDone |             RunnableVal2<Command, CommandResult> whenDone | ||||||
|     ) { |     ) { | ||||||
|         Plot plot1 = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot1 = location.getPlotAbs(); | ||||||
|         if (plot1 == null) { |         if (plot1 == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
|   | |||||||
| @@ -23,6 +23,7 @@ import com.plotsquared.core.configuration.caption.TranslatableCaption; | |||||||
| import com.plotsquared.core.events.PlotFlagAddEvent; | import com.plotsquared.core.events.PlotFlagAddEvent; | ||||||
| import com.plotsquared.core.events.PlotFlagRemoveEvent; | import com.plotsquared.core.events.PlotFlagRemoveEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -73,7 +74,8 @@ public class Music extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         final Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         final Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -21,6 +21,7 @@ package com.plotsquared.core.command; | |||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.database.DBFunc; | import com.plotsquared.core.database.DBFunc; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -55,7 +56,8 @@ public class Remove extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
| @@ -130,7 +132,8 @@ public class Remove extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { |     public Collection<Command> tab(final PlotPlayer<?> player, final String[] args, final boolean space) { | ||||||
|         Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             return Collections.emptyList(); |             return Collections.emptyList(); | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -22,6 +22,7 @@ import com.google.common.collect.Lists; | |||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| import com.plotsquared.core.player.ConsolePlayer; | import com.plotsquared.core.player.ConsolePlayer; | ||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| @@ -101,7 +102,8 @@ public class SchematicCmd extends SubCommand { | |||||||
|                     ); |                     ); | ||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|                 final Plot plot = player.getCurrentPlot(); |                 Location loc = player.getLocation(); | ||||||
|  |                 final Plot plot = loc.getPlotAbs(); | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |                     player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|                     return false; |                     return false; | ||||||
| @@ -245,7 +247,8 @@ public class SchematicCmd extends SubCommand { | |||||||
|                     player.sendMessage(TranslatableCaption.of("error.task_in_process")); |                     player.sendMessage(TranslatableCaption.of("error.task_in_process")); | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|                 Plot plot = player.getCurrentPlot(); |                 Location location = player.getLocation(); | ||||||
|  |                 Plot plot = location.getPlotAbs(); | ||||||
|                 if (plot == null) { |                 if (plot == null) { | ||||||
|                     player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |                     player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|                     return false; |                     return false; | ||||||
|   | |||||||
| @@ -78,7 +78,7 @@ public class Set extends SubCommand { | |||||||
|  |  | ||||||
|             @Override |             @Override | ||||||
|             public boolean set(PlotPlayer<?> player, final Plot plot, String value) { |             public boolean set(PlotPlayer<?> player, final Plot plot, String value) { | ||||||
|                 final PlotArea plotArea = player.getContextualPlotArea(); |                 final PlotArea plotArea = player.getLocation().getPlotArea(); | ||||||
|                 if (plotArea == null) { |                 if (plotArea == null) { | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
| package com.plotsquared.core.command; | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -31,7 +32,8 @@ public abstract class SetCommand extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { |     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||||
|         Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -19,6 +19,7 @@ | |||||||
| package com.plotsquared.core.command; | package com.plotsquared.core.command; | ||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -43,7 +44,8 @@ public class Swap extends SubCommand { | |||||||
|             RunnableVal3<Command, Runnable, Runnable> confirm, |             RunnableVal3<Command, Runnable, Runnable> confirm, | ||||||
|             RunnableVal2<Command, CommandResult> whenDone |             RunnableVal2<Command, CommandResult> whenDone | ||||||
|     ) { |     ) { | ||||||
|         Plot plot1 = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         Plot plot1 = location.getPlotAbs(); | ||||||
|         if (plot1 == null) { |         if (plot1 == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return CompletableFuture.completedFuture(false); |             return CompletableFuture.completedFuture(false); | ||||||
| @@ -77,10 +79,8 @@ public class Swap extends SubCommand { | |||||||
|         String p1 = plot1.toString(); |         String p1 = plot1.toString(); | ||||||
|         String p2 = plot2.toString(); |         String p2 = plot2.toString(); | ||||||
|  |  | ||||||
|         return plot1.getPlotModificationManager().move( |         return plot1.getPlotModificationManager().move(plot2, player, () -> { | ||||||
|                 plot2, player, () -> { |         }, true).thenApply(result -> { | ||||||
|                 }, true |  | ||||||
|         ).thenApply(result -> { |  | ||||||
|             if (result) { |             if (result) { | ||||||
|                 player.sendMessage( |                 player.sendMessage( | ||||||
|                         TranslatableCaption.of("swap.swap_success"), |                         TranslatableCaption.of("swap.swap_success"), | ||||||
|   | |||||||
| @@ -22,6 +22,7 @@ import com.google.inject.Inject; | |||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.events.PlotUnlinkEvent; | import com.plotsquared.core.events.PlotUnlinkEvent; | ||||||
| import com.plotsquared.core.events.Result; | import com.plotsquared.core.events.Result; | ||||||
|  | import com.plotsquared.core.location.Location; | ||||||
| import com.plotsquared.core.permissions.Permission; | 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; | ||||||
| @@ -50,7 +51,8 @@ public class Unlink extends SubCommand { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { |     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||||
|         final Plot plot = player.getCurrentPlot(); |         Location location = player.getLocation(); | ||||||
|  |         final Plot plot = location.getPlotAbs(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); |             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -1,62 +0,0 @@ | |||||||
| /* |  | ||||||
|  * PlotSquared, a land and world management plugin for Minecraft. |  | ||||||
|  * Copyright (C) IntellectualSites <https://intellectualsites.com> |  | ||||||
|  * Copyright (C) IntellectualSites team and contributors |  | ||||||
|  * |  | ||||||
|  * This program is free software: you can redistribute it and/or modify |  | ||||||
|  * it under the terms of the GNU General Public License as published by |  | ||||||
|  * the Free Software Foundation, either version 3 of the License, or |  | ||||||
|  * (at your option) any later version. |  | ||||||
|  * |  | ||||||
|  * This program is distributed in the hope that it will be useful, |  | ||||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
|  * GNU General Public License for more details. |  | ||||||
|  * |  | ||||||
|  * You should have received a copy of the GNU General Public License |  | ||||||
|  * along with this program.  If not, see <https://www.gnu.org/licenses/>. |  | ||||||
|  */ |  | ||||||
| package com.plotsquared.core.exception; |  | ||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.caption.Caption; |  | ||||||
| import com.plotsquared.core.configuration.caption.LocaleHolder; |  | ||||||
|  |  | ||||||
| /** |  | ||||||
|  * Internal use only. Used to allow adventure captions to be used in an exception |  | ||||||
|  * |  | ||||||
|  * @since 7.5.7 |  | ||||||
|  */ |  | ||||||
| public final class PlotSquaredException extends RuntimeException { |  | ||||||
|  |  | ||||||
|     private final Caption caption; |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Create a new instance with the given caption |  | ||||||
|      * |  | ||||||
|      * @param caption caption |  | ||||||
|      */ |  | ||||||
|     public PlotSquaredException(Caption caption) { |  | ||||||
|         this.caption = caption; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Create a new instance with the given caption and cause |  | ||||||
|      * |  | ||||||
|      * @param caption caption |  | ||||||
|      * @param cause   cause |  | ||||||
|      */ |  | ||||||
|     public PlotSquaredException(Caption caption, Exception cause) { |  | ||||||
|         super(cause); |  | ||||||
|         this.caption = caption; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |  | ||||||
|     public String getMessage() { |  | ||||||
|         return caption.getComponent(LocaleHolder.console()); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     public Caption getCaption() { |  | ||||||
|         return caption; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @@ -164,6 +164,9 @@ public abstract class ClassicPlotWorld extends SquarePlotWorld { | |||||||
|                 : getMinBuildHeight(); |                 : getMinBuildHeight(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the lowest height of plot, road, and wall. Accounts for {@link Settings.Schematics#USE_WALL_IN_ROAD_SCHEM_HEIGHT} | ||||||
|  |      */ | ||||||
|     int schematicStartHeight() { |     int schematicStartHeight() { | ||||||
|         int plotRoadMin = Math.min(PLOT_HEIGHT, ROAD_HEIGHT); |         int plotRoadMin = Math.min(PLOT_HEIGHT, ROAD_HEIGHT); | ||||||
|         if (!Settings.Schematics.USE_WALL_IN_ROAD_SCHEM_HEIGHT) { |         if (!Settings.Schematics.USE_WALL_IN_ROAD_SCHEM_HEIGHT) { | ||||||
|   | |||||||
| @@ -274,7 +274,8 @@ public class HybridPlotWorld extends ClassicPlotWorld { | |||||||
|                 SCHEM_Y = getMinGenHeight(); |                 SCHEM_Y = getMinGenHeight(); | ||||||
|                 plotY = 0; |                 plotY = 0; | ||||||
|             } else if (!Settings.Schematics.PASTE_ON_TOP) { |             } else if (!Settings.Schematics.PASTE_ON_TOP) { | ||||||
|                 SCHEM_Y = getMinGenHeight(); |                 // Schematics should generate/be pasted from build height | ||||||
|  |                 SCHEM_Y = getMinBuildHeight(); | ||||||
|                 plotY = 0; |                 plotY = 0; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -291,18 +292,14 @@ public class HybridPlotWorld extends ClassicPlotWorld { | |||||||
|                 roadY = 0; // Road is the lowest schematic |                 roadY = 0; // Road is the lowest schematic | ||||||
|                 if (schematic3 != null && schematic3.getClipboard().getDimensions().getY() != worldGenHeight) { |                 if (schematic3 != null && schematic3.getClipboard().getDimensions().getY() != worldGenHeight) { | ||||||
|                     // Road is the lowest schematic. Normalize plotY to it. |                     // Road is the lowest schematic. Normalize plotY to it. | ||||||
|                     if (Settings.Schematics.PASTE_ON_TOP) { |                     plotY = (Settings.Schematics.PASTE_ON_TOP ? PLOT_HEIGHT : getMinBuildHeight()) - SCHEM_Y; | ||||||
|                         plotY = PLOT_HEIGHT - getMinGenHeight(); |  | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
|             } else if (!Settings.Schematics.PASTE_ROAD_ON_TOP) { |             } else if (!Settings.Schematics.PASTE_ROAD_ON_TOP) { | ||||||
|                 roadY = 0; |                 roadY = 0; | ||||||
|                 SCHEM_Y = getMinGenHeight(); |                 SCHEM_Y = getMinGenHeight(); | ||||||
|                 if (schematic3 != null) { |                 if (schematic3 != null && schematic3.getClipboard().getDimensions().getY() != worldGenHeight) { | ||||||
|                     if (Settings.Schematics.PASTE_ON_TOP) { |  | ||||||
|                     // Road is the lowest schematic. Normalize plotY to it. |                     // Road is the lowest schematic. Normalize plotY to it. | ||||||
|                         plotY = PLOT_HEIGHT - SCHEM_Y; |                     plotY = (Settings.Schematics.PASTE_ON_TOP ? PLOT_HEIGHT : getMinBuildHeight()) - SCHEM_Y; | ||||||
|                     } |  | ||||||
|                 } |                 } | ||||||
|             } else { |             } else { | ||||||
|                 roadY = minRoadWall - SCHEM_Y; |                 roadY = minRoadWall - SCHEM_Y; | ||||||
|   | |||||||
| @@ -68,6 +68,7 @@ import java.util.HashSet; | |||||||
| import java.util.Iterator; | import java.util.Iterator; | ||||||
| import java.util.LinkedHashSet; | import java.util.LinkedHashSet; | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  | import java.util.Objects; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.concurrent.atomic.AtomicBoolean; | import java.util.concurrent.atomic.AtomicBoolean; | ||||||
| import java.util.concurrent.atomic.AtomicInteger; | import java.util.concurrent.atomic.AtomicInteger; | ||||||
| @@ -529,7 +530,7 @@ public class HybridUtils { | |||||||
|         final QueueCoordinator queue = blockQueue.getNewQueue(worldUtil.getWeWorld(world)); |         final QueueCoordinator queue = blockQueue.getNewQueue(worldUtil.getWeWorld(world)); | ||||||
|         Location bot = plot.getBottomAbs().subtract(1, 0, 1); |         Location bot = plot.getBottomAbs().subtract(1, 0, 1); | ||||||
|         Location top = plot.getTopAbs(); |         Location top = plot.getTopAbs(); | ||||||
|         final HybridPlotWorld plotworld = (HybridPlotWorld) plot.getArea(); |         final HybridPlotWorld plotworld = Objects.requireNonNull((HybridPlotWorld) plot.getArea()); | ||||||
|         // Do not use plotworld#schematicStartHeight() here as we want to restore the pre 6.1.4 way of doing it if |         // Do not use plotworld#schematicStartHeight() here as we want to restore the pre 6.1.4 way of doing it if | ||||||
|         //  USE_WALL_IN_ROAD_SCHEM_HEIGHT is false |         //  USE_WALL_IN_ROAD_SCHEM_HEIGHT is false | ||||||
|         int schemY = Settings.Schematics.USE_WALL_IN_ROAD_SCHEM_HEIGHT ? |         int schemY = Settings.Schematics.USE_WALL_IN_ROAD_SCHEM_HEIGHT ? | ||||||
|   | |||||||
| @@ -290,7 +290,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|      * |      * | ||||||
|      * @return the plot the player is standing on or null if standing on a road or not in a {@link PlotArea} |      * @return the plot the player is standing on or null if standing on a road or not in a {@link PlotArea} | ||||||
|      */ |      */ | ||||||
|     public @Nullable Plot getCurrentPlot() { |     public Plot getCurrentPlot() { | ||||||
|         try (final MetaDataAccess<Plot> lastPlotAccess = |         try (final MetaDataAccess<Plot> lastPlotAccess = | ||||||
|                      this.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_LAST_PLOT)) { |                      this.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_LAST_PLOT)) { | ||||||
|             if (lastPlotAccess.get().orElse(null) == null && !Settings.Enabled_Components.EVENTS) { |             if (lastPlotAccess.get().orElse(null) == null && !Settings.Enabled_Components.EVENTS) { | ||||||
| @@ -319,7 +319,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|      */ |      */ | ||||||
|     public int getPlotCount() { |     public int getPlotCount() { | ||||||
|         if (!Settings.Limit.GLOBAL) { |         if (!Settings.Limit.GLOBAL) { | ||||||
|             return getPlotCount(getContextualWorldName()); |             return getPlotCount(getLocation().getWorldName()); | ||||||
|         } |         } | ||||||
|         final AtomicInteger count = new AtomicInteger(0); |         final AtomicInteger count = new AtomicInteger(0); | ||||||
|         final UUID uuid = getUUID(); |         final UUID uuid = getUUID(); | ||||||
| @@ -339,7 +339,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|  |  | ||||||
|     public int getClusterCount() { |     public int getClusterCount() { | ||||||
|         if (!Settings.Limit.GLOBAL) { |         if (!Settings.Limit.GLOBAL) { | ||||||
|             return getClusterCount(getContextualWorldName()); |             return getClusterCount(getLocation().getWorldName()); | ||||||
|         } |         } | ||||||
|         final AtomicInteger count = new AtomicInteger(0); |         final AtomicInteger count = new AtomicInteger(0); | ||||||
|         this.plotAreaManager.forEachPlotArea(value -> { |         this.plotAreaManager.forEachPlotArea(value -> { | ||||||
| @@ -352,34 +352,6 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|         return count.get(); |         return count.get(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * {@return the world name at the player's contextual position} |  | ||||||
|      * The contextual position can be affected when using a command with |  | ||||||
|      * an explicit plot override, e.g., `/plot <id> info`. |  | ||||||
|      */ |  | ||||||
|     private @NonNull String getContextualWorldName() { |  | ||||||
|         Plot current = getCurrentPlot(); |  | ||||||
|         if (current != null) { |  | ||||||
|             return current.getWorldName(); |  | ||||||
|         } |  | ||||||
|         return getLocation().getWorldName(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * {@return the plot area at the player's contextual position} |  | ||||||
|      * The contextual position can be affected when using a command with |  | ||||||
|      * an explicit plot override, e.g., `/plot <id> info`. |  | ||||||
|      * |  | ||||||
|      * @since TODO |  | ||||||
|      */ |  | ||||||
|     public @Nullable PlotArea getContextualPlotArea() { |  | ||||||
|         Plot current = getCurrentPlot(); |  | ||||||
|         if (current != null) { |  | ||||||
|             return current.getArea(); |  | ||||||
|         } |  | ||||||
|         return getLocation().getPlotArea(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Get the number of plots this player owns in the world. |      * Get the number of plots this player owns in the world. | ||||||
|      * |      * | ||||||
| @@ -436,12 +408,8 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public PlotArea getApplicablePlotArea() { |     public PlotArea getApplicablePlotArea() { | ||||||
|         Plot plot = getCurrentPlot(); |  | ||||||
|         if (plot == null) { |  | ||||||
|         return this.plotAreaManager.getApplicablePlotArea(getLocation()); |         return this.plotAreaManager.getApplicablePlotArea(getLocation()); | ||||||
|     } |     } | ||||||
|         return plot.getArea(); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull RequiredType getSuperCaller() { |     public @NonNull RequiredType getSuperCaller() { | ||||||
| @@ -646,16 +614,16 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|             PlotId id = plot.getId(); |             PlotId id = plot.getId(); | ||||||
|             int x = id.getX(); |             int x = id.getX(); | ||||||
|             int z = id.getY(); |             int z = id.getY(); | ||||||
|             ByteBuffer buffer = ByteBuffer.allocate(14); |             ByteBuffer buffer = ByteBuffer.allocate(13); | ||||||
|             buffer.putShort((short) x); |             buffer.putShort((short) x); | ||||||
|             buffer.putShort((short) z); |             buffer.putShort((short) z); | ||||||
|             Location location = getLocation(); |             Location location = getLocation(); | ||||||
|             buffer.putInt(location.getX()); |             buffer.putInt(location.getX()); | ||||||
|             buffer.putShort((short) location.getY()); |             buffer.put((byte) location.getY()); | ||||||
|             buffer.putInt(location.getZ()); |             buffer.putInt(location.getZ()); | ||||||
|             setPersistentMeta("quitLocV2", buffer.array()); |             setPersistentMeta("quitLoc", buffer.array()); | ||||||
|         } else if (hasPersistentMeta("quitLocV2")) { |         } else if (hasPersistentMeta("quitLoc")) { | ||||||
|             removePersistentMeta("quitLocV2"); |             removePersistentMeta("quitLoc"); | ||||||
|         } |         } | ||||||
|         if (plot != null) { |         if (plot != null) { | ||||||
|             this.eventDispatcher.callLeave(this, plot); |             this.eventDispatcher.callLeave(this, plot); | ||||||
| @@ -710,8 +678,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|  |  | ||||||
|     public void populatePersistentMetaMap() { |     public void populatePersistentMetaMap() { | ||||||
|         if (Settings.Enabled_Components.PERSISTENT_META) { |         if (Settings.Enabled_Components.PERSISTENT_META) { | ||||||
|             DBFunc.getPersistentMeta( |             DBFunc.getPersistentMeta(getUUID(), new RunnableVal<>() { | ||||||
|                     getUUID(), new RunnableVal<>() { |  | ||||||
|                 @Override |                 @Override | ||||||
|                 public void run(Map<String, byte[]> value) { |                 public void run(Map<String, byte[]> value) { | ||||||
|                     try { |                     try { | ||||||
| @@ -733,18 +700,11 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|                         PlotArea area = ((SinglePlotAreaManager) manager).getArea(); |                         PlotArea area = ((SinglePlotAreaManager) manager).getArea(); | ||||||
|                                 boolean V2 = false; |  | ||||||
|                         byte[] arr = PlotPlayer.this.getPersistentMeta("quitLoc"); |                         byte[] arr = PlotPlayer.this.getPersistentMeta("quitLoc"); | ||||||
|                                 if (arr == null) { |  | ||||||
|                                     arr = PlotPlayer.this.getPersistentMeta("quitLocV2"); |  | ||||||
|                         if (arr == null) { |                         if (arr == null) { | ||||||
|                             return; |                             return; | ||||||
|                         } |                         } | ||||||
|                                     V2 = true; |  | ||||||
|                                     removePersistentMeta("quitLocV2"); |  | ||||||
|                                 } else { |  | ||||||
|                         removePersistentMeta("quitLoc"); |                         removePersistentMeta("quitLoc"); | ||||||
|                                 } |  | ||||||
|  |  | ||||||
|                         if (!getMeta("teleportOnLogin", true)) { |                         if (!getMeta("teleportOnLogin", true)) { | ||||||
|                             return; |                             return; | ||||||
| @@ -754,7 +714,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|                         final int plotZ = quitWorld.getShort(); |                         final int plotZ = quitWorld.getShort(); | ||||||
|                         PlotId id = PlotId.of(plotX, plotZ); |                         PlotId id = PlotId.of(plotX, plotZ); | ||||||
|                         int x = quitWorld.getInt(); |                         int x = quitWorld.getInt(); | ||||||
|                                 int y = V2 ? quitWorld.getShort() : (quitWorld.get() & 0xFF); |                         int y = quitWorld.get() & 0xFF; | ||||||
|                         int z = quitWorld.getInt(); |                         int z = quitWorld.getInt(); | ||||||
|                         Plot plot = area.getOwnedPlot(id); |                         Plot plot = area.getOwnedPlot(id); | ||||||
|  |  | ||||||
| @@ -788,11 +748,10 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|                     } catch (Throwable e) { |                     } catch (Throwable e) { | ||||||
|                                 LOGGER.error("Error populating persistent meta for player {}", PlotPlayer.this.getName(), e); |                         e.printStackTrace(); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                     } |             }); | ||||||
|             ); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -860,8 +819,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @SuppressWarnings("unchecked") |     @SuppressWarnings("unchecked") | ||||||
|     @Nullable |     @Nullable <T> T getPersistentMeta(final @NonNull MetaDataKey<T> key) { | ||||||
|     <T> T getPersistentMeta(final @NonNull MetaDataKey<T> key) { |  | ||||||
|         final byte[] value = this.getPersistentMeta(key.toString()); |         final byte[] value = this.getPersistentMeta(key.toString()); | ||||||
|         if (value == null) { |         if (value == null) { | ||||||
|             return null; |             return null; | ||||||
| @@ -1031,11 +989,9 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | |||||||
|             if (throwable != null) { |             if (throwable != null) { | ||||||
|                 sendMessage( |                 sendMessage( | ||||||
|                         TranslatableCaption.of("errors.error"), |                         TranslatableCaption.of("errors.error"), | ||||||
|                         TagResolver.resolver( |                         TagResolver.resolver("value", Tag.inserting( | ||||||
|                                 "value", Tag.inserting( |  | ||||||
|                                 Component.text("Failed to resolve asynchronous caption replacements") |                                 Component.text("Failed to resolve asynchronous caption replacements") | ||||||
|                                 ) |                         )) | ||||||
|                         ) |  | ||||||
|                 ); |                 ); | ||||||
|                 LOGGER.error("Failed to resolve asynchronous tagresolver(s) for " + caption, throwable); |                 LOGGER.error("Failed to resolve asynchronous tagresolver(s) for " + caption, throwable); | ||||||
|             } else { |             } else { | ||||||
|   | |||||||
| @@ -541,7 +541,7 @@ public class Plot { | |||||||
|      * |      * | ||||||
|      * @return World name |      * @return World name | ||||||
|      */ |      */ | ||||||
|     public @NonNull String getWorldName() { |     public @Nullable String getWorldName() { | ||||||
|         return area.getWorldName(); |         return area.getWorldName(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -58,7 +58,7 @@ public class SinglePlot extends Plot { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull String getWorldName() { |     public String getWorldName() { | ||||||
|         return getId().toUnderscoreSeparatedString(); |         return getId().toUnderscoreSeparatedString(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -135,7 +135,6 @@ public abstract class SchematicHandler { | |||||||
|         } |         } | ||||||
|         final String filename; |         final String filename; | ||||||
|         final String website; |         final String website; | ||||||
|         final @Nullable UUID finalUuid = uuid; |  | ||||||
|         if (uuid == null) { |         if (uuid == null) { | ||||||
|             uuid = UUID.randomUUID(); |             uuid = UUID.randomUUID(); | ||||||
|             website = Settings.Web.URL + "upload.php?" + uuid; |             website = Settings.Web.URL + "upload.php?" + uuid; | ||||||
| @@ -145,11 +144,10 @@ public abstract class SchematicHandler { | |||||||
|             filename = file + '.' + extension; |             filename = file + '.' + extension; | ||||||
|         } |         } | ||||||
|         final URL url; |         final URL url; | ||||||
|         String uri = Settings.Web.URL + "?key=" + uuid + "&type=" + extension; |  | ||||||
|         try { |         try { | ||||||
|             url = URI.create(uri).toURL(); |             url = URI.create(Settings.Web.URL + "?key=" + uuid + "&type=" + extension).toURL(); | ||||||
|         } catch (MalformedURLException e) { |         } catch (MalformedURLException e) { | ||||||
|             LOGGER.error("Malformed URI `{}`", uri, e); |             e.printStackTrace(); | ||||||
|             whenDone.run(); |             whenDone.run(); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -195,7 +193,7 @@ public abstract class SchematicHandler { | |||||||
|                 } |                 } | ||||||
|                 TaskManager.runTask(whenDone); |                 TaskManager.runTask(whenDone); | ||||||
|             } catch (IOException e) { |             } catch (IOException e) { | ||||||
|                 LOGGER.error("Error while uploading schematic for UUID {}", finalUuid, e); |                 e.printStackTrace(); | ||||||
|                 TaskManager.runTask(whenDone); |                 TaskManager.runTask(whenDone); | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
| @@ -390,14 +388,8 @@ public abstract class SchematicHandler { | |||||||
|             } |             } | ||||||
|             queue.enqueue(); |             queue.enqueue(); | ||||||
|         } catch (Exception e) { |         } catch (Exception e) { | ||||||
|  |             e.printStackTrace(); | ||||||
|             TaskManager.runTask(whenDone); |             TaskManager.runTask(whenDone); | ||||||
|             LOGGER.error( |  | ||||||
|                     "Error pasting schematic to plot {};{} for player {}", |  | ||||||
|                     plot.getArea(), |  | ||||||
|                     plot.getId(), |  | ||||||
|                     actor == null ? "null" : actor.getName(), |  | ||||||
|                     e |  | ||||||
|             ); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -464,7 +456,7 @@ public abstract class SchematicHandler { | |||||||
|                 Clipboard clip = reader.read(); |                 Clipboard clip = reader.read(); | ||||||
|                 return new Schematic(clip); |                 return new Schematic(clip); | ||||||
|             } catch (IOException e) { |             } catch (IOException e) { | ||||||
|                 LOGGER.error("Error reading schematic from file {}", file.getAbsolutePath(), e); |                 e.printStackTrace(); | ||||||
|             } |             } | ||||||
|         } else { |         } else { | ||||||
|             throw new UnsupportedFormatException("This schematic format is not recognised or supported."); |             throw new UnsupportedFormatException("This schematic format is not recognised or supported."); | ||||||
| @@ -478,7 +470,7 @@ public abstract class SchematicHandler { | |||||||
|             InputStream inputStream = Channels.newInputStream(readableByteChannel); |             InputStream inputStream = Channels.newInputStream(readableByteChannel); | ||||||
|             return getSchematic(inputStream); |             return getSchematic(inputStream); | ||||||
|         } catch (IOException e) { |         } catch (IOException e) { | ||||||
|             LOGGER.error("Error reading schematic from {}", url, e); |             e.printStackTrace(); | ||||||
|         } |         } | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
| @@ -494,7 +486,7 @@ public abstract class SchematicHandler { | |||||||
|                 Clipboard clip = schematicReader.read(); |                 Clipboard clip = schematicReader.read(); | ||||||
|                 return new Schematic(clip); |                 return new Schematic(clip); | ||||||
|             } catch (IOException e) { |             } catch (IOException e) { | ||||||
|                 LOGGER.error("Error reading schematic", e); |                 e.printStackTrace(); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         return null; |         return null; | ||||||
| @@ -523,7 +515,7 @@ public abstract class SchematicHandler { | |||||||
|             } |             } | ||||||
|             return schematics; |             return schematics; | ||||||
|         } catch (JsonParseException | IOException e) { |         } catch (JsonParseException | IOException e) { | ||||||
|             LOGGER.error("Error retrieving saves for UUID {}", uuid, e); |             e.printStackTrace(); | ||||||
|         } |         } | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
| @@ -540,7 +532,7 @@ public abstract class SchematicHandler { | |||||||
|                 try (NBTOutputStream nos = new NBTOutputStream(new GZIPOutputStream(output, true))) { |                 try (NBTOutputStream nos = new NBTOutputStream(new GZIPOutputStream(output, true))) { | ||||||
|                     nos.writeNamedTag("Schematic", tag); |                     nos.writeNamedTag("Schematic", tag); | ||||||
|                 } catch (IOException e1) { |                 } catch (IOException e1) { | ||||||
|                     LOGGER.error("Error uploading schematic for UUID {}", uuid, e1); |                     e1.printStackTrace(); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         }, whenDone); |         }, whenDone); | ||||||
| @@ -564,9 +556,9 @@ public abstract class SchematicHandler { | |||||||
|                 nbtStream.writeNamedTag("Schematic", tag); |                 nbtStream.writeNamedTag("Schematic", tag); | ||||||
|             } |             } | ||||||
|         } catch (FileNotFoundException e) { |         } catch (FileNotFoundException e) { | ||||||
|             LOGGER.error("Error saving schematic at {}", path, e); |             e.printStackTrace(); | ||||||
|         } catch (IOException e) { |         } catch (IOException e) { | ||||||
|             LOGGER.error("Error saving schematic at {}", path, e); |             e.printStackTrace(); | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|         return true; |         return true; | ||||||
| @@ -589,7 +581,7 @@ public abstract class SchematicHandler { | |||||||
|         schematic.put("BlockData", new ByteArrayTag(buffer.toByteArray())); |         schematic.put("BlockData", new ByteArrayTag(buffer.toByteArray())); | ||||||
|         schematic.put("BlockEntities", new ListTag(CompoundTag.class, tileEntities)); |         schematic.put("BlockEntities", new ListTag(CompoundTag.class, tileEntities)); | ||||||
|  |  | ||||||
|         if (biomeBuffer.size() == 0 || biomePalette.isEmpty()) { |         if (biomeBuffer.size() == 0 || biomePalette.size() == 0) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -741,7 +733,10 @@ public abstract class SchematicHandler { | |||||||
|                                     } |                                     } | ||||||
|                                     BaseBlock block = aabb.getWorld().getFullBlock(point); |                                     BaseBlock block = aabb.getWorld().getFullBlock(point); | ||||||
|                                     if (block.getNbtData() != null) { |                                     if (block.getNbtData() != null) { | ||||||
|                                         Map<String, Tag> values = new HashMap<>(block.getNbtData().getValue()); |                                         Map<String, Tag> values = new HashMap<>(); | ||||||
|  |                                         for (Map.Entry<String, Tag> entry : block.getNbtData().getValue().entrySet()) { | ||||||
|  |                                             values.put(entry.getKey(), entry.getValue()); | ||||||
|  |                                         } | ||||||
|  |  | ||||||
|                                         // Positions are kept in NBT, we don't want that. |                                         // Positions are kept in NBT, we don't want that. | ||||||
|                                         values.remove("x"); |                                         values.remove("x"); | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ plugins { | |||||||
| } | } | ||||||
|  |  | ||||||
| group = "com.intellectualsites.plotsquared" | group = "com.intellectualsites.plotsquared" | ||||||
| version = "7.5.9-SNAPSHOT" | version = "7.5.7-SNAPSHOT" | ||||||
|  |  | ||||||
| if (!File("$rootDir/.git").exists()) { | if (!File("$rootDir/.git").exists()) { | ||||||
|     logger.lifecycle(""" |     logger.lifecycle(""" | ||||||
| @@ -65,16 +65,10 @@ subprojects { | |||||||
|         plugin<IdeaPlugin>() |         plugin<IdeaPlugin>() | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     configurations.matching { it.name == "signatures" }.configureEach { |  | ||||||
|         attributes { |  | ||||||
|             attribute(Attribute.of("signatures-unique", String::class.java), "true") |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     dependencies { |     dependencies { | ||||||
|         // Tests |         // Tests | ||||||
|         testImplementation("org.junit.jupiter:junit-jupiter:6.0.0") |         testImplementation("org.junit.jupiter:junit-jupiter:5.13.4") | ||||||
|         testRuntimeOnly("org.junit.platform:junit-platform-launcher:6.0.0") |         testRuntimeOnly("org.junit.platform:junit-platform-launcher:1.13.4") | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     plugins.withId("java") { |     plugins.withId("java") { | ||||||
| @@ -101,16 +95,10 @@ subprojects { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     afterEvaluate { |  | ||||||
|     val javaComponent = components["java"] as AdhocComponentWithVariants |     val javaComponent = components["java"] as AdhocComponentWithVariants | ||||||
|         configurations.findByName("shadowRuntimeElements")?.let { shadowRuntimeElements -> |     javaComponent.withVariantsFromConfiguration(configurations["shadowRuntimeElements"]) { | ||||||
|             javaComponent.withVariantsFromConfiguration(shadowRuntimeElements) { |  | ||||||
|         skip() |         skip() | ||||||
|     } |     } | ||||||
|         } ?: run { |  | ||||||
|             logger.warn("Configuration 'shadowRuntimeElements' does not exist.") |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     signing { |     signing { | ||||||
|         if (!project.hasProperty("skip.signing") && !version.toString().endsWith("-SNAPSHOT")) { |         if (!project.hasProperty("skip.signing") && !version.toString().endsWith("-SNAPSHOT")) { | ||||||
|   | |||||||
| @@ -2,18 +2,18 @@ | |||||||
| # Platform expectations | # Platform expectations | ||||||
| paper = "1.20.4-R0.1-SNAPSHOT" | paper = "1.20.4-R0.1-SNAPSHOT" | ||||||
| guice = "7.0.0" | guice = "7.0.0" | ||||||
| spotbugs = "4.9.8" | spotbugs = "4.9.4" | ||||||
| checkerqual = "3.51.1" | checkerqual = "3.49.5" | ||||||
| gson = "2.10" | gson = "2.10" | ||||||
| guava = "31.1-jre" | guava = "31.1-jre" | ||||||
| snakeyaml = "2.0" | snakeyaml = "2.0" | ||||||
| adventure = "4.25.0" | adventure = "4.24.0" | ||||||
| adventure-bukkit = "4.4.1" | adventure-bukkit = "4.4.1" | ||||||
| log4j = "2.19.0" | log4j = "2.19.0" | ||||||
|  |  | ||||||
| # Plugins | # Plugins | ||||||
| worldedit = "7.3.16" | worldedit = "7.2.20" | ||||||
| fawe = "2.14.0" | fawe = "2.13.1" | ||||||
| placeholderapi = "2.11.6" | placeholderapi = "2.11.6" | ||||||
| luckperms = "5.5" | luckperms = "5.5" | ||||||
| essentialsx = "2.21.2" | essentialsx = "2.21.2" | ||||||
| @@ -33,11 +33,11 @@ vault = "1.7.1" | |||||||
| serverlib = "2.3.7" | serverlib = "2.3.7" | ||||||
|  |  | ||||||
| # Gradle plugins | # Gradle plugins | ||||||
| shadow = "9.2.2" | shadow = "8.3.9" | ||||||
| grgit = "4.1.1" | grgit = "4.1.1" | ||||||
| spotless = "8.0.0" | spotless = "7.2.1" | ||||||
| publish = "0.34.0" | publish = "0.34.0" | ||||||
| runPaper = "3.0.2" | runPaper = "2.3.1" | ||||||
|  |  | ||||||
| [libraries] | [libraries] | ||||||
| # Platform expectations | # Platform expectations | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| distributionBase=GRADLE_USER_HOME | distributionBase=GRADLE_USER_HOME | ||||||
| distributionPath=wrapper/dists | distributionPath=wrapper/dists | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-9.1.0-bin.zip | distributionUrl=https\://services.gradle.org/distributions/gradle-8.14.3-bin.zip | ||||||
| networkTimeout=10000 | networkTimeout=10000 | ||||||
| validateDistributionUrl=true | validateDistributionUrl=true | ||||||
| zipStoreBase=GRADLE_USER_HOME | zipStoreBase=GRADLE_USER_HOME | ||||||
|   | |||||||
							
								
								
									
										5
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							| @@ -1,7 +1,7 @@ | |||||||
| #!/bin/sh | #!/bin/sh | ||||||
|  |  | ||||||
| # | # | ||||||
| # Copyright © 2015 the original authors. | # Copyright © 2015-2021 the original authors. | ||||||
| # | # | ||||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | # Licensed under the Apache License, Version 2.0 (the "License"); | ||||||
| # you may not use this file except in compliance with the License. | # you may not use this file except in compliance with the License. | ||||||
| @@ -114,6 +114,7 @@ case "$( uname )" in                #( | |||||||
|   NONSTOP* )        nonstop=true ;; |   NONSTOP* )        nonstop=true ;; | ||||||
| esac | esac | ||||||
|  |  | ||||||
|  | CLASSPATH="\\\"\\\"" | ||||||
|  |  | ||||||
|  |  | ||||||
| # Determine the Java command to use to start the JVM. | # Determine the Java command to use to start the JVM. | ||||||
| @@ -171,6 +172,7 @@ fi | |||||||
| # For Cygwin or MSYS, switch paths to Windows format before running java | # For Cygwin or MSYS, switch paths to Windows format before running java | ||||||
| if "$cygwin" || "$msys" ; then | if "$cygwin" || "$msys" ; then | ||||||
|     APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) |     APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) | ||||||
|  |     CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) | ||||||
|  |  | ||||||
|     JAVACMD=$( cygpath --unix "$JAVACMD" ) |     JAVACMD=$( cygpath --unix "$JAVACMD" ) | ||||||
|  |  | ||||||
| @@ -210,6 +212,7 @@ DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' | |||||||
|  |  | ||||||
| set -- \ | set -- \ | ||||||
|         "-Dorg.gradle.appname=$APP_BASE_NAME" \ |         "-Dorg.gradle.appname=$APP_BASE_NAME" \ | ||||||
|  |         -classpath "$CLASSPATH" \ | ||||||
|         -jar "$APP_HOME/gradle/wrapper/gradle-wrapper.jar" \ |         -jar "$APP_HOME/gradle/wrapper/gradle-wrapper.jar" \ | ||||||
|         "$@" |         "$@" | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							| @@ -70,10 +70,11 @@ goto fail | |||||||
| :execute | :execute | ||||||
| @rem Setup the command line | @rem Setup the command line | ||||||
|  |  | ||||||
|  | set CLASSPATH= | ||||||
|  |  | ||||||
|  |  | ||||||
| @rem Execute Gradle | @rem Execute Gradle | ||||||
| "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -jar "%APP_HOME%\gradle\wrapper\gradle-wrapper.jar" %* | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" -jar "%APP_HOME%\gradle\wrapper\gradle-wrapper.jar" %* | ||||||
|  |  | ||||||
| :end | :end | ||||||
| @rem End local scope for the variables with windows NT shell | @rem End local scope for the variables with windows NT shell | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user