mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-25 15:43:44 +02:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			main
			...
			fix/v7/com
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 534414d240 | ||
|   | c7f96e3a78 | 
							
								
								
									
										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); | ||||||
|   | |||||||
| @@ -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; | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -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,43 +326,20 @@ 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); |  | ||||||
|                         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)) |  | ||||||
|                                 ) |  | ||||||
|                         ); |                         ); | ||||||
|  |                         throwable.printStackTrace(); | ||||||
|                     } else { |                     } else { | ||||||
|                         final com.plotsquared.core.backup.Backup backup = |                         if (number < 1 || number > backups.size()) { | ||||||
|                                 backups.get(number - 1); |  | ||||||
|                         if (backup == null || backup.getFile() == null || !Files |  | ||||||
|                                 .exists(backup.getFile())) { |  | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
|                                     TranslatableCaption.of("backups.backup_impossible"), |                                     TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                                     TagResolver.resolver( |                                     TagResolver.resolver( | ||||||
| @@ -378,23 +350,37 @@ public final class Backup extends Command { | |||||||
|                                     ) |                                     ) | ||||||
|                             ); |                             ); | ||||||
|                         } else { |                         } else { | ||||||
|                             CmdConfirm.addPending( |                             final com.plotsquared.core.backup.Backup backup = | ||||||
|                                     player, "/plot backup load " + number, |                                     backups.get(number - 1); | ||||||
|                                     () -> backupProfile.restoreBackup(backup, player) |                             if (backup == null || backup.getFile() == null || !Files | ||||||
|                                             .whenComplete((n, error) -> { |                                     .exists(backup.getFile())) { | ||||||
|                                                 if (error != null) { |                                 player.sendMessage( | ||||||
|                                                     player.sendMessage( |                                         TranslatableCaption.of("backups.backup_impossible"), | ||||||
|                                                             TranslatableCaption.of("backups.backup_load_failure"), |                                         TagResolver.resolver( | ||||||
|                                                             TagResolver.resolver( |                                                 "plot", | ||||||
|                                                                     "reason", |                                                 Tag.inserting(TranslatableCaption | ||||||
|                                                                     Tag.inserting(Component.text(error.getMessage())) |                                                         .of("generic.generic_invalid_choice") | ||||||
|                                                             ) |                                                         .toComponent(player)) | ||||||
|                                                     ); |                                         ) | ||||||
|                                                 } else { |                                 ); | ||||||
|                                                     player.sendMessage(TranslatableCaption.of("backups.backup_load_success")); |                             } 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")); | ||||||
|  |                                                     } | ||||||
|  |                                                 }) | ||||||
|  |                                 ); | ||||||
|  |                             } | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 }); |                 }); | ||||||
|   | |||||||
| @@ -90,7 +90,7 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public boolean regenPlot(PlotPlayer<?> player) { |     public boolean regenPlot(PlotPlayer<?> player) { | ||||||
|         PlotArea area = player.getContextualPlotArea(); |         PlotArea area = player.getCurrentPlot().getArea(); | ||||||
|         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 +145,9 @@ public class DebugRoadRegen extends SubCommand { | |||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         PlotArea area = player.getContextualPlotArea(); |         PlotArea area = player.getCurrentPlot().getArea(); | ||||||
|         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(); | ||||||
|   | |||||||
| @@ -150,8 +150,8 @@ public class ListCmd extends SubCommand { | |||||||
|             page = 0; |             page = 0; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         PlotArea area = player.getContextualPlotArea(); |         String world = player.getCurrentPlot().getWorldName(); | ||||||
|         String world = area != null ? area.getWorldName() : ""; |         PlotArea area = player.getCurrentPlot().getArea(); | ||||||
|         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.getCurrentPlot().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")); | ||||||
|   | |||||||
| @@ -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.getCurrentPlot().getArea(); | ||||||
|                 if (plotArea == null) { |                 if (plotArea == null) { | ||||||
|                     return false; |                     return false; | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -435,11 +435,6 @@ public class Settings extends Config { | |||||||
|  |  | ||||||
|         public static String SCHEMATICS = "schematics"; |         public static String SCHEMATICS = "schematics"; | ||||||
|         public static String TEMPLATES = "templates"; |         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,8 +140,7 @@ public class HybridPlotWorld extends ClassicPlotWorld { | |||||||
|     @NonNull |     @NonNull | ||||||
|     @Override |     @Override | ||||||
|     protected PlotManager createManager() { |     protected PlotManager createManager() { | ||||||
|         return new HybridPlotManager( |         return new HybridPlotManager(this, PlotSquared.platform().regionManager(), | ||||||
|                 this, PlotSquared.platform().regionManager(), |  | ||||||
|                 PlotSquared.platform().injector().getInstance(ProgressSubscriberFactory.class) |                 PlotSquared.platform().injector().getInstance(ProgressSubscriberFactory.class) | ||||||
|         ); |         ); | ||||||
|     } |     } | ||||||
| @@ -216,16 +215,15 @@ public class HybridPlotWorld extends ClassicPlotWorld { | |||||||
|  |  | ||||||
|         // Try to determine root. This means that plot areas can have separate schematic |         // Try to determine root. This means that plot areas can have separate schematic | ||||||
|         // directories |         // directories | ||||||
|         String schematicFolder = Settings.Paths.USE_SCHEMATICS_PATH_FOR_GEN_SCHEMATICS ? Settings.Paths.SCHEMATICS : "schematics"; |  | ||||||
|         if (!(root = |         if (!(root = | ||||||
|                 FileUtils.getFile( |                 FileUtils.getFile( | ||||||
|                         PlotSquared.platform().getDirectory(), |                         PlotSquared.platform().getDirectory(), | ||||||
|                         schematicFolder + File.separator + "GEN_ROAD_SCHEMATIC" + File.separator + this.getWorldName() + File.separator + this.getId() |                         "schematics/GEN_ROAD_SCHEMATIC/" + this.getWorldName() + "/" + this.getId() | ||||||
|                 )) |                 )) | ||||||
|                 .exists()) { |                 .exists()) { | ||||||
|             root = FileUtils.getFile( |             root = FileUtils.getFile( | ||||||
|                     PlotSquared.platform().getDirectory(), |                     PlotSquared.platform().getDirectory(), | ||||||
|                     schematicFolder + File.separator + "GEN_ROAD_SCHEMATIC" + File.separator + this.getWorldName() |                     "schematics/GEN_ROAD_SCHEMATIC/" + this.getWorldName() | ||||||
|             ); |             ); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -290,7 +290,8 @@ 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() { |     @Nullable | ||||||
|  |     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 +320,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(getCurrentPlot().getWorldName()); | ||||||
|         } |         } | ||||||
|         final AtomicInteger count = new AtomicInteger(0); |         final AtomicInteger count = new AtomicInteger(0); | ||||||
|         final UUID uuid = getUUID(); |         final UUID uuid = getUUID(); | ||||||
| @@ -339,7 +340,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(getCurrentPlot().getWorldName()); | ||||||
|         } |         } | ||||||
|         final AtomicInteger count = new AtomicInteger(0); |         final AtomicInteger count = new AtomicInteger(0); | ||||||
|         this.plotAreaManager.forEachPlotArea(value -> { |         this.plotAreaManager.forEachPlotArea(value -> { | ||||||
| @@ -352,34 +353,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. | ||||||
|      * |      * | ||||||
| @@ -646,16 +619,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,89 +683,80 @@ 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 { |                         PlotPlayer.this.metaMap = value; | ||||||
|                                 PlotPlayer.this.metaMap = value; |                         if (value.isEmpty()) { | ||||||
|                                 if (value.isEmpty()) { |                             return; | ||||||
|                                     return; |                         } | ||||||
|                                 } |  | ||||||
|  |  | ||||||
|                                 if (PlotPlayer.this.getAttribute("debug")) { |                         if (PlotPlayer.this.getAttribute("debug")) { | ||||||
|                                     debugModeEnabled.add(PlotPlayer.this); |                             debugModeEnabled.add(PlotPlayer.this); | ||||||
|                                 } |                         } | ||||||
|  |  | ||||||
|                                 if (!Settings.Teleport.ON_LOGIN) { |                         if (!Settings.Teleport.ON_LOGIN) { | ||||||
|                                     return; |                             return; | ||||||
|                                 } |                         } | ||||||
|                                 PlotAreaManager manager = PlotPlayer.this.plotAreaManager; |                         PlotAreaManager manager = PlotPlayer.this.plotAreaManager; | ||||||
|  |  | ||||||
|                                 if (!(manager instanceof SinglePlotAreaManager)) { |                         if (!(manager instanceof SinglePlotAreaManager)) { | ||||||
|                                     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) { | ||||||
|                                 if (arr == null) { |                             return; | ||||||
|                                     arr = PlotPlayer.this.getPersistentMeta("quitLocV2"); |                         } | ||||||
|                                     if (arr == null) { |                         removePersistentMeta("quitLoc"); | ||||||
|                                         return; |  | ||||||
|                                     } |  | ||||||
|                                     V2 = true; |  | ||||||
|                                     removePersistentMeta("quitLocV2"); |  | ||||||
|                                 } else { |  | ||||||
|                                     removePersistentMeta("quitLoc"); |  | ||||||
|                                 } |  | ||||||
|  |  | ||||||
|                                 if (!getMeta("teleportOnLogin", true)) { |                         if (!getMeta("teleportOnLogin", true)) { | ||||||
|                                     return; |                             return; | ||||||
|                                 } |                         } | ||||||
|                                 ByteBuffer quitWorld = ByteBuffer.wrap(arr); |                         ByteBuffer quitWorld = ByteBuffer.wrap(arr); | ||||||
|                                 final int plotX = quitWorld.getShort(); |                         final int plotX = quitWorld.getShort(); | ||||||
|                                 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); | ||||||
|  |  | ||||||
|                                 if (plot == null) { |                         if (plot == null) { | ||||||
|                                     return; |                             return; | ||||||
|                                 } |                         } | ||||||
|  |  | ||||||
|                                 final Location location = Location.at(plot.getWorldName(), x, y, z); |                         final Location location = Location.at(plot.getWorldName(), x, y, z); | ||||||
|                                 if (plot.isLoaded()) { |                         if (plot.isLoaded()) { | ||||||
|                                     TaskManager.runTask(() -> { |                             TaskManager.runTask(() -> { | ||||||
|                                         if (getMeta("teleportOnLogin", true)) { |                                 if (getMeta("teleportOnLogin", true)) { | ||||||
|                                             teleport(location, TeleportCause.LOGIN); |                                     teleport(location, TeleportCause.LOGIN); | ||||||
|                                             sendMessage( |                                     sendMessage( | ||||||
|                                                     TranslatableCaption.of("teleport.teleported_to_plot")); |                                             TranslatableCaption.of("teleport.teleported_to_plot")); | ||||||
|                                         } |  | ||||||
|                                     }); |  | ||||||
|                                 } else if (!PlotSquared.get().isMainThread(Thread.currentThread())) { |  | ||||||
|                                     if (getMeta("teleportOnLogin", true)) { |  | ||||||
|                                         plot.teleportPlayer( |  | ||||||
|                                                 PlotPlayer.this, |  | ||||||
|                                                 result -> TaskManager.runTask(() -> { |  | ||||||
|                                                     if (getMeta("teleportOnLogin", true)) { |  | ||||||
|                                                         if (plot.isLoaded()) { |  | ||||||
|                                                             teleport(location, TeleportCause.LOGIN); |  | ||||||
|                                                             sendMessage(TranslatableCaption |  | ||||||
|                                                                     .of("teleport.teleported_to_plot")); |  | ||||||
|                                                         } |  | ||||||
|                                                     } |  | ||||||
|                                                 }) |  | ||||||
|                                         ); |  | ||||||
|                                     } |  | ||||||
|                                 } |                                 } | ||||||
|                             } catch (Throwable e) { |                             }); | ||||||
|                                 LOGGER.error("Error populating persistent meta for player {}", PlotPlayer.this.getName(), e); |                         } else if (!PlotSquared.get().isMainThread(Thread.currentThread())) { | ||||||
|  |                             if (getMeta("teleportOnLogin", true)) { | ||||||
|  |                                 plot.teleportPlayer( | ||||||
|  |                                         PlotPlayer.this, | ||||||
|  |                                         result -> TaskManager.runTask(() -> { | ||||||
|  |                                             if (getMeta("teleportOnLogin", true)) { | ||||||
|  |                                                 if (plot.isLoaded()) { | ||||||
|  |                                                     teleport(location, TeleportCause.LOGIN); | ||||||
|  |                                                     sendMessage(TranslatableCaption | ||||||
|  |                                                             .of("teleport.teleported_to_plot")); | ||||||
|  |                                                 } | ||||||
|  |                                             } | ||||||
|  |                                         }) | ||||||
|  |                                 ); | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|  |                     } catch (Throwable e) { | ||||||
|  |                         e.printStackTrace(); | ||||||
|                     } |                     } | ||||||
|             ); |                 } | ||||||
|  |             }); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -860,8 +824,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 +994,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"); | ||||||
|   | |||||||
| @@ -204,9 +204,6 @@ public final class PlaceholderRegistry { | |||||||
|         this.createPlaceholder("currentplot_x", (player, plot) -> Integer.toString(plot.getId().getX())); |         this.createPlaceholder("currentplot_x", (player, plot) -> Integer.toString(plot.getId().getX())); | ||||||
|         this.createPlaceholder("currentplot_y", (player, plot) -> Integer.toString(plot.getId().getY())); |         this.createPlaceholder("currentplot_y", (player, plot) -> Integer.toString(plot.getId().getY())); | ||||||
|         this.createPlaceholder("currentplot_xy", (player, plot) -> plot.getId().toString()); |         this.createPlaceholder("currentplot_xy", (player, plot) -> plot.getId().toString()); | ||||||
|         this.createPlaceholder("currentplot_abs_x", (player, plot) -> Integer.toString(plot.getId().getX()), true); |  | ||||||
|         this.createPlaceholder("currentplot_abs_y", (player, plot) -> Integer.toString(plot.getId().getY()), true); |  | ||||||
|         this.createPlaceholder("currentplot_abs_xy", (player, plot) -> plot.getId().toString(), true); |  | ||||||
|         this.createPlaceholder("currentplot_rating", (player, plot) -> { |         this.createPlaceholder("currentplot_rating", (player, plot) -> { | ||||||
|             if (Double.isNaN(plot.getAverageRating())) { |             if (Double.isNaN(plot.getAverageRating())) { | ||||||
|                 return legacyComponent(TranslatableCaption.of("placeholder.nan"), player); |                 return legacyComponent(TranslatableCaption.of("placeholder.nan"), player); | ||||||
| @@ -256,23 +253,7 @@ public final class PlaceholderRegistry { | |||||||
|             final @NonNull String key, |             final @NonNull String key, | ||||||
|             final @NonNull BiFunction<PlotPlayer<?>, Plot, String> placeholderFunction |             final @NonNull BiFunction<PlotPlayer<?>, Plot, String> placeholderFunction | ||||||
|     ) { |     ) { | ||||||
|         this.createPlaceholder(key, placeholderFunction, false); |         this.registerPlaceholder(new PlotSpecificPlaceholder(key) { | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Create a functional placeholder |  | ||||||
|      * |  | ||||||
|      * @param key                 Placeholder key |  | ||||||
|      * @param placeholderFunction Placeholder generator. Cannot return null |  | ||||||
|      * @param requireAbsolute     If the plot given to the placeholder should be the absolute (not base) plot |  | ||||||
|      * @since TODO |  | ||||||
|      */ |  | ||||||
|     public void createPlaceholder( |  | ||||||
|             final @NonNull String key, |  | ||||||
|             final @NonNull BiFunction<PlotPlayer<?>, Plot, String> placeholderFunction, |  | ||||||
|             final boolean requireAbsolute |  | ||||||
|     ) { |  | ||||||
|         this.registerPlaceholder(new PlotSpecificPlaceholder(key, requireAbsolute) { |  | ||||||
|             @Override |             @Override | ||||||
|             public @NonNull String getValue(final @NonNull PlotPlayer<?> player, final @NonNull Plot plot) { |             public @NonNull String getValue(final @NonNull PlotPlayer<?> player, final @NonNull Plot plot) { | ||||||
|                 return placeholderFunction.apply(player, plot); |                 return placeholderFunction.apply(player, plot); | ||||||
|   | |||||||
| @@ -27,28 +27,14 @@ import org.checkerframework.checker.nullness.qual.NonNull; | |||||||
|  */ |  */ | ||||||
| public abstract class PlotSpecificPlaceholder extends Placeholder { | public abstract class PlotSpecificPlaceholder extends Placeholder { | ||||||
|  |  | ||||||
|     private final boolean requireAbsolute; |  | ||||||
|  |  | ||||||
|     public PlotSpecificPlaceholder(final @NonNull String key) { |     public PlotSpecificPlaceholder(final @NonNull String key) { | ||||||
|         this(key, false); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     /** |  | ||||||
|      * Create a functional placeholder |  | ||||||
|      * |  | ||||||
|      * @param key             Placeholder key |  | ||||||
|      * @param requireAbsolute If the plot given to the placeholder should be the absolute (not base) plot |  | ||||||
|      * @since TODO |  | ||||||
|      */ |  | ||||||
|     public PlotSpecificPlaceholder(final @NonNull String key, final boolean requireAbsolute) { |  | ||||||
|         super(key); |         super(key); | ||||||
|         this.requireAbsolute = requireAbsolute; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull |     public @NonNull | ||||||
|     final String getValue(final @NonNull PlotPlayer<?> player) { |     final String getValue(final @NonNull PlotPlayer<?> player) { | ||||||
|         final Plot plot = requireAbsolute ? player.getLocation().getPlotAbs() : player.getCurrentPlot(); |         final Plot plot = player.getCurrentPlot(); | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             return ""; |             return ""; | ||||||
|         } |         } | ||||||
|   | |||||||
| @@ -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,15 +95,9 @@ subprojects { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     afterEvaluate { |     val javaComponent = components["java"] as AdhocComponentWithVariants | ||||||
|         val javaComponent = components["java"] as AdhocComponentWithVariants |     javaComponent.withVariantsFromConfiguration(configurations["shadowRuntimeElements"]) { | ||||||
|         configurations.findByName("shadowRuntimeElements")?.let { shadowRuntimeElements -> |         skip() | ||||||
|             javaComponent.withVariantsFromConfiguration(shadowRuntimeElements) { |  | ||||||
|                 skip() |  | ||||||
|             } |  | ||||||
|         } ?: run { |  | ||||||
|             logger.warn("Configuration 'shadowRuntimeElements' does not exist.") |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     signing { |     signing { | ||||||
|   | |||||||
| @@ -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.2.20" | 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