Jump to content

Recommended Posts

Posted

The Forge 1.12.2 Build 2657 is crashing on startup. Console message is below.

11.04 11:14:17 [Server] main/INFO [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.FMLServerTweaker
11.04 11:14:17 [Server] main/INFO [LaunchWrapper]: Using primary tweak class name net.minecraftforge.fml.common.launcher.FMLServerTweaker
11.04 11:14:17 [Server] main/INFO [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLServerTweaker
11.04 11:14:17 [Server] main/INFO [FML]: Forge Mod Loader version 14.23.3.2657 for Minecraft 1.12.2 loading
11.04 11:14:17 [Server] main/INFO [FML]: Java is Java HotSpot(TM) 64-Bit Server VM, version 1.8.0_152, running on Linux:amd64:3.11.0-26-generic, installed at /usr/lib/jvm/jre1.8.0_152
11.04 11:14:17 [Server] main/ERROR [LaunchWrapper]: Unable to launch
11.04 11:14:17 [Server] INFO java.lang.RuntimeException: An error occurred trying to configure the Minecraft home at /. for Forge Mod Loader
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.relauncher.FMLLaunchHandler.setupHome(FMLLaunchHandler.java:109) ~[custom.jar:?]
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.relauncher.FMLLaunchHandler.setupServer(FMLLaunchHandler.java:85) ~[custom.jar:?]
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.relauncher.FMLLaunchHandler.configureForServerLaunch(FMLLaunchHandler.java:47) ~[custom.jar:?]
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.common.launcher.FMLServerTweaker.injectIntoClassLoader(FMLServerTweaker.java:62) ~[custom.jar:?]
11.04 11:14:17 [Server] INFO at net.minecraft.launchwrapper.Launch.launch(Launch.java:115) [launchwrapper-1.12.jar:?]
11.04 11:14:17 [Server] INFO at net.minecraft.launchwrapper.Launch.main(Launch.java:28) [launchwrapper-1.12.jar:?]
11.04 11:14:17 [Server] INFO at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.8.0_152]
11.04 11:14:17 [Server] INFO at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[?:1.8.0_152]
11.04 11:14:17 [Server] INFO at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:1.8.0_152]
11.04 11:14:17 [Server] INFO at java.lang.reflect.Method.invoke(Method.java:498) ~[?:1.8.0_152]
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.relauncher.ServerLaunchWrapper.run(ServerLaunchWrapper.java:62) [custom.jar:?]
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.relauncher.ServerLaunchWrapper.main(ServerLaunchWrapper.java:31) [custom.jar:?]
11.04 11:14:17 [Server] INFO Caused by: java.lang.NoClassDefFoundError: org/apache/maven/artifact/versioning/ArtifactVersion
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.relauncher.libraries.LibraryManager.findLibraryFolder(LibraryManager.java:122) ~[custom.jar:?]
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.relauncher.libraries.LibraryManager.setup(LibraryManager.java:76) ~[custom.jar:?]
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.relauncher.FMLLaunchHandler.setupHome(FMLLaunchHandler.java:104) ~[custom.jar:?]
11.04 11:14:17 [Server] INFO ... 11 more
11.04 11:14:17 [Server] INFO Caused by: java.lang.ClassNotFoundException: org.apache.maven.artifact.versioning.ArtifactVersion
11.04 11:14:17 [Server] INFO at java.net.URLClassLoader.findClass(URLClassLoader.java:381) ~[?:1.8.0_152]
11.04 11:14:17 [Server] INFO at java.lang.ClassLoader.loadClass(ClassLoader.java:424) ~[?:1.8.0_152]
11.04 11:14:17 [Server] INFO at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:338) ~[?:1.8.0_152]
11.04 11:14:17 [Server] INFO at java.lang.ClassLoader.loadClass(ClassLoader.java:357) ~[?:1.8.0_152]
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.relauncher.libraries.LibraryManager.findLibraryFolder(LibraryManager.java:122) ~[custom.jar:?]
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.relauncher.libraries.LibraryManager.setup(LibraryManager.java:76) ~[custom.jar:?]
11.04 11:14:17 [Server] INFO at net.minecraftforge.fml.relauncher.FMLLaunchHandler.setupHome(FMLLaunchHandler.java:104) ~[custom.jar:?]
11.04 11:14:17 [Server] INFO ... 11 more
11.04 11:14:17 [Server] INFO A problem occurred running the Server launcher.[11:14:17] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:31]: java.lang.reflect.InvocationTargetException
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:31]: at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:31]: at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:31]: at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:31]: at java.lang.reflect.Method.invoke(Method.java:498)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:31]: at net.minecraftforge.fml.relauncher.ServerLaunchWrapper.run(ServerLaunchWrapper.java:62)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:31]: at net.minecraftforge.fml.relauncher.ServerLaunchWrapper.main(ServerLaunchWrapper.java:31)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:67]: Caused by: net.minecraftforge.fml.relauncher.FMLSecurityManager$ExitTrappedException
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:67]: at net.minecraftforge.fml.relauncher.FMLSecurityManager.checkPermission(FMLSecurityManager.java:49)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:67]: at java.lang.SecurityManager.checkExit(SecurityManager.java:761)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:67]: at java.lang.Runtime.exit(Runtime.java:107)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:67]: at java.lang.System.exit(System.java:971)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:67]: at net.minecraft.launchwrapper.Launch.launch(Launch.java:138)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:67]: at net.minecraft.launchwrapper.Launch.main(Launch.java:28)
11.04 11:14:17 [Server] main/INFO [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:67]: ... 6 more
11.04 11:14:17 [Multicraft] Server shut down (starting)
11.04 11:14:17 [Multicraft] Restarting crashed server in 2.0 seconds
11.04 11:14:17 [Multicraft] Looks like a crash, check the server console. Return value: 1
11.04 11:14:17 [Multicraft] Server stopped

