mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-24 23:23:44 +02:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			7.5.7
			...
			feat/v7/ge
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 005074efdb | ||
|   | 91153e1b7b | 
							
								
								
									
										4
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							| @@ -9,11 +9,11 @@ jobs: | ||||
|         os: [ ubuntu-latest, windows-latest, macos-latest ] | ||||
|     steps: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v5 | ||||
|         uses: actions/checkout@v4 | ||||
|       - name: Validate Gradle Wrapper | ||||
|         uses: gradle/actions/wrapper-validation@v4 | ||||
|       - name: Setup Java | ||||
|         uses: actions/setup-java@v5 | ||||
|         uses: actions/setup-java@v4 | ||||
|         with: | ||||
|           distribution: temurin | ||||
|           java-version: 21 | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -9,11 +9,11 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v5 | ||||
|         uses: actions/checkout@v4 | ||||
|       - name: Validate Gradle Wrapper | ||||
|         uses: gradle/actions/wrapper-validation@v4 | ||||
|       - name: Setup Java | ||||
|         uses: actions/setup-java@v5 | ||||
|         uses: actions/setup-java@v4 | ||||
|         with: | ||||
|           distribution: temurin | ||||
|           java-version: 21 | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -20,9 +20,9 @@ jobs: | ||||
|         language: [ 'java' ] | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v5 | ||||
|         uses: actions/checkout@v4 | ||||
|       - name: Setup Java | ||||
|         uses: actions/setup-java@v5 | ||||
|         uses: actions/setup-java@v4 | ||||
|         with: | ||||
|           distribution: temurin | ||||
|           java-version: 21 | ||||
|   | ||||
| @@ -18,8 +18,6 @@ | ||||
|  */ | ||||
| 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 java.io.IOException; | ||||
| @@ -32,14 +30,12 @@ import java.nio.file.Path; | ||||
|  */ | ||||
| public class Backup { | ||||
|  | ||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + Backup.class.getSimpleName()); | ||||
|  | ||||
|     private final BackupProfile owner; | ||||
|     private final long creationTime; | ||||
|     @Nullable | ||||
|     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.creationTime = creationTime; | ||||
|         this.file = file; | ||||
| @@ -53,7 +49,7 @@ public class Backup { | ||||
|             try { | ||||
|                 Files.deleteIfExists(file); | ||||
|             } 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.assistedinject.Assisted; | ||||
| 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.plot.Plot; | ||||
| import com.plotsquared.core.plot.schematic.Schematic; | ||||
| import com.plotsquared.core.util.SchematicHandler; | ||||
| import com.plotsquared.core.util.task.RunnableVal; | ||||
| import com.plotsquared.core.util.task.TaskManager; | ||||
| import org.apache.logging.log4j.LogManager; | ||||
| import org.apache.logging.log4j.Logger; | ||||
| import net.kyori.adventure.text.minimessage.MiniMessage; | ||||
| import org.checkerframework.checker.nullness.qual.NonNull; | ||||
| import org.checkerframework.checker.nullness.qual.Nullable; | ||||
|  | ||||
| @@ -52,7 +51,7 @@ import java.util.concurrent.CompletableFuture; | ||||
|  */ | ||||
| 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 Plot plot; | ||||
| @@ -88,7 +87,7 @@ public class PlayerBackupProfile implements BackupProfile { | ||||
|                 Files.createDirectory(path); | ||||
|             } | ||||
|         } catch (final Exception e) { | ||||
|             LOGGER.error("Error resolving {} from {}", child, parent, e); | ||||
|             e.printStackTrace(); | ||||
|         } | ||||
|         return path; | ||||
|     } | ||||
| @@ -105,7 +104,7 @@ public class PlayerBackupProfile implements BackupProfile { | ||||
|                     try { | ||||
|                         Files.createDirectories(path); | ||||
|                     } catch (IOException e) { | ||||
|                         LOGGER.error("Error creating directory {}", path, e); | ||||
|                         e.printStackTrace(); | ||||
|                         return Collections.emptyList(); | ||||
|                     } | ||||
|                 } | ||||
| @@ -118,11 +117,11 @@ public class PlayerBackupProfile implements BackupProfile { | ||||
|                             backups.add( | ||||
|                                     new Backup(this, basicFileAttributes.creationTime().toMillis(), file)); | ||||
|                         } catch (IOException e) { | ||||
|                             LOGGER.error("Error getting attributes for file {} to create backup", file, e); | ||||
|                             e.printStackTrace(); | ||||
|                         } | ||||
|                     }); | ||||
|                 } catch (IOException e) { | ||||
|                     LOGGER.error("Error walking files from {}", path, e); | ||||
|                     e.printStackTrace(); | ||||
|                 } | ||||
|                 backups.sort(Comparator.comparingLong(Backup::getCreationTime).reversed()); | ||||
|                 return (this.backupCache = backups); | ||||
| @@ -134,7 +133,7 @@ public class PlayerBackupProfile implements BackupProfile { | ||||
|     public void destroy() { | ||||
|         this.listBackups().whenCompleteAsync((backups, error) -> { | ||||
|             if (error != null) { | ||||
|                 LOGGER.error("Error while listing backups", error); | ||||
|                 error.printStackTrace(); | ||||
|             } | ||||
|             backups.forEach(Backup::delete); | ||||
|             this.backupCache = null; | ||||
| @@ -142,12 +141,10 @@ public class PlayerBackupProfile implements BackupProfile { | ||||
|     } | ||||
|  | ||||
|     public @NonNull Path getBackupDirectory() { | ||||
|         return resolve( | ||||
|                 resolve( | ||||
|                         resolve(backupManager.getBackupPath(), Objects.requireNonNull(plot.getArea().toString(), "plot area id")), | ||||
|                         Objects.requireNonNull(plot.getId().toDashSeparatedString(), "plot id") | ||||
|                 ), Objects.requireNonNull(owner.toString(), "owner") | ||||
|         ); | ||||
|         return resolve(resolve( | ||||
|                 resolve(backupManager.getBackupPath(), Objects.requireNonNull(plot.getArea().toString(), "plot area id")), | ||||
|                 Objects.requireNonNull(plot.getId().toDashSeparatedString(), "plot id") | ||||
|         ), Objects.requireNonNull(owner.toString(), "owner")); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
| @@ -159,8 +156,7 @@ public class PlayerBackupProfile implements BackupProfile { | ||||
|                     backups.get(backups.size() - 1).delete(); | ||||
|                 } | ||||
|                 final List<Plot> plots = Collections.singletonList(plot); | ||||
|                 final boolean result = this.schematicHandler.exportAll( | ||||
|                         plots, getBackupDirectory().toFile(), | ||||
|                 final boolean result = this.schematicHandler.exportAll(plots, getBackupDirectory().toFile(), | ||||
|                         "%world%-%id%-" + System.currentTimeMillis(), () -> | ||||
|                                 future.complete(new Backup(this, System.currentTimeMillis(), null)) | ||||
|                 ); | ||||
| @@ -184,7 +180,7 @@ public class PlayerBackupProfile implements BackupProfile { | ||||
|                 try { | ||||
|                     schematic = this.schematicHandler.getSchematic(backup.getFile().toFile()); | ||||
|                 } catch (SchematicHandler.UnsupportedFormatException e) { | ||||
|                     LOGGER.error("Unsupported format for backup {}", backup.getFile(), e); | ||||
|                     e.printStackTrace(); | ||||
|                 } | ||||
|                 if (schematic == null) { | ||||
|                     future.completeExceptionally(new IllegalArgumentException( | ||||
| @@ -204,9 +200,10 @@ public class PlayerBackupProfile implements BackupProfile { | ||||
|                                     if (value) { | ||||
|                                         future.complete(null); | ||||
|                                     } else { | ||||
|                                         future.completeExceptionally(new PlotSquaredException( | ||||
|                                         future.completeExceptionally(new RuntimeException(MINI_MESSAGE.escapeTags( | ||||
|                                                 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.minimessage.tag.Tag; | ||||
| 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.Nullable; | ||||
|  | ||||
| @@ -49,7 +47,6 @@ import java.util.concurrent.TimeUnit; | ||||
| @Singleton | ||||
| public class SimpleBackupManager implements BackupManager { | ||||
|  | ||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + SimpleBackupManager.class.getSimpleName()); | ||||
|     private final Path backupPath; | ||||
|     private final boolean automaticBackup; | ||||
|     private final int backupLimit; | ||||
| @@ -115,12 +112,7 @@ public class SimpleBackupManager implements BackupManager { | ||||
|                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) | ||||
|                         ); | ||||
|                     } | ||||
|                     LOGGER.error( | ||||
|                             "Error creating backup for plot {};{} and player {}", | ||||
|                             plot.getArea(), | ||||
|                             plot.getId(), | ||||
|                             player == null ? "null" : player.getName(), throwable | ||||
|                     ); | ||||
|                     throwable.printStackTrace(); | ||||
|                 } else { | ||||
|                     if (player != null) { | ||||
|                         player.sendMessage(TranslatableCaption.of("backups.backup_automatic_finished")); | ||||
| @@ -136,7 +128,6 @@ public class SimpleBackupManager implements BackupManager { | ||||
|         return this.automaticBackup; | ||||
|     } | ||||
|  | ||||
|     @NonNull | ||||
|     public Path getBackupPath() { | ||||
|         return this.backupPath; | ||||
|     } | ||||
|   | ||||
| @@ -21,6 +21,7 @@ package com.plotsquared.core.command; | ||||
| import com.plotsquared.core.PlotSquared; | ||||
| import com.plotsquared.core.configuration.Settings; | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| @@ -57,7 +58,8 @@ public class Alias extends SubCommand { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         Plot plot = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         Plot plot = location.getPlotAbs(); | ||||
|         if (plot == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
|   | ||||
| @@ -24,7 +24,6 @@ import com.plotsquared.core.backup.BackupProfile; | ||||
| import com.plotsquared.core.backup.NullBackupProfile; | ||||
| import com.plotsquared.core.backup.PlayerBackupProfile; | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.exception.PlotSquaredException; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| 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.minimessage.tag.Tag; | ||||
| 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 java.nio.file.Files; | ||||
| @@ -60,8 +57,6 @@ import java.util.stream.Stream; | ||||
|         permission = "plots.backup") | ||||
| public final class Backup extends Command { | ||||
|  | ||||
|     private static final Logger LOGGER = LogManager.getLogger("PlotSquared/" + Backup.class.getSimpleName()); | ||||
|  | ||||
|     private final BackupManager backupManager; | ||||
|  | ||||
|     @Inject | ||||
| @@ -331,43 +326,20 @@ public final class Backup extends Command { | ||||
|             if (backupProfile instanceof NullBackupProfile) { | ||||
|                 player.sendMessage( | ||||
|                         TranslatableCaption.of("backups.backup_impossible"), | ||||
|                         TagResolver.resolver( | ||||
|                                 "plot", Tag.inserting( | ||||
|                                         TranslatableCaption.of("generic.generic_other").toComponent(player) | ||||
|                                 ) | ||||
|                         ) | ||||
|                         TagResolver.resolver("plot", Tag.inserting( | ||||
|                                 TranslatableCaption.of("generic.generic_other").toComponent(player) | ||||
|                         )) | ||||
|                 ); | ||||
|             } else { | ||||
|                 backupProfile.listBackups().whenComplete((backups, throwable) -> { | ||||
|                     if (throwable != null) { | ||||
|                         Component reason; | ||||
|                         if (throwable instanceof PlotSquaredException pe) { | ||||
|                             reason = pe.getCaption().toComponent(player); | ||||
|                         } else { | ||||
|                             reason = Component.text(throwable.getMessage()); | ||||
|                         } | ||||
|                         player.sendMessage( | ||||
|                                 TranslatableCaption.of("backups.backup_load_failure"), | ||||
|                                 TagResolver.resolver("reason", Tag.inserting(reason)) | ||||
|                         ); | ||||
|                         LOGGER.error("Error loading player ({}) backup", player.getName(), throwable); | ||||
|                         return; | ||||
|                     } | ||||
|                     if (number < 1 || number > backups.size()) { | ||||
|                         player.sendMessage( | ||||
|                                 TranslatableCaption.of("backups.backup_impossible"), | ||||
|                                 TagResolver.resolver( | ||||
|                                         "plot", | ||||
|                                         Tag.inserting(TranslatableCaption | ||||
|                                                 .of("generic.generic_invalid_choice") | ||||
|                                                 .toComponent(player)) | ||||
|                                 ) | ||||
|                                 TagResolver.resolver("reason", Tag.inserting(Component.text(throwable.getMessage()))) | ||||
|                         ); | ||||
|                         throwable.printStackTrace(); | ||||
|                     } else { | ||||
|                         final com.plotsquared.core.backup.Backup backup = | ||||
|                                 backups.get(number - 1); | ||||
|                         if (backup == null || backup.getFile() == null || !Files | ||||
|                                 .exists(backup.getFile())) { | ||||
|                         if (number < 1 || number > backups.size()) { | ||||
|                             player.sendMessage( | ||||
|                                     TranslatableCaption.of("backups.backup_impossible"), | ||||
|                                     TagResolver.resolver( | ||||
| @@ -378,23 +350,37 @@ public final class Backup extends Command { | ||||
|                                     ) | ||||
|                             ); | ||||
|                         } else { | ||||
|                             CmdConfirm.addPending( | ||||
|                                     player, "/plot backup load " + number, | ||||
|                                     () -> backupProfile.restoreBackup(backup, player) | ||||
|                                             .whenComplete((n, error) -> { | ||||
|                                                 if (error != null) { | ||||
|                                                     player.sendMessage( | ||||
|                                                             TranslatableCaption.of("backups.backup_load_failure"), | ||||
|                                                             TagResolver.resolver( | ||||
|                                                                     "reason", | ||||
|                                                                     Tag.inserting(Component.text(error.getMessage())) | ||||
|                                                             ) | ||||
|                                                     ); | ||||
|                                                 } else { | ||||
|                                                     player.sendMessage(TranslatableCaption.of("backups.backup_load_success")); | ||||
|                                                 } | ||||
|                                             }) | ||||
|                             ); | ||||
|                             final com.plotsquared.core.backup.Backup backup = | ||||
|                                     backups.get(number - 1); | ||||
|                             if (backup == null || backup.getFile() == null || !Files | ||||
|                                     .exists(backup.getFile())) { | ||||
|                                 player.sendMessage( | ||||
|                                         TranslatableCaption.of("backups.backup_impossible"), | ||||
|                                         TagResolver.resolver( | ||||
|                                                 "plot", | ||||
|                                                 Tag.inserting(TranslatableCaption | ||||
|                                                         .of("generic.generic_invalid_choice") | ||||
|                                                         .toComponent(player)) | ||||
|                                         ) | ||||
|                                 ); | ||||
|                             } else { | ||||
|                                 CmdConfirm.addPending(player, "/plot backup load " + number, | ||||
|                                         () -> backupProfile.restoreBackup(backup, player) | ||||
|                                                 .whenComplete((n, error) -> { | ||||
|                                                     if (error != null) { | ||||
|                                                         player.sendMessage( | ||||
|                                                                 TranslatableCaption.of("backups.backup_load_failure"), | ||||
|                                                                 TagResolver.resolver( | ||||
|                                                                         "reason", | ||||
|                                                                         Tag.inserting(Component.text(error.getMessage())) | ||||
|                                                                 ) | ||||
|                                                         ); | ||||
|                                                     } else { | ||||
|                                                         player.sendMessage(TranslatableCaption.of("backups.backup_load_success")); | ||||
|                                                     } | ||||
|                                                 }) | ||||
|                                 ); | ||||
|                             } | ||||
|                         } | ||||
|                     } | ||||
|                 }); | ||||
|   | ||||
| @@ -20,7 +20,6 @@ package com.plotsquared.core.command; | ||||
|  | ||||
| import com.google.inject.Inject; | ||||
| import com.plotsquared.core.PlotSquared; | ||||
| import com.plotsquared.core.configuration.Settings; | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.events.PlayerBuyPlotEvent; | ||||
| 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.isOwner(player.getUUID()), TranslatableCaption.of("economy.cannot_buy_own")); | ||||
|         Set<Plot> plots = plot.getConnectedPlots(); | ||||
|         int plotCount = Settings.Limit.GLOBAL ? player.getPlotCount() : player.getPlotCount(plot.getWorldName()); | ||||
|         checkTrue( | ||||
|                 plotCount + plots.size() <= player.getAllowedPlots(), | ||||
|                 player.getPlotCount() + plots.size() <= player.getAllowedPlots(), | ||||
|                 TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||
|                 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.Result; | ||||
| import com.plotsquared.core.location.Direction; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.MetaDataAccess; | ||||
| import com.plotsquared.core.player.PlayerMetaDataKeys; | ||||
| @@ -71,7 +72,8 @@ public class Claim extends SubCommand { | ||||
|         if (args.length >= 1) { | ||||
|             schematic = args[0]; | ||||
|         } | ||||
|         Plot plot = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         Plot plot = location.getPlotAbs(); | ||||
|         if (plot == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
| @@ -88,7 +90,7 @@ public class Claim extends SubCommand { | ||||
|         boolean force = event.getEventResult() == Result.FORCE; | ||||
|         int currentPlots = Settings.Limit.GLOBAL ? | ||||
|                 player.getPlotCount() : | ||||
|                 player.getPlotCount(plot.getWorldName()); | ||||
|                 player.getPlotCount(location.getWorldName()); | ||||
|  | ||||
|         final PlotArea area = plot.getArea(); | ||||
|  | ||||
|   | ||||
| @@ -68,8 +68,8 @@ public class Continue extends SubCommand { | ||||
|             return false; | ||||
|         } | ||||
|         int size = plot.getConnectedPlots().size(); | ||||
|         int plotCount = Settings.Limit.GLOBAL ? player.getPlotCount() : player.getPlotCount(plot.getWorldName()); | ||||
|         if (!Settings.Done.COUNTS_TOWARDS_LIMIT && (player.getAllowedPlots() < plotCount + size)) { | ||||
|         if (!Settings.Done.COUNTS_TOWARDS_LIMIT && (player.getAllowedPlots() | ||||
|                 < player.getPlotCount() + size)) { | ||||
|             player.sendMessage( | ||||
|                     TranslatableCaption.of("permission.cant_claim_more_plots"), | ||||
|                     TagResolver.resolver("amount", Tag.inserting(Component.text(player.getAllowedPlots()))) | ||||
|   | ||||
| @@ -19,6 +19,7 @@ | ||||
| package com.plotsquared.core.command; | ||||
|  | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| @@ -36,7 +37,8 @@ public class Copy extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||
|         Plot plot1 = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         Plot plot1 = location.getPlotAbs(); | ||||
|         if (plot1 == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
|   | ||||
| @@ -22,6 +22,7 @@ import com.google.inject.Inject; | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.generator.HybridPlotWorld; | ||||
| import com.plotsquared.core.generator.HybridUtils; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| import net.kyori.adventure.text.Component; | ||||
| @@ -46,7 +47,8 @@ public class CreateRoadSchematic extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||
|         Plot plot = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         Plot plot = location.getPlotAbs(); | ||||
|         if (plot == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
| @@ -55,7 +57,7 @@ public class CreateRoadSchematic extends SubCommand { | ||||
|             player.sendMessage(TranslatableCaption.of("schematics.schematic_too_large")); | ||||
|             return false; | ||||
|         } | ||||
|         if (!(plot.getArea() instanceof HybridPlotWorld)) { | ||||
|         if (!(location.getPlotArea() instanceof HybridPlotWorld)) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||
|         } | ||||
|         this.hybridUtils.setupRoadSchematic(plot); | ||||
|   | ||||
| @@ -22,6 +22,7 @@ import com.google.inject.Inject; | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.generator.HybridPlotManager; | ||||
| import com.plotsquared.core.generator.HybridUtils; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| import com.plotsquared.core.plot.PlotArea; | ||||
| @@ -56,7 +57,8 @@ public class DebugRoadRegen extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||
|         Plot plot = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         Plot plot = location.getPlotAbs(); | ||||
|         if (args.length < 1) { | ||||
|             player.sendMessage( | ||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||
| @@ -90,7 +92,8 @@ public class DebugRoadRegen extends SubCommand { | ||||
|     } | ||||
|  | ||||
|     public boolean regenPlot(PlotPlayer<?> player) { | ||||
|         PlotArea area = player.getCurrentPlot().getArea(); | ||||
|         Location location = player.getLocation(); | ||||
|         PlotArea area = location.getPlotArea(); | ||||
|         if (area == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||
|             return false; | ||||
| @@ -145,7 +148,8 @@ public class DebugRoadRegen extends SubCommand { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         PlotArea area = player.getCurrentPlot().getArea(); | ||||
|         Location location = player.getLocation(); | ||||
|         PlotArea area = location.getPlotArea(); | ||||
|         if (area == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||
|         } | ||||
|   | ||||
| @@ -23,6 +23,7 @@ import com.plotsquared.core.configuration.Settings; | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.events.Result; | ||||
| import com.plotsquared.core.events.TeleportCause; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| @@ -60,7 +61,8 @@ public class Delete extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     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) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
| @@ -90,7 +92,7 @@ public class Delete extends SubCommand { | ||||
|         final java.util.Set<Plot> plots = plot.getConnectedPlots(); | ||||
|         final int currentPlots = Settings.Limit.GLOBAL ? | ||||
|                 player.getPlotCount() : | ||||
|                 player.getPlotCount(plot.getWorldName()); | ||||
|                 player.getPlotCount(location.getWorldName()); | ||||
|         Runnable run = () -> { | ||||
|             if (plot.getRunning() > 0) { | ||||
|                 player.sendMessage(TranslatableCaption.of("errors.wait_for_timer")); | ||||
|   | ||||
| @@ -70,7 +70,8 @@ public class Deny extends SubCommand { | ||||
|     @Override | ||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||
|  | ||||
|         final Plot plot = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         final Plot plot = location.getPlotAbs(); | ||||
|         if (plot == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
|   | ||||
| @@ -26,6 +26,7 @@ import com.plotsquared.core.events.PlotDoneEvent; | ||||
| import com.plotsquared.core.events.PlotFlagAddEvent; | ||||
| import com.plotsquared.core.events.Result; | ||||
| import com.plotsquared.core.generator.HybridUtils; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| @@ -60,7 +61,8 @@ public class Done extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     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()) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
|   | ||||
| @@ -73,7 +73,7 @@ public class Download extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     public boolean onCommand(final PlotPlayer<?> player, String[] args) { | ||||
|         String world = player.getCurrentPlot().getWorldName(); | ||||
|         String world = player.getLocation().getWorldName(); | ||||
|         if (!this.plotAreaManager.hasPlotArea(world)) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||
|             return false; | ||||
|   | ||||
| @@ -27,6 +27,7 @@ import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.events.PlotFlagAddEvent; | ||||
| import com.plotsquared.core.events.PlotFlagRemoveEvent; | ||||
| import com.plotsquared.core.events.Result; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| 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 | ||||
|      */ | ||||
|     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) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
| @@ -342,7 +344,7 @@ public final class FlagCommand extends Command { | ||||
|         if (plotFlag == null) { | ||||
|             return; | ||||
|         } | ||||
|         Plot plot = player.getCurrentPlot(); | ||||
|         Plot plot = player.getLocation().getPlotAbs(); | ||||
|         PlotFlagAddEvent event = eventDispatcher.callFlagAdd(plotFlag, plot); | ||||
|         if (event.getEventResult() == Result.DENY) { | ||||
|             player.sendMessage( | ||||
| @@ -407,7 +409,7 @@ public final class FlagCommand extends Command { | ||||
|         if (plotFlag == null) { | ||||
|             return; | ||||
|         } | ||||
|         Plot plot = player.getCurrentPlot(); | ||||
|         Plot plot = player.getLocation().getPlotAbs(); | ||||
|         PlotFlagAddEvent event = eventDispatcher.callFlagAdd(plotFlag, plot); | ||||
|         if (event.getEventResult() == Result.DENY) { | ||||
|             player.sendMessage( | ||||
| @@ -417,7 +419,7 @@ public final class FlagCommand extends Command { | ||||
|             return; | ||||
|         } | ||||
|         boolean force = event.getEventResult() == Result.FORCE; | ||||
|         final PlotFlag localFlag = player.getCurrentPlot().getFlagContainer() | ||||
|         final PlotFlag localFlag = player.getLocation().getPlotAbs().getFlagContainer() | ||||
|                 .getFlag(event.getFlag().getClass()); | ||||
|         if (!force) { | ||||
|             for (String entry : args[1].split(",")) { | ||||
| @@ -442,7 +444,7 @@ public final class FlagCommand extends Command { | ||||
|             return; | ||||
|         } | ||||
|         boolean result = | ||||
|                 player.getCurrentPlot().setFlag(localFlag.merge(parsed.getValue())); | ||||
|                 player.getLocation().getPlotAbs().setFlag(localFlag.merge(parsed.getValue())); | ||||
|         if (!result) { | ||||
|             player.sendMessage(TranslatableCaption.of("flag.flag_not_added")); | ||||
|             return; | ||||
| @@ -482,7 +484,7 @@ public final class FlagCommand extends Command { | ||||
|         if (flag == null) { | ||||
|             return; | ||||
|         } | ||||
|         final Plot plot = player.getCurrentPlot(); | ||||
|         final Plot plot = player.getLocation().getPlotAbs(); | ||||
|         final PlotFlag<?, ?> flagWithOldValue = plot.getFlagContainer().getFlag(flag.getClass()); | ||||
|         PlotFlagRemoveEvent event = eventDispatcher.callFlagRemove(flag, plot); | ||||
|         if (event.getEventResult() == Result.DENY) { | ||||
| @@ -685,7 +687,7 @@ public final class FlagCommand extends Command { | ||||
|                             .build() | ||||
|             ); | ||||
|             // Default value | ||||
|             final String defaultValue = player.getCurrentPlot().getArea().getFlagContainer() | ||||
|             final String defaultValue = player.getLocation().getPlotArea().getFlagContainer() | ||||
|                     .getFlagErased(plotFlag.getClass()).toString(); | ||||
|             player.sendMessage( | ||||
|                     TranslatableCaption.of("flag.flag_info_default_value"), | ||||
|   | ||||
| @@ -65,7 +65,8 @@ public class Kick extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||
|         Plot plot = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         Plot plot = location.getPlot(); | ||||
|         if (plot == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
| @@ -123,7 +124,7 @@ public class Kick extends SubCommand { | ||||
|                         ); | ||||
|                         return; | ||||
|                     } | ||||
|                     Location spawn = this.worldUtil.getSpawn(plot.getWorldName()); | ||||
|                     Location spawn = this.worldUtil.getSpawn(location.getWorldName()); | ||||
|                     player2.sendMessage(TranslatableCaption.of("kick.you_got_kicked")); | ||||
|                     if (plot.equals(spawn.getPlot())) { | ||||
|                         Location newSpawn = this.worldUtil.getSpawn(this.plotAreaManager.getAllWorlds()[0]); | ||||
| @@ -147,7 +148,8 @@ public class Kick extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     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) { | ||||
|             return Collections.emptyList(); | ||||
|         } | ||||
|   | ||||
| @@ -150,8 +150,8 @@ public class ListCmd extends SubCommand { | ||||
|             page = 0; | ||||
|         } | ||||
|  | ||||
|         String world = player.getCurrentPlot().getWorldName(); | ||||
|         PlotArea area = player.getCurrentPlot().getArea(); | ||||
|         String world = player.getLocation().getWorldName(); | ||||
|         PlotArea area = player.getApplicablePlotArea(); | ||||
|         String arg = args[0].toLowerCase(); | ||||
|         final boolean[] sort = new boolean[]{true}; | ||||
|  | ||||
|   | ||||
| @@ -68,7 +68,7 @@ public class Load extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     public boolean onCommand(final PlotPlayer<?> player, final String[] args) { | ||||
|         final String world = player.getCurrentPlot().getWorldName(); | ||||
|         final String world = player.getLocation().getWorldName(); | ||||
|         if (!this.plotAreaManager.hasPlotArea(world)) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||
|             return false; | ||||
|   | ||||
| @@ -20,6 +20,7 @@ package com.plotsquared.core.command; | ||||
|  | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.events.TeleportCause; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
|  | ||||
| @@ -35,7 +36,8 @@ public class Middle extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     public boolean onCommand(PlotPlayer<?> player, String[] arguments) { | ||||
|         Plot plot = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         Plot plot = location.getPlot(); | ||||
|         if (plot == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
|   | ||||
| @@ -20,6 +20,7 @@ package com.plotsquared.core.command; | ||||
|  | ||||
| import com.google.inject.Inject; | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| @@ -54,7 +55,8 @@ public class Move extends SubCommand { | ||||
|             RunnableVal3<Command, Runnable, Runnable> confirm, | ||||
|             RunnableVal2<Command, CommandResult> whenDone | ||||
|     ) { | ||||
|         Plot plot1 = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         Plot plot1 = location.getPlotAbs(); | ||||
|         if (plot1 == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             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.PlotFlagRemoveEvent; | ||||
| import com.plotsquared.core.events.Result; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| @@ -73,7 +74,8 @@ public class Music extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||
|         final Plot plot = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         final Plot plot = location.getPlotAbs(); | ||||
|         if (plot == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
|   | ||||
| @@ -21,6 +21,7 @@ package com.plotsquared.core.command; | ||||
| import com.google.inject.Inject; | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.database.DBFunc; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| @@ -55,7 +56,8 @@ public class Remove extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||
|         Plot plot = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         Plot plot = location.getPlotAbs(); | ||||
|         if (plot == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
| @@ -130,7 +132,8 @@ public class Remove extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     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) { | ||||
|             return Collections.emptyList(); | ||||
|         } | ||||
|   | ||||
| @@ -22,6 +22,7 @@ import com.google.common.collect.Lists; | ||||
| import com.google.inject.Inject; | ||||
| import com.plotsquared.core.configuration.Settings; | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.ConsolePlayer; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| @@ -101,7 +102,8 @@ public class SchematicCmd extends SubCommand { | ||||
|                     ); | ||||
|                     break; | ||||
|                 } | ||||
|                 final Plot plot = player.getCurrentPlot(); | ||||
|                 Location loc = player.getLocation(); | ||||
|                 final Plot plot = loc.getPlotAbs(); | ||||
|                 if (plot == null) { | ||||
|                     player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|                     return false; | ||||
| @@ -245,7 +247,8 @@ public class SchematicCmd extends SubCommand { | ||||
|                     player.sendMessage(TranslatableCaption.of("error.task_in_process")); | ||||
|                     return false; | ||||
|                 } | ||||
|                 Plot plot = player.getCurrentPlot(); | ||||
|                 Location location = player.getLocation(); | ||||
|                 Plot plot = location.getPlotAbs(); | ||||
|                 if (plot == null) { | ||||
|                     player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|                     return false; | ||||
|   | ||||
| @@ -78,7 +78,7 @@ public class Set extends SubCommand { | ||||
|  | ||||
|             @Override | ||||
|             public boolean set(PlotPlayer<?> player, final Plot plot, String value) { | ||||
|                 final PlotArea plotArea = player.getCurrentPlot().getArea(); | ||||
|                 final PlotArea plotArea = player.getLocation().getPlotArea(); | ||||
|                 if (plotArea == null) { | ||||
|                     return false; | ||||
|                 } | ||||
|   | ||||
| @@ -19,6 +19,7 @@ | ||||
| package com.plotsquared.core.command; | ||||
|  | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| @@ -31,7 +32,8 @@ public abstract class SetCommand extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     public boolean onCommand(PlotPlayer<?> player, String[] args) { | ||||
|         Plot plot = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         Plot plot = location.getPlotAbs(); | ||||
|         if (plot == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
|   | ||||
| @@ -19,6 +19,7 @@ | ||||
| package com.plotsquared.core.command; | ||||
|  | ||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| @@ -43,7 +44,8 @@ public class Swap extends SubCommand { | ||||
|             RunnableVal3<Command, Runnable, Runnable> confirm, | ||||
|             RunnableVal2<Command, CommandResult> whenDone | ||||
|     ) { | ||||
|         Plot plot1 = player.getCurrentPlot(); | ||||
|         Location location = player.getLocation(); | ||||
|         Plot plot1 = location.getPlotAbs(); | ||||
|         if (plot1 == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return CompletableFuture.completedFuture(false); | ||||
| @@ -77,10 +79,8 @@ public class Swap extends SubCommand { | ||||
|         String p1 = plot1.toString(); | ||||
|         String p2 = plot2.toString(); | ||||
|  | ||||
|         return plot1.getPlotModificationManager().move( | ||||
|                 plot2, player, () -> { | ||||
|                 }, true | ||||
|         ).thenApply(result -> { | ||||
|         return plot1.getPlotModificationManager().move(plot2, player, () -> { | ||||
|         }, true).thenApply(result -> { | ||||
|             if (result) { | ||||
|                 player.sendMessage( | ||||
|                         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.events.PlotUnlinkEvent; | ||||
| import com.plotsquared.core.events.Result; | ||||
| import com.plotsquared.core.location.Location; | ||||
| import com.plotsquared.core.permissions.Permission; | ||||
| import com.plotsquared.core.player.PlotPlayer; | ||||
| import com.plotsquared.core.plot.Plot; | ||||
| @@ -50,7 +51,8 @@ public class Unlink extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     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) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|             return false; | ||||
|   | ||||
| @@ -435,6 +435,11 @@ public class Settings extends Config { | ||||
|  | ||||
|         public static String SCHEMATICS = "schematics"; | ||||
|         public static String TEMPLATES = "templates"; | ||||
|         @Comment({"If schematics used for generation should be searched for in the path.schematics location", | ||||
|                 " - This setting exists and is `false` by default for backwards compatibility.", | ||||
|                 " - If false then generation schematics must be located in `schematics`", | ||||
|                 " - Schematics must still always be under GEN_ROAD_SCHEMATIC/<world> etc."}) | ||||
|         public static boolean USE_SCHEMATICS_PATH_FOR_GEN_SCHEMATICS = 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; | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -140,7 +140,8 @@ public class HybridPlotWorld extends ClassicPlotWorld { | ||||
|     @NonNull | ||||
|     @Override | ||||
|     protected PlotManager createManager() { | ||||
|         return new HybridPlotManager(this, PlotSquared.platform().regionManager(), | ||||
|         return new HybridPlotManager( | ||||
|                 this, PlotSquared.platform().regionManager(), | ||||
|                 PlotSquared.platform().injector().getInstance(ProgressSubscriberFactory.class) | ||||
|         ); | ||||
|     } | ||||
| @@ -215,15 +216,16 @@ public class HybridPlotWorld extends ClassicPlotWorld { | ||||
|  | ||||
|         // Try to determine root. This means that plot areas can have separate schematic | ||||
|         // directories | ||||
|         String schematicFolder = Settings.Paths.USE_SCHEMATICS_PATH_FOR_GEN_SCHEMATICS ? Settings.Paths.SCHEMATICS : "schematics"; | ||||
|         if (!(root = | ||||
|                 FileUtils.getFile( | ||||
|                         PlotSquared.platform().getDirectory(), | ||||
|                         "schematics/GEN_ROAD_SCHEMATIC/" + this.getWorldName() + "/" + this.getId() | ||||
|                         schematicFolder + File.separator + "GEN_ROAD_SCHEMATIC" + File.separator + this.getWorldName() + File.separator + this.getId() | ||||
|                 )) | ||||
|                 .exists()) { | ||||
|             root = FileUtils.getFile( | ||||
|                     PlotSquared.platform().getDirectory(), | ||||
|                     "schematics/GEN_ROAD_SCHEMATIC/" + this.getWorldName() | ||||
|                     schematicFolder + File.separator + "GEN_ROAD_SCHEMATIC" + File.separator + this.getWorldName() | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|   | ||||
| @@ -290,7 +290,6 @@ 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} | ||||
|      */ | ||||
|     @Nullable | ||||
|     public Plot getCurrentPlot() { | ||||
|         try (final MetaDataAccess<Plot> lastPlotAccess = | ||||
|                      this.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_LAST_PLOT)) { | ||||
| @@ -320,7 +319,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|      */ | ||||
|     public int getPlotCount() { | ||||
|         if (!Settings.Limit.GLOBAL) { | ||||
|             return getPlotCount(getCurrentPlot().getWorldName()); | ||||
|             return getPlotCount(getLocation().getWorldName()); | ||||
|         } | ||||
|         final AtomicInteger count = new AtomicInteger(0); | ||||
|         final UUID uuid = getUUID(); | ||||
| @@ -340,7 +339,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|  | ||||
|     public int getClusterCount() { | ||||
|         if (!Settings.Limit.GLOBAL) { | ||||
|             return getClusterCount(getCurrentPlot().getWorldName()); | ||||
|             return getClusterCount(getLocation().getWorldName()); | ||||
|         } | ||||
|         final AtomicInteger count = new AtomicInteger(0); | ||||
|         this.plotAreaManager.forEachPlotArea(value -> { | ||||
| @@ -409,11 +408,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|     } | ||||
|  | ||||
|     public PlotArea getApplicablePlotArea() { | ||||
|         Plot plot = getCurrentPlot(); | ||||
|         if (plot == null) { | ||||
|             return this.plotAreaManager.getApplicablePlotArea(getLocation()); | ||||
|         } | ||||
|         return plot.getArea(); | ||||
|         return this.plotAreaManager.getApplicablePlotArea(getLocation()); | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
| @@ -619,16 +614,16 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|             PlotId id = plot.getId(); | ||||
|             int x = id.getX(); | ||||
|             int z = id.getY(); | ||||
|             ByteBuffer buffer = ByteBuffer.allocate(14); | ||||
|             ByteBuffer buffer = ByteBuffer.allocate(13); | ||||
|             buffer.putShort((short) x); | ||||
|             buffer.putShort((short) z); | ||||
|             Location location = getLocation(); | ||||
|             buffer.putInt(location.getX()); | ||||
|             buffer.putShort((short) location.getY()); | ||||
|             buffer.put((byte) location.getY()); | ||||
|             buffer.putInt(location.getZ()); | ||||
|             setPersistentMeta("quitLocV2", buffer.array()); | ||||
|         } else if (hasPersistentMeta("quitLocV2")) { | ||||
|             removePersistentMeta("quitLocV2"); | ||||
|             setPersistentMeta("quitLoc", buffer.array()); | ||||
|         } else if (hasPersistentMeta("quitLoc")) { | ||||
|             removePersistentMeta("quitLoc"); | ||||
|         } | ||||
|         if (plot != null) { | ||||
|             this.eventDispatcher.callLeave(this, plot); | ||||
| @@ -705,18 +700,11 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|                             return; | ||||
|                         } | ||||
|                         PlotArea area = ((SinglePlotAreaManager) manager).getArea(); | ||||
|                         boolean V2 = false; | ||||
|                         byte[] arr = PlotPlayer.this.getPersistentMeta("quitLoc"); | ||||
|                         if (arr == null) { | ||||
|                             arr = PlotPlayer.this.getPersistentMeta("quitLocV2"); | ||||
|                             if (arr == null) { | ||||
|                                 return; | ||||
|                             } | ||||
|                             V2 = true; | ||||
|                             removePersistentMeta("quitLocV2"); | ||||
|                         } else { | ||||
|                             removePersistentMeta("quitLoc"); | ||||
|                             return; | ||||
|                         } | ||||
|                         removePersistentMeta("quitLoc"); | ||||
|  | ||||
|                         if (!getMeta("teleportOnLogin", true)) { | ||||
|                             return; | ||||
| @@ -726,7 +714,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|                         final int plotZ = quitWorld.getShort(); | ||||
|                         PlotId id = PlotId.of(plotX, plotZ); | ||||
|                         int x = quitWorld.getInt(); | ||||
|                         int y = V2 ? quitWorld.getShort() : (quitWorld.get() & 0xFF); | ||||
|                         int y = quitWorld.get() & 0xFF; | ||||
|                         int z = quitWorld.getInt(); | ||||
|                         Plot plot = area.getOwnedPlot(id); | ||||
|  | ||||
| @@ -760,11 +748,10 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|                             } | ||||
|                         } | ||||
|                     } catch (Throwable e) { | ||||
|                         LOGGER.error("Error populating persistent meta for player {}", PlotPlayer.this.getName(), e); | ||||
|                         e.printStackTrace(); | ||||
|                     } | ||||
|                 } | ||||
|                     } | ||||
|             ); | ||||
|             }); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -135,7 +135,6 @@ public abstract class SchematicHandler { | ||||
|         } | ||||
|         final String filename; | ||||
|         final String website; | ||||
|         final @Nullable UUID finalUuid = uuid; | ||||
|         if (uuid == null) { | ||||
|             uuid = UUID.randomUUID(); | ||||
|             website = Settings.Web.URL + "upload.php?" + uuid; | ||||
| @@ -145,11 +144,10 @@ public abstract class SchematicHandler { | ||||
|             filename = file + '.' + extension; | ||||
|         } | ||||
|         final URL url; | ||||
|         String uri = Settings.Web.URL + "?key=" + uuid + "&type=" + extension; | ||||
|         try { | ||||
|             url = URI.create(uri).toURL(); | ||||
|             url = URI.create(Settings.Web.URL + "?key=" + uuid + "&type=" + extension).toURL(); | ||||
|         } catch (MalformedURLException e) { | ||||
|             LOGGER.error("Malformed URI `{}`", uri, e); | ||||
|             e.printStackTrace(); | ||||
|             whenDone.run(); | ||||
|             return; | ||||
|         } | ||||
| @@ -195,7 +193,7 @@ public abstract class SchematicHandler { | ||||
|                 } | ||||
|                 TaskManager.runTask(whenDone); | ||||
|             } catch (IOException e) { | ||||
|                 LOGGER.error("Error while uploading schematic for UUID {}", finalUuid, e); | ||||
|                 e.printStackTrace(); | ||||
|                 TaskManager.runTask(whenDone); | ||||
|             } | ||||
|         }); | ||||
| @@ -390,14 +388,8 @@ public abstract class SchematicHandler { | ||||
|             } | ||||
|             queue.enqueue(); | ||||
|         } catch (Exception e) { | ||||
|             e.printStackTrace(); | ||||
|             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(); | ||||
|                 return new Schematic(clip); | ||||
|             } catch (IOException e) { | ||||
|                 LOGGER.error("Error reading schematic from file {}", file.getAbsolutePath(), e); | ||||
|                 e.printStackTrace(); | ||||
|             } | ||||
|         } else { | ||||
|             throw new UnsupportedFormatException("This schematic format is not recognised or supported."); | ||||
| @@ -478,7 +470,7 @@ public abstract class SchematicHandler { | ||||
|             InputStream inputStream = Channels.newInputStream(readableByteChannel); | ||||
|             return getSchematic(inputStream); | ||||
|         } catch (IOException e) { | ||||
|             LOGGER.error("Error reading schematic from {}", url, e); | ||||
|             e.printStackTrace(); | ||||
|         } | ||||
|         return null; | ||||
|     } | ||||
| @@ -494,7 +486,7 @@ public abstract class SchematicHandler { | ||||
|                 Clipboard clip = schematicReader.read(); | ||||
|                 return new Schematic(clip); | ||||
|             } catch (IOException e) { | ||||
|                 LOGGER.error("Error reading schematic", e); | ||||
|                 e.printStackTrace(); | ||||
|             } | ||||
|         } | ||||
|         return null; | ||||
| @@ -523,7 +515,7 @@ public abstract class SchematicHandler { | ||||
|             } | ||||
|             return schematics; | ||||
|         } catch (JsonParseException | IOException e) { | ||||
|             LOGGER.error("Error retrieving saves for UUID {}", uuid, e); | ||||
|             e.printStackTrace(); | ||||
|         } | ||||
|         return null; | ||||
|     } | ||||
| @@ -540,7 +532,7 @@ public abstract class SchematicHandler { | ||||
|                 try (NBTOutputStream nos = new NBTOutputStream(new GZIPOutputStream(output, true))) { | ||||
|                     nos.writeNamedTag("Schematic", tag); | ||||
|                 } catch (IOException e1) { | ||||
|                     LOGGER.error("Error uploading schematic for UUID {}", uuid, e1); | ||||
|                     e1.printStackTrace(); | ||||
|                 } | ||||
|             } | ||||
|         }, whenDone); | ||||
| @@ -564,9 +556,9 @@ public abstract class SchematicHandler { | ||||
|                 nbtStream.writeNamedTag("Schematic", tag); | ||||
|             } | ||||
|         } catch (FileNotFoundException e) { | ||||
|             LOGGER.error("Error saving schematic at {}", path, e); | ||||
|             e.printStackTrace(); | ||||
|         } catch (IOException e) { | ||||
|             LOGGER.error("Error saving schematic at {}", path, e); | ||||
|             e.printStackTrace(); | ||||
|             return false; | ||||
|         } | ||||
|         return true; | ||||
| @@ -589,7 +581,7 @@ public abstract class SchematicHandler { | ||||
|         schematic.put("BlockData", new ByteArrayTag(buffer.toByteArray())); | ||||
|         schematic.put("BlockEntities", new ListTag(CompoundTag.class, tileEntities)); | ||||
|  | ||||
|         if (biomeBuffer.size() == 0 || biomePalette.isEmpty()) { | ||||
|         if (biomeBuffer.size() == 0 || biomePalette.size() == 0) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
| @@ -741,7 +733,10 @@ public abstract class SchematicHandler { | ||||
|                                     } | ||||
|                                     BaseBlock block = aabb.getWorld().getFullBlock(point); | ||||
|                                     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. | ||||
|                                         values.remove("x"); | ||||
|   | ||||
| @@ -20,7 +20,7 @@ plugins { | ||||
| } | ||||
|  | ||||
| group = "com.intellectualsites.plotsquared" | ||||
| version = "7.5.7" | ||||
| version = "7.5.7-SNAPSHOT" | ||||
|  | ||||
| if (!File("$rootDir/.git").exists()) { | ||||
|     logger.lifecycle(""" | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
| paper = "1.20.4-R0.1-SNAPSHOT" | ||||
| guice = "7.0.0" | ||||
| spotbugs = "4.9.4" | ||||
| checkerqual = "3.50.0" | ||||
| checkerqual = "3.49.5" | ||||
| gson = "2.10" | ||||
| guava = "31.1-jre" | ||||
| snakeyaml = "2.0" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user