mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-22 14:13:44 +02:00 
			
		
		
		
	Compare commits
	
		
			9 Commits
		
	
	
		
			renovate/m
			...
			fix/contex
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 5b3c7a2934 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | b7b25252c6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 7123f51bb5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 897afa894e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 2238609551 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 255959232b | ||
|   | 622c9f1d13 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e7aff3982e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | db7ea780f9 | 
							
								
								
									
										2
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/build-pr.yml
									
									
									
									
										vendored
									
									
								
							| @@ -11,7 +11,7 @@ jobs: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v5 | ||||
|       - name: Validate Gradle Wrapper | ||||
|         uses: gradle/actions/wrapper-validation@v4 | ||||
|         uses: gradle/actions/wrapper-validation@v5 | ||||
|       - name: Setup Java | ||||
|         uses: actions/setup-java@v5 | ||||
|         with: | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -11,7 +11,7 @@ jobs: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v5 | ||||
|       - name: Validate Gradle Wrapper | ||||
|         uses: gradle/actions/wrapper-validation@v4 | ||||
|         uses: gradle/actions/wrapper-validation@v5 | ||||
|       - name: Setup Java | ||||
|         uses: actions/setup-java@v5 | ||||
|         with: | ||||
|   | ||||
							
								
								
									
										6
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/codeql.yml
									
									
									
									
										vendored
									
									
								
							| @@ -27,10 +27,10 @@ jobs: | ||||