Posted

I'm running a Multicraft Server. The issue I'm having is with Forge 1.12.2 Build 2657 (Universal JAR). I was running Universal JAR Build 2654 and have reverted back to that version until I can test the next Universal release. If the Universal JAR for Build 2657 is missing libraries, please add them.

Posted

Multicraft is broken then, it should use the installer, or atleast give you the ability to upload all the files the installer generates.

2656+ has a new library dependency, so they need to allow you to install it.

I do Forge for free, however the servers to run it arn't free, so anything is appreciated.
Consider supporting the team on Patreon

  • 3 years later...
Posted

Hi, I have the same issue, and I used the official installer of Forge. I dont know how to install the libraries....

 

 

 

 

 

 

C:\Users\Usuario\Desktop\server>java -jar forge-1.12.2-14.23.5.2855.jar
2021-08-25 19:17:12,486 main WARN Disabling terminal, you're running in an unsupported environment.
[19:17:12] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.FMLServerTweaker
[19:17:12] [main/INFO] [LaunchWrapper]: Using primary tweak class name net.minecraftforge.fml.common.launcher.FMLServerTweaker
[19:17:12] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLServerTweaker
[19:17:12] [main/INFO] [FML]: Forge Mod Loader version 14.23.5.2855 for Minecraft 1.12.2 loading
[19:17:12] [main/INFO] [FML]: Java is Java HotSpot(TM) 64-Bit Server VM, version 1.8.0_301, running on Windows 10:amd64:10.0, installed at C:\Program Files\Java\jre1.8.0_301
[19:17:12] [main/INFO] [FML]: Searching C:\Users\Usuario\Desktop\server\.\mods for mods
[19:17:12] [main/WARN] [FML]: Found FMLCorePluginContainsFMLMod marker in Thaumcraft-1.8.9-5.2.4.jar. This is not recommended, @Mods should be in a separate jar from the coremod.
[19:17:12] [main/WARN] [FML]: The coremod thaumcraft.loader.ThaumcraftLoader does not have a MCVersion annotation, it may cause issues with this version of Minecraft
[19:17:12] [main/WARN] [FML]: The coremod ThaumcraftLoader (thaumcraft.loader.ThaumcraftLoader) is not signed!
[19:17:12] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.FMLInjectionAndSortingTweaker
[19:17:12] [main/INFO] [LaunchWrapper]: Loading tweak class name net.minecraftforge.fml.common.launcher.FMLDeobfTweaker
[19:17:12] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLInjectionAndSortingTweaker
[19:17:12] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.common.launcher.FMLInjectionAndSortingTweaker
[19:17:12] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.relauncher.CoreModManager$FMLPluginWrapper
[19:17:13] [main/INFO] [FML]: Found valid fingerprint for Minecraft Forge. Certificate fingerprint e3c3d50c7c986df74c645c0ac54639741c90a557
[19:17:13] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.relauncher.CoreModManager$FMLPluginWrapper
[19:17:13] [main/INFO] [LaunchWrapper]: Calling tweak class net.minecraftforge.fml.relauncher.CoreModManager$FMLPluginWrapper
[19:17:13] [main/INFO] [ThaumcraftLoader]: Downloading file https://dl.dropboxusercontent.com/u/47135879/Baubles-1.8.9-1.1.3.0.jar
[19:17:15] [main/ERROR] [LaunchWrapper]: Unable to launch
java.lang.RuntimeException: java.lang.RuntimeException: download error
        at net.minecraftforge.fml.relauncher.CoreModManager$FMLPluginWrapper.injectIntoClassLoader(CoreModManager.java:169) ~[forge-1.12.2-14.23.5.2855.jar:?]
        at net.minecraft.launchwrapper.Launch.launch(Launch.java:115) [launchwrapper-1.12.jar:?]
        at net.minecraft.launchwrapper.Launch.main(Launch.java:28) [launchwrapper-1.12.jar:?]
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.8.0_301]
        at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) ~[?:1.8.0_301]
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) ~[?:1.8.0_301]
        at java.lang.reflect.Method.invoke(Unknown Source) ~[?:1.8.0_301]
        at net.minecraftforge.fml.relauncher.ServerLaunchWrapper.run(ServerLaunchWrapper.java:70) [forge-1.12.2-14.23.5.2855.jar:?]
        at net.minecraftforge.fml.relauncher.ServerLaunchWrapper.main(ServerLaunchWrapper.java:34) [forge-1.12.2-14.23.5.2855.jar:?]
