9
0
mirror of https://github.com/Xiao-MoMi/Custom-Fishing.git synced 2025-12-19 15:09:24 +00:00

add craftengine functions support

This commit is contained in:
XiaoMoMi
2025-11-08 14:47:28 +08:00
parent 7841a95166
commit 24c5c22525
5 changed files with 51 additions and 27 deletions

View File

@@ -69,8 +69,8 @@ dependencies {
compileOnly("io.th0rgal:oraxen:1.168.0")
compileOnly("com.nexomc:nexo:1.7.3")
compileOnly("com.github.brcdev-minecraft:shopgui-api:3.0.0")
compileOnly("net.momirealms:craft-engine-core:0.0.61")
compileOnly("net.momirealms:craft-engine-bukkit:0.0.61")
compileOnly("net.momirealms:craft-engine-core:0.0.65")
compileOnly("net.momirealms:craft-engine-bukkit:0.0.65")
// entity
compileOnly("io.lumine:Mythic-Dist:5.6.2")
// eco

View File

@@ -0,0 +1,43 @@
package net.momirealms.customfishing.bukkit.integration.action;
import net.momirealms.craftengine.bukkit.api.BukkitAdaptors;
import net.momirealms.craftengine.core.plugin.context.ContextHolder;
import net.momirealms.craftengine.core.plugin.context.PlayerOptionalContext;
import net.momirealms.craftengine.core.plugin.context.event.EventFunctions;
import net.momirealms.craftengine.core.plugin.context.function.Function;
import net.momirealms.customfishing.api.BukkitCustomFishingPlugin;
import net.momirealms.customfishing.api.mechanic.action.Action;
import net.momirealms.customfishing.api.mechanic.action.ActionFactory;
import net.momirealms.customfishing.api.mechanic.misc.value.MathValue;
import org.bukkit.entity.Player;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
public class CEActionExpansion implements ActionFactory<Player> {
public static void register() {
BukkitCustomFishingPlugin.getInstance().getActionManager().registerAction(new CEActionExpansion(), "ce-function");
}
@SuppressWarnings({"unchecked", "rawtypes"})
@Override
public Action<Player> process(Object arg, MathValue<Player> mathValue) {
if (arg instanceof List<?> list) {
List<Function<net.momirealms.craftengine.core.plugin.context.Context>> functions = new ArrayList<>();
for (Object o : list) {
if (o instanceof Map functionArguments) {
functions.add(EventFunctions.fromMap(functionArguments));
}
}
return context -> {
PlayerOptionalContext ctx = PlayerOptionalContext.of(BukkitAdaptors.adapt(context.holder()), ContextHolder.builder());
for (Function<net.momirealms.craftengine.core.plugin.context.Context> function : functions) {
function.run(ctx);
}
};
}
return context -> {};
}
}

View File

@@ -57,7 +57,6 @@ dependencies {
tasks {
shadowJar {
from(project(":compatibility:j21").tasks.jar.get().archiveFile)
archiveFileName = "CustomFishing-${rootProject.properties["project_version"]}.jar"
destinationDirectory.set(file("$rootDir/target"))
relocate("net.kyori", "net.momirealms.customfishing.libraries")

View File

@@ -21,7 +21,9 @@ import net.momirealms.customfishing.api.BukkitCustomFishingPlugin;
import net.momirealms.customfishing.api.integration.*;
import net.momirealms.customfishing.bukkit.block.BukkitBlockManager;
import net.momirealms.customfishing.bukkit.entity.BukkitEntityManager;
import net.momirealms.customfishing.bukkit.integration.action.CEActionExpansion;
import net.momirealms.customfishing.bukkit.integration.block.ItemsAdderBlockProvider;
import net.momirealms.customfishing.bukkit.integration.block.NexoBlockProvider;
import net.momirealms.customfishing.bukkit.integration.block.OraxenBlockProvider;
import net.momirealms.customfishing.bukkit.integration.enchant.AdvancedEnchantmentsProvider;
import net.momirealms.customfishing.bukkit.integration.enchant.VanillaEnchantmentsProvider;
@@ -103,31 +105,12 @@ public class BukkitIntegrationManager implements IntegrationManager {
registerEntityProvider(new ItemsAdderEntityProvider());
}
if (isHooked("CraftEngine")) {
try {
Class<?> ceItemProviderClass = Class.forName("net.momirealms.customfishing.bukkit.integration.item.CraftEngineItemProvider");
Constructor<?> itemProviderConstructor = ceItemProviderClass.getDeclaredConstructor();
itemProviderConstructor.setAccessible(true);
ItemProvider itemProvider = (ItemProvider) itemProviderConstructor.newInstance();
registerItemProvider(itemProvider);
} catch (ReflectiveOperationException e) {
plugin.getPluginLogger().warn("Failed to hook CraftEngine", e);
}
registerItemProvider(new CraftEngineItemProvider());
CEActionExpansion.register();
}
if (isHooked("Nexo")) {
try {
Class<?> nexoItemProviderClass = Class.forName("net.momirealms.customfishing.bukkit.integration.item.NexoItemProvider");
Constructor<?> itemProviderConstructor = nexoItemProviderClass.getDeclaredConstructor();
itemProviderConstructor.setAccessible(true);
ItemProvider itemProvider = (ItemProvider) itemProviderConstructor.newInstance();
registerItemProvider(itemProvider);
Class<?> nexoBlockProviderClass = Class.forName("net.momirealms.customfishing.bukkit.integration.block.NexoBlockProvider");
Constructor<?> nexoBlockProviderConstructor = nexoBlockProviderClass.getDeclaredConstructor();
nexoBlockProviderConstructor.setAccessible(true);
BlockProvider blockProvider = (BlockProvider) nexoBlockProviderConstructor.newInstance();
registerBlockProvider(blockProvider);
} catch (ReflectiveOperationException e) {
plugin.getPluginLogger().warn("Failed to hook Nexo", e);
}
registerItemProvider(new NexoItemProvider());
registerBlockProvider(new NexoBlockProvider());
}
if (isHooked("MMOItems")) {
registerItemProvider(new MMOItemsItemProvider());

View File

@@ -2,4 +2,3 @@ rootProject.name = "CustomFishing"
include(":api")
include(":core")
include(":compatibility")
include(":compatibility:j21")