Compare commits
1 Commits
6.69.2
...
dependabot
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5595e95701 |
2
.github/workflows/java-ci.yml
vendored
2
.github/workflows/java-ci.yml
vendored
@@ -1,6 +1,6 @@
|
|||||||
name: Java CI
|
name: Java CI
|
||||||
|
|
||||||
on: [ push, pull_request, workflow_dispatch ]
|
on: [ push, pull_request ]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
|
|||||||
@@ -14,7 +14,6 @@ plugins {
|
|||||||
id("maven-publish")
|
id("maven-publish")
|
||||||
id("java")
|
id("java")
|
||||||
kotlin("jvm") version "1.9.21"
|
kotlin("jvm") version "1.9.21"
|
||||||
kotlin("plugin.serialization") version "1.9.21"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
@@ -30,7 +29,6 @@ dependencies {
|
|||||||
implementation(project(path = ":eco-core:core-nms:v1_19_R3", configuration = "reobf"))
|
implementation(project(path = ":eco-core:core-nms:v1_19_R3", configuration = "reobf"))
|
||||||
implementation(project(path = ":eco-core:core-nms:v1_20_R1", configuration = "reobf"))
|
implementation(project(path = ":eco-core:core-nms:v1_20_R1", configuration = "reobf"))
|
||||||
implementation(project(path = ":eco-core:core-nms:v1_20_R2", configuration = "reobf"))
|
implementation(project(path = ":eco-core:core-nms:v1_20_R2", configuration = "reobf"))
|
||||||
implementation(project(path = ":eco-core:core-nms:v1_20_R3", configuration = "reobf"))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
allprojects {
|
allprojects {
|
||||||
@@ -39,13 +37,15 @@ allprojects {
|
|||||||
apply(plugin = "maven-publish")
|
apply(plugin = "maven-publish")
|
||||||
apply(plugin = "com.github.johnrengelman.shadow")
|
apply(plugin = "com.github.johnrengelman.shadow")
|
||||||
apply(plugin = "kotlin")
|
apply(plugin = "kotlin")
|
||||||
apply(plugin = "org.jetbrains.kotlin.plugin.serialization")
|
|
||||||
|
|
||||||
repositories {
|
repositories {
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
mavenLocal()
|
mavenLocal()
|
||||||
maven("https://repo.auxilor.io/repository/maven-public/")
|
|
||||||
maven("https://jitpack.io")
|
maven("https://jitpack.io")
|
||||||
|
maven("https://repo.auxilor.io/repository/maven-public/")
|
||||||
|
|
||||||
|
// CustomCrafting
|
||||||
|
maven("https://maven.wolfyscript.com/repository/public/")
|
||||||
|
|
||||||
// SuperiorSkyblock2
|
// SuperiorSkyblock2
|
||||||
maven("https://repo.bg-software.com/repository/api/")
|
maven("https://repo.bg-software.com/repository/api/")
|
||||||
@@ -88,12 +88,6 @@ allprojects {
|
|||||||
|
|
||||||
// Denizen
|
// Denizen
|
||||||
maven("https://maven.citizensnpcs.co/repo")
|
maven("https://maven.citizensnpcs.co/repo")
|
||||||
|
|
||||||
// IridiumSkyblock
|
|
||||||
maven("https://nexus.iridiumdevelopment.net/repository/maven-releases/")
|
|
||||||
|
|
||||||
// HuskPlugins
|
|
||||||
maven("https://repo.william278.net/releases")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
@@ -141,14 +135,6 @@ allprojects {
|
|||||||
setExtendsFrom(listOf(configurations.compileOnly.get(), configurations.implementation.get()))
|
setExtendsFrom(listOf(configurations.compileOnly.get(), configurations.implementation.get()))
|
||||||
}
|
}
|
||||||
|
|
||||||
java {
|
|
||||||
toolchain.languageVersion = JavaLanguageVersion.of(17)
|
|
||||||
}
|
|
||||||
|
|
||||||
kotlin {
|
|
||||||
jvmToolchain(17)
|
|
||||||
}
|
|
||||||
|
|
||||||
tasks {
|
tasks {
|
||||||
compileKotlin {
|
compileKotlin {
|
||||||
kotlinOptions {
|
kotlinOptions {
|
||||||
@@ -176,6 +162,8 @@ allprojects {
|
|||||||
relocate("google.protobuf", "com.willfp.eco.libs.protobuf") // Still don't know
|
relocate("google.protobuf", "com.willfp.eco.libs.protobuf") // Still don't know
|
||||||
relocate("com.zaxxer.hikari", "com.willfp.eco.libs.hikari")
|
relocate("com.zaxxer.hikari", "com.willfp.eco.libs.hikari")
|
||||||
//relocate("com.mysql", "com.willfp.eco.libs.mysql")
|
//relocate("com.mysql", "com.willfp.eco.libs.mysql")
|
||||||
|
relocate("de.undercouch.bson4jackson", "com.willfp.eco.libs.bson4jackson")
|
||||||
|
relocate("com.fasterxml.jackson", "com.willfp.eco.libs.jackson")
|
||||||
relocate("com.mongodb", "com.willfp.eco.libs.mongodb")
|
relocate("com.mongodb", "com.willfp.eco.libs.mongodb")
|
||||||
relocate("org.bson", "com.willfp.eco.libs.bson")
|
relocate("org.bson", "com.willfp.eco.libs.bson")
|
||||||
relocate("org.litote", "com.willfp.eco.libs.litote")
|
relocate("org.litote", "com.willfp.eco.libs.litote")
|
||||||
|
|||||||
@@ -167,7 +167,7 @@ public abstract class EcoPlugin extends JavaPlugin implements PluginLike, Regist
|
|||||||
/**
|
/**
|
||||||
* The tasks to run on task creation.
|
* The tasks to run on task creation.
|
||||||
*/
|
*/
|
||||||
private final ListMap<LifecyclePosition, Runnable> onCreateTasks = new ListMap<>();
|
private final ListMap<LifecyclePosition, Runnable> createTasks = new ListMap<>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a new plugin.
|
* Create a new plugin.
|
||||||
@@ -638,7 +638,7 @@ public abstract class EcoPlugin extends JavaPlugin implements PluginLike, Regist
|
|||||||
this.handleLifecycle(this.onReload, this::handleReload);
|
this.handleLifecycle(this.onReload, this::handleReload);
|
||||||
|
|
||||||
if (cancelTasks) {
|
if (cancelTasks) {
|
||||||
this.handleLifecycle(this.onCreateTasks, this::createTasks);
|
this.handleLifecycle(this.createTasks, this::createTasks);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (Extension extension : this.extensionLoader.getLoadedExtensions()) {
|
for (Extension extension : this.extensionLoader.getLoadedExtensions()) {
|
||||||
@@ -666,26 +666,6 @@ public abstract class EcoPlugin extends JavaPlugin implements PluginLike, Regist
|
|||||||
this.onReload.append(position, task);
|
this.onReload.append(position, task);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Add new task to run on createTasks.
|
|
||||||
*
|
|
||||||
* @param task The task.
|
|
||||||
*/
|
|
||||||
public final void onCreateTasks(@NotNull final Runnable task) {
|
|
||||||
this.onCreateTasks(LifecyclePosition.END, task);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add new task to run on createTasks.
|
|
||||||
*
|
|
||||||
* @param position The position to run the task.
|
|
||||||
* @param task The task.
|
|
||||||
*/
|
|
||||||
public final void onCreateTasks(@NotNull final LifecyclePosition position,
|
|
||||||
@NotNull final Runnable task) {
|
|
||||||
this.onCreateTasks.append(position, task);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Reload the plugin and return the time taken to reload.
|
* Reload the plugin and return the time taken to reload.
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -37,14 +37,6 @@ public class Prerequisite {
|
|||||||
"Requires server to have ProtocolLib"
|
"Requires server to have ProtocolLib"
|
||||||
);
|
);
|
||||||
|
|
||||||
/**
|
|
||||||
* Requires the server to be running 1.20.3.
|
|
||||||
*/
|
|
||||||
public static final Prerequisite HAS_1_20_3 = new Prerequisite(
|
|
||||||
() -> ProxyConstants.NMS_VERSION.contains("20_R3"),
|
|
||||||
"Requires server to be running 1.20.3+"
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Requires the server to be running 1.20.
|
* Requires the server to be running 1.20.
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -29,22 +29,6 @@ public interface LoadableConfig extends Config {
|
|||||||
*/
|
*/
|
||||||
void save() throws IOException;
|
void save() throws IOException;
|
||||||
|
|
||||||
/**
|
|
||||||
* Save the config asynchronously.
|
|
||||||
*/
|
|
||||||
default void saveAsync() {
|
|
||||||
// This default implementation exists purely for backwards compatibility
|
|
||||||
// with legacy Config implementations that don't have saveAsync().
|
|
||||||
// Default eco implementations of Config have saveAsync() implemented.
|
|
||||||
new Thread(() -> {
|
|
||||||
try {
|
|
||||||
this.save();
|
|
||||||
} catch (IOException e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}).start();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the config file.
|
* Get the config file.
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -27,7 +27,7 @@ public class DropQueuePushEvent extends PlayerEvent implements Cancellable {
|
|||||||
/**
|
/**
|
||||||
* The items.
|
* The items.
|
||||||
*/
|
*/
|
||||||
private Collection<? extends ItemStack> items;
|
private final Collection<? extends ItemStack> items;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The xp.
|
* The xp.
|
||||||
@@ -114,15 +114,6 @@ public class DropQueuePushEvent extends PlayerEvent implements Cancellable {
|
|||||||
return items;
|
return items;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the items to be dropped.
|
|
||||||
*
|
|
||||||
* @param items The items.
|
|
||||||
*/
|
|
||||||
public void setItems(Collection<? extends ItemStack> items) {
|
|
||||||
this.items = items;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the xp to be dropped.
|
* Get the xp to be dropped.
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -86,7 +86,7 @@ public class ConfigSlot extends CustomSlot {
|
|||||||
for (String command : config.getStrings(configKey)) {
|
for (String command : config.getStrings(configKey)) {
|
||||||
if (command.startsWith("console:")) {
|
if (command.startsWith("console:")) {
|
||||||
commands.add(new CommandToDispatch(
|
commands.add(new CommandToDispatch(
|
||||||
StringUtils.removePrefix(command, "console:"),
|
StringUtils.removePrefix("console:", command),
|
||||||
true
|
true
|
||||||
));
|
));
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -120,12 +120,8 @@ public final class ConfiguredPrice implements Price {
|
|||||||
*/
|
*/
|
||||||
public String getDisplay(@NotNull final Player player,
|
public String getDisplay(@NotNull final Player player,
|
||||||
final double multiplier) {
|
final double multiplier) {
|
||||||
double value = this.getPrice().getValue(player, multiplier);
|
|
||||||
|
|
||||||
return StringUtils.format(
|
return StringUtils.format(
|
||||||
formatString
|
formatString.replace("%value%", NumberUtils.format(this.getPrice().getValue(player, multiplier))),
|
||||||
.replace("%value%", NumberUtils.format(value))
|
|
||||||
.replace("%value_commas%", NumberUtils.formatWithCommas(value)),
|
|
||||||
player,
|
player,
|
||||||
StringUtils.FormatOption.WITH_PLACEHOLDERS
|
StringUtils.FormatOption.WITH_PLACEHOLDERS
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
package com.willfp.eco.core.proxy;
|
package com.willfp.eco.core.proxy;
|
||||||
|
|
||||||
import com.willfp.eco.core.version.Version;
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
@@ -13,7 +12,7 @@ public final class ProxyConstants {
|
|||||||
/**
|
/**
|
||||||
* The NMS version that the server is running on.
|
* The NMS version that the server is running on.
|
||||||
*/
|
*/
|
||||||
public static final String NMS_VERSION;
|
public static final String NMS_VERSION = Bukkit.getServer().getClass().getPackage().getName().split("\\.")[3];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* All supported NMS versions.
|
* All supported NMS versions.
|
||||||
@@ -26,24 +25,10 @@ public final class ProxyConstants {
|
|||||||
"v1_19_R2",
|
"v1_19_R2",
|
||||||
"v1_19_R3",
|
"v1_19_R3",
|
||||||
"v1_20_R1",
|
"v1_20_R1",
|
||||||
"v1_20_R2",
|
"v1_20_R2"
|
||||||
"v1_20_R3"
|
|
||||||
);
|
);
|
||||||
|
|
||||||
private ProxyConstants() {
|
private ProxyConstants() {
|
||||||
throw new UnsupportedOperationException("This is a utility class and cannot be instantiated");
|
throw new UnsupportedOperationException("This is a utility class and cannot be instantiated");
|
||||||
}
|
}
|
||||||
|
|
||||||
static {
|
|
||||||
String currentMinecraftVersion = Bukkit.getServer().getBukkitVersion().split("-")[0];
|
|
||||||
String nmsVersion;
|
|
||||||
|
|
||||||
if (new Version(currentMinecraftVersion).compareTo(new Version("1.20.5")) < 0) {
|
|
||||||
nmsVersion = Bukkit.getServer().getClass().getPackage().getName().split("\\.")[3];
|
|
||||||
} else {
|
|
||||||
nmsVersion = "v" + currentMinecraftVersion.replace(".", "_");
|
|
||||||
}
|
|
||||||
|
|
||||||
NMS_VERSION = nmsVersion;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -203,20 +203,6 @@ public final class NumberUtils {
|
|||||||
return formatted.endsWith("00") ? String.valueOf((int) toFormat) : formatted;
|
return formatted.endsWith("00") ? String.valueOf((int) toFormat) : formatted;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Format double to string with commas.
|
|
||||||
*
|
|
||||||
* @param toFormat The number to format.
|
|
||||||
* @return Formatted.
|
|
||||||
*/
|
|
||||||
@NotNull
|
|
||||||
public static String formatWithCommas(final double toFormat) {
|
|
||||||
DecimalFormat df = new DecimalFormat("#,##0.00");
|
|
||||||
String formatted = df.format(toFormat);
|
|
||||||
|
|
||||||
return formatted.endsWith(".00") ? formatted.substring(0, formatted.length() - 3) : formatted;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Evaluate an expression.
|
* Evaluate an expression.
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -2,7 +2,6 @@ package com.willfp.eco.util;
|
|||||||
|
|
||||||
import com.github.benmanes.caffeine.cache.Cache;
|
import com.github.benmanes.caffeine.cache.Cache;
|
||||||
import com.github.benmanes.caffeine.cache.Caffeine;
|
import com.github.benmanes.caffeine.cache.Caffeine;
|
||||||
import com.willfp.eco.core.Eco;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
@@ -16,7 +15,7 @@ public final class PatternUtils {
|
|||||||
* Cache of compiled literal patterns.
|
* Cache of compiled literal patterns.
|
||||||
*/
|
*/
|
||||||
private static final Cache<String, Pattern> LITERAL_PATTERN_CACHE = Caffeine.newBuilder()
|
private static final Cache<String, Pattern> LITERAL_PATTERN_CACHE = Caffeine.newBuilder()
|
||||||
.expireAfterAccess(Eco.get().getEcoPlugin().getConfigYml().getInt("literal-cache-ttl"), TimeUnit.MINUTES)
|
.expireAfterAccess(1, TimeUnit.MINUTES)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -37,14 +37,9 @@ fun ItemStack.toSNBT() =
|
|||||||
Items.toSNBT(this)
|
Items.toSNBT(this)
|
||||||
|
|
||||||
/** @see Items.isEmpty */
|
/** @see Items.isEmpty */
|
||||||
@Deprecated("Use ItemStack.isEcoEmpty", ReplaceWith("Items.isEmpty(this)"))
|
|
||||||
val ItemStack?.isEmpty: Boolean
|
val ItemStack?.isEmpty: Boolean
|
||||||
get() = Items.isEmpty(this)
|
get() = Items.isEmpty(this)
|
||||||
|
|
||||||
/** @see Items.isEmpty */
|
|
||||||
val ItemStack?.isEcoEmpty: Boolean
|
|
||||||
get() = Items.isEmpty(this)
|
|
||||||
|
|
||||||
/** @see Items.matchesAny */
|
/** @see Items.matchesAny */
|
||||||
fun Collection<TestableItem>.matches(item: ItemStack): Boolean =
|
fun Collection<TestableItem>.matches(item: ItemStack): Boolean =
|
||||||
Items.matchesAny(item, this)
|
Items.matchesAny(item, this)
|
||||||
|
|||||||
@@ -8,10 +8,6 @@ import com.willfp.eco.core.placeholder.context.PlaceholderContext
|
|||||||
fun Number.toNumeral(): String =
|
fun Number.toNumeral(): String =
|
||||||
NumberUtils.toNumeral(this.toInt())
|
NumberUtils.toNumeral(this.toInt())
|
||||||
|
|
||||||
/** @see NumberUtils.formatWithCommas */
|
|
||||||
fun Number.formatWithCommas(): String =
|
|
||||||
NumberUtils.formatWithCommas(this.toDouble())
|
|
||||||
|
|
||||||
/** @see NumberUtils.fromNumeral */
|
/** @see NumberUtils.fromNumeral */
|
||||||
fun String.parseNumeral(): Int =
|
fun String.parseNumeral(): Int =
|
||||||
NumberUtils.fromNumeral(this)
|
NumberUtils.fromNumeral(this)
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ public class NumberUtilsTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testFormatDouble() {
|
public void testFormatDouble() {
|
||||||
Assertions.assertEquals("3", NumberUtils.format(3.0D));
|
Assertions.assertEquals("3", NumberUtils.format(3.0D));
|
||||||
//Assertions.assertEquals("3.20", NumberUtils.format(3.2D));
|
Assertions.assertEquals("3.20", NumberUtils.format(3.2D));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ dependencies {
|
|||||||
implementation("org.reflections:reflections:0.9.12")
|
implementation("org.reflections:reflections:0.9.12")
|
||||||
implementation("org.objenesis:objenesis:3.2")
|
implementation("org.objenesis:objenesis:3.2")
|
||||||
|
|
||||||
compileOnly("io.papermc.paper:paper-api:1.20.2-R0.1-SNAPSHOT")
|
compileOnly("org.spigotmc:spigot-api:1.20.2-R0.1-SNAPSHOT")
|
||||||
compileOnly("me.clip:placeholderapi:2.11.4")
|
compileOnly("me.clip:placeholderapi:2.11.4")
|
||||||
compileOnly("net.kyori:adventure-text-minimessage:4.10.0")
|
compileOnly("net.kyori:adventure-text-minimessage:4.10.0")
|
||||||
compileOnly("net.kyori:adventure-platform-bukkit:4.1.0")
|
compileOnly("net.kyori:adventure-platform-bukkit:4.1.0")
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ package com.willfp.eco.internal.command
|
|||||||
import com.willfp.eco.core.EcoPlugin
|
import com.willfp.eco.core.EcoPlugin
|
||||||
import com.willfp.eco.core.command.CommandBase
|
import com.willfp.eco.core.command.CommandBase
|
||||||
import com.willfp.eco.core.command.NotificationException
|
import com.willfp.eco.core.command.NotificationException
|
||||||
|
import com.willfp.eco.core.config.base.LangYml
|
||||||
import org.bukkit.Bukkit
|
import org.bukkit.Bukkit
|
||||||
import org.bukkit.command.Command
|
import org.bukkit.command.Command
|
||||||
import org.bukkit.command.CommandExecutor
|
import org.bukkit.command.CommandExecutor
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ package com.willfp.eco.internal.config
|
|||||||
|
|
||||||
import com.willfp.eco.core.config.ConfigType
|
import com.willfp.eco.core.config.ConfigType
|
||||||
import com.willfp.eco.core.placeholder.InjectablePlaceholder
|
import com.willfp.eco.core.placeholder.InjectablePlaceholder
|
||||||
|
import java.util.concurrent.ConcurrentHashMap
|
||||||
|
|
||||||
class EcoConfigSection(
|
class EcoConfigSection(
|
||||||
type: ConfigType,
|
type: ConfigType,
|
||||||
|
|||||||
@@ -10,11 +10,10 @@ import java.io.IOException
|
|||||||
import java.io.InputStreamReader
|
import java.io.InputStreamReader
|
||||||
import java.io.OutputStream
|
import java.io.OutputStream
|
||||||
import java.io.Reader
|
import java.io.Reader
|
||||||
import java.nio.ByteBuffer
|
|
||||||
import java.nio.channels.AsynchronousFileChannel
|
|
||||||
import java.nio.file.Files
|
import java.nio.file.Files
|
||||||
import java.nio.file.StandardOpenOption
|
import java.nio.file.StandardOpenOption
|
||||||
|
|
||||||
|
@Suppress("UNCHECKED_CAST")
|
||||||
open class EcoLoadableConfig(
|
open class EcoLoadableConfig(
|
||||||
type: ConfigType,
|
type: ConfigType,
|
||||||
configName: String,
|
configName: String,
|
||||||
@@ -75,20 +74,6 @@ open class EcoLoadableConfig(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun saveAsync() {
|
|
||||||
// Save asynchronously using NIO
|
|
||||||
AsynchronousFileChannel.open(
|
|
||||||
configFile.toPath(),
|
|
||||||
StandardOpenOption.WRITE,
|
|
||||||
StandardOpenOption.CREATE
|
|
||||||
).use { channel ->
|
|
||||||
channel.write(
|
|
||||||
ByteBuffer.wrap(this.toPlaintext().toByteArray()),
|
|
||||||
0
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun makeHeader(contents: String) {
|
private fun makeHeader(contents: String) {
|
||||||
header.clear()
|
header.clear()
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
package com.willfp.eco.internal.drops
|
package com.willfp.eco.internal.drops
|
||||||
|
|
||||||
import com.willfp.eco.core.Prerequisite
|
|
||||||
import com.willfp.eco.core.drops.DropQueue
|
import com.willfp.eco.core.drops.DropQueue
|
||||||
import com.willfp.eco.core.events.DropQueuePushEvent
|
import com.willfp.eco.core.events.DropQueuePushEvent
|
||||||
import com.willfp.eco.core.integrations.antigrief.AntigriefManager
|
import com.willfp.eco.core.integrations.antigrief.AntigriefManager
|
||||||
@@ -54,16 +53,13 @@ open class EcoDropQueue(val player: Player) : DropQueue() {
|
|||||||
hasTelekinesis = false
|
hasTelekinesis = false
|
||||||
}
|
}
|
||||||
|
|
||||||
val pushEvent = DropQueuePushEvent(player, items.toMutableList(), location, xp, hasTelekinesis)
|
val pushEvent = DropQueuePushEvent(player, items, location, xp, hasTelekinesis)
|
||||||
Bukkit.getServer().pluginManager.callEvent(pushEvent)
|
Bukkit.getServer().pluginManager.callEvent(pushEvent)
|
||||||
|
|
||||||
if (pushEvent.isCancelled) {
|
if (pushEvent.isCancelled) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
items.clear()
|
|
||||||
items.addAll(pushEvent.items)
|
|
||||||
|
|
||||||
val world = location.world!!
|
val world = location.world!!
|
||||||
location = location.add(0.5, 0.5, 0.5)
|
location = location.add(0.5, 0.5, 0.5)
|
||||||
items.removeIf { itemStack: ItemStack -> itemStack.type == Material.AIR }
|
items.removeIf { itemStack: ItemStack -> itemStack.type == Material.AIR }
|
||||||
@@ -76,17 +72,10 @@ open class EcoDropQueue(val player: Player) : DropQueue() {
|
|||||||
world.dropItem(location, drop!!).velocity = Vector()
|
world.dropItem(location, drop!!).velocity = Vector()
|
||||||
}
|
}
|
||||||
if (xp > 0) {
|
if (xp > 0) {
|
||||||
if (Prerequisite.HAS_PAPER.isMet) {
|
val orb =
|
||||||
player.giveExp(xp, true)
|
world.spawnEntity(player.location.add(0.0, 0.2, 0.0), EntityType.EXPERIENCE_ORB) as ExperienceOrb
|
||||||
} else {
|
orb.velocity = Vector(0, 0, 0)
|
||||||
val orb =
|
orb.experience = xp
|
||||||
world.spawnEntity(
|
|
||||||
player.location.add(0.0, 0.2, 0.0),
|
|
||||||
EntityType.EXPERIENCE_ORB
|
|
||||||
) as ExperienceOrb
|
|
||||||
orb.velocity = Vector(0, 0, 0)
|
|
||||||
orb.experience = xp
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
for (drop in items) {
|
for (drop in items) {
|
||||||
|
|||||||
@@ -19,7 +19,6 @@ object EntityArgParserName : EntityArgParser {
|
|||||||
|
|
||||||
val formatted = StringUtils.format(name)
|
val formatted = StringUtils.format(name)
|
||||||
|
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
return EntityArgParseResult(
|
return EntityArgParseResult(
|
||||||
{ it.customName == formatted },
|
{ it.customName == formatted },
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -42,7 +42,6 @@ class EcoExtensionLoader(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
@Throws(MalformedExtensionException::class)
|
@Throws(MalformedExtensionException::class)
|
||||||
private fun loadExtension(extensionJar: File) {
|
private fun loadExtension(extensionJar: File) {
|
||||||
val url = extensionJar.toURI().toURL()
|
val url = extensionJar.toURI().toURL()
|
||||||
@@ -60,7 +59,6 @@ class EcoExtensionLoader(
|
|||||||
val pluginVersion = Version(extensionYml.getStringOrNull("plugin-version") ?: "0.0.0")
|
val pluginVersion = Version(extensionYml.getStringOrNull("plugin-version") ?: "0.0.0")
|
||||||
val pluginName = extensionYml.getStringOrNull("plugin")
|
val pluginName = extensionYml.getStringOrNull("plugin")
|
||||||
|
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
if (pluginName != null && !pluginName.equals(this.plugin.description.name, ignoreCase = true)) {
|
if (pluginName != null && !pluginName.equals(this.plugin.description.name, ignoreCase = true)) {
|
||||||
throw ExtensionLoadException("${extensionJar.name} is only compatible with $pluginName!")
|
throw ExtensionLoadException("${extensionJar.name} is only compatible with $pluginName!")
|
||||||
}
|
}
|
||||||
@@ -84,7 +82,6 @@ class EcoExtensionLoader(
|
|||||||
author = "Unnamed Author"
|
author = "Unnamed Author"
|
||||||
}
|
}
|
||||||
|
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
if (Version(this.plugin.description.version) < pluginVersion) {
|
if (Version(this.plugin.description.version) < pluginVersion) {
|
||||||
throw ExtensionLoadException("Plugin version is too low for ${extensionJar.name}!")
|
throw ExtensionLoadException("Plugin version is too low for ${extensionJar.name}!")
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,6 +7,6 @@ import org.bukkit.NamespacedKey
|
|||||||
|
|
||||||
class EcoNamespacedKeyFactory(private val plugin: EcoPlugin) : NamespacedKeyFactory {
|
class EcoNamespacedKeyFactory(private val plugin: EcoPlugin) : NamespacedKeyFactory {
|
||||||
override fun create(key: String): NamespacedKey {
|
override fun create(key: String): NamespacedKey {
|
||||||
return NamespacedKeyUtils.create(plugin.id, key)
|
return NamespacedKeyUtils.create(plugin.name, key)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -25,6 +25,7 @@ class FastInternalNamespacedKeyFactory : InternalNamespacedKeyFactory {
|
|||||||
|
|
||||||
class SafeInternalNamespacedKeyFactory : InternalNamespacedKeyFactory {
|
class SafeInternalNamespacedKeyFactory : InternalNamespacedKeyFactory {
|
||||||
override fun create(namespace: String, key: String): NamespacedKey {
|
override fun create(namespace: String, key: String): NamespacedKey {
|
||||||
|
@Suppress("DEPRECATION")
|
||||||
return NamespacedKey(namespace, key)
|
return NamespacedKey(namespace, key)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -43,7 +43,6 @@ class EcoMenu(
|
|||||||
getPossiblyReactiveSlot(row, column, player)
|
getPossiblyReactiveSlot(row, column, player)
|
||||||
|
|
||||||
override fun open(player: Player): Inventory {
|
override fun open(player: Player): Inventory {
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
val inventory = if (columns == 9) {
|
val inventory = if (columns == 9) {
|
||||||
Bukkit.createInventory(null, rows * columns, title)
|
Bukkit.createInventory(null, rows * columns, title)
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
package com.willfp.eco.internal.gui.menu
|
package com.willfp.eco.internal.gui.menu
|
||||||
|
|
||||||
import com.willfp.eco.core.gui.menu.events.CaptiveItemChangeEvent
|
import com.willfp.eco.core.gui.menu.events.CaptiveItemChangeEvent
|
||||||
import com.willfp.eco.core.items.isEcoEmpty
|
import com.willfp.eco.core.items.isEmpty
|
||||||
import com.willfp.eco.core.recipe.parts.EmptyTestableItem
|
import com.willfp.eco.core.recipe.parts.EmptyTestableItem
|
||||||
import com.willfp.eco.util.MenuUtils
|
import com.willfp.eco.util.MenuUtils
|
||||||
import com.willfp.eco.util.openMenu
|
import com.willfp.eco.util.openMenu
|
||||||
@@ -55,7 +55,7 @@ class RenderedInventory(
|
|||||||
val actualItem = inventory.getItem(bukkit) ?: continue
|
val actualItem = inventory.getItem(bukkit) ?: continue
|
||||||
|
|
||||||
if (slot.isCaptiveFromEmpty) {
|
if (slot.isCaptiveFromEmpty) {
|
||||||
if (!actualItem.isEcoEmpty) {
|
if (!actualItem.isEmpty) {
|
||||||
newCaptive[position] = actualItem
|
newCaptive[position] = actualItem
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -6,7 +6,6 @@ import com.willfp.eco.core.placeholder.context.placeholderContext
|
|||||||
import me.clip.placeholderapi.expansion.PlaceholderExpansion
|
import me.clip.placeholderapi.expansion.PlaceholderExpansion
|
||||||
import org.bukkit.entity.Player
|
import org.bukkit.entity.Player
|
||||||
|
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
class PAPIExpansion(private val plugin: EcoPlugin) : PlaceholderExpansion() {
|
class PAPIExpansion(private val plugin: EcoPlugin) : PlaceholderExpansion() {
|
||||||
init {
|
init {
|
||||||
register()
|
register()
|
||||||
@@ -21,17 +20,14 @@ class PAPIExpansion(private val plugin: EcoPlugin) : PlaceholderExpansion() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
override fun getAuthor(): String {
|
override fun getAuthor(): String {
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
return java.lang.String.join(", ", plugin.description.authors)
|
return java.lang.String.join(", ", plugin.description.authors)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun getIdentifier(): String {
|
override fun getIdentifier(): String {
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
return plugin.description.name.lowercase()
|
return plugin.description.name.lowercase()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun getVersion(): String {
|
override fun getVersion(): String {
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
return plugin.description.version
|
return plugin.description.version
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,64 +0,0 @@
|
|||||||
package com.willfp.eco.internal.items
|
|
||||||
|
|
||||||
import com.willfp.eco.core.items.args.LookupArgParser
|
|
||||||
import org.bukkit.block.CreatureSpawner
|
|
||||||
import org.bukkit.entity.EntityType
|
|
||||||
import org.bukkit.inventory.ItemStack
|
|
||||||
import org.bukkit.inventory.meta.BlockStateMeta
|
|
||||||
import org.bukkit.inventory.meta.ItemMeta
|
|
||||||
import java.util.function.Predicate
|
|
||||||
|
|
||||||
object ArgParserEntity : LookupArgParser {
|
|
||||||
override fun parseArguments(args: Array<out String>, meta: ItemMeta): Predicate<ItemStack>? {
|
|
||||||
if (meta !is BlockStateMeta) {
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
|
|
||||||
if (meta.hasBlockState() || meta.blockState !is CreatureSpawner) {
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
|
|
||||||
val state = meta.blockState as CreatureSpawner
|
|
||||||
|
|
||||||
var type: String? = null
|
|
||||||
|
|
||||||
for (arg in args) {
|
|
||||||
val argSplit = arg.split(":")
|
|
||||||
if (!argSplit[0].equals("entity", ignoreCase = true)) {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if (argSplit.size < 2) {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
type = argSplit[1]
|
|
||||||
}
|
|
||||||
|
|
||||||
type ?: return null
|
|
||||||
|
|
||||||
val entityType = runCatching { EntityType.valueOf(type.uppercase()) }.getOrNull() ?: return null
|
|
||||||
|
|
||||||
state.spawnedType = entityType
|
|
||||||
|
|
||||||
meta.blockState = state
|
|
||||||
|
|
||||||
return Predicate {
|
|
||||||
val testMeta = ((it.itemMeta as? BlockStateMeta) as? CreatureSpawner) ?: return@Predicate false
|
|
||||||
|
|
||||||
testMeta.spawnedType?.name?.equals(type, true) == true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun serializeBack(meta: ItemMeta): String? {
|
|
||||||
if (meta !is BlockStateMeta) {
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
|
|
||||||
if (meta.hasBlockState() || meta.blockState !is CreatureSpawner) {
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
|
|
||||||
val state = meta.blockState as CreatureSpawner
|
|
||||||
|
|
||||||
return state.spawnedType?.let { "entity:${state.spawnedType!!.name}" } ?: return null
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -28,6 +28,7 @@ object ArgParserHead : LookupArgParser {
|
|||||||
|
|
||||||
playerName ?: return null
|
playerName ?: return null
|
||||||
|
|
||||||
|
@Suppress("DEPRECATION")
|
||||||
val player = Bukkit.getOfflinePlayer(playerName)
|
val player = Bukkit.getOfflinePlayer(playerName)
|
||||||
|
|
||||||
meta.owningPlayer = player
|
meta.owningPlayer = player
|
||||||
|
|||||||
@@ -22,13 +22,12 @@ object ArgParserName : LookupArgParser {
|
|||||||
val formatted = StringUtils.format(name)
|
val formatted = StringUtils.format(name)
|
||||||
|
|
||||||
// I don't know why it says it's redundant, the compiler yells at me
|
// I don't know why it says it's redundant, the compiler yells at me
|
||||||
@Suppress("UsePropertyAccessSyntax", "RedundantSuppression", "DEPRECATION")
|
@Suppress("UsePropertyAccessSyntax", "RedundantSuppression")
|
||||||
meta.setDisplayName(formatted)
|
meta.setDisplayName(formatted)
|
||||||
|
|
||||||
return Predicate {
|
return Predicate {
|
||||||
val testMeta = it.itemMeta ?: return@Predicate false
|
val testMeta = it.itemMeta ?: return@Predicate false
|
||||||
|
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
testMeta.displayName == formatted
|
testMeta.displayName == formatted
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -38,7 +37,6 @@ object ArgParserName : LookupArgParser {
|
|||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
|
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
return "name:\"${meta.displayName}\""
|
return "name:\"${meta.displayName}\""
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -1,11 +1,13 @@
|
|||||||
package com.willfp.eco.internal.items
|
package com.willfp.eco.internal.items
|
||||||
|
|
||||||
import com.willfp.eco.core.items.args.LookupArgParser
|
import com.willfp.eco.core.items.args.LookupArgParser
|
||||||
|
import org.bukkit.Color
|
||||||
import org.bukkit.NamespacedKey
|
import org.bukkit.NamespacedKey
|
||||||
import org.bukkit.Registry
|
import org.bukkit.Registry
|
||||||
import org.bukkit.inventory.ItemStack
|
import org.bukkit.inventory.ItemStack
|
||||||
import org.bukkit.inventory.meta.ArmorMeta
|
import org.bukkit.inventory.meta.ArmorMeta
|
||||||
import org.bukkit.inventory.meta.ItemMeta
|
import org.bukkit.inventory.meta.ItemMeta
|
||||||
|
import org.bukkit.inventory.meta.LeatherArmorMeta
|
||||||
import org.bukkit.inventory.meta.trim.ArmorTrim
|
import org.bukkit.inventory.meta.trim.ArmorTrim
|
||||||
import org.bukkit.inventory.meta.trim.TrimMaterial
|
import org.bukkit.inventory.meta.trim.TrimMaterial
|
||||||
import org.bukkit.inventory.meta.trim.TrimPattern
|
import org.bukkit.inventory.meta.trim.TrimPattern
|
||||||
|
|||||||
@@ -7,8 +7,6 @@ import com.willfp.eco.core.placeholder.InjectablePlaceholder
|
|||||||
import com.willfp.eco.core.placeholder.Placeholder
|
import com.willfp.eco.core.placeholder.Placeholder
|
||||||
import com.willfp.eco.core.placeholder.context.PlaceholderContext
|
import com.willfp.eco.core.placeholder.context.PlaceholderContext
|
||||||
import com.willfp.eco.util.StringUtils
|
import com.willfp.eco.util.StringUtils
|
||||||
import com.willfp.eco.util.evaluateExpression
|
|
||||||
import com.willfp.eco.util.toNiceString
|
|
||||||
import java.util.concurrent.TimeUnit
|
import java.util.concurrent.TimeUnit
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -21,8 +19,6 @@ but it's still best to minimise the memory overhead.
|
|||||||
|
|
||||||
class PlaceholderParser {
|
class PlaceholderParser {
|
||||||
private val placeholderRegex = Regex("%([^% ]+)%")
|
private val placeholderRegex = Regex("%([^% ]+)%")
|
||||||
private val prettyMathExpressionRegex = Regex("(\\{\\^\\{)(.)+(}})")
|
|
||||||
private val mathExpressionRegex = Regex("(\\{\\{)(.)+(}})")
|
|
||||||
|
|
||||||
private val placeholderLookupCache = Caffeine.newBuilder()
|
private val placeholderLookupCache = Caffeine.newBuilder()
|
||||||
.expireAfterWrite(1, TimeUnit.SECONDS)
|
.expireAfterWrite(1, TimeUnit.SECONDS)
|
||||||
@@ -38,29 +34,6 @@ class PlaceholderParser {
|
|||||||
injections: Collection<InjectablePlaceholder>,
|
injections: Collection<InjectablePlaceholder>,
|
||||||
translateEcoPlaceholders: Boolean = true
|
translateEcoPlaceholders: Boolean = true
|
||||||
): String {
|
): String {
|
||||||
var processed = text
|
|
||||||
|
|
||||||
// Only evaluate math expressions if there might be any
|
|
||||||
// Checking { as a char is faster than checking a string sequence,
|
|
||||||
// even if it might lead to false positives.
|
|
||||||
if ('{' in processed) {
|
|
||||||
if ('^' in processed) {
|
|
||||||
// Evaluate pretty math expressions
|
|
||||||
processed = prettyMathExpressionRegex.findAll(processed).fold(processed) { acc, matchResult ->
|
|
||||||
val expression = matchResult.value.substring(3, matchResult.value.length - 2)
|
|
||||||
val result = evaluateExpression(expression, context)
|
|
||||||
acc.replace(matchResult.value, result.toNiceString())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Evaluate math expressions
|
|
||||||
processed = mathExpressionRegex.findAll(processed).fold(processed) { acc, matchResult ->
|
|
||||||
val expression = matchResult.value.substring(2, matchResult.value.length - 2)
|
|
||||||
val result = evaluateExpression(expression, context)
|
|
||||||
acc.replace(matchResult.value, result.toString())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
||||||
Why am I doing injections at the start, and again at the end?
|
Why am I doing injections at the start, and again at the end?
|
||||||
@@ -82,7 +55,7 @@ class PlaceholderParser {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// Apply injections first
|
// Apply injections first
|
||||||
processed = injections.fold(processed) { acc, injection ->
|
var processed = injections.fold(text) { acc, injection ->
|
||||||
injection.tryTranslateQuickly(acc, context)
|
injection.tryTranslateQuickly(acc, context)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -93,7 +66,7 @@ class PlaceholderParser {
|
|||||||
val prefix = "%${additionalPlayer.identifier}_"
|
val prefix = "%${additionalPlayer.identifier}_"
|
||||||
processed = found.fold(processed) { acc, placeholder ->
|
processed = found.fold(processed) { acc, placeholder ->
|
||||||
if (placeholder.startsWith(prefix)) {
|
if (placeholder.startsWith(prefix)) {
|
||||||
val newPlaceholder = "%${StringUtils.removePrefix(placeholder, prefix)}"
|
val newPlaceholder = "%${StringUtils.removePrefix(prefix, placeholder)}"
|
||||||
val translation = translatePlacholders(
|
val translation = translatePlacholders(
|
||||||
newPlaceholder,
|
newPlaceholder,
|
||||||
context.copyWithPlayer(additionalPlayer.player),
|
context.copyWithPlayer(additionalPlayer.player),
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
plugins {
|
plugins {
|
||||||
id("io.papermc.paperweight.userdev") version "1.5.13" apply false
|
id("io.papermc.paperweight.userdev") version "1.5.3" apply false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,12 +1,9 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.common
|
package com.willfp.eco.internal.spigot.proxy.common
|
||||||
|
|
||||||
import com.willfp.eco.core.Prerequisite
|
|
||||||
import com.willfp.eco.core.entities.ai.EntityGoal
|
import com.willfp.eco.core.entities.ai.EntityGoal
|
||||||
import com.willfp.eco.core.entities.ai.TargetGoal
|
import com.willfp.eco.core.entities.ai.TargetGoal
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.ai.EntityGoalFactory
|
import com.willfp.eco.internal.spigot.proxy.common.ai.EntityGoalFactory
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.ai.TargetGoalFactory
|
import com.willfp.eco.internal.spigot.proxy.common.ai.TargetGoalFactory
|
||||||
import io.papermc.paper.adventure.PaperAdventure
|
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.minecraft.nbt.CompoundTag
|
import net.minecraft.nbt.CompoundTag
|
||||||
import net.minecraft.resources.ResourceLocation
|
import net.minecraft.resources.ResourceLocation
|
||||||
import net.minecraft.server.level.ServerPlayer
|
import net.minecraft.server.level.ServerPlayer
|
||||||
@@ -71,9 +68,6 @@ fun CompoundTag.setPdc(pdc: PersistentDataContainer?, item: net.minecraft.world.
|
|||||||
fun Player.toNMS(): ServerPlayer =
|
fun Player.toNMS(): ServerPlayer =
|
||||||
impl.toNMS(this)
|
impl.toNMS(this)
|
||||||
|
|
||||||
fun Component.toNMS(): net.minecraft.network.chat.Component =
|
|
||||||
if (Prerequisite.HAS_PAPER.isMet) PaperAdventure.asVanilla(this) else impl.toNMS(this)
|
|
||||||
|
|
||||||
interface CommonsProvider {
|
interface CommonsProvider {
|
||||||
val nbtTagString: Int
|
val nbtTagString: Int
|
||||||
|
|
||||||
@@ -107,8 +101,6 @@ interface CommonsProvider {
|
|||||||
|
|
||||||
fun toNMS(player: Player): ServerPlayer
|
fun toNMS(player: Player): ServerPlayer
|
||||||
|
|
||||||
fun toNMS(component: Component): net.minecraft.network.chat.Component
|
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
fun setIfNeeded(provider: CommonsProvider) {
|
fun setIfNeeded(provider: CommonsProvider) {
|
||||||
if (::impl.isInitialized) {
|
if (::impl.isInitialized) {
|
||||||
|
|||||||
@@ -5,8 +5,6 @@ import com.willfp.eco.internal.spigot.proxy.CommonsInitializerProxy
|
|||||||
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.kyori.adventure.text.serializer.gson.GsonComponentSerializer
|
|
||||||
import net.minecraft.core.Registry
|
import net.minecraft.core.Registry
|
||||||
import net.minecraft.nbt.CompoundTag
|
import net.minecraft.nbt.CompoundTag
|
||||||
import net.minecraft.nbt.Tag
|
import net.minecraft.nbt.Tag
|
||||||
@@ -157,10 +155,5 @@ class CommonsInitializer : CommonsInitializerProxy {
|
|||||||
override fun toNMS(player: Player): ServerPlayer {
|
override fun toNMS(player: Player): ServerPlayer {
|
||||||
return (player as CraftPlayer).handle
|
return (player as CraftPlayer).handle
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun toNMS(component: Component): net.minecraft.network.chat.Component {
|
|
||||||
val json = GsonComponentSerializer.gson().serialize(component)
|
|
||||||
return net.minecraft.network.chat.Component.Serializer.fromJson(json)!!
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,83 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_17_R1
|
|
||||||
|
|
||||||
import com.willfp.eco.core.packet.Packet
|
|
||||||
import com.willfp.eco.core.packet.sendPacket
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.DisplayNameProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toNMS
|
|
||||||
import it.unimi.dsi.fastutil.ints.Int2ObjectMap
|
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.minecraft.network.protocol.game.ClientboundSetEntityDataPacket
|
|
||||||
import net.minecraft.network.syncher.EntityDataAccessor
|
|
||||||
import net.minecraft.network.syncher.SynchedEntityData
|
|
||||||
import net.minecraft.world.entity.Entity
|
|
||||||
import org.bukkit.craftbukkit.v1_17_R1.entity.CraftLivingEntity
|
|
||||||
import org.bukkit.entity.LivingEntity
|
|
||||||
import org.bukkit.entity.Player
|
|
||||||
import java.util.Optional
|
|
||||||
|
|
||||||
@Suppress("UNCHECKED_CAST")
|
|
||||||
class DisplayName : DisplayNameProxy {
|
|
||||||
private val displayNameAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[2]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Optional<net.minecraft.network.chat.Component>>
|
|
||||||
|
|
||||||
private val customNameVisibleAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[3]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Boolean>
|
|
||||||
|
|
||||||
private val itemsByIDMapField = SynchedEntityData::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == Int2ObjectMap::class.java }
|
|
||||||
.toList()[0]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
|
|
||||||
override fun setClientsideDisplayName(
|
|
||||||
entity: LivingEntity,
|
|
||||||
player: Player,
|
|
||||||
displayName: Component,
|
|
||||||
visible: Boolean
|
|
||||||
) {
|
|
||||||
if (entity !is CraftLivingEntity) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
val nmsComponent = displayName.toNMS()
|
|
||||||
|
|
||||||
val nmsEntity = entity.handle
|
|
||||||
nmsEntity.isCustomNameVisible
|
|
||||||
val entityData = SynchedEntityData(nmsEntity)
|
|
||||||
|
|
||||||
entityData.forceSet(displayNameAccessor, Optional.of(nmsComponent))
|
|
||||||
entityData.forceSet(customNameVisibleAccessor, visible)
|
|
||||||
|
|
||||||
val packet = ClientboundSetEntityDataPacket(
|
|
||||||
nmsEntity.id,
|
|
||||||
entityData,
|
|
||||||
true
|
|
||||||
)
|
|
||||||
|
|
||||||
player.sendPacket(Packet(packet))
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.forceSet(
|
|
||||||
accessor: EntityDataAccessor<T>,
|
|
||||||
value: T
|
|
||||||
) {
|
|
||||||
if (!this.hasItem(accessor)) {
|
|
||||||
this.define(accessor, value)
|
|
||||||
}
|
|
||||||
this[accessor] = value
|
|
||||||
this.markDirty(accessor)
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.hasItem(accessor: EntityDataAccessor<T>): Boolean {
|
|
||||||
val itemsByIDMap = itemsByIDMapField.get(this) as Int2ObjectMap<Any>
|
|
||||||
return itemsByIDMap.containsKey(accessor.id)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -5,8 +5,6 @@ import com.willfp.eco.internal.spigot.proxy.CommonsInitializerProxy
|
|||||||
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.kyori.adventure.text.serializer.gson.GsonComponentSerializer
|
|
||||||
import net.minecraft.core.Registry
|
import net.minecraft.core.Registry
|
||||||
import net.minecraft.nbt.CompoundTag
|
import net.minecraft.nbt.CompoundTag
|
||||||
import net.minecraft.nbt.Tag
|
import net.minecraft.nbt.Tag
|
||||||
@@ -157,10 +155,5 @@ class CommonsInitializer : CommonsInitializerProxy {
|
|||||||
override fun toNMS(player: Player): ServerPlayer {
|
override fun toNMS(player: Player): ServerPlayer {
|
||||||
return (player as CraftPlayer).handle
|
return (player as CraftPlayer).handle
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun toNMS(component: Component): net.minecraft.network.chat.Component {
|
|
||||||
val json = GsonComponentSerializer.gson().serialize(component)
|
|
||||||
return net.minecraft.network.chat.Component.Serializer.fromJson(json)!!
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,83 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_18_R1
|
|
||||||
|
|
||||||
import com.willfp.eco.core.packet.Packet
|
|
||||||
import com.willfp.eco.core.packet.sendPacket
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.DisplayNameProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toNMS
|
|
||||||
import it.unimi.dsi.fastutil.ints.Int2ObjectMap
|
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.minecraft.network.protocol.game.ClientboundSetEntityDataPacket
|
|
||||||
import net.minecraft.network.syncher.EntityDataAccessor
|
|
||||||
import net.minecraft.network.syncher.SynchedEntityData
|
|
||||||
import net.minecraft.world.entity.Entity
|
|
||||||
import org.bukkit.craftbukkit.v1_18_R1.entity.CraftLivingEntity
|
|
||||||
import org.bukkit.entity.LivingEntity
|
|
||||||
import org.bukkit.entity.Player
|
|
||||||
import java.util.Optional
|
|
||||||
|
|
||||||
@Suppress("UNCHECKED_CAST")
|
|
||||||
class DisplayName : DisplayNameProxy {
|
|
||||||
private val displayNameAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[2]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Optional<net.minecraft.network.chat.Component>>
|
|
||||||
|
|
||||||
private val customNameVisibleAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[3]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Boolean>
|
|
||||||
|
|
||||||
private val itemsByIDMapField = SynchedEntityData::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == Int2ObjectMap::class.java }
|
|
||||||
.toList()[0]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
|
|
||||||
override fun setClientsideDisplayName(
|
|
||||||
entity: LivingEntity,
|
|
||||||
player: Player,
|
|
||||||
displayName: Component,
|
|
||||||
visible: Boolean
|
|
||||||
) {
|
|
||||||
if (entity !is CraftLivingEntity) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
val nmsComponent = displayName.toNMS()
|
|
||||||
|
|
||||||
val nmsEntity = entity.handle
|
|
||||||
nmsEntity.isCustomNameVisible
|
|
||||||
val entityData = SynchedEntityData(nmsEntity)
|
|
||||||
|
|
||||||
entityData.forceSet(displayNameAccessor, Optional.of(nmsComponent))
|
|
||||||
entityData.forceSet(customNameVisibleAccessor, visible)
|
|
||||||
|
|
||||||
val packet = ClientboundSetEntityDataPacket(
|
|
||||||
nmsEntity.id,
|
|
||||||
entityData,
|
|
||||||
true
|
|
||||||
)
|
|
||||||
|
|
||||||
player.sendPacket(Packet(packet))
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.forceSet(
|
|
||||||
accessor: EntityDataAccessor<T>,
|
|
||||||
value: T
|
|
||||||
) {
|
|
||||||
if (!this.hasItem(accessor)) {
|
|
||||||
this.define(accessor, value)
|
|
||||||
}
|
|
||||||
this[accessor] = value
|
|
||||||
this.markDirty(accessor)
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.hasItem(accessor: EntityDataAccessor<T>): Boolean {
|
|
||||||
val itemsByIDMap = itemsByIDMapField.get(this) as Int2ObjectMap<Any>
|
|
||||||
return itemsByIDMap.containsKey(accessor.id)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -5,8 +5,6 @@ import com.willfp.eco.internal.spigot.proxy.CommonsInitializerProxy
|
|||||||
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.kyori.adventure.text.serializer.gson.GsonComponentSerializer
|
|
||||||
import net.minecraft.core.Registry
|
import net.minecraft.core.Registry
|
||||||
import net.minecraft.nbt.CompoundTag
|
import net.minecraft.nbt.CompoundTag
|
||||||
import net.minecraft.nbt.Tag
|
import net.minecraft.nbt.Tag
|
||||||
@@ -157,10 +155,5 @@ class CommonsInitializer : CommonsInitializerProxy {
|
|||||||
override fun toNMS(player: Player): ServerPlayer {
|
override fun toNMS(player: Player): ServerPlayer {
|
||||||
return (player as CraftPlayer).handle
|
return (player as CraftPlayer).handle
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun toNMS(component: Component): net.minecraft.network.chat.Component {
|
|
||||||
val json = GsonComponentSerializer.gson().serialize(component)
|
|
||||||
return net.minecraft.network.chat.Component.Serializer.fromJson(json)!!
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,83 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_18_R2
|
|
||||||
|
|
||||||
import com.willfp.eco.core.packet.Packet
|
|
||||||
import com.willfp.eco.core.packet.sendPacket
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.DisplayNameProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toNMS
|
|
||||||
import it.unimi.dsi.fastutil.ints.Int2ObjectMap
|
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.minecraft.network.protocol.game.ClientboundSetEntityDataPacket
|
|
||||||
import net.minecraft.network.syncher.EntityDataAccessor
|
|
||||||
import net.minecraft.network.syncher.SynchedEntityData
|
|
||||||
import net.minecraft.world.entity.Entity
|
|
||||||
import org.bukkit.craftbukkit.v1_18_R2.entity.CraftLivingEntity
|
|
||||||
import org.bukkit.entity.LivingEntity
|
|
||||||
import org.bukkit.entity.Player
|
|
||||||
import java.util.Optional
|
|
||||||
|
|
||||||
@Suppress("UNCHECKED_CAST")
|
|
||||||
class DisplayName : DisplayNameProxy {
|
|
||||||
private val displayNameAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[2]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Optional<net.minecraft.network.chat.Component>>
|
|
||||||
|
|
||||||
private val customNameVisibleAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[3]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Boolean>
|
|
||||||
|
|
||||||
private val itemsByIDMapField = SynchedEntityData::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == Int2ObjectMap::class.java }
|
|
||||||
.toList()[0]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
|
|
||||||
override fun setClientsideDisplayName(
|
|
||||||
entity: LivingEntity,
|
|
||||||
player: Player,
|
|
||||||
displayName: Component,
|
|
||||||
visible: Boolean
|
|
||||||
) {
|
|
||||||
if (entity !is CraftLivingEntity) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
val nmsComponent = displayName.toNMS()
|
|
||||||
|
|
||||||
val nmsEntity = entity.handle
|
|
||||||
nmsEntity.isCustomNameVisible
|
|
||||||
val entityData = SynchedEntityData(nmsEntity)
|
|
||||||
|
|
||||||
entityData.forceSet(displayNameAccessor, Optional.of(nmsComponent))
|
|
||||||
entityData.forceSet(customNameVisibleAccessor, visible)
|
|
||||||
|
|
||||||
val packet = ClientboundSetEntityDataPacket(
|
|
||||||
nmsEntity.id,
|
|
||||||
entityData,
|
|
||||||
true
|
|
||||||
)
|
|
||||||
|
|
||||||
player.sendPacket(Packet(packet))
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.forceSet(
|
|
||||||
accessor: EntityDataAccessor<T>,
|
|
||||||
value: T
|
|
||||||
) {
|
|
||||||
if (!this.hasItem(accessor)) {
|
|
||||||
this.define(accessor, value)
|
|
||||||
}
|
|
||||||
this[accessor] = value
|
|
||||||
this.markDirty(accessor)
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.hasItem(accessor: EntityDataAccessor<T>): Boolean {
|
|
||||||
val itemsByIDMap = itemsByIDMapField.get(this) as Int2ObjectMap<Any>
|
|
||||||
return itemsByIDMap.containsKey(accessor.id)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -5,8 +5,6 @@ import com.willfp.eco.internal.spigot.proxy.CommonsInitializerProxy
|
|||||||
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.kyori.adventure.text.serializer.gson.GsonComponentSerializer
|
|
||||||
import net.minecraft.core.Registry
|
import net.minecraft.core.Registry
|
||||||
import net.minecraft.nbt.CompoundTag
|
import net.minecraft.nbt.CompoundTag
|
||||||
import net.minecraft.nbt.Tag
|
import net.minecraft.nbt.Tag
|
||||||
@@ -157,10 +155,5 @@ class CommonsInitializer : CommonsInitializerProxy {
|
|||||||
override fun toNMS(player: Player): ServerPlayer {
|
override fun toNMS(player: Player): ServerPlayer {
|
||||||
return (player as CraftPlayer).handle
|
return (player as CraftPlayer).handle
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun toNMS(component: Component): net.minecraft.network.chat.Component {
|
|
||||||
val json = GsonComponentSerializer.gson().serialize(component)
|
|
||||||
return net.minecraft.network.chat.Component.Serializer.fromJson(json)!!
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,83 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_19_R1
|
|
||||||
|
|
||||||
import com.willfp.eco.core.packet.Packet
|
|
||||||
import com.willfp.eco.core.packet.sendPacket
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.DisplayNameProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toNMS
|
|
||||||
import it.unimi.dsi.fastutil.ints.Int2ObjectMap
|
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.minecraft.network.protocol.game.ClientboundSetEntityDataPacket
|
|
||||||
import net.minecraft.network.syncher.EntityDataAccessor
|
|
||||||
import net.minecraft.network.syncher.SynchedEntityData
|
|
||||||
import net.minecraft.world.entity.Entity
|
|
||||||
import org.bukkit.craftbukkit.v1_19_R1.entity.CraftLivingEntity
|
|
||||||
import org.bukkit.entity.LivingEntity
|
|
||||||
import org.bukkit.entity.Player
|
|
||||||
import java.util.Optional
|
|
||||||
|
|
||||||
@Suppress("UNCHECKED_CAST")
|
|
||||||
class DisplayName : DisplayNameProxy {
|
|
||||||
private val displayNameAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[2]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Optional<net.minecraft.network.chat.Component>>
|
|
||||||
|
|
||||||
private val customNameVisibleAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[3]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Boolean>
|
|
||||||
|
|
||||||
private val itemsByIDMapField = SynchedEntityData::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == Int2ObjectMap::class.java }
|
|
||||||
.toList()[0]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
|
|
||||||
override fun setClientsideDisplayName(
|
|
||||||
entity: LivingEntity,
|
|
||||||
player: Player,
|
|
||||||
displayName: Component,
|
|
||||||
visible: Boolean
|
|
||||||
) {
|
|
||||||
if (entity !is CraftLivingEntity) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
val nmsComponent = displayName.toNMS()
|
|
||||||
|
|
||||||
val nmsEntity = entity.handle
|
|
||||||
nmsEntity.isCustomNameVisible
|
|
||||||
val entityData = SynchedEntityData(nmsEntity)
|
|
||||||
|
|
||||||
entityData.forceSet(displayNameAccessor, Optional.of(nmsComponent))
|
|
||||||
entityData.forceSet(customNameVisibleAccessor, visible)
|
|
||||||
|
|
||||||
val packet = ClientboundSetEntityDataPacket(
|
|
||||||
nmsEntity.id,
|
|
||||||
entityData,
|
|
||||||
true
|
|
||||||
)
|
|
||||||
|
|
||||||
player.sendPacket(Packet(packet))
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.forceSet(
|
|
||||||
accessor: EntityDataAccessor<T>,
|
|
||||||
value: T
|
|
||||||
) {
|
|
||||||
if (!this.hasItem(accessor)) {
|
|
||||||
this.define(accessor, value)
|
|
||||||
}
|
|
||||||
this[accessor] = value
|
|
||||||
this.markDirty(accessor)
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.hasItem(accessor: EntityDataAccessor<T>): Boolean {
|
|
||||||
val itemsByIDMap = itemsByIDMapField.get(this) as Int2ObjectMap<Any>
|
|
||||||
return itemsByIDMap.containsKey(accessor.id)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -6,8 +6,6 @@ import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
|||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
||||||
import io.netty.channel.Channel
|
import io.netty.channel.Channel
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.kyori.adventure.text.serializer.gson.GsonComponentSerializer
|
|
||||||
import net.minecraft.core.registries.BuiltInRegistries
|
import net.minecraft.core.registries.BuiltInRegistries
|
||||||
import net.minecraft.nbt.CompoundTag
|
import net.minecraft.nbt.CompoundTag
|
||||||
import net.minecraft.nbt.Tag
|
import net.minecraft.nbt.Tag
|
||||||
@@ -159,10 +157,5 @@ class CommonsInitializer : CommonsInitializerProxy {
|
|||||||
override fun toNMS(player: Player): ServerPlayer {
|
override fun toNMS(player: Player): ServerPlayer {
|
||||||
return (player as CraftPlayer).handle
|
return (player as CraftPlayer).handle
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun toNMS(component: Component): net.minecraft.network.chat.Component {
|
|
||||||
val json = GsonComponentSerializer.gson().serialize(component)
|
|
||||||
return net.minecraft.network.chat.Component.Serializer.fromJson(json)!!
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,82 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_19_R2
|
|
||||||
|
|
||||||
import com.willfp.eco.core.packet.Packet
|
|
||||||
import com.willfp.eco.core.packet.sendPacket
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.DisplayNameProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toNMS
|
|
||||||
import it.unimi.dsi.fastutil.ints.Int2ObjectMap
|
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.minecraft.network.protocol.game.ClientboundSetEntityDataPacket
|
|
||||||
import net.minecraft.network.syncher.EntityDataAccessor
|
|
||||||
import net.minecraft.network.syncher.SynchedEntityData
|
|
||||||
import net.minecraft.world.entity.Entity
|
|
||||||
import org.bukkit.craftbukkit.v1_19_R2.entity.CraftLivingEntity
|
|
||||||
import org.bukkit.entity.LivingEntity
|
|
||||||
import org.bukkit.entity.Player
|
|
||||||
import java.util.Optional
|
|
||||||
|
|
||||||
@Suppress("UNCHECKED_CAST")
|
|
||||||
class DisplayName : DisplayNameProxy {
|
|
||||||
private val displayNameAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[2]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Optional<net.minecraft.network.chat.Component>>
|
|
||||||
|
|
||||||
private val customNameVisibleAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[3]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Boolean>
|
|
||||||
|
|
||||||
private val itemsByIDMapField = SynchedEntityData::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == Int2ObjectMap::class.java }
|
|
||||||
.toList()[0]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
|
|
||||||
override fun setClientsideDisplayName(
|
|
||||||
entity: LivingEntity,
|
|
||||||
player: Player,
|
|
||||||
displayName: Component,
|
|
||||||
visible: Boolean
|
|
||||||
) {
|
|
||||||
if (entity !is CraftLivingEntity) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
val nmsComponent = displayName.toNMS()
|
|
||||||
|
|
||||||
val nmsEntity = entity.handle
|
|
||||||
nmsEntity.isCustomNameVisible
|
|
||||||
val entityData = SynchedEntityData(nmsEntity)
|
|
||||||
|
|
||||||
entityData.forceSet(displayNameAccessor, Optional.of(nmsComponent))
|
|
||||||
entityData.forceSet(customNameVisibleAccessor, visible)
|
|
||||||
|
|
||||||
val packet = ClientboundSetEntityDataPacket(
|
|
||||||
nmsEntity.id,
|
|
||||||
entityData.packDirty() ?: throw IllegalStateException("No packed entity data")
|
|
||||||
)
|
|
||||||
|
|
||||||
player.sendPacket(Packet(packet))
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.forceSet(
|
|
||||||
accessor: EntityDataAccessor<T>,
|
|
||||||
value: T
|
|
||||||
) {
|
|
||||||
if (!this.hasItem(accessor)) {
|
|
||||||
this.define(accessor, value)
|
|
||||||
}
|
|
||||||
this[accessor] = value
|
|
||||||
this.markDirty(accessor)
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.hasItem(accessor: EntityDataAccessor<T>): Boolean {
|
|
||||||
val itemsByIDMap = itemsByIDMapField.get(this) as Int2ObjectMap<Any>
|
|
||||||
return itemsByIDMap.containsKey(accessor.id)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -5,8 +5,6 @@ import com.willfp.eco.internal.spigot.proxy.CommonsInitializerProxy
|
|||||||
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.kyori.adventure.text.serializer.gson.GsonComponentSerializer
|
|
||||||
import net.minecraft.core.registries.BuiltInRegistries
|
import net.minecraft.core.registries.BuiltInRegistries
|
||||||
import net.minecraft.nbt.CompoundTag
|
import net.minecraft.nbt.CompoundTag
|
||||||
import net.minecraft.nbt.Tag
|
import net.minecraft.nbt.Tag
|
||||||
@@ -157,10 +155,5 @@ class CommonsInitializer : CommonsInitializerProxy {
|
|||||||
override fun toNMS(player: Player): ServerPlayer {
|
override fun toNMS(player: Player): ServerPlayer {
|
||||||
return (player as CraftPlayer).handle
|
return (player as CraftPlayer).handle
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun toNMS(component: Component): net.minecraft.network.chat.Component {
|
|
||||||
val json = GsonComponentSerializer.gson().serialize(component)
|
|
||||||
return net.minecraft.network.chat.Component.Serializer.fromJson(json)!!
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,82 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_19_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.core.packet.Packet
|
|
||||||
import com.willfp.eco.core.packet.sendPacket
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.DisplayNameProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toNMS
|
|
||||||
import it.unimi.dsi.fastutil.ints.Int2ObjectMap
|
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.minecraft.network.protocol.game.ClientboundSetEntityDataPacket
|
|
||||||
import net.minecraft.network.syncher.EntityDataAccessor
|
|
||||||
import net.minecraft.network.syncher.SynchedEntityData
|
|
||||||
import net.minecraft.world.entity.Entity
|
|
||||||
import org.bukkit.craftbukkit.v1_19_R3.entity.CraftLivingEntity
|
|
||||||
import org.bukkit.entity.LivingEntity
|
|
||||||
import org.bukkit.entity.Player
|
|
||||||
import java.util.Optional
|
|
||||||
|
|
||||||
@Suppress("UNCHECKED_CAST")
|
|
||||||
class DisplayName : DisplayNameProxy {
|
|
||||||
private val displayNameAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[2]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Optional<net.minecraft.network.chat.Component>>
|
|
||||||
|
|
||||||
private val customNameVisibleAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[3]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Boolean>
|
|
||||||
|
|
||||||
private val itemsByIDMapField = SynchedEntityData::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == Int2ObjectMap::class.java }
|
|
||||||
.toList()[0]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
|
|
||||||
override fun setClientsideDisplayName(
|
|
||||||
entity: LivingEntity,
|
|
||||||
player: Player,
|
|
||||||
displayName: Component,
|
|
||||||
visible: Boolean
|
|
||||||
) {
|
|
||||||
if (entity !is CraftLivingEntity) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
val nmsComponent = displayName.toNMS()
|
|
||||||
|
|
||||||
val nmsEntity = entity.handle
|
|
||||||
nmsEntity.isCustomNameVisible
|
|
||||||
val entityData = SynchedEntityData(nmsEntity)
|
|
||||||
|
|
||||||
entityData.forceSet(displayNameAccessor, Optional.of(nmsComponent))
|
|
||||||
entityData.forceSet(customNameVisibleAccessor, visible)
|
|
||||||
|
|
||||||
val packet = ClientboundSetEntityDataPacket(
|
|
||||||
nmsEntity.id,
|
|
||||||
entityData.packDirty() ?: throw IllegalStateException("No packed entity data")
|
|
||||||
)
|
|
||||||
|
|
||||||
player.sendPacket(Packet(packet))
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.forceSet(
|
|
||||||
accessor: EntityDataAccessor<T>,
|
|
||||||
value: T
|
|
||||||
) {
|
|
||||||
if (!this.hasItem(accessor)) {
|
|
||||||
this.define(accessor, value)
|
|
||||||
}
|
|
||||||
this[accessor] = value
|
|
||||||
this.markDirty(accessor)
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T : Any> SynchedEntityData.hasItem(accessor: EntityDataAccessor<T>): Boolean {
|
|
||||||
val itemsByIDMap = itemsByIDMapField.get(this) as Int2ObjectMap<Any>
|
|
||||||
return itemsByIDMap.containsKey(accessor.id)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -5,8 +5,6 @@ import com.willfp.eco.internal.spigot.proxy.CommonsInitializerProxy
|
|||||||
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.kyori.adventure.text.serializer.json.JSONComponentSerializer
|
|
||||||
import net.minecraft.core.registries.BuiltInRegistries
|
import net.minecraft.core.registries.BuiltInRegistries
|
||||||
import net.minecraft.nbt.CompoundTag
|
import net.minecraft.nbt.CompoundTag
|
||||||
import net.minecraft.nbt.Tag
|
import net.minecraft.nbt.Tag
|
||||||
@@ -157,10 +155,5 @@ class CommonsInitializer : CommonsInitializerProxy {
|
|||||||
override fun toNMS(player: Player): ServerPlayer {
|
override fun toNMS(player: Player): ServerPlayer {
|
||||||
return (player as CraftPlayer).handle
|
return (player as CraftPlayer).handle
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun toNMS(component: Component): net.minecraft.network.chat.Component {
|
|
||||||
val json = JSONComponentSerializer.json().serialize(component)
|
|
||||||
return net.minecraft.network.chat.Component.Serializer.fromJson(json)!!
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,6 @@ package com.willfp.eco.internal.spigot.proxy.v1_20_R1
|
|||||||
import com.willfp.eco.core.packet.Packet
|
import com.willfp.eco.core.packet.Packet
|
||||||
import com.willfp.eco.core.packet.sendPacket
|
import com.willfp.eco.core.packet.sendPacket
|
||||||
import com.willfp.eco.internal.spigot.proxy.DisplayNameProxy
|
import com.willfp.eco.internal.spigot.proxy.DisplayNameProxy
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toNMS
|
|
||||||
import io.papermc.paper.adventure.PaperAdventure
|
import io.papermc.paper.adventure.PaperAdventure
|
||||||
import net.kyori.adventure.text.Component
|
import net.kyori.adventure.text.Component
|
||||||
import net.minecraft.network.protocol.game.ClientboundSetEntityDataPacket
|
import net.minecraft.network.protocol.game.ClientboundSetEntityDataPacket
|
||||||
@@ -41,7 +40,8 @@ class DisplayName : DisplayNameProxy {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
val nmsComponent = displayName.toNMS()
|
val nmsComponent = PaperAdventure.asVanilla(displayName)
|
||||||
|
?: throw IllegalStateException("Display name component is null!")
|
||||||
|
|
||||||
val nmsEntity = entity.handle
|
val nmsEntity = entity.handle
|
||||||
nmsEntity.isCustomNameVisible
|
nmsEntity.isCustomNameVisible
|
||||||
|
|||||||
@@ -5,8 +5,6 @@ import com.willfp.eco.internal.spigot.proxy.CommonsInitializerProxy
|
|||||||
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.kyori.adventure.text.serializer.json.JSONComponentSerializer
|
|
||||||
import net.minecraft.core.registries.BuiltInRegistries
|
import net.minecraft.core.registries.BuiltInRegistries
|
||||||
import net.minecraft.nbt.CompoundTag
|
import net.minecraft.nbt.CompoundTag
|
||||||
import net.minecraft.nbt.Tag
|
import net.minecraft.nbt.Tag
|
||||||
@@ -157,10 +155,5 @@ class CommonsInitializer : CommonsInitializerProxy {
|
|||||||
override fun toNMS(player: Player): ServerPlayer {
|
override fun toNMS(player: Player): ServerPlayer {
|
||||||
return (player as CraftPlayer).handle
|
return (player as CraftPlayer).handle
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun toNMS(component: Component): net.minecraft.network.chat.Component {
|
|
||||||
val json = JSONComponentSerializer.json().serialize(component)
|
|
||||||
return net.minecraft.network.chat.Component.Serializer.fromJson(json)!!
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,6 @@ package com.willfp.eco.internal.spigot.proxy.v1_20_R2
|
|||||||
import com.willfp.eco.core.packet.Packet
|
import com.willfp.eco.core.packet.Packet
|
||||||
import com.willfp.eco.core.packet.sendPacket
|
import com.willfp.eco.core.packet.sendPacket
|
||||||
import com.willfp.eco.internal.spigot.proxy.DisplayNameProxy
|
import com.willfp.eco.internal.spigot.proxy.DisplayNameProxy
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toNMS
|
|
||||||
import io.papermc.paper.adventure.PaperAdventure
|
import io.papermc.paper.adventure.PaperAdventure
|
||||||
import net.kyori.adventure.text.Component
|
import net.kyori.adventure.text.Component
|
||||||
import net.minecraft.network.protocol.game.ClientboundSetEntityDataPacket
|
import net.minecraft.network.protocol.game.ClientboundSetEntityDataPacket
|
||||||
@@ -38,7 +37,8 @@ class DisplayName : DisplayNameProxy {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
val nmsComponent = displayName.toNMS()
|
val nmsComponent = PaperAdventure.asVanilla(displayName)
|
||||||
|
?: throw IllegalStateException("Display name component is null!")
|
||||||
|
|
||||||
val nmsEntity = entity.handle
|
val nmsEntity = entity.handle
|
||||||
nmsEntity.isCustomNameVisible
|
nmsEntity.isCustomNameVisible
|
||||||
|
|||||||
@@ -1,39 +0,0 @@
|
|||||||
plugins {
|
|
||||||
id("io.papermc.paperweight.userdev")
|
|
||||||
}
|
|
||||||
|
|
||||||
group = "com.willfp"
|
|
||||||
version = rootProject.version
|
|
||||||
|
|
||||||
dependencies {
|
|
||||||
implementation(project(":eco-core:core-nms:nms-common"))
|
|
||||||
paperweight.paperDevBundle("1.20.4-R0.1-SNAPSHOT")
|
|
||||||
|
|
||||||
implementation("net.kyori:adventure-text-minimessage:4.11.0") {
|
|
||||||
version {
|
|
||||||
strictly("4.11.0")
|
|
||||||
}
|
|
||||||
exclude(group = "net.kyori", module = "adventure-api")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
tasks {
|
|
||||||
build {
|
|
||||||
dependsOn(reobfJar)
|
|
||||||
}
|
|
||||||
|
|
||||||
reobfJar {
|
|
||||||
mustRunAfter(shadowJar)
|
|
||||||
}
|
|
||||||
|
|
||||||
shadowJar {
|
|
||||||
relocate(
|
|
||||||
"com.willfp.eco.internal.spigot.proxy.common",
|
|
||||||
"com.willfp.eco.internal.spigot.proxy.v1_20_R3.common"
|
|
||||||
)
|
|
||||||
relocate(
|
|
||||||
"net.kyori.adventure.text.minimessage",
|
|
||||||
"com.willfp.eco.internal.spigot.proxy.v1_20_R3.minimessage"
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,35 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.core.command.PluginCommandBase
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.BukkitCommandsProxy
|
|
||||||
import org.bukkit.Bukkit
|
|
||||||
import org.bukkit.command.Command
|
|
||||||
import org.bukkit.command.SimpleCommandMap
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.CraftServer
|
|
||||||
import java.lang.reflect.Field
|
|
||||||
|
|
||||||
class BukkitCommands : BukkitCommandsProxy {
|
|
||||||
private val knownCommandsField: Field by lazy {
|
|
||||||
SimpleCommandMap::class.java.getDeclaredField("knownCommands")
|
|
||||||
.apply {
|
|
||||||
isAccessible = true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Suppress("UNCHECKED_CAST")
|
|
||||||
private val knownCommands: MutableMap<String, Command>
|
|
||||||
get() = knownCommandsField.get(getCommandMap()) as MutableMap<String, Command>
|
|
||||||
|
|
||||||
override fun getCommandMap(): SimpleCommandMap {
|
|
||||||
return (Bukkit.getServer() as CraftServer).commandMap
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun syncCommands() {
|
|
||||||
(Bukkit.getServer() as CraftServer).syncCommands()
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun unregisterCommand(command: PluginCommandBase) {
|
|
||||||
knownCommands.remove(command.name)
|
|
||||||
knownCommands.remove("${command.plugin.name.lowercase()}:${command.name}")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,166 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.core.EcoPlugin
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.CommonsInitializerProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.CommonsProvider
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.PacketInjectorListener
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toResourceLocation
|
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.kyori.adventure.text.serializer.json.JSONComponentSerializer
|
|
||||||
import net.minecraft.core.registries.BuiltInRegistries
|
|
||||||
import net.minecraft.nbt.CompoundTag
|
|
||||||
import net.minecraft.nbt.Tag
|
|
||||||
import net.minecraft.resources.ResourceLocation
|
|
||||||
import net.minecraft.server.level.ServerPlayer
|
|
||||||
import net.minecraft.world.entity.PathfinderMob
|
|
||||||
import net.minecraft.world.item.Item
|
|
||||||
import org.bukkit.Bukkit
|
|
||||||
import org.bukkit.Material
|
|
||||||
import org.bukkit.NamespacedKey
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.CraftServer
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.entity.CraftEntity
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.entity.CraftMob
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.entity.CraftPlayer
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.inventory.CraftItemStack
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.persistence.CraftPersistentDataContainer
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.persistence.CraftPersistentDataTypeRegistry
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.util.CraftMagicNumbers
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.util.CraftNamespacedKey
|
|
||||||
import org.bukkit.entity.LivingEntity
|
|
||||||
import org.bukkit.entity.Mob
|
|
||||||
import org.bukkit.entity.Player
|
|
||||||
import org.bukkit.inventory.ItemStack
|
|
||||||
import org.bukkit.persistence.PersistentDataContainer
|
|
||||||
import java.lang.reflect.Field
|
|
||||||
|
|
||||||
class CommonsInitializer : CommonsInitializerProxy {
|
|
||||||
override fun init(plugin: EcoPlugin) {
|
|
||||||
CommonsProvider.setIfNeeded(CommonsProviderImpl)
|
|
||||||
plugin.onEnable {
|
|
||||||
plugin.eventManager.registerListener(PacketInjectorListener)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
object CommonsProviderImpl : CommonsProvider {
|
|
||||||
private val cisHandle: Field = CraftItemStack::class.java.getDeclaredField("handle").apply {
|
|
||||||
isAccessible = true
|
|
||||||
}
|
|
||||||
|
|
||||||
private val pdcRegsitry = Class.forName("org.bukkit.craftbukkit.v1_20_R3.inventory.CraftMetaItem")
|
|
||||||
.getDeclaredField("DATA_TYPE_REGISTRY")
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as CraftPersistentDataTypeRegistry
|
|
||||||
|
|
||||||
override val nbtTagString = CraftMagicNumbers.NBT.TAG_STRING
|
|
||||||
|
|
||||||
override fun toPathfinderMob(mob: Mob): PathfinderMob? {
|
|
||||||
val craft = mob as? CraftMob ?: return null
|
|
||||||
return craft.handle as? PathfinderMob
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun toResourceLocation(namespacedKey: NamespacedKey): ResourceLocation =
|
|
||||||
CraftNamespacedKey.toMinecraft(namespacedKey)
|
|
||||||
|
|
||||||
override fun asNMSStack(itemStack: ItemStack): net.minecraft.world.item.ItemStack {
|
|
||||||
return if (itemStack !is CraftItemStack) {
|
|
||||||
CraftItemStack.asNMSCopy(itemStack)
|
|
||||||
} else {
|
|
||||||
cisHandle[itemStack] as net.minecraft.world.item.ItemStack? ?: CraftItemStack.asNMSCopy(itemStack)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun asBukkitStack(itemStack: net.minecraft.world.item.ItemStack): ItemStack {
|
|
||||||
return CraftItemStack.asCraftMirror(itemStack)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun mergeIfNeeded(itemStack: ItemStack, nmsStack: net.minecraft.world.item.ItemStack) {
|
|
||||||
if (itemStack !is CraftItemStack) {
|
|
||||||
itemStack.itemMeta = CraftItemStack.asCraftMirror(nmsStack).itemMeta
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun toBukkitEntity(entity: net.minecraft.world.entity.LivingEntity): LivingEntity? =
|
|
||||||
CraftEntity.getEntity(Bukkit.getServer() as CraftServer, entity) as? LivingEntity
|
|
||||||
|
|
||||||
override fun makePdc(tag: CompoundTag, base: Boolean): PersistentDataContainer {
|
|
||||||
fun emptyPdc(): CraftPersistentDataContainer = CraftPersistentDataContainer(pdcRegsitry)
|
|
||||||
|
|
||||||
fun CompoundTag?.toPdc(): PersistentDataContainer {
|
|
||||||
val pdc = emptyPdc()
|
|
||||||
this ?: return pdc
|
|
||||||
val keys = this.allKeys
|
|
||||||
for (key in keys) {
|
|
||||||
pdc.put(key, this[key])
|
|
||||||
}
|
|
||||||
|
|
||||||
return pdc
|
|
||||||
}
|
|
||||||
|
|
||||||
return if (base) {
|
|
||||||
tag.toPdc()
|
|
||||||
} else {
|
|
||||||
if (tag.contains("PublicBukkitValues")) {
|
|
||||||
tag.getCompound("PublicBukkitValues").toPdc()
|
|
||||||
} else {
|
|
||||||
emptyPdc()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun setPdc(
|
|
||||||
tag: CompoundTag,
|
|
||||||
pdc: PersistentDataContainer?,
|
|
||||||
item: net.minecraft.world.item.ItemStack?
|
|
||||||
) {
|
|
||||||
fun CraftPersistentDataContainer.toTag(): CompoundTag {
|
|
||||||
val compound = CompoundTag()
|
|
||||||
val rawPublicMap: Map<String, Tag> = this.raw
|
|
||||||
for ((key, value) in rawPublicMap) {
|
|
||||||
compound.put(key, value)
|
|
||||||
}
|
|
||||||
|
|
||||||
return compound
|
|
||||||
}
|
|
||||||
|
|
||||||
val container = when (pdc) {
|
|
||||||
is CraftPersistentDataContainer? -> pdc
|
|
||||||
else -> null
|
|
||||||
}
|
|
||||||
|
|
||||||
if (item != null) {
|
|
||||||
if (container != null && !container.isEmpty) {
|
|
||||||
for (key in tag.allKeys.toSet()) {
|
|
||||||
tag.remove(key)
|
|
||||||
}
|
|
||||||
|
|
||||||
tag.merge(container.toTag())
|
|
||||||
} else {
|
|
||||||
item.tag = null
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (container != null && !container.isEmpty) {
|
|
||||||
tag.put("PublicBukkitValues", container.toTag())
|
|
||||||
} else {
|
|
||||||
tag.remove("PublicBukkitValues")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun materialToItem(material: Material): Item =
|
|
||||||
BuiltInRegistries.ITEM.getOptional(material.key.toResourceLocation())
|
|
||||||
.orElseThrow { IllegalArgumentException("Material is not item!") }
|
|
||||||
|
|
||||||
override fun itemToMaterial(item: Item) =
|
|
||||||
Material.getMaterial(BuiltInRegistries.ITEM.getKey(item).path.uppercase())
|
|
||||||
?: throw IllegalArgumentException("Invalid material!")
|
|
||||||
|
|
||||||
override fun toNMS(player: Player): ServerPlayer {
|
|
||||||
return (player as CraftPlayer).handle
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun toNMS(component: Component): net.minecraft.network.chat.Component {
|
|
||||||
val json = JSONComponentSerializer.json().serialize(component)
|
|
||||||
return net.minecraft.network.chat.Component.Serializer.fromJson(json)!!
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,68 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.core.packet.Packet
|
|
||||||
import com.willfp.eco.core.packet.sendPacket
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.DisplayNameProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toNMS
|
|
||||||
import io.papermc.paper.adventure.PaperAdventure
|
|
||||||
import net.kyori.adventure.text.Component
|
|
||||||
import net.minecraft.network.protocol.game.ClientboundSetEntityDataPacket
|
|
||||||
import net.minecraft.network.syncher.EntityDataAccessor
|
|
||||||
import net.minecraft.network.syncher.SynchedEntityData
|
|
||||||
import net.minecraft.world.entity.Entity
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.entity.CraftLivingEntity
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.entity.CraftMob
|
|
||||||
import org.bukkit.entity.LivingEntity
|
|
||||||
import org.bukkit.entity.Mob
|
|
||||||
import org.bukkit.entity.Player
|
|
||||||
import java.util.Optional
|
|
||||||
|
|
||||||
@Suppress("UNCHECKED_CAST")
|
|
||||||
class DisplayName : DisplayNameProxy {
|
|
||||||
private val displayNameAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[2]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Optional<net.minecraft.network.chat.Component>>
|
|
||||||
|
|
||||||
private val customNameVisibleAccessor = Entity::class.java
|
|
||||||
.declaredFields
|
|
||||||
.filter { it.type == EntityDataAccessor::class.java }
|
|
||||||
.toList()[3]
|
|
||||||
.apply { isAccessible = true }
|
|
||||||
.get(null) as EntityDataAccessor<Boolean>
|
|
||||||
|
|
||||||
override fun setClientsideDisplayName(entity: LivingEntity, player: Player, displayName: Component, visible: Boolean) {
|
|
||||||
if (entity !is CraftLivingEntity) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
val nmsComponent = displayName.toNMS()
|
|
||||||
|
|
||||||
val nmsEntity = entity.handle
|
|
||||||
nmsEntity.isCustomNameVisible
|
|
||||||
val entityData = SynchedEntityData(nmsEntity)
|
|
||||||
|
|
||||||
entityData.forceSet(displayNameAccessor, Optional.of(nmsComponent))
|
|
||||||
entityData.forceSet(customNameVisibleAccessor, visible)
|
|
||||||
|
|
||||||
val packet = ClientboundSetEntityDataPacket(
|
|
||||||
nmsEntity.id,
|
|
||||||
entityData.packDirty() ?: throw IllegalStateException("No packed entity data")
|
|
||||||
)
|
|
||||||
|
|
||||||
player.sendPacket(Packet(packet))
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun <T: Any> SynchedEntityData.forceSet(
|
|
||||||
accessor: EntityDataAccessor<T>,
|
|
||||||
value: T
|
|
||||||
) {
|
|
||||||
if (!this.hasItem(accessor)) {
|
|
||||||
this.define(accessor, value)
|
|
||||||
}
|
|
||||||
this[accessor] = value
|
|
||||||
this.markDirty(accessor)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,16 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.internal.entities.EcoDummyEntity
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.DummyEntityFactoryProxy
|
|
||||||
import org.bukkit.Location
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.CraftWorld
|
|
||||||
import org.bukkit.entity.Entity
|
|
||||||
import org.bukkit.entity.EntityType
|
|
||||||
import org.bukkit.entity.Zombie
|
|
||||||
|
|
||||||
class DummyEntityFactory : DummyEntityFactoryProxy {
|
|
||||||
override fun createDummyEntity(location: Location): Entity {
|
|
||||||
val world = location.world as CraftWorld
|
|
||||||
return EcoDummyEntity(world.createEntity(location, Zombie::class.java))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,12 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.core.entities.ai.EntityController
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.EntityControllerFactoryProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.v1_20_R3.entity.EcoEntityController
|
|
||||||
import org.bukkit.entity.Mob
|
|
||||||
|
|
||||||
class EntityControllerFactory : EntityControllerFactoryProxy {
|
|
||||||
override fun <T : Mob> createEntityController(entity: T): EntityController<T> {
|
|
||||||
return EcoEntityController(entity)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,82 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.core.data.ExtendedPersistentDataContainer
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.ExtendedPersistentDataContainerFactoryProxy
|
|
||||||
import net.minecraft.nbt.Tag
|
|
||||||
import org.bukkit.Material
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.inventory.CraftItemStack
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.persistence.CraftPersistentDataContainer
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.persistence.CraftPersistentDataTypeRegistry
|
|
||||||
import org.bukkit.inventory.ItemStack
|
|
||||||
import org.bukkit.persistence.PersistentDataContainer
|
|
||||||
import org.bukkit.persistence.PersistentDataType
|
|
||||||
|
|
||||||
class ExtendedPersistentDataContainerFactory : ExtendedPersistentDataContainerFactoryProxy {
|
|
||||||
private val registry: CraftPersistentDataTypeRegistry
|
|
||||||
|
|
||||||
init {
|
|
||||||
/*
|
|
||||||
Can't grab actual instance since it's in CraftMetaItem (which is package-private)
|
|
||||||
And getting it would mean more janky reflection
|
|
||||||
*/
|
|
||||||
val item = CraftItemStack.asCraftCopy(ItemStack(Material.STONE))
|
|
||||||
val pdc = item.itemMeta!!.persistentDataContainer
|
|
||||||
this.registry = CraftPersistentDataContainer::class.java.getDeclaredField("registry")
|
|
||||||
.apply { isAccessible = true }.get(pdc) as CraftPersistentDataTypeRegistry
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun adapt(pdc: PersistentDataContainer): ExtendedPersistentDataContainer {
|
|
||||||
return when (pdc) {
|
|
||||||
is CraftPersistentDataContainer -> EcoPersistentDataContainer(pdc)
|
|
||||||
else -> throw IllegalArgumentException("Custom PDC instance ims not supported!")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun newPdc(): PersistentDataContainer {
|
|
||||||
return CraftPersistentDataContainer(registry)
|
|
||||||
}
|
|
||||||
|
|
||||||
inner class EcoPersistentDataContainer(
|
|
||||||
private val handle: CraftPersistentDataContainer
|
|
||||||
) : ExtendedPersistentDataContainer {
|
|
||||||
@Suppress("UNCHECKED_CAST")
|
|
||||||
private val customDataTags: MutableMap<String, Tag> =
|
|
||||||
CraftPersistentDataContainer::class.java.getDeclaredField("customDataTags")
|
|
||||||
.apply { isAccessible = true }.get(handle) as MutableMap<String, Tag>
|
|
||||||
|
|
||||||
override fun <T : Any, Z : Any> set(key: String, dataType: PersistentDataType<T, Z>, value: Z) {
|
|
||||||
customDataTags[key] =
|
|
||||||
registry.wrap(dataType, dataType.toPrimitive(value, handle.adapterContext))
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun <T : Any, Z : Any> has(key: String, dataType: PersistentDataType<T, Z>): Boolean {
|
|
||||||
val value = customDataTags[key] ?: return false
|
|
||||||
return registry.isInstanceOf(dataType, value)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun <T : Any, Z : Any> get(key: String, dataType: PersistentDataType<T, Z>): Z? {
|
|
||||||
val value = customDataTags[key] ?: return null
|
|
||||||
return dataType.fromPrimitive(registry.extract<T, Tag>(dataType, value), handle.adapterContext)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun <T : Any, Z : Any> getOrDefault(
|
|
||||||
key: String,
|
|
||||||
dataType: PersistentDataType<T, Z>,
|
|
||||||
defaultValue: Z
|
|
||||||
): Z {
|
|
||||||
return get(key, dataType) ?: defaultValue
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun remove(key: String) {
|
|
||||||
customDataTags.remove(key)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun getAllKeys(): MutableSet<String> {
|
|
||||||
return customDataTags.keys
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun getBase(): PersistentDataContainer {
|
|
||||||
return handle
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,12 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.core.fast.FastItemStack
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.FastItemStackFactoryProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.item.EcoFastItemStack
|
|
||||||
import org.bukkit.inventory.ItemStack
|
|
||||||
|
|
||||||
class FastItemStackFactory : FastItemStackFactoryProxy {
|
|
||||||
override fun create(itemStack: ItemStack): FastItemStack {
|
|
||||||
return EcoFastItemStack(itemStack)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,33 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.core.display.Display
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.MiniMessageTranslatorProxy
|
|
||||||
import com.willfp.eco.util.toLegacy
|
|
||||||
import net.kyori.adventure.text.minimessage.MiniMessage
|
|
||||||
|
|
||||||
class MiniMessageTranslator : MiniMessageTranslatorProxy {
|
|
||||||
override fun format(message: String): String {
|
|
||||||
var mut = message
|
|
||||||
|
|
||||||
val startsWithPrefix = mut.startsWith(Display.PREFIX)
|
|
||||||
if (startsWithPrefix) {
|
|
||||||
mut = mut.substring(2)
|
|
||||||
}
|
|
||||||
|
|
||||||
mut = mut.replace('§', '&')
|
|
||||||
|
|
||||||
val miniMessage = runCatching {
|
|
||||||
MiniMessage.miniMessage().deserialize(
|
|
||||||
mut
|
|
||||||
).toLegacy()
|
|
||||||
}.getOrNull() ?: mut
|
|
||||||
|
|
||||||
mut = if (startsWithPrefix) {
|
|
||||||
Display.PREFIX + miniMessage
|
|
||||||
} else {
|
|
||||||
miniMessage
|
|
||||||
}
|
|
||||||
|
|
||||||
return mut
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,46 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.core.EcoPlugin
|
|
||||||
import com.willfp.eco.core.packet.PacketListener
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.PacketHandlerProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.display.PacketAutoRecipe
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.display.PacketHeldItemSlot
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.display.PacketOpenWindowMerchant
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.display.PacketSetCreativeSlot
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.display.PacketSetSlot
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.display.PacketWindowItems
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.packet.display.frame.clearFrames
|
|
||||||
import net.minecraft.network.protocol.Packet
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.entity.CraftPlayer
|
|
||||||
import org.bukkit.entity.Player
|
|
||||||
|
|
||||||
class PacketHandler : PacketHandlerProxy {
|
|
||||||
override fun sendPacket(player: Player, packet: com.willfp.eco.core.packet.Packet) {
|
|
||||||
if (player !is CraftPlayer) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
val handle = packet.handle
|
|
||||||
|
|
||||||
if (handle !is Packet<*>) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
player.handle.connection.send(handle)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun clearDisplayFrames() {
|
|
||||||
clearFrames()
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun getPacketListeners(plugin: EcoPlugin): List<PacketListener> {
|
|
||||||
return listOf(
|
|
||||||
PacketAutoRecipe(plugin),
|
|
||||||
PacketHeldItemSlot,
|
|
||||||
PacketOpenWindowMerchant,
|
|
||||||
PacketSetCreativeSlot,
|
|
||||||
PacketSetSlot,
|
|
||||||
PacketWindowItems(plugin)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,52 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.core.items.TestableItem
|
|
||||||
import com.willfp.eco.core.recipe.parts.EmptyTestableItem
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.SNBTConverterProxy
|
|
||||||
import net.minecraft.nbt.CompoundTag
|
|
||||||
import net.minecraft.nbt.SnbtPrinterTagVisitor
|
|
||||||
import net.minecraft.nbt.TagParser
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.inventory.CraftItemStack
|
|
||||||
import org.bukkit.inventory.ItemStack
|
|
||||||
|
|
||||||
class SNBTConverter : SNBTConverterProxy {
|
|
||||||
override fun fromSNBT(snbt: String): ItemStack? {
|
|
||||||
val nbt = runCatching { TagParser.parseTag(snbt) }.getOrNull() ?: return null
|
|
||||||
val nms = net.minecraft.world.item.ItemStack.of(nbt)
|
|
||||||
return CraftItemStack.asBukkitCopy(nms)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun toSNBT(itemStack: ItemStack): String {
|
|
||||||
val nms = CraftItemStack.asNMSCopy(itemStack)
|
|
||||||
return SnbtPrinterTagVisitor().visit(nms.save(CompoundTag()))
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun makeSNBTTestable(snbt: String): TestableItem {
|
|
||||||
val nbt = runCatching { TagParser.parseTag(snbt) }.getOrNull() ?: return EmptyTestableItem()
|
|
||||||
val nms = net.minecraft.world.item.ItemStack.of(nbt)
|
|
||||||
if (nms == net.minecraft.world.item.ItemStack.EMPTY) {
|
|
||||||
return EmptyTestableItem()
|
|
||||||
}
|
|
||||||
|
|
||||||
nbt.remove("Count")
|
|
||||||
return SNBTTestableItem(CraftItemStack.asBukkitCopy(nms), nbt)
|
|
||||||
}
|
|
||||||
|
|
||||||
class SNBTTestableItem(
|
|
||||||
private val item: ItemStack,
|
|
||||||
private val tag: CompoundTag
|
|
||||||
) : TestableItem {
|
|
||||||
override fun matches(itemStack: ItemStack?): Boolean {
|
|
||||||
if (itemStack == null) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
val nms = CraftItemStack.asNMSCopy(itemStack)
|
|
||||||
val nmsTag = nms.save(CompoundTag())
|
|
||||||
nmsTag.remove("Count")
|
|
||||||
return tag.copy().merge(nmsTag) == nmsTag && itemStack.type == item.type
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun getItem(): ItemStack = item
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,18 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.SkullProxy
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.texture
|
|
||||||
import org.bukkit.inventory.meta.SkullMeta
|
|
||||||
|
|
||||||
class Skull : SkullProxy {
|
|
||||||
override fun setSkullTexture(
|
|
||||||
meta: SkullMeta,
|
|
||||||
base64: String
|
|
||||||
) {
|
|
||||||
meta.texture = base64
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun getSkullTexture(
|
|
||||||
meta: SkullMeta
|
|
||||||
): String? = meta.texture
|
|
||||||
}
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3
|
|
||||||
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.TPSProxy
|
|
||||||
import org.bukkit.Bukkit
|
|
||||||
import org.bukkit.craftbukkit.v1_20_R3.CraftServer
|
|
||||||
|
|
||||||
class TPS : TPSProxy {
|
|
||||||
override fun getTPS(): Double {
|
|
||||||
return (Bukkit.getServer() as CraftServer).handle.server.recentTps[0]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,95 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.proxy.v1_20_R3.entity
|
|
||||||
|
|
||||||
import com.willfp.eco.core.entities.ai.CustomGoal
|
|
||||||
import com.willfp.eco.core.entities.ai.EntityController
|
|
||||||
import com.willfp.eco.core.entities.ai.EntityGoal
|
|
||||||
import com.willfp.eco.core.entities.ai.TargetGoal
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.ai.CustomGoalFactory
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.ai.getGoalFactory
|
|
||||||
import com.willfp.eco.internal.spigot.proxy.common.toPathfinderMob
|
|
||||||
import net.minecraft.world.entity.PathfinderMob
|
|
||||||
import net.minecraft.world.entity.ai.goal.Goal
|
|
||||||
import org.bukkit.entity.Mob
|
|
||||||
|
|
||||||
class EcoEntityController<T : Mob>(
|
|
||||||
private val handle: T
|
|
||||||
) : EntityController<T> {
|
|
||||||
override fun addEntityGoal(priority: Int, goal: EntityGoal<in T>): EntityController<T> {
|
|
||||||
val nms = getNms() ?: return this
|
|
||||||
|
|
||||||
nms.goalSelector.addGoal(
|
|
||||||
priority,
|
|
||||||
goal.getGoalFactory()?.create(goal, nms) ?: return this
|
|
||||||
)
|
|
||||||
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun removeEntityGoal(goal: EntityGoal<in T>): EntityController<T> {
|
|
||||||
val nms = getNms() ?: return this
|
|
||||||
|
|
||||||
val predicate: (Goal) -> Boolean = if (goal is CustomGoal<*>) {
|
|
||||||
{ CustomGoalFactory.isGoalOfType(it, goal) }
|
|
||||||
} else {
|
|
||||||
{ goal.getGoalFactory()?.isGoalOfType(it) == true }
|
|
||||||
}
|
|
||||||
|
|
||||||
for (wrapped in nms.goalSelector.availableGoals.toSet()) {
|
|
||||||
if (predicate(wrapped.goal)) {
|
|
||||||
nms.goalSelector.removeGoal(wrapped.goal)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun clearEntityGoals(): EntityController<T> {
|
|
||||||
val nms = getNms() ?: return this
|
|
||||||
nms.goalSelector.availableGoals.clear()
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun addTargetGoal(priority: Int, goal: TargetGoal<in T>): EntityController<T> {
|
|
||||||
val nms = getNms() ?: return this
|
|
||||||
|
|
||||||
nms.targetSelector.addGoal(
|
|
||||||
priority, goal.getGoalFactory()?.create(goal, nms) ?: return this
|
|
||||||
)
|
|
||||||
|
|
||||||
nms.targetSelector
|
|
||||||
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun removeTargetGoal(goal: TargetGoal<in T>): EntityController<T> {
|
|
||||||
val nms = getNms() ?: return this
|
|
||||||
|
|
||||||
val predicate: (Goal) -> Boolean = if (goal is CustomGoal<*>) {
|
|
||||||
{ CustomGoalFactory.isGoalOfType(it, goal) }
|
|
||||||
} else {
|
|
||||||
{ goal.getGoalFactory()?.isGoalOfType(it) == true }
|
|
||||||
}
|
|
||||||
|
|
||||||
for (wrapped in nms.targetSelector.availableGoals.toSet()) {
|
|
||||||
if (predicate(wrapped.goal)) {
|
|
||||||
nms.targetSelector.removeGoal(wrapped.goal)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun clearTargetGoals(): EntityController<T> {
|
|
||||||
val nms = getNms() ?: return this
|
|
||||||
nms.targetSelector.availableGoals.clear()
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun getNms(): PathfinderMob? {
|
|
||||||
return handle.toPathfinderMob()
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun getEntity(): T {
|
|
||||||
return handle
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -16,9 +16,8 @@ dependencies {
|
|||||||
implementation("com.zaxxer:HikariCP:5.0.0")
|
implementation("com.zaxxer:HikariCP:5.0.0")
|
||||||
implementation("net.kyori:adventure-platform-bukkit:4.1.0")
|
implementation("net.kyori:adventure-platform-bukkit:4.1.0")
|
||||||
implementation("org.javassist:javassist:3.29.2-GA")
|
implementation("org.javassist:javassist:3.29.2-GA")
|
||||||
implementation("org.mongodb:mongodb-driver-kotlin-coroutine:5.0.0")
|
implementation("org.mongodb:mongodb-driver-sync:4.6.0")
|
||||||
implementation("org.jetbrains.kotlinx:kotlinx-serialization-core:1.5.1")
|
implementation("org.litote.kmongo:kmongo-coroutine:4.10.0")
|
||||||
implementation("org.mongodb:bson-kotlinx:5.0.0")
|
|
||||||
implementation("com.moandjiezana.toml:toml4j:0.7.2") {
|
implementation("com.moandjiezana.toml:toml4j:0.7.2") {
|
||||||
exclude(group = "com.google.code.gson", module = "gson")
|
exclude(group = "com.google.code.gson", module = "gson")
|
||||||
}
|
}
|
||||||
@@ -26,7 +25,7 @@ dependencies {
|
|||||||
|
|
||||||
// Included in spigot jar
|
// Included in spigot jar
|
||||||
compileOnly("com.google.code.gson:gson:2.8.8")
|
compileOnly("com.google.code.gson:gson:2.8.8")
|
||||||
compileOnly("io.papermc.paper:paper-api:1.20.2-R0.1-SNAPSHOT")
|
compileOnly("io.papermc.paper:paper-api:1.19.3-R0.1-SNAPSHOT")
|
||||||
|
|
||||||
// Plugin dependencies
|
// Plugin dependencies
|
||||||
compileOnly("com.comphenix.protocol:ProtocolLib:5.0.0-SNAPSHOT")
|
compileOnly("com.comphenix.protocol:ProtocolLib:5.0.0-SNAPSHOT")
|
||||||
@@ -41,15 +40,17 @@ dependencies {
|
|||||||
compileOnly("com.github.jiangdashao:matrix-api-repo:317d4635fd")
|
compileOnly("com.github.jiangdashao:matrix-api-repo:317d4635fd")
|
||||||
compileOnly("com.gmail.nossr50.mcMMO:mcMMO:2.1.202")
|
compileOnly("com.gmail.nossr50.mcMMO:mcMMO:2.1.202")
|
||||||
compileOnly("me.clip:placeholderapi:2.11.4")
|
compileOnly("me.clip:placeholderapi:2.11.4")
|
||||||
|
compileOnly("com.github.oraxen:oraxen:1.155.0")
|
||||||
compileOnly("com.github.brcdev-minecraft:shopgui-api:3.0.0")
|
compileOnly("com.github.brcdev-minecraft:shopgui-api:3.0.0")
|
||||||
compileOnly("com.github.LoneDev6:API-ItemsAdder:2.4.7")
|
compileOnly("com.github.LoneDev6:API-ItemsAdder:2.4.7")
|
||||||
compileOnly("com.arcaniax:HeadDatabase-API:1.3.1")
|
compileOnly("com.arcaniax:HeadDatabase-API:1.3.1")
|
||||||
compileOnly("com.gmail.filoghost.holographicdisplays:holographicdisplays-api:2.4.0")
|
compileOnly("com.gmail.filoghost.holographicdisplays:holographicdisplays-api:2.4.0")
|
||||||
compileOnly("com.github.EssentialsX:Essentials:2.18.2")
|
compileOnly("com.github.EssentialsX:Essentials:2.20.0")
|
||||||
compileOnly("com.bgsoftware:SuperiorSkyblockAPI:1.8.3")
|
compileOnly("com.bgsoftware:SuperiorSkyblockAPI:1.8.3")
|
||||||
compileOnly("com.github.MilkBowl:VaultAPI:1.7")
|
compileOnly("com.github.MilkBowl:VaultAPI:1.7")
|
||||||
compileOnly("com.github.WhipDevelopment:CrashClaim:f9cd7d92eb")
|
compileOnly("com.github.WhipDevelopment:CrashClaim:f9cd7d92eb")
|
||||||
compileOnly("com.github.decentsoftware-eu:decentholograms:2.8.5")
|
compileOnly("com.wolfyscript.wolfyutilities:wolfyutilities:3.16.0.0")
|
||||||
|
compileOnly("com.github.decentsoftware-eu:decentholograms:2.1.2")
|
||||||
compileOnly("com.github.Gypopo:EconomyShopGUI-API:1.4.6")
|
compileOnly("com.github.Gypopo:EconomyShopGUI-API:1.4.6")
|
||||||
compileOnly("com.github.N0RSKA:ScytherAPI:55a")
|
compileOnly("com.github.N0RSKA:ScytherAPI:55a")
|
||||||
compileOnly("org.black_ixx:playerpoints:3.2.5")
|
compileOnly("org.black_ixx:playerpoints:3.2.5")
|
||||||
@@ -62,10 +63,6 @@ dependencies {
|
|||||||
compileOnly("com.denizenscript:denizen:1.2.7-SNAPSHOT") {
|
compileOnly("com.denizenscript:denizen:1.2.7-SNAPSHOT") {
|
||||||
exclude(group = "*", module = "*")
|
exclude(group = "*", module = "*")
|
||||||
}
|
}
|
||||||
compileOnly("com.iridium:IridiumSkyblock:4.0.8")
|
|
||||||
compileOnly("net.william278.huskclaims:huskclaims-bukkit:1.0.1")
|
|
||||||
compileOnly("net.william278:husktowns:2.6.1")
|
|
||||||
compileOnly("com.github.jojodmo:ItemBridge:b0054538c1")
|
|
||||||
|
|
||||||
compileOnly(fileTree("../../lib") {
|
compileOnly(fileTree("../../lib") {
|
||||||
include("*.jar")
|
include("*.jar")
|
||||||
|
|||||||
@@ -352,5 +352,7 @@ class EcoImpl : EcoSpigotPlugin(), Eco {
|
|||||||
placeholderParser.getPlaceholderResult(plugin, args, context)
|
placeholderParser.getPlaceholderResult(plugin, args, context)
|
||||||
|
|
||||||
override fun setClientsideDisplayName(entity: LivingEntity, player: Player, name: Component, visible: Boolean) =
|
override fun setClientsideDisplayName(entity: LivingEntity, player: Player, name: Component, visible: Boolean) =
|
||||||
this.getProxy(DisplayNameProxy::class.java).setClientsideDisplayName(entity, player, name, visible)
|
if (Prerequisite.HAS_PAPER.isMet && Prerequisite.HAS_1_20.isMet)
|
||||||
|
this.getProxy(DisplayNameProxy::class.java).setClientsideDisplayName(entity, player, name, visible)
|
||||||
|
else Unit
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -22,8 +22,34 @@ import com.willfp.eco.core.particle.Particles
|
|||||||
import com.willfp.eco.core.price.Prices
|
import com.willfp.eco.core.price.Prices
|
||||||
import com.willfp.eco.internal.data.MavenVersionToStringAdapter
|
import com.willfp.eco.internal.data.MavenVersionToStringAdapter
|
||||||
import com.willfp.eco.internal.data.VersionToStringAdapter
|
import com.willfp.eco.internal.data.VersionToStringAdapter
|
||||||
import com.willfp.eco.internal.entities.*
|
import com.willfp.eco.internal.entities.EntityArgParserAdult
|
||||||
import com.willfp.eco.internal.items.*
|
import com.willfp.eco.internal.entities.EntityArgParserAttackDamage
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserAttackSpeed
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserBaby
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserCharged
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserEquipment
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserExplosionRadius
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserFlySpeed
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserFollowRange
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserHealth
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserJumpStrength
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserKnockback
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserKnockbackResistance
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserName
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserNoAI
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserSilent
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserSize
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserSpawnReinforcements
|
||||||
|
import com.willfp.eco.internal.entities.EntityArgParserSpeed
|
||||||
|
import com.willfp.eco.internal.items.ArgParserColor
|
||||||
|
import com.willfp.eco.internal.items.ArgParserCustomModelData
|
||||||
|
import com.willfp.eco.internal.items.ArgParserEnchantment
|
||||||
|
import com.willfp.eco.internal.items.ArgParserFlag
|
||||||
|
import com.willfp.eco.internal.items.ArgParserHead
|
||||||
|
import com.willfp.eco.internal.items.ArgParserName
|
||||||
|
import com.willfp.eco.internal.items.ArgParserTexture
|
||||||
|
import com.willfp.eco.internal.items.ArgParserTrim
|
||||||
|
import com.willfp.eco.internal.items.ArgParserUnbreakable
|
||||||
import com.willfp.eco.internal.lookup.SegmentParserGroup
|
import com.willfp.eco.internal.lookup.SegmentParserGroup
|
||||||
import com.willfp.eco.internal.lookup.SegmentParserUseIfPresent
|
import com.willfp.eco.internal.lookup.SegmentParserUseIfPresent
|
||||||
import com.willfp.eco.internal.particle.ParticleFactoryRGB
|
import com.willfp.eco.internal.particle.ParticleFactoryRGB
|
||||||
@@ -43,10 +69,37 @@ import com.willfp.eco.internal.spigot.eventlisteners.armor.ArmorListener
|
|||||||
import com.willfp.eco.internal.spigot.gui.GUIListener
|
import com.willfp.eco.internal.spigot.gui.GUIListener
|
||||||
import com.willfp.eco.internal.spigot.integrations.afk.AFKIntegrationCMI
|
import com.willfp.eco.internal.spigot.integrations.afk.AFKIntegrationCMI
|
||||||
import com.willfp.eco.internal.spigot.integrations.afk.AFKIntegrationEssentials
|
import com.willfp.eco.internal.spigot.integrations.afk.AFKIntegrationEssentials
|
||||||
import com.willfp.eco.internal.spigot.integrations.anticheat.*
|
import com.willfp.eco.internal.spigot.integrations.anticheat.AnticheatAAC
|
||||||
import com.willfp.eco.internal.spigot.integrations.antigrief.*
|
import com.willfp.eco.internal.spigot.integrations.anticheat.AnticheatAlice
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.anticheat.AnticheatMatrix
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.anticheat.AnticheatNCP
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.anticheat.AnticheatSpartan
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.anticheat.AnticheatVulcan
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefBentoBox
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefCombatLogXV10
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefCombatLogXV11
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefCrashClaim
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefDeluxeCombat
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefFabledSkyBlock
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefFactionsUUID
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefGriefPrevention
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefIridiumSkyblock
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefKingdoms
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefLands
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefPvPManager
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefRPGHorses
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefSuperiorSkyblock2
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefTowny
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.antigrief.AntigriefWorldGuard
|
||||||
import com.willfp.eco.internal.spigot.integrations.customentities.CustomEntitiesMythicMobs
|
import com.willfp.eco.internal.spigot.integrations.customentities.CustomEntitiesMythicMobs
|
||||||
import com.willfp.eco.internal.spigot.integrations.customitems.*
|
import com.willfp.eco.internal.spigot.integrations.customitems.CustomItemsCustomCrafting
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.customitems.CustomItemsDenizen
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.customitems.CustomItemsExecutableItems
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.customitems.CustomItemsHeadDatabase
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.customitems.CustomItemsItemsAdder
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.customitems.CustomItemsMythicMobs
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.customitems.CustomItemsOraxen
|
||||||
|
import com.willfp.eco.internal.spigot.integrations.customitems.CustomItemsScyther
|
||||||
import com.willfp.eco.internal.spigot.integrations.customrecipes.CustomRecipeCustomCrafting
|
import com.willfp.eco.internal.spigot.integrations.customrecipes.CustomRecipeCustomCrafting
|
||||||
import com.willfp.eco.internal.spigot.integrations.economy.EconomyVault
|
import com.willfp.eco.internal.spigot.integrations.economy.EconomyVault
|
||||||
import com.willfp.eco.internal.spigot.integrations.entitylookup.EntityLookupModelEngine
|
import com.willfp.eco.internal.spigot.integrations.entitylookup.EntityLookupModelEngine
|
||||||
@@ -96,7 +149,6 @@ abstract class EcoSpigotPlugin : EcoPlugin() {
|
|||||||
Items.registerArgParser(ArgParserUnbreakable)
|
Items.registerArgParser(ArgParserUnbreakable)
|
||||||
Items.registerArgParser(ArgParserName)
|
Items.registerArgParser(ArgParserName)
|
||||||
Items.registerArgParser(ArgParserHead)
|
Items.registerArgParser(ArgParserHead)
|
||||||
Items.registerArgParser(ArgParserEntity)
|
|
||||||
if (Prerequisite.HAS_1_20.isMet) {
|
if (Prerequisite.HAS_1_20.isMet) {
|
||||||
Items.registerArgParser(ArgParserTrim)
|
Items.registerArgParser(ArgParserTrim)
|
||||||
}
|
}
|
||||||
@@ -209,8 +261,6 @@ abstract class EcoSpigotPlugin : EcoPlugin() {
|
|||||||
profileHandler.migrateIfNeeded()
|
profileHandler.migrateIfNeeded()
|
||||||
}
|
}
|
||||||
|
|
||||||
profileHandler.startAutosaving()
|
|
||||||
|
|
||||||
ProfileSaver(this, profileHandler).startTicking()
|
ProfileSaver(this, profileHandler).startTicking()
|
||||||
|
|
||||||
this.scheduler.runTimer(
|
this.scheduler.runTimer(
|
||||||
@@ -244,8 +294,6 @@ abstract class EcoSpigotPlugin : EcoPlugin() {
|
|||||||
IntegrationLoader("Kingdoms") { AntigriefManager.register(AntigriefKingdoms()) },
|
IntegrationLoader("Kingdoms") { AntigriefManager.register(AntigriefKingdoms()) },
|
||||||
IntegrationLoader("RPGHorses") { AntigriefManager.register(AntigriefRPGHorses()) },
|
IntegrationLoader("RPGHorses") { AntigriefManager.register(AntigriefRPGHorses()) },
|
||||||
IntegrationLoader("CrashClaim") { AntigriefManager.register(AntigriefCrashClaim()) },
|
IntegrationLoader("CrashClaim") { AntigriefManager.register(AntigriefCrashClaim()) },
|
||||||
IntegrationLoader("HuskTowns") { AntigriefManager.register(AntigriefHuskTowns()) },
|
|
||||||
IntegrationLoader("HuskClaims") { AntigriefManager.register(AntigriefHuskClaims()) },
|
|
||||||
IntegrationLoader("CombatLogX") {
|
IntegrationLoader("CombatLogX") {
|
||||||
val pluginManager = Bukkit.getPluginManager()
|
val pluginManager = Bukkit.getPluginManager()
|
||||||
val combatLogXPlugin = pluginManager.getPlugin("CombatLogX") ?: return@IntegrationLoader
|
val combatLogXPlugin = pluginManager.getPlugin("CombatLogX") ?: return@IntegrationLoader
|
||||||
@@ -285,7 +333,6 @@ abstract class EcoSpigotPlugin : EcoPlugin() {
|
|||||||
IntegrationLoader("MythicMobs") { CustomItemsManager.register(CustomItemsMythicMobs(this)) },
|
IntegrationLoader("MythicMobs") { CustomItemsManager.register(CustomItemsMythicMobs(this)) },
|
||||||
IntegrationLoader("Scyther") { CustomItemsManager.register(CustomItemsScyther()) },
|
IntegrationLoader("Scyther") { CustomItemsManager.register(CustomItemsScyther()) },
|
||||||
IntegrationLoader("Denizen") { CustomItemsManager.register(CustomItemsDenizen()) },
|
IntegrationLoader("Denizen") { CustomItemsManager.register(CustomItemsDenizen()) },
|
||||||
IntegrationLoader("ItemBridge") { CustomItemsManager.register(CustomItemsItemBridge()) },
|
|
||||||
|
|
||||||
// Shop
|
// Shop
|
||||||
IntegrationLoader("ShopGUIPlus") { ShopManager.register(ShopShopGuiPlus()) },
|
IntegrationLoader("ShopGUIPlus") { ShopManager.register(ShopShopGuiPlus()) },
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
package com.willfp.eco.internal.spigot.arrows
|
package com.willfp.eco.internal.spigot.arrows
|
||||||
|
|
||||||
import com.willfp.eco.core.EcoPlugin
|
import com.willfp.eco.core.EcoPlugin
|
||||||
import com.willfp.eco.core.items.isEcoEmpty
|
import com.willfp.eco.core.items.isEmpty
|
||||||
import org.bukkit.entity.Arrow
|
import org.bukkit.entity.Arrow
|
||||||
import org.bukkit.entity.LivingEntity
|
import org.bukkit.entity.LivingEntity
|
||||||
import org.bukkit.event.EventHandler
|
import org.bukkit.event.EventHandler
|
||||||
@@ -29,7 +29,7 @@ class ArrowDataListener(
|
|||||||
|
|
||||||
val item = entity.equipment?.itemInMainHand
|
val item = entity.equipment?.itemInMainHand
|
||||||
|
|
||||||
if (item.isEcoEmpty || item == null) {
|
if (item.isEmpty || item == null) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -169,17 +169,4 @@ class ProfileHandler(
|
|||||||
localHandler.initialize()
|
localHandler.initialize()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fun startAutosaving() {
|
|
||||||
if (!plugin.configYml.getBool("yaml.autosave")) {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
val interval = plugin.configYml.getInt("yaml.autosave-interval") * 20L
|
|
||||||
|
|
||||||
plugin.scheduler.runTimer(20, interval) {
|
|
||||||
handler.saveAsync()
|
|
||||||
localHandler.saveAsync()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -27,10 +27,6 @@ abstract class DataHandler(
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
open fun saveAsync() {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
open fun initialize() {
|
open fun initialize() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,11 +1,5 @@
|
|||||||
package com.willfp.eco.internal.spigot.data.storage
|
package com.willfp.eco.internal.spigot.data.storage
|
||||||
|
|
||||||
import com.mongodb.client.model.Filters
|
|
||||||
import com.mongodb.client.model.ReplaceOptions
|
|
||||||
import com.mongodb.client.model.UpdateOptions
|
|
||||||
import com.mongodb.client.model.Updates
|
|
||||||
import com.mongodb.kotlin.client.coroutine.MongoClient
|
|
||||||
import com.mongodb.kotlin.client.coroutine.MongoCollection
|
|
||||||
import com.willfp.eco.core.data.keys.PersistentDataKey
|
import com.willfp.eco.core.data.keys.PersistentDataKey
|
||||||
import com.willfp.eco.internal.spigot.EcoSpigotPlugin
|
import com.willfp.eco.internal.spigot.EcoSpigotPlugin
|
||||||
import com.willfp.eco.internal.spigot.data.ProfileHandler
|
import com.willfp.eco.internal.spigot.data.ProfileHandler
|
||||||
@@ -14,20 +8,21 @@ import kotlinx.coroutines.Dispatchers
|
|||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
import kotlinx.coroutines.runBlocking
|
import kotlinx.coroutines.runBlocking
|
||||||
import org.bson.codecs.pojo.annotations.BsonId
|
import org.bson.codecs.pojo.annotations.BsonId
|
||||||
|
import org.litote.kmongo.coroutine.CoroutineClient
|
||||||
|
import org.litote.kmongo.coroutine.CoroutineCollection
|
||||||
|
import org.litote.kmongo.coroutine.coroutine
|
||||||
|
import org.litote.kmongo.eq
|
||||||
|
import org.litote.kmongo.reactivestreams.KMongo
|
||||||
|
import org.litote.kmongo.setValue
|
||||||
import java.util.UUID
|
import java.util.UUID
|
||||||
import kotlinx.coroutines.flow.firstOrNull
|
|
||||||
import kotlinx.serialization.Contextual
|
|
||||||
import kotlinx.serialization.SerialName
|
|
||||||
import kotlinx.serialization.Serializable
|
|
||||||
import org.bukkit.Bukkit
|
|
||||||
|
|
||||||
@Suppress("UNCHECKED_CAST")
|
@Suppress("UNCHECKED_CAST")
|
||||||
class MongoDataHandler(
|
class MongoDataHandler(
|
||||||
plugin: EcoSpigotPlugin,
|
plugin: EcoSpigotPlugin,
|
||||||
private val handler: ProfileHandler
|
private val handler: ProfileHandler
|
||||||
) : DataHandler(HandlerType.MONGO) {
|
) : DataHandler(HandlerType.MONGO) {
|
||||||
private val client: MongoClient
|
private val client: CoroutineClient
|
||||||
private val collection: MongoCollection<UUIDProfile>
|
private val collection: CoroutineCollection<UUIDProfile>
|
||||||
|
|
||||||
private val scope = CoroutineScope(Dispatchers.IO)
|
private val scope = CoroutineScope(Dispatchers.IO)
|
||||||
|
|
||||||
@@ -39,9 +34,8 @@ class MongoDataHandler(
|
|||||||
|
|
||||||
val url = plugin.configYml.getString("mongodb.url")
|
val url = plugin.configYml.getString("mongodb.url")
|
||||||
|
|
||||||
client = MongoClient.create(url)
|
client = KMongo.createClient(url).coroutine
|
||||||
collection = client.getDatabase(plugin.configYml.getString("mongodb.database"))
|
collection = client.getDatabase("eco").getCollection()
|
||||||
.getCollection<UUIDProfile>("uuidprofile") // Compat with jackson mapping
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun <T : Any> read(uuid: UUID, key: PersistentDataKey<T>): T? {
|
override fun <T : Any> read(uuid: UUID, key: PersistentDataKey<T>): T? {
|
||||||
@@ -72,7 +66,7 @@ class MongoDataHandler(
|
|||||||
private suspend fun <T> doWrite(uuid: UUID, key: PersistentDataKey<T>, value: T) {
|
private suspend fun <T> doWrite(uuid: UUID, key: PersistentDataKey<T>, value: T) {
|
||||||
val profile = getOrCreateDocument(uuid)
|
val profile = getOrCreateDocument(uuid)
|
||||||
|
|
||||||
profile.data.run {
|
val newData = profile.data.apply {
|
||||||
if (value == null) {
|
if (value == null) {
|
||||||
this.remove(key.key.toString())
|
this.remove(key.key.toString())
|
||||||
} else {
|
} else {
|
||||||
@@ -80,33 +74,25 @@ class MongoDataHandler(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
collection.updateOne(
|
collection.updateOne(UUIDProfile::uuid eq uuid.toString(), setValue(UUIDProfile::data, newData))
|
||||||
Filters.eq(UUIDProfile::uuid.name, uuid.toString()),
|
|
||||||
Updates.set(UUIDProfile::data.name, profile.data)
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private suspend fun <T> doRead(uuid: UUID, key: PersistentDataKey<T>): T? {
|
private suspend fun <T> doRead(uuid: UUID, key: PersistentDataKey<T>): T? {
|
||||||
val profile = collection.find<UUIDProfile>(Filters.eq(UUIDProfile::uuid.name, uuid.toString()))
|
val profile = collection.findOne(UUIDProfile::uuid eq uuid.toString()) ?: return key.defaultValue
|
||||||
.firstOrNull() ?: return key.defaultValue
|
|
||||||
return profile.data[key.key.toString()] as? T?
|
return profile.data[key.key.toString()] as? T?
|
||||||
}
|
}
|
||||||
|
|
||||||
private suspend fun getOrCreateDocument(uuid: UUID): UUIDProfile {
|
private suspend fun getOrCreateDocument(uuid: UUID): UUIDProfile {
|
||||||
val profile = collection.find<UUIDProfile>(Filters.eq(UUIDProfile::uuid.name, uuid.toString()))
|
val profile = collection.findOne(UUIDProfile::uuid eq uuid.toString())
|
||||||
.firstOrNull()
|
|
||||||
return if (profile == null) {
|
return if (profile == null) {
|
||||||
val toInsert = UUIDProfile(
|
collection.insertOne(
|
||||||
uuid.toString(),
|
UUIDProfile(
|
||||||
mutableMapOf()
|
uuid.toString(),
|
||||||
|
mutableMapOf()
|
||||||
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
collection.replaceOne(
|
getOrCreateDocument(uuid)
|
||||||
Filters.eq(UUIDProfile::uuid.name, uuid.toString()),
|
|
||||||
toInsert,
|
|
||||||
ReplaceOptions().upsert(true)
|
|
||||||
)
|
|
||||||
toInsert
|
|
||||||
} else {
|
} else {
|
||||||
profile
|
profile
|
||||||
}
|
}
|
||||||
@@ -125,10 +111,10 @@ class MongoDataHandler(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Serializable
|
private data class UUIDProfile(
|
||||||
internal data class UUIDProfile(
|
|
||||||
// Storing UUID as strings for serialization
|
// Storing UUID as strings for serialization
|
||||||
@SerialName("_id") val uuid: String,
|
@BsonId
|
||||||
|
val uuid: String,
|
||||||
// Storing NamespacedKeys as strings for serialization
|
// Storing NamespacedKeys as strings for serialization
|
||||||
val data: MutableMap<String, @Contextual Any>
|
val data: MutableMap<String, Any>
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -18,10 +18,6 @@ class YamlDataHandler(
|
|||||||
dataYml.save()
|
dataYml.save()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun saveAsync() {
|
|
||||||
dataYml.saveAsync()
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun <T : Any> read(uuid: UUID, key: PersistentDataKey<T>): T? {
|
override fun <T : Any> read(uuid: UUID, key: PersistentDataKey<T>): T? {
|
||||||
// Separate `as T?` for each branch to prevent compiler warnings.
|
// Separate `as T?` for each branch to prevent compiler warnings.
|
||||||
val value = when (key.type) {
|
val value = when (key.type) {
|
||||||
|
|||||||
@@ -1,135 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.integrations.antigrief
|
|
||||||
|
|
||||||
import com.willfp.eco.core.integrations.antigrief.AntigriefIntegration
|
|
||||||
import net.crashcraft.crashclaim.CrashClaim
|
|
||||||
import net.crashcraft.crashclaim.permissions.PermissionRoute
|
|
||||||
import net.william278.huskclaims.api.HuskClaimsAPI
|
|
||||||
import net.william278.huskclaims.libraries.cloplib.operation.Operation
|
|
||||||
import net.william278.huskclaims.libraries.cloplib.operation.OperationPosition
|
|
||||||
import net.william278.huskclaims.libraries.cloplib.operation.OperationType
|
|
||||||
import net.william278.huskclaims.position.Position
|
|
||||||
import net.william278.huskclaims.position.World
|
|
||||||
import org.bukkit.Location
|
|
||||||
import org.bukkit.block.Block
|
|
||||||
import org.bukkit.entity.LivingEntity
|
|
||||||
import org.bukkit.entity.Monster
|
|
||||||
import org.bukkit.entity.Player
|
|
||||||
import kotlin.jvm.optionals.getOrElse
|
|
||||||
|
|
||||||
class AntigriefHuskClaims : AntigriefIntegration {
|
|
||||||
override fun canBreakBlock(
|
|
||||||
player: Player,
|
|
||||||
block: Block
|
|
||||||
): Boolean {
|
|
||||||
val api = HuskClaimsAPI.getInstance() ?: return true
|
|
||||||
|
|
||||||
val user = api.getOnlineUser(player.uniqueId) ?: return true
|
|
||||||
|
|
||||||
return api.isOperationAllowed(
|
|
||||||
Operation.of(
|
|
||||||
user,
|
|
||||||
OperationType.BLOCK_BREAK,
|
|
||||||
Position.at(
|
|
||||||
block.x.toDouble(),
|
|
||||||
block.y.toDouble(),
|
|
||||||
block.z.toDouble(),
|
|
||||||
api.getWorld(block.location.world.name)
|
|
||||||
),
|
|
||||||
true
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun canCreateExplosion(
|
|
||||||
player: Player,
|
|
||||||
location: Location
|
|
||||||
): Boolean {
|
|
||||||
val api = HuskClaimsAPI.getInstance() ?: return true
|
|
||||||
|
|
||||||
val user = api.getOnlineUser(player.uniqueId) ?: return true
|
|
||||||
|
|
||||||
return api.isOperationAllowed(
|
|
||||||
Operation.of(
|
|
||||||
user,
|
|
||||||
OperationType.EXPLOSION_DAMAGE_ENTITY,
|
|
||||||
Position.at(
|
|
||||||
location.x,
|
|
||||||
location.y,
|
|
||||||
location.z,
|
|
||||||
api.getWorld(location.world.name)
|
|
||||||
),
|
|
||||||
true
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun canPlaceBlock(
|
|
||||||
player: Player,
|
|
||||||
block: Block
|
|
||||||
): Boolean {
|
|
||||||
val api = HuskClaimsAPI.getInstance() ?: return true
|
|
||||||
|
|
||||||
val user = api.getOnlineUser(player.uniqueId) ?: return true
|
|
||||||
|
|
||||||
return api.isOperationAllowed(
|
|
||||||
Operation.of(
|
|
||||||
user,
|
|
||||||
OperationType.BLOCK_PLACE,
|
|
||||||
Position.at(
|
|
||||||
block.x.toDouble(),
|
|
||||||
block.y.toDouble(),
|
|
||||||
block.z.toDouble(),
|
|
||||||
api.getWorld(block.location.world.name)
|
|
||||||
),
|
|
||||||
true
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun canInjure(
|
|
||||||
player: Player,
|
|
||||||
victim: LivingEntity
|
|
||||||
): Boolean {
|
|
||||||
val api = HuskClaimsAPI.getInstance() ?: return true
|
|
||||||
|
|
||||||
val user = api.getOnlineUser(player.uniqueId) ?: return true
|
|
||||||
|
|
||||||
return api.isOperationAllowed(
|
|
||||||
Operation.of(
|
|
||||||
user,
|
|
||||||
when (victim) {
|
|
||||||
is Monster -> OperationType.PLAYER_DAMAGE_MONSTER
|
|
||||||
is Player -> OperationType.PLAYER_DAMAGE_PLAYER
|
|
||||||
else -> OperationType.PLAYER_DAMAGE_ENTITY
|
|
||||||
},
|
|
||||||
Position.at(
|
|
||||||
victim.x,
|
|
||||||
victim.y,
|
|
||||||
victim.z,
|
|
||||||
api.getWorld(victim.location.world.name)
|
|
||||||
),
|
|
||||||
true
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun canPickupItem(player: Player, location: Location): Boolean {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun getPluginName(): String {
|
|
||||||
return "HuskClaims"
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun equals(other: Any?): Boolean {
|
|
||||||
if (other !is AntigriefIntegration) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
return other.pluginName == this.pluginName
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun hashCode(): Int {
|
|
||||||
return this.pluginName.hashCode()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,129 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.integrations.antigrief
|
|
||||||
|
|
||||||
import com.willfp.eco.core.integrations.antigrief.AntigriefIntegration
|
|
||||||
import net.william278.husktowns.api.HuskTownsAPI
|
|
||||||
import net.william278.husktowns.claim.Position
|
|
||||||
import net.william278.husktowns.listener.Operation
|
|
||||||
import org.bukkit.Location
|
|
||||||
import org.bukkit.block.Block
|
|
||||||
import org.bukkit.entity.LivingEntity
|
|
||||||
import org.bukkit.entity.Monster
|
|
||||||
import org.bukkit.entity.Player
|
|
||||||
|
|
||||||
class AntigriefHuskTowns : AntigriefIntegration {
|
|
||||||
override fun canBreakBlock(
|
|
||||||
player: Player,
|
|
||||||
block: Block
|
|
||||||
): Boolean {
|
|
||||||
val api = HuskTownsAPI.getInstance() ?: return true
|
|
||||||
|
|
||||||
val user = api.getOnlineUser(player) ?: return true
|
|
||||||
|
|
||||||
return api.isOperationAllowed(
|
|
||||||
Operation.of(
|
|
||||||
user,
|
|
||||||
Operation.Type.BLOCK_BREAK,
|
|
||||||
Position.at(
|
|
||||||
block.location.x,
|
|
||||||
block.location.y,
|
|
||||||
block.location.z,
|
|
||||||
api.getWorld(block.world)
|
|
||||||
),
|
|
||||||
true
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun canCreateExplosion(
|
|
||||||
player: Player,
|
|
||||||
location: Location
|
|
||||||
): Boolean {
|
|
||||||
val api = HuskTownsAPI.getInstance() ?: return true
|
|
||||||
|
|
||||||
val user = api.getOnlineUser(player) ?: return true
|
|
||||||
|
|
||||||
return api.isOperationAllowed(
|
|
||||||
Operation.of(
|
|
||||||
user,
|
|
||||||
Operation.Type.EXPLOSION_DAMAGE_ENTITY,
|
|
||||||
Position.at(
|
|
||||||
location.x,
|
|
||||||
location.y,
|
|
||||||
location.z,
|
|
||||||
api.getWorld(location.world)
|
|
||||||
),
|
|
||||||
true
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun canPlaceBlock(
|
|
||||||
player: Player,
|
|
||||||
block: Block
|
|
||||||
): Boolean {
|
|
||||||
val api = HuskTownsAPI.getInstance() ?: return true
|
|
||||||
|
|
||||||
val user = api.getOnlineUser(player) ?: return true
|
|
||||||
|
|
||||||
return api.isOperationAllowed(
|
|
||||||
Operation.of(
|
|
||||||
user,
|
|
||||||
Operation.Type.BLOCK_PLACE,
|
|
||||||
Position.at(
|
|
||||||
block.location.x,
|
|
||||||
block.location.y,
|
|
||||||
block.location.z,
|
|
||||||
api.getWorld(block.world)
|
|
||||||
),
|
|
||||||
true
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun canInjure(
|
|
||||||
player: Player,
|
|
||||||
victim: LivingEntity
|
|
||||||
): Boolean {
|
|
||||||
val api = HuskTownsAPI.getInstance() ?: return true
|
|
||||||
|
|
||||||
val user = api.getOnlineUser(player) ?: return true
|
|
||||||
|
|
||||||
return api.isOperationAllowed(
|
|
||||||
Operation.of(
|
|
||||||
user,
|
|
||||||
when(victim) {
|
|
||||||
is Monster -> Operation.Type.PLAYER_DAMAGE_MONSTER
|
|
||||||
is Player -> Operation.Type.PLAYER_DAMAGE_PLAYER
|
|
||||||
else -> Operation.Type.PLACE_HANGING_ENTITY
|
|
||||||
},
|
|
||||||
Position.at(
|
|
||||||
player.location.x,
|
|
||||||
player.location.y,
|
|
||||||
player.location.z,
|
|
||||||
api.getWorld(player.world)
|
|
||||||
),
|
|
||||||
true
|
|
||||||
)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun canPickupItem(player: Player, location: Location): Boolean {
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun getPluginName(): String {
|
|
||||||
return "HuskTowns"
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun equals(other: Any?): Boolean {
|
|
||||||
if (other !is AntigriefIntegration) {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
return other.pluginName == this.pluginName
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun hashCode(): Int {
|
|
||||||
return this.pluginName.hashCode()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
package com.willfp.eco.internal.spigot.integrations.antigrief
|
package com.willfp.eco.internal.spigot.integrations.antigrief
|
||||||
|
|
||||||
|
import com.iridium.iridiumskyblock.PermissionType
|
||||||
import com.iridium.iridiumskyblock.api.IridiumSkyblockAPI
|
import com.iridium.iridiumskyblock.api.IridiumSkyblockAPI
|
||||||
import com.iridium.iridiumteams.PermissionType
|
|
||||||
import com.willfp.eco.core.integrations.antigrief.AntigriefIntegration
|
import com.willfp.eco.core.integrations.antigrief.AntigriefIntegration
|
||||||
import org.bukkit.Location
|
import org.bukkit.Location
|
||||||
import org.bukkit.block.Block
|
import org.bukkit.block.Block
|
||||||
@@ -13,7 +13,7 @@ class AntigriefIridiumSkyblock : AntigriefIntegration {
|
|||||||
player: Player,
|
player: Player,
|
||||||
block: Block
|
block: Block
|
||||||
): Boolean {
|
): Boolean {
|
||||||
val api = IridiumSkyblockAPI.getInstance() ?: return false
|
val api = IridiumSkyblockAPI.getInstance()
|
||||||
|
|
||||||
return api.getIslandPermission(api.getIslandViaLocation(block.location).orElse(null) ?: return true, api.getUser(player), PermissionType.BLOCK_BREAK)
|
return api.getIslandPermission(api.getIslandViaLocation(block.location).orElse(null) ?: return true, api.getUser(player), PermissionType.BLOCK_BREAK)
|
||||||
}
|
}
|
||||||
@@ -22,7 +22,7 @@ class AntigriefIridiumSkyblock : AntigriefIntegration {
|
|||||||
player: Player,
|
player: Player,
|
||||||
location: Location
|
location: Location
|
||||||
): Boolean {
|
): Boolean {
|
||||||
val api = IridiumSkyblockAPI.getInstance() ?: return false
|
val api = IridiumSkyblockAPI.getInstance()
|
||||||
|
|
||||||
return api.getIslandPermission(api.getIslandViaLocation(location).orElse(null) ?: return true, api.getUser(player), PermissionType.BLOCK_BREAK)
|
return api.getIslandPermission(api.getIslandViaLocation(location).orElse(null) ?: return true, api.getUser(player), PermissionType.BLOCK_BREAK)
|
||||||
}
|
}
|
||||||
@@ -31,7 +31,7 @@ class AntigriefIridiumSkyblock : AntigriefIntegration {
|
|||||||
player: Player,
|
player: Player,
|
||||||
block: Block
|
block: Block
|
||||||
): Boolean {
|
): Boolean {
|
||||||
val api = IridiumSkyblockAPI.getInstance() ?: return false
|
val api = IridiumSkyblockAPI.getInstance()
|
||||||
|
|
||||||
return api.getIslandPermission(api.getIslandViaLocation(block.location).orElse(null) ?: return true, api.getUser(player), PermissionType.BLOCK_PLACE)
|
return api.getIslandPermission(api.getIslandViaLocation(block.location).orElse(null) ?: return true, api.getUser(player), PermissionType.BLOCK_PLACE)
|
||||||
}
|
}
|
||||||
@@ -40,7 +40,7 @@ class AntigriefIridiumSkyblock : AntigriefIntegration {
|
|||||||
player: Player,
|
player: Player,
|
||||||
victim: LivingEntity
|
victim: LivingEntity
|
||||||
): Boolean {
|
): Boolean {
|
||||||
val api = IridiumSkyblockAPI.getInstance() ?: return false
|
val api = IridiumSkyblockAPI.getInstance()
|
||||||
|
|
||||||
return when (victim) {
|
return when (victim) {
|
||||||
is Player -> api.getIslandViaLocation(victim.location).orElse(null) != null
|
is Player -> api.getIslandViaLocation(victim.location).orElse(null) != null
|
||||||
@@ -49,13 +49,8 @@ class AntigriefIridiumSkyblock : AntigriefIntegration {
|
|||||||
}
|
}
|
||||||
|
|
||||||
override fun canPickupItem(player: Player, location: Location): Boolean {
|
override fun canPickupItem(player: Player, location: Location): Boolean {
|
||||||
return true
|
|
||||||
/*
|
|
||||||
val api = IridiumSkyblockAPI.getInstance()
|
val api = IridiumSkyblockAPI.getInstance()
|
||||||
return api.getIslandPermission(api.getIslandViaLocation(location).orElse(null) ?: return true, api.getUser(player), PermissionType.PICKUP_ITEMS)
|
return api.getIslandPermission(api.getIslandViaLocation(location).orElse(null) ?: return true, api.getUser(player), PermissionType.PICKUP_ITEMS)
|
||||||
|
|
||||||
PICKUP_ITEMS was removed in Iridium v4
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun getPluginName(): String {
|
override fun getPluginName(): String {
|
||||||
|
|||||||
@@ -1,47 +0,0 @@
|
|||||||
package com.willfp.eco.internal.spigot.integrations.customitems
|
|
||||||
|
|
||||||
import com.jojodmo.itembridge.ItemBridge
|
|
||||||
import com.willfp.eco.core.integrations.customitems.CustomItemsIntegration
|
|
||||||
import com.willfp.eco.core.items.CustomItem
|
|
||||||
import com.willfp.eco.core.items.Items
|
|
||||||
import com.willfp.eco.core.items.TestableItem
|
|
||||||
import com.willfp.eco.core.items.provider.ItemProvider
|
|
||||||
import com.willfp.eco.util.namespacedKeyOf
|
|
||||||
import org.bukkit.inventory.ItemStack
|
|
||||||
|
|
||||||
class CustomItemsItemBridge : CustomItemsIntegration {
|
|
||||||
override fun registerProvider() {
|
|
||||||
Items.registerItemProvider(ItemBridgeProvider())
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun getPluginName(): String {
|
|
||||||
return "ItemBridge"
|
|
||||||
}
|
|
||||||
|
|
||||||
private class ItemBridgeProvider : ItemProvider("itembridge") {
|
|
||||||
override fun provideForKey(key: String): TestableItem? {
|
|
||||||
|
|
||||||
val split = key.split(":").toMutableList()
|
|
||||||
|
|
||||||
if (split.size < 2) {
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
|
|
||||||
val itemKey = split[0]
|
|
||||||
|
|
||||||
val item = split[1]
|
|
||||||
|
|
||||||
val stack = ItemBridge.getItemStack(itemKey, item) ?: kotlin.run {
|
|
||||||
return null
|
|
||||||
}
|
|
||||||
|
|
||||||
return CustomItem(
|
|
||||||
namespacedKeyOf("eco:${key.lowercase().replace(":", "__")}"),
|
|
||||||
{ test: ItemStack ->
|
|
||||||
ItemBridge.isItemStack(test, itemKey, item)
|
|
||||||
},
|
|
||||||
stack
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -7,7 +7,7 @@ import org.bukkit.Location
|
|||||||
import java.util.UUID
|
import java.util.UUID
|
||||||
|
|
||||||
class HologramDecentHolograms : HologramIntegration {
|
class HologramDecentHolograms : HologramIntegration {
|
||||||
override fun createHologram(location: Location, contents: List<String>): Hologram {
|
override fun createHologram(location: Location, contents: MutableList<String>): Hologram {
|
||||||
val id = UUID.randomUUID().toString()
|
val id = UUID.randomUUID().toString()
|
||||||
|
|
||||||
DHAPI.createHologram(id, location, contents)
|
DHAPI.createHologram(id, location, contents)
|
||||||
@@ -26,7 +26,7 @@ class HologramDecentHolograms : HologramIntegration {
|
|||||||
DHAPI.getHologram(id)?.destroy()
|
DHAPI.getHologram(id)?.destroy()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun setContents(contents: List<String>) {
|
override fun setContents(contents: MutableList<String>) {
|
||||||
DHAPI.setHologramLines(DHAPI.getHologram(id), contents)
|
DHAPI.setHologramLines(DHAPI.getHologram(id), contents)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -5,7 +5,6 @@ import com.github.benmanes.caffeine.cache.Caffeine
|
|||||||
import com.willfp.eco.core.integrations.placeholder.PlaceholderManager
|
import com.willfp.eco.core.integrations.placeholder.PlaceholderManager
|
||||||
import com.willfp.eco.core.placeholder.context.PlaceholderContext
|
import com.willfp.eco.core.placeholder.context.PlaceholderContext
|
||||||
import com.willfp.eco.internal.placeholder.PlaceholderParser
|
import com.willfp.eco.internal.placeholder.PlaceholderParser
|
||||||
import com.willfp.eco.util.randDouble
|
|
||||||
import redempt.crunch.CompiledExpression
|
import redempt.crunch.CompiledExpression
|
||||||
import redempt.crunch.Crunch
|
import redempt.crunch.Crunch
|
||||||
import redempt.crunch.functional.EvaluationEnvironment
|
import redempt.crunch.functional.EvaluationEnvironment
|
||||||
@@ -23,10 +22,6 @@ private val max = Function("max", 2) {
|
|||||||
max(it[0], it[1])
|
max(it[0], it[1])
|
||||||
}
|
}
|
||||||
|
|
||||||
private val rand = Function("random", 2) {
|
|
||||||
randDouble(it[0], it[1])
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ExpressionHandler {
|
interface ExpressionHandler {
|
||||||
fun evaluate(expression: String, context: PlaceholderContext): Double?
|
fun evaluate(expression: String, context: PlaceholderContext): Double?
|
||||||
}
|
}
|
||||||
@@ -82,7 +77,7 @@ class ImmediatePlaceholderTranslationExpressionHandler(
|
|||||||
.build()
|
.build()
|
||||||
|
|
||||||
private val env = EvaluationEnvironment().apply {
|
private val env = EvaluationEnvironment().apply {
|
||||||
addFunctions(min, max, rand)
|
addFunctions(min, max)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun evaluate(expression: String, context: PlaceholderContext): Double? {
|
override fun evaluate(expression: String, context: PlaceholderContext): Double? {
|
||||||
@@ -111,7 +106,7 @@ class LazyPlaceholderTranslationExpressionHandler(
|
|||||||
val compiled = cache.getOrPut(expression) {
|
val compiled = cache.getOrPut(expression) {
|
||||||
val env = EvaluationEnvironment()
|
val env = EvaluationEnvironment()
|
||||||
env.setVariableNames(*placeholders.toTypedArray())
|
env.setVariableNames(*placeholders.toTypedArray())
|
||||||
env.addFunctions(rand, min, max)
|
env.addFunctions(min, max)
|
||||||
runCatching { Crunch.compileExpression(expression, env) }.getOrNull()
|
runCatching { Crunch.compileExpression(expression, env) }.getOrNull()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ package com.willfp.eco.internal.spigot.recipes
|
|||||||
|
|
||||||
import com.willfp.eco.core.EcoPlugin
|
import com.willfp.eco.core.EcoPlugin
|
||||||
import com.willfp.eco.core.items.TestableItem
|
import com.willfp.eco.core.items.TestableItem
|
||||||
import com.willfp.eco.core.items.isEcoEmpty
|
import com.willfp.eco.core.items.isEmpty
|
||||||
import com.willfp.eco.core.recipe.Recipes
|
import com.willfp.eco.core.recipe.Recipes
|
||||||
import com.willfp.eco.core.recipe.parts.GroupedTestableItems
|
import com.willfp.eco.core.recipe.parts.GroupedTestableItems
|
||||||
import com.willfp.eco.core.recipe.parts.TestableStack
|
import com.willfp.eco.core.recipe.parts.TestableStack
|
||||||
@@ -33,7 +33,7 @@ class StackedRecipeListener(
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Just in case
|
// Just in case
|
||||||
if (inventory.getItem(event.slot).isEcoEmpty) {
|
if (inventory.getItem(event.slot).isEmpty) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -16,8 +16,6 @@ perform-data-migration: true
|
|||||||
mongodb:
|
mongodb:
|
||||||
# The full MongoDB connection URL.
|
# The full MongoDB connection URL.
|
||||||
url: ""
|
url: ""
|
||||||
# The name of the database to use.
|
|
||||||
database: "eco"
|
|
||||||
|
|
||||||
mysql:
|
mysql:
|
||||||
# How many threads to execute statements on. Higher numbers can be faster however
|
# How many threads to execute statements on. Higher numbers can be faster however
|
||||||
@@ -32,10 +30,6 @@ mysql:
|
|||||||
user: username
|
user: username
|
||||||
password: passy
|
password: passy
|
||||||
|
|
||||||
yaml:
|
|
||||||
autosave: true # If data should be saved automatically
|
|
||||||
autosave-interval: 1800 # How often data should be saved (in seconds)
|
|
||||||
|
|
||||||
# How many ticks to wait between committing data to a database. This doesn't
|
# How many ticks to wait between committing data to a database. This doesn't
|
||||||
# affect yaml storage, only MySQL and MongoDB. By default, data is committed
|
# affect yaml storage, only MySQL and MongoDB. By default, data is committed
|
||||||
# every tick, but you can increase this to be every x ticks, for example 20
|
# every tick, but you can increase this to be every x ticks, for example 20
|
||||||
@@ -98,11 +92,6 @@ use-immediate-placeholder-translation-for-math: false
|
|||||||
# less reactive values.
|
# less reactive values.
|
||||||
math-cache-ttl: 200
|
math-cache-ttl: 200
|
||||||
|
|
||||||
# The time (in minutes) for literal patterns to be cached for. Higher values will lead to
|
|
||||||
# faster evaluation times (less CPU usage) at the expense of slightly more memory usage and
|
|
||||||
# less reactive values. (Do not change unless you are told to).
|
|
||||||
literal-cache-ttl: 1
|
|
||||||
|
|
||||||
# If anonymous usage statistics should be tracked. This is very valuable information as it
|
# If anonymous usage statistics should be tracked. This is very valuable information as it
|
||||||
# helps understand how eco and other plugins are being used by logging player and server
|
# helps understand how eco and other plugins are being used by logging player and server
|
||||||
# counts. This is completely anonymous and no personal information is logged. This data
|
# counts. This is completely anonymous and no personal information is logged. This data
|
||||||
|
|||||||
@@ -2,7 +2,6 @@ multiple-in-craft: '&l&c! &fThis recipe requires &a%amount%&f of this item.'
|
|||||||
|
|
||||||
# Specify default display names for prices made through ConfiguredPrice#create
|
# Specify default display names for prices made through ConfiguredPrice#create
|
||||||
# These will override any custom configured price display names.
|
# These will override any custom configured price display names.
|
||||||
# You can use %value% and %value_commas% as placeholders.
|
|
||||||
price-display:
|
price-display:
|
||||||
- type: example_type
|
- type: example_type
|
||||||
display: "&e%value% Price"
|
display: "&e%value% Price"
|
||||||
|
|||||||
@@ -5,32 +5,18 @@ api-version: 1.17
|
|||||||
authors: [ Auxilor ]
|
authors: [ Auxilor ]
|
||||||
website: willfp.com
|
website: willfp.com
|
||||||
load: STARTUP
|
load: STARTUP
|
||||||
|
|
||||||
# Fixes some plugins breaking load order
|
|
||||||
loadbefore:
|
|
||||||
- Spartan
|
|
||||||
- CustomCrafting
|
|
||||||
- Lands
|
|
||||||
- EconomyShopGUI
|
|
||||||
- EconomyShopGUI-Premium
|
|
||||||
- CMI
|
|
||||||
- DeluxeCombat
|
|
||||||
- SCore
|
|
||||||
- ExecutableItems
|
|
||||||
softdepend:
|
softdepend:
|
||||||
- ItemBridge
|
|
||||||
- HuskClaims
|
|
||||||
- HuskTowns
|
|
||||||
- Terra
|
|
||||||
- ProtocolLib
|
- ProtocolLib
|
||||||
- WorldGuard
|
- WorldGuard
|
||||||
- GriefPrevention
|
- GriefPrevention
|
||||||
- Towny
|
- Towny
|
||||||
- FactionsUUID
|
- FactionsUUID
|
||||||
|
- Lands
|
||||||
- Kingdoms
|
- Kingdoms
|
||||||
- NoCheatPlus
|
- NoCheatPlus
|
||||||
- AAC
|
- AAC
|
||||||
- Matrix
|
- Matrix
|
||||||
|
- Spartan
|
||||||
- Vulcan
|
- Vulcan
|
||||||
- PlaceholderAPI
|
- PlaceholderAPI
|
||||||
- mcMMO
|
- mcMMO
|
||||||
@@ -43,16 +29,22 @@ softdepend:
|
|||||||
- Alice
|
- Alice
|
||||||
- HolographicDisplays
|
- HolographicDisplays
|
||||||
- GHolo
|
- GHolo
|
||||||
|
- CMI
|
||||||
- Essentials
|
- Essentials
|
||||||
- Vault
|
- Vault
|
||||||
- BentoBox
|
- BentoBox
|
||||||
|
- DeluxeCombat
|
||||||
- IridiumSkyblock
|
- IridiumSkyblock
|
||||||
- SuperiorSkyblock2
|
- SuperiorSkyblock2
|
||||||
- FabledSkyBlock
|
- FabledSkyBlock
|
||||||
- CrashClaim
|
- CrashClaim
|
||||||
- DecentHolograms
|
- DecentHolograms
|
||||||
- MythicMobs
|
- MythicMobs
|
||||||
|
- CustomCrafting
|
||||||
|
- ExecutableItems
|
||||||
- RPGHorses
|
- RPGHorses
|
||||||
|
- EconomyShopGUI
|
||||||
|
- EconomyShopGUI-Premium
|
||||||
- zShop
|
- zShop
|
||||||
- DeluxeSellwands
|
- DeluxeSellwands
|
||||||
- Scyther
|
- Scyther
|
||||||
|
|||||||
@@ -1,2 +1,2 @@
|
|||||||
version = 6.69.2
|
version = 6.67.0
|
||||||
kotlin.incremental.useClasspathSnapshot=false
|
kotlin.incremental.useClasspathSnapshot=false
|
||||||
BIN
gradle/wrapper/gradle-wrapper.jar
vendored
BIN
gradle/wrapper/gradle-wrapper.jar
vendored
Binary file not shown.
4
gradle/wrapper/gradle-wrapper.properties
vendored
4
gradle/wrapper/gradle-wrapper.properties
vendored
@@ -1,7 +1,5 @@
|
|||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.7-bin.zip
|
distributionUrl=https\://services.gradle.org/distributions/gradle-8.2-bin.zip
|
||||||
networkTimeout=10000
|
|
||||||
validateDistributionUrl=true
|
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
|
|||||||
35
gradlew
vendored
35
gradlew
vendored
@@ -55,7 +55,7 @@
|
|||||||
# Darwin, MinGW, and NonStop.
|
# Darwin, MinGW, and NonStop.
|
||||||
#
|
#
|
||||||
# (3) This script is generated from the Groovy template
|
# (3) This script is generated from the Groovy template
|
||||||
# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
|
# https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
|
||||||
# within the Gradle project.
|
# within the Gradle project.
|
||||||
#
|
#
|
||||||
# You can find Gradle at https://github.com/gradle/gradle/.
|
# You can find Gradle at https://github.com/gradle/gradle/.
|
||||||
@@ -80,11 +80,13 @@ do
|
|||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
# This is normally unused
|
APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
|
||||||
# shellcheck disable=SC2034
|
|
||||||
|
APP_NAME="Gradle"
|
||||||
APP_BASE_NAME=${0##*/}
|
APP_BASE_NAME=${0##*/}
|
||||||
# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036)
|
|
||||||
APP_HOME=$( cd "${APP_HOME:-./}" > /dev/null && pwd -P ) || exit
|
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
||||||
|
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
||||||
|
|
||||||
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
# Use the maximum available, or set MAX_FD != -1 to use that value.
|
||||||
MAX_FD=maximum
|
MAX_FD=maximum
|
||||||
@@ -131,29 +133,22 @@ location of your Java installation."
|
|||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
JAVACMD=java
|
JAVACMD=java
|
||||||
if ! command -v java >/dev/null 2>&1
|
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||||
then
|
|
||||||
die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
|
||||||
|
|
||||||
Please set the JAVA_HOME variable in your environment to match the
|
Please set the JAVA_HOME variable in your environment to match the
|
||||||
location of your Java installation."
|
location of your Java installation."
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Increase the maximum file descriptors if we can.
|
# Increase the maximum file descriptors if we can.
|
||||||
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
|
||||||
case $MAX_FD in #(
|
case $MAX_FD in #(
|
||||||
max*)
|
max*)
|
||||||
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
|
|
||||||
# shellcheck disable=SC2039,SC3045
|
|
||||||
MAX_FD=$( ulimit -H -n ) ||
|
MAX_FD=$( ulimit -H -n ) ||
|
||||||
warn "Could not query maximum file descriptor limit"
|
warn "Could not query maximum file descriptor limit"
|
||||||
esac
|
esac
|
||||||
case $MAX_FD in #(
|
case $MAX_FD in #(
|
||||||
'' | soft) :;; #(
|
'' | soft) :;; #(
|
||||||
*)
|
*)
|
||||||
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
|
|
||||||
# shellcheck disable=SC2039,SC3045
|
|
||||||
ulimit -n "$MAX_FD" ||
|
ulimit -n "$MAX_FD" ||
|
||||||
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
warn "Could not set maximum file descriptor limit to $MAX_FD"
|
||||||
esac
|
esac
|
||||||
@@ -198,15 +193,11 @@ if "$cygwin" || "$msys" ; then
|
|||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Collect all arguments for the java command;
|
||||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
|
# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of
|
||||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
|
# shell script including quotes and variable substitutions, so put them in
|
||||||
|
# double quotes to make sure that they get re-expanded; and
|
||||||
# Collect all arguments for the java command:
|
# * put everything else in single quotes, so that it's not re-expanded.
|
||||||
# * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
|
|
||||||
# and any embedded shellness will be escaped.
|
|
||||||
# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
|
|
||||||
# treated as '${Hostname}' itself on the command line.
|
|
||||||
|
|
||||||
set -- \
|
set -- \
|
||||||
"-Dorg.gradle.appname=$APP_BASE_NAME" \
|
"-Dorg.gradle.appname=$APP_BASE_NAME" \
|
||||||
|
|||||||
21
gradlew.bat
vendored
21
gradlew.bat
vendored
@@ -26,7 +26,6 @@ if "%OS%"=="Windows_NT" setlocal
|
|||||||
|
|
||||||
set DIRNAME=%~dp0
|
set DIRNAME=%~dp0
|
||||||
if "%DIRNAME%"=="" set DIRNAME=.
|
if "%DIRNAME%"=="" set DIRNAME=.
|
||||||
@rem This is normally unused
|
|
||||||
set APP_BASE_NAME=%~n0
|
set APP_BASE_NAME=%~n0
|
||||||
set APP_HOME=%DIRNAME%
|
set APP_HOME=%DIRNAME%
|
||||||
|
|
||||||
@@ -43,11 +42,11 @@ set JAVA_EXE=java.exe
|
|||||||
%JAVA_EXE% -version >NUL 2>&1
|
%JAVA_EXE% -version >NUL 2>&1
|
||||||
if %ERRORLEVEL% equ 0 goto execute
|
if %ERRORLEVEL% equ 0 goto execute
|
||||||
|
|
||||||
echo. 1>&2
|
echo.
|
||||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2
|
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
|
||||||
echo. 1>&2
|
echo.
|
||||||
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
|
echo Please set the JAVA_HOME variable in your environment to match the
|
||||||
echo location of your Java installation. 1>&2
|
echo location of your Java installation.
|
||||||
|
|
||||||
goto fail
|
goto fail
|
||||||
|
|
||||||
@@ -57,11 +56,11 @@ set JAVA_EXE=%JAVA_HOME%/bin/java.exe
|
|||||||
|
|
||||||
if exist "%JAVA_EXE%" goto execute
|
if exist "%JAVA_EXE%" goto execute
|
||||||
|
|
||||||
echo. 1>&2
|
echo.
|
||||||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2
|
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
|
||||||
echo. 1>&2
|
echo.
|
||||||
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
|
echo Please set the JAVA_HOME variable in your environment to match the
|
||||||
echo location of your Java installation. 1>&2
|
echo location of your Java installation.
|
||||||
|
|
||||||
goto fail
|
goto fail
|
||||||
|
|
||||||
|
|||||||
BIN
lib/IridiumSkyblock-3.2.8.jar
Normal file
BIN
lib/IridiumSkyblock-3.2.8.jar
Normal file
Binary file not shown.
BIN
lib/customcrafting-spigot-3.16.0.0-f.jar
Normal file
BIN
lib/customcrafting-spigot-3.16.0.0-f.jar
Normal file
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@@ -20,7 +20,6 @@ include(":eco-core:core-nms:v1_19_R2")
|
|||||||
include(":eco-core:core-nms:v1_19_R3")
|
include(":eco-core:core-nms:v1_19_R3")
|
||||||
include(":eco-core:core-nms:v1_20_R1")
|
include(":eco-core:core-nms:v1_20_R1")
|
||||||
include(":eco-core:core-nms:v1_20_R2")
|
include(":eco-core:core-nms:v1_20_R2")
|
||||||
include(":eco-core:core-nms:v1_20_R3")
|
|
||||||
include(":eco-core:core-proxy")
|
include(":eco-core:core-proxy")
|
||||||
include(":eco-core:core-plugin")
|
include(":eco-core:core-plugin")
|
||||||
include(":eco-core:core-backend")
|
include(":eco-core:core-backend")
|
||||||
Reference in New Issue
Block a user