Caused by: java.lang.RuntimeException: download error
        at thaumcraft.loader.ThaumcraftLoader$DepLoadInst.installError(ThaumcraftLoader.java:443) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader$DepLoadInst.download(ThaumcraftLoader.java:433) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader$DepLoadInst.install(ThaumcraftLoader.java:384) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader$DepLoadInst.load(ThaumcraftLoader.java:606) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader$DepLoadInst.loadDeps(ThaumcraftLoader.java:593) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader$DepLoadInst.load(ThaumcraftLoader.java:523) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader.load(ThaumcraftLoader.java:712) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader.call(ThaumcraftLoader.java:737) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader.call(ThaumcraftLoader.java:75) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at net.minecraftforge.fml.relauncher.CoreModManager$FMLPluginWrapper.injectIntoClassLoader(CoreModManager.java:165) ~[forge-1.12.2-14.23.5.2855.jar:?]
        ... 8 more
Caused by: java.io.FileNotFoundException: https://dl.dropboxusercontent.com/u/47135879/Baubles-1.8.9-1.1.3.0.jar
        at sun.net.www.protocol.http.HttpURLConnection.getInputStream0(Unknown Source) ~[?:1.8.0_301]
        at sun.net.www.protocol.http.HttpURLConnection.access$200(Unknown Source) ~[?:1.8.0_301]
        at sun.net.www.protocol.http.HttpURLConnection$9.run(Unknown Source) ~[?:1.8.0_301]
        at sun.net.www.protocol.http.HttpURLConnection$9.run(Unknown Source) ~[?:1.8.0_301]
        at java.security.AccessController.doPrivileged(Native Method) ~[?:1.8.0_301]
        at java.security.AccessController.doPrivilegedWithCombiner(Unknown Source) ~[?:1.8.0_301]
        at sun.net.www.protocol.http.HttpURLConnection.getInputStream(Unknown Source) ~[?:1.8.0_301]
        at sun.net.www.protocol.https.HttpsURLConnectionImpl.getInputStream(Unknown Source) ~[?:1.8.0_301]
        at thaumcraft.loader.ThaumcraftLoader$DepLoadInst.download(ThaumcraftLoader.java:429) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader$DepLoadInst.install(ThaumcraftLoader.java:384) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader$DepLoadInst.load(ThaumcraftLoader.java:606) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader$DepLoadInst.loadDeps(ThaumcraftLoader.java:593) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader$DepLoadInst.load(ThaumcraftLoader.java:523) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader.load(ThaumcraftLoader.java:712) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader.call(ThaumcraftLoader.java:737) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at thaumcraft.loader.ThaumcraftLoader.call(ThaumcraftLoader.java:75) ~[Thaumcraft-1.8.9-5.2.4.jar:?]
        at net.minecraftforge.fml.relauncher.CoreModManager$FMLPluginWrapper.injectIntoClassLoader(CoreModManager.java:165) ~[forge-1.12.2-14.23.5.2855.jar:?]
        ... 8 more