|           distribution: temurin | ||||
|           java-version: 21 | ||||
|       - name: Initialize CodeQL | ||||
|         uses: github/codeql-action/init@v3 | ||||
|         uses: github/codeql-action/init@v4 | ||||
|         with: | ||||
|           languages: ${{ matrix.language }} | ||||
|       - name: Autobuild | ||||
|         uses: github/codeql-action/autobuild@v3 | ||||
|         uses: github/codeql-action/autobuild@v4 | ||||
|       - name: Perform CodeQL Analysis | ||||
|         uses: github/codeql-action/analyze@v3 | ||||
|         uses: github/codeql-action/analyze@v4 | ||||
|   | ||||
| @@ -160,7 +160,7 @@ public class EntityEventListener implements Listener { | ||||
|                     return; | ||||
|                 } | ||||
|             } | ||||
|             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL", | ||||
|             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SILVERFISH_BLOCK", "ENDER_PEARL", | ||||
|                  "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN", "NETHER_PORTAL", | ||||
|                  "FROZEN", "SPELL", "DEFAULT" -> { | ||||
|                 if (!area.isMobSpawning()) { | ||||
|   | ||||
| @@ -202,7 +202,7 @@ public class PaperListener implements Listener { | ||||
|                     return; | ||||
|                 } | ||||
|             } | ||||
|             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SHEARED", "SILVERFISH_BLOCK", "ENDER_PEARL", "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN" -> { | ||||
|             case "REINFORCEMENTS", "NATURAL", "MOUNT", "PATROL", "RAID", "SILVERFISH_BLOCK", "ENDER_PEARL", "TRAP", "VILLAGE_DEFENSE", "VILLAGE_INVASION", "BEEHIVE", "CHUNK_GEN" -> { | ||||
|                 if (!area.isMobSpawning()) { | ||||
|                     event.setShouldAbortSpawn(true); | ||||
|                     event.setCancelled(true); | ||||
|   | ||||
| @@ -90,7 +90,7 @@ public class DebugRoadRegen extends SubCommand { | ||||
|     } | ||||
|  | ||||
|     public boolean regenPlot(PlotPlayer<?> player) { | ||||
|         PlotArea area = player.getCurrentPlot().getArea(); | ||||
|         PlotArea area = player.getContextualPlotArea(); | ||||
|         if (area == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||
|             return false; | ||||
| @@ -145,9 +145,10 @@ public class DebugRoadRegen extends SubCommand { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         PlotArea area = player.getCurrentPlot().getArea(); | ||||
|         PlotArea area = player.getContextualPlotArea(); | ||||
|         if (area == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot_world")); | ||||
|             return false; | ||||
|         } | ||||
|         Plot plot = player.getCurrentPlot(); | ||||
|         PlotManager manager = area.getPlotManager(); | ||||
|   | ||||
| @@ -150,8 +150,8 @@ public class ListCmd extends SubCommand { | ||||
|             page = 0; | ||||
|         } | ||||
|  | ||||
|         String world = player.getCurrentPlot().getWorldName(); | ||||
|         PlotArea area = player.getCurrentPlot().getArea(); | ||||
|         PlotArea area = player.getContextualPlotArea(); | ||||
|         String world = area != null ? area.getWorldName() : ""; | ||||
|         String arg = args[0].toLowerCase(); | ||||
|         final boolean[] sort = new boolean[]{true}; | ||||
|  | ||||
|   | ||||
| @@ -68,11 +68,6 @@ public class Load extends SubCommand { | ||||
|  | ||||
|     @Override | ||||
|     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(); | ||||
|         if (plot == null) { | ||||
|             player.sendMessage(TranslatableCaption.of("errors.not_in_plot")); | ||||
|   | ||||
| @@ -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.getContextualPlotArea(); | ||||
|                 if (plotArea == null) { | ||||
|                     return false; | ||||
|                 } | ||||
|   | ||||
| @@ -290,8 +290,7 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|      * | ||||
|      * @return the plot the player is standing on or null if standing on a road or not in a {@link PlotArea} | ||||
|      */ | ||||
|     @Nullable | ||||
|     public Plot getCurrentPlot() { | ||||
|     public @Nullable Plot getCurrentPlot() { | ||||
|         try (final MetaDataAccess<Plot> lastPlotAccess = | ||||
|                      this.accessTemporaryMetaData(PlayerMetaDataKeys.TEMPORARY_LAST_PLOT)) { | ||||
|             if (lastPlotAccess.get().orElse(null) == null && !Settings.Enabled_Components.EVENTS) { | ||||
| @@ -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(getContextualWorldName()); | ||||
|         } | ||||
|         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(getContextualWorldName()); | ||||
|         } | ||||
|         final AtomicInteger count = new AtomicInteger(0); | ||||
|         this.plotAreaManager.forEachPlotArea(value -> { | ||||
| @@ -353,6 +352,34 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|         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. | ||||
|      * | ||||
| @@ -683,7 +710,8 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|  | ||||
|     public void populatePersistentMetaMap() { | ||||
|         if (Settings.Enabled_Components.PERSISTENT_META) { | ||||
|             DBFunc.getPersistentMeta(getUUID(), new RunnableVal<>() { | ||||
|             DBFunc.getPersistentMeta( | ||||
|                     getUUID(), new RunnableVal<>() { | ||||
|                         @Override | ||||
|                         public void run(Map<String, byte[]> value) { | ||||
|                             try { | ||||
| @@ -832,7 +860,8 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|     } | ||||
|  | ||||
|     @SuppressWarnings("unchecked") | ||||
|     @Nullable <T> T getPersistentMeta(final @NonNull MetaDataKey<T> key) { | ||||
|     @Nullable | ||||
|     <T> T getPersistentMeta(final @NonNull MetaDataKey<T> key) { | ||||
|         final byte[] value = this.getPersistentMeta(key.toString()); | ||||
|         if (value == null) { | ||||
|             return null; | ||||
| @@ -1002,9 +1031,11 @@ public abstract class PlotPlayer<P> implements CommandCaller, OfflinePlotPlayer, | ||||
|             if (throwable != null) { | ||||
|                 sendMessage( | ||||
|                         TranslatableCaption.of("errors.error"), | ||||
|                         TagResolver.resolver("value", Tag.inserting( | ||||
|                         TagResolver.resolver( | ||||
|                                 "value", Tag.inserting( | ||||
|                                         Component.text("Failed to resolve asynchronous caption replacements") | ||||
|                         )) | ||||
|                                 ) | ||||
|                         ) | ||||
|                 ); | ||||
|                 LOGGER.error("Failed to resolve asynchronous tagresolver(s) for " + caption, throwable); | ||||
|             } else { | ||||
|   | ||||
| @@ -541,7 +541,7 @@ public class Plot { | ||||
|      * | ||||
|      * @return World name | ||||
|      */ | ||||
|     public @Nullable String getWorldName() { | ||||
|     public @NonNull String getWorldName() { | ||||
|         return area.getWorldName(); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -58,7 +58,7 @@ public class SinglePlot extends Plot { | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public String getWorldName() { | ||||
|     public @NonNull String getWorldName() { | ||||
|         return getId().toUnderscoreSeparatedString(); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -65,10 +65,16 @@ subprojects { | ||||
|         plugin<IdeaPlugin>() | ||||
|     } | ||||
|  | ||||
|     configurations.matching { it.name == "signatures" }.configureEach { | ||||
|         attributes { | ||||
|             attribute(Attribute.of("signatures-unique", String::class.java), "true") | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     dependencies { | ||||
|         // Tests | ||||
|         testImplementation("org.junit.jupiter:junit-jupiter:5.14.0") | ||||
|         testRuntimeOnly("org.junit.platform:junit-platform-launcher:1.14.0") | ||||
|         testImplementation("org.junit.jupiter:junit-jupiter:6.0.0") | ||||
|         testRuntimeOnly("org.junit.platform:junit-platform-launcher:6.0.0") | ||||
|     } | ||||
|  | ||||
|     plugins.withId("java") { | ||||
| @@ -95,10 +101,16 @@ subprojects { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     afterEvaluate { | ||||
|         val javaComponent = components["java"] as AdhocComponentWithVariants | ||||
|     javaComponent.withVariantsFromConfiguration(configurations["shadowRuntimeElements"]) { | ||||
|         configurations.findByName("shadowRuntimeElements")?.let { shadowRuntimeElements -> | ||||
|             javaComponent.withVariantsFromConfiguration(shadowRuntimeElements) { | ||||
|                 skip() | ||||
|             } | ||||
|         } ?: run { | ||||
|             logger.warn("Configuration 'shadowRuntimeElements' does not exist.") | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     signing { | ||||
|         if (!project.hasProperty("skip.signing") && !version.toString().endsWith("-SNAPSHOT")) { | ||||
|   | ||||
| @@ -7,7 +7,7 @@ checkerqual = "3.51.1" | ||||
| gson = "2.10" | ||||
| guava = "31.1-jre" | ||||
| snakeyaml = "2.0" | ||||
| adventure = "4.24.0" | ||||
| adventure = "4.25.0" | ||||
| adventure-bukkit = "4.4.1" | ||||
| log4j = "2.19.0" | ||||
|  | ||||
| @@ -33,11 +33,11 @@ vault = "1.7.1" | ||||
| serverlib = "2.3.7" | ||||
|  | ||||
| # Gradle plugins | ||||
| shadow = "8.3.9" | ||||
| shadow = "9.2.2" | ||||
| grgit = "4.1.1" | ||||
| spotless = "8.0.0" | ||||
| publish = "0.34.0" | ||||
| runPaper = "3.0.1" | ||||
| runPaper = "3.0.2" | ||||
|  | ||||
| [libraries] | ||||
| # 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 | ||||
| distributionPath=wrapper/dists | ||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-8.14.3-bin.zip | ||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-9.1.0-bin.zip | ||||
| networkTimeout=10000 | ||||
| validateDistributionUrl=true | ||||
| zipStoreBase=GRADLE_USER_HOME | ||||
|   | ||||
							
								
								
									
										5
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							| @@ -1,7 +1,7 @@ | ||||
| #!/bin/sh | ||||
|  | ||||
| # | ||||
| # Copyright © 2015-2021 the original authors. | ||||
| # Copyright © 2015 the original authors. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| @@ -114,7 +114,6 @@ case "$( uname )" in                #( | ||||
|   NONSTOP* )        nonstop=true ;; | ||||
| esac | ||||
|  | ||||
| CLASSPATH="\\\"\\\"" | ||||
|  | ||||
|  | ||||
| # Determine the Java command to use to start the JVM. | ||||
| @@ -172,7 +171,6 @@ fi | ||||
| # For Cygwin or MSYS, switch paths to Windows format before running java | ||||
| if "$cygwin" || "$msys" ; then | ||||
|     APP_HOME=$( cygpath --path --mixed "$APP_HOME" ) | ||||
|     CLASSPATH=$( cygpath --path --mixed "$CLASSPATH" ) | ||||
|  | ||||
|     JAVACMD=$( cygpath --unix "$JAVACMD" ) | ||||
|  | ||||
| @@ -212,7 +210,6 @@ DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' | ||||
|  | ||||
| set -- \ | ||||
|         "-Dorg.gradle.appname=$APP_BASE_NAME" \ | ||||
|         -classpath "$CLASSPATH" \ | ||||
|         -jar "$APP_HOME/gradle/wrapper/gradle-wrapper.jar" \ | ||||
|         "$@" | ||||
|  | ||||
|   | ||||
							
								
								
									
										3
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							| @@ -70,11 +70,10 @@ goto fail | ||||
| :execute | ||||
| @rem Setup the command line | ||||
|  | ||||
| set CLASSPATH= | ||||
|  | ||||
|  | ||||
| @rem Execute Gradle | ||||
| "%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" %* | ||||
| "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -jar "%APP_HOME%\gradle\wrapper\gradle-wrapper.jar" %* | ||||
|  | ||||
| :end | ||||
| @rem End local scope for the variables with windows NT shell | ||||
|   | ||||
		Reference in New Issue
	
	Block a user