A problem occurred running the Server launcher.[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:34]: java.lang.reflect.InvocationTargetException
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:34]:       at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:34]:       at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:34]:       at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:34]:       at java.lang.reflect.Method.invoke(Unknown Source)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:34]:       at net.minecraftforge.fml.relauncher.ServerLaunchWrapper.run(ServerLaunchWrapper.java:70)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:main:34]:       at net.minecraftforge.fml.relauncher.ServerLaunchWrapper.main(ServerLaunchWrapper.java:34)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:75]: Caused by: net.minecraftforge.fml.relauncher.FMLSecurityManager$ExitTrappedException
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:75]:        at net.minecraftforge.fml.relauncher.FMLSecurityManager.checkPermission(FMLSecurityManager.java:49)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:75]:        at java.lang.SecurityManager.checkExit(Unknown Source)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:75]:        at java.lang.Runtime.exit(Unknown Source)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:75]:        at java.lang.System.exit(Unknown Source)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:75]:        at net.minecraft.launchwrapper.Launch.launch(Launch.java:138)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:75]:        at net.minecraft.launchwrapper.Launch.main(Launch.java:28)
[19:17:15] [main/INFO] [STDERR]: [net.minecraftforge.fml.relauncher.ServerLaunchWrapper:run:75]:        ... 6 more

Guest
This topic is now closed to further replies.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • Version 1.19 - Forge 41.0.63 I want to create a wolf entity that I can ride, so far it seems to be working, but the problem is that when I get on the wolf, I can’t control it. I then discovered that the issue is that the server doesn’t detect that I’m riding the wolf, so I’m struggling with synchronization. However, it seems to not be working properly. As I understand it, the server receives the packet but doesn’t register it correctly. I’m a bit new to Java, and I’ll try to provide all the relevant code and prints *The comments and prints are translated by chatgpt since they were originally in Spanish* Thank you very much in advance No player is mounted, or the passenger is not a player. No player is mounted, or the passenger is not a player. No player is mounted, or the passenger is not a player. No player is mounted, or the passenger is not a player. No player is mounted, or the passenger is not a player. MountableWolfEntity package com.vals.valscraft.entity; import com.vals.valscraft.network.MountSyncPacket; import com.vals.valscraft.network.NetworkHandler; import net.minecraft.client.Minecraft; import net.minecraft.network.syncher.EntityDataAccessor; import net.minecraft.network.syncher.EntityDataSerializers; import net.minecraft.network.syncher.SynchedEntityData; import net.minecraft.server.MinecraftServer; import net.minecraft.server.level.ServerPlayer; import net.minecraft.world.entity.EntityType; import net.minecraft.world.entity.Mob; import net.minecraft.world.entity.ai.attributes.AttributeSupplier; import net.minecraft.world.entity.ai.attributes.Attributes; import net.minecraft.world.entity.animal.Wolf; import net.minecraft.world.entity.player.Player; import net.minecraft.world.entity.Entity; import net.minecraft.world.InteractionHand; import net.minecraft.world.InteractionResult; import net.minecraft.world.item.ItemStack; import net.minecraft.world.item.Items; import net.minecraft.world.level.Level; import net.minecraft.world.phys.Vec3; import net.minecraftforge.event.TickEvent; import net.minecraftforge.eventbus.api.SubscribeEvent; import net.minecraftforge.network.PacketDistributor; public class MountableWolfEntity extends Wolf { private boolean hasSaddle; private static final EntityDataAccessor<Byte> DATA_ID_FLAGS = SynchedEntityData.defineId(MountableWolfEntity.class, EntityDataSerializers.BYTE); public MountableWolfEntity(EntityType<? extends Wolf> type, Level level) { super(type, level); this.hasSaddle = false; } @Override protected void defineSynchedData() { super.defineSynchedData(); this.entityData.define(DATA_ID_FLAGS, (byte)0); } public static AttributeSupplier.Builder createAttributes() { return Wolf.createAttributes() .add(Attributes.MAX_HEALTH, 20.0) .add(Attributes.MOVEMENT_SPEED, 0.3); } @Override public InteractionResult mobInteract(Player player, InteractionHand hand) { ItemStack itemstack = player.getItemInHand(hand); if (itemstack.getItem() == Items.SADDLE && !this.hasSaddle()) { if (!player.isCreative()) { itemstack.shrink(1); } this.setSaddle(true); return InteractionResult.SUCCESS; } else if (!level.isClientSide && this.hasSaddle()) { player.startRiding(this); MountSyncPacket packet = new MountSyncPacket(true); // 'true' means the player is mounted NetworkHandler.CHANNEL.sendToServer(packet); // Ensure the server handles the packet return InteractionResult.SUCCESS; } return InteractionResult.PASS; } @Override public void travel(Vec3 travelVector) { if (this.isVehicle() && this.getControllingPassenger() instanceof Player) { System.out.println("The wolf has a passenger."); System.out.println("The passenger is a player."); Player player = (Player) this.getControllingPassenger(); // Ensure the player is the controller this.setYRot(player.getYRot()); this.yRotO = this.getYRot(); this.setXRot(player.getXRot() * 0.5F); this.setRot(this.getYRot(), this.getXRot()); this.yBodyRot = this.getYRot(); this.yHeadRot = this.yBodyRot; float forward = player.zza; float strafe = player.xxa; if (forward <= 0.0F) { forward *= 0.25F; } this.flyingSpeed = this.getSpeed() * 0.1F; this.setSpeed((float) this.getAttributeValue(Attributes.MOVEMENT_SPEED) * 1.5F); this.setDeltaMovement(new Vec3(strafe, travelVector.y, forward).scale(this.getSpeed())); this.calculateEntityAnimation(this, false); } else { // The wolf does not have a passenger or the passenger is not a player System.out.println("No player is mounted, or the passenger is not a player."); super.travel(travelVector); } } public boolean hasSaddle() { return this.hasSaddle; } public void setSaddle(boolean hasSaddle) { this.hasSaddle = hasSaddle; } @Override protected void dropEquipment() { super.dropEquipment(); if (this.hasSaddle()) { this.spawnAtLocation(Items.SADDLE); this.setSaddle(false); } } @SubscribeEvent public static void onServerTick(TickEvent.ServerTickEvent event) { if (event.phase == TickEvent.Phase.START) { MinecraftServer server = net.minecraftforge.server.ServerLifecycleHooks.getCurrentServer(); if (server != null) { for (ServerPlayer player : server.getPlayerList().getPlayers()) { if (player.isPassenger() && player.getVehicle() instanceof MountableWolfEntity) { MountableWolfEntity wolf = (MountableWolfEntity) player.getVehicle(); System.out.println("Tick: " + player.getName().getString() + " is correctly mounted on " + wolf); } } } } } private boolean lastMountedState = false; @Override public void tick() { super.tick(); if (!this.level.isClientSide) { // Only on the server boolean isMounted = this.isVehicle() && this.getControllingPassenger() instanceof Player; // Only print if the state changed if (isMounted != lastMountedState) { if (isMounted) { Player player = (Player) this.getControllingPassenger(); // Verify the passenger is a player System.out.println("Server: Player " + player.getName().getString() + " is now mounted."); } else { System.out.println("Server: The wolf no longer has a passenger."); } lastMountedState = isMounted; } } } @Override public void addPassenger(Entity passenger) { super.addPassenger(passenger); if (passenger instanceof Player) { Player player = (Player) passenger; if (!this.level.isClientSide && player instanceof ServerPlayer) { // Send the packet to the server to indicate the player is mounted NetworkHandler.CHANNEL.send(PacketDistributor.PLAYER.with(() -> (ServerPlayer) player), new MountSyncPacket(true)); } } } @Override public void removePassenger(Entity passenger) { super.removePassenger(passenger); if (passenger instanceof Player) { Player player = (Player) passenger; if (!this.level.isClientSide && player instanceof ServerPlayer) { // Send the packet to the server to indicate the player is no longer mounted NetworkHandler.CHANNEL.send(PacketDistributor.PLAYER.with(() -> (ServerPlayer) player), new MountSyncPacket(false)); } } } @Override public boolean isControlledByLocalInstance() { Entity entity = this.getControllingPassenger(); return entity instanceof Player; } @Override public void positionRider(Entity passenger) { if (this.hasPassenger(passenger)) { double xOffset = Math.cos(Math.toRadians(this.getYRot() + 90)) * 0.4; double zOffset = Math.sin(Math.toRadians(this.getYRot() + 90)) * 0.4; passenger.setPos(this.getX() + xOffset, this.getY() + this.getPassengersRidingOffset() + passenger.getMyRidingOffset(), this.getZ() + zOffset); } } } MountSyncPacket package com.vals.valscraft.network; import com.vals.valscraft.entity.MountableWolfEntity; import net.minecraft.network.FriendlyByteBuf; import net.minecraft.server.level.ServerLevel; import net.minecraft.server.level.ServerPlayer; import net.minecraft.world.entity.Entity; import net.minecraft.world.entity.player.Player; import net.minecraftforge.network.NetworkEvent; import java.util.function.Supplier; public class MountSyncPacket { private final boolean isMounted; public MountSyncPacket(boolean isMounted) { this.isMounted = isMounted; } public void encode(FriendlyByteBuf buffer) { buffer.writeBoolean(isMounted); } public static MountSyncPacket decode(FriendlyByteBuf buffer) { return new MountSyncPacket(buffer.readBoolean()); } public void handle(NetworkEvent.Context context) { context.enqueueWork(() -> { ServerPlayer player = context.getSender(); // Get the player from the context if (player != null) { // Verifies if the player has dismounted if (!isMounted) { Entity vehicle = player.getVehicle(); if (vehicle instanceof MountableWolfEntity wolf) { // Logic to remove the player as a passenger wolf.removePassenger(player); System.out.println("Server: Player " + player.getName().getString() + " is no longer mounted."); } } } }); context.setPacketHandled(true); // Marks the packet as handled } } networkHandler package com.vals.valscraft.network; import com.vals.valscraft.valscraft; import net.minecraft.resources.ResourceLocation; import net.minecraftforge.network.NetworkRegistry; import net.minecraftforge.network.simple.SimpleChannel; import net.minecraftforge.network.NetworkEvent; import java.util.function.Supplier; public class NetworkHandler { private static final String PROTOCOL_VERSION = "1"; public static final SimpleChannel CHANNEL = NetworkRegistry.newSimpleChannel( new ResourceLocation(valscraft.MODID, "main"), () -> PROTOCOL_VERSION, PROTOCOL_VERSION::equals, PROTOCOL_VERSION::equals ); public static void init() { int packetId = 0; // Register the mount synchronization packet CHANNEL.registerMessage( packetId++, MountSyncPacket.class, MountSyncPacket::encode, MountSyncPacket::decode, (msg, context) -> msg.handle(context.get()) // Get the context with context.get() ); } }  
    • Do you use features of inventory profiles next (ipnext) or is there a change without it?
    • Remove rubidium - you are already using embeddium, which is a fork of rubidium
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.