Jump to content

[1.10.2] Sync capabilities with client


JimiIT92

Recommended Posts

I've created a custom capability to add mana, strength and other stats. Server side they works as intended but i'm having troubles displaying them correctly client side. So, for instance, i have a mana bar that will display the current amount of mana. But it always display 100 (the base value), even if i send a message to the client telling it what is the current mana value. So here are the message and the message handler i'm using

package com.rpg.messages;

import com.rpg.capabilities.player.IPlayerCapabilities;

import io.netty.buffer.ByteBuf;
import net.minecraftforge.fml.common.network.simpleimpl.IMessage;

public class PlayerCapabilitiesMessage implements IMessage{

private IPlayerCapabilities value;

public PlayerCapabilitiesMessage() {
	this.value = null;
}

public PlayerCapabilitiesMessage(IPlayerCapabilities value) {
	this.value = value;
}

@Override
public void fromBytes(ByteBuf buf) {
	if(this.value != null) {
		this.value.setStrength(buf.readInt());
		this.value.setSkill(buf.readInt());
		this.value.setResistance(buf.readInt());
		this.value.setSpeed(buf.readInt());
		this.value.setVitality(buf.readInt());
		this.value.setMana(buf.readInt());
		this.value.setLevel(buf.readInt());
		this.value.setMaxHealth(buf.readFloat());
		this.value.setMaxHunger(buf.readFloat());
	}
}

@Override
public void toBytes(ByteBuf buf) {
	if(this.value != null) {
		buf.writeInt(this.value.getStrength());
		buf.writeInt(this.value.getSkill());
		buf.writeInt(this.value.getResistance());
		buf.writeInt(this.value.getSpeed());
		buf.writeInt(this.value.getVitality());
		buf.writeInt(this.value.getMana());
		buf.writeInt(this.value.getLevel());
		buf.writeFloat(this.value.getMaxHealth());
		buf.writeFloat(this.value.getMaxHunger());
	}
}

public void setValue(IPlayerCapabilities value) {
	this.value = value;
}

public IPlayerCapabilities getValue() {
	return this.value;
}
}

package com.rpg.messages;

import com.rpg.RPG;
import com.rpg.capabilities.player.IPlayerCapabilities;
import com.rpg.capabilities.player.PlayerCapabilitiesProvider;

import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.util.IThreadListener;
import net.minecraftforge.fml.common.network.simpleimpl.IMessage;
import net.minecraftforge.fml.common.network.simpleimpl.IMessageHandler;
import net.minecraftforge.fml.common.network.simpleimpl.MessageContext;

public class PlayerMessageHandler implements IMessageHandler<PlayerCapabilitiesMessage, IMessage>{

@Override
public IMessage onMessage(PlayerCapabilitiesMessage message, MessageContext ctx) {
	IThreadListener thread = RPG.PROXY.getListener(ctx);
	final EntityPlayer player = RPG.PROXY.getPlayer(ctx);
	final IPlayerCapabilities value = message.getValue();
	thread.addScheduledTask(new Runnable() {
		@Override
		public void run() {
			if(player != null) {
				IPlayerCapabilities capabilities = player.getCapability(PlayerCapabilitiesProvider.PLAYER_CAP, null);
				if(capabilities != null && value != null) {
					capabilities.setStrength(value.getStrength());
					capabilities.setSkill(value.getSkill());
					capabilities.setResistance(value.getResistance());
					capabilities.setSpeed(value.getSpeed());
					capabilities.setVitality(value.getVitality());
					capabilities.setMana(value.getMana());
					capabilities.setLevel(value.getLevel());
					capabilities.setMaxHealth(value.getMaxHealth());
					capabilities.setMaxHunger(value.getMaxHunger());
				}
			}
		}
	});
	return null;
}

}

 

This is the mana bar rendering code

package com.rpg.gui;

import org.lwjgl.opengl.GL11;

import com.rpg.RPG;
import com.rpg.capabilities.player.IPlayerCapabilities;
import com.rpg.capabilities.player.PlayerCapabilitiesProvider;

import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.Gui;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.util.ResourceLocation;
import net.minecraftforge.client.event.RenderGameOverlayEvent;
import net.minecraftforge.client.event.RenderGameOverlayEvent.ElementType;
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;

public class GuiOverlay extends Gui{
private Minecraft mc;
private static final ResourceLocation icons = new ResourceLocation(RPG.MODID, "textures/gui/icons.png");

public GuiOverlay(Minecraft mc) {
	super();
	this.mc = mc;
}


@SubscribeEvent
public void onRenderExperienceBar(RenderGameOverlayEvent event) {
	if (event.isCancelable() || event.getType() != ElementType.EXPERIENCE)
		return;

	int xPos = 2;
	int yPos = 2;

	GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
	GL11.glDisable(GL11.GL_LIGHTING);
	this.mc.getTextureManager().bindTexture(icons);

	EntityPlayer player = this.mc.thePlayer;
        IPlayerCapabilities iplayer = player.getCapability(PlayerCapabilitiesProvider.PLAYER_CAP, null);
        
        if(iplayer != null) {
        	this.drawTexturedModalRect(xPos, yPos, 0, 80, 100, 5);
    		int manaBarWidth = (int) (((float) iplayer.getMana() / 100) * 100);
    		this.drawTexturedModalRect(xPos, yPos, 0, 85, manaBarWidth, 5);
    		this.drawCenteredString(this.mc.fontRendererObj, String.valueOf(iplayer.getMana()),xPos + 50, yPos - 1, 0xFFFFFF);
        }
}
}

 

This is how i registered the message

public static SimpleNetworkWrapper NETWORK;
@EventHandler
    public void preInit(FMLPreInitializationEvent event) {
    	NETWORK = NetworkRegistry.INSTANCE.newSimpleChannel(MODID);
    	
    	NETWORK.registerMessage(PlayerMessageHandler.class, PlayerCapabilitiesMessage.class, 1, Side.CLIENT);
    }

 

And these are the proxyes

package com.rpg.proxy;

import com.rpg.events.EventDimensionChange;
import com.rpg.events.EventPlayerClone;
import com.rpg.events.EventPlayerLogIn;
import com.rpg.events.EventPlayerTick;
import com.rpg.messages.PlayerMessageHandler;

import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.util.IThreadListener;
import net.minecraft.world.WorldServer;
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.fml.common.network.simpleimpl.MessageContext;

public class CommonProxy {

public void init() {
	MinecraftForge.EVENT_BUS.register(new PlayerMessageHandler());
}

public IThreadListener getListener(MessageContext ctx) {
	return (WorldServer) ctx.getServerHandler().playerEntity.worldObj;
}

public EntityPlayer getPlayer(MessageContext ctx) {
	return ctx.getServerHandler().playerEntity;
}
}

package com.rpg.proxy;

import com.rpg.RPG;
import com.rpg.capabilities.CapabilityHandler;
import com.rpg.capabilities.item.IItemCapabilities;
import com.rpg.capabilities.item.ItemCapabilities;
import com.rpg.capabilities.item.ItemCapabilitiesStorage;
import com.rpg.capabilities.player.IPlayerCapabilities;
import com.rpg.capabilities.player.PlayerCapabilities;
import com.rpg.capabilities.player.PlayerCapabilitiesStorage;
import com.rpg.events.EventDimensionChange;
import com.rpg.events.EventPlayerClone;
import com.rpg.events.EventPlayerLogIn;
import com.rpg.events.EventPlayerRespawn;
import com.rpg.events.EventPlayerTick;
import com.rpg.events.EventRightClick;
import com.rpg.gui.GuiHandler;
import com.rpg.gui.GuiOverlay;

import net.minecraft.client.Minecraft;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.util.IThreadListener;
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.common.capabilities.CapabilityManager;
import net.minecraftforge.fml.common.network.NetworkRegistry;
import net.minecraftforge.fml.common.network.simpleimpl.MessageContext;
import net.minecraftforge.fml.relauncher.Side;

public class ClientProxy extends CommonProxy{

public void init() {
	CapabilityManager.INSTANCE.register(IPlayerCapabilities.class, new PlayerCapabilitiesStorage(), PlayerCapabilities.class);
	CapabilityManager.INSTANCE.register(IItemCapabilities.class, new ItemCapabilitiesStorage(), ItemCapabilities.class);

	MinecraftForge.EVENT_BUS.register(new CapabilityHandler());

	MinecraftForge.EVENT_BUS.register(new EventDimensionChange());
	MinecraftForge.EVENT_BUS.register(new EventPlayerClone());
	MinecraftForge.EVENT_BUS.register(new EventPlayerLogIn());
	MinecraftForge.EVENT_BUS.register(new EventPlayerTick());
	MinecraftForge.EVENT_BUS.register(new EventPlayerRespawn());
	MinecraftForge.EVENT_BUS.register(new EventRightClick());

	MinecraftForge.EVENT_BUS.register(new GuiOverlay(Minecraft.getMinecraft()));

	NetworkRegistry.INSTANCE.registerGuiHandler(RPG.INSTANCE, new GuiHandler());
}

public IThreadListener getListener(MessageContext ctx) {
	return ctx.side == Side.CLIENT ? Minecraft.getMinecraft() : super.getListener(ctx);
}

public EntityPlayer getPlayer(MessageContext ctx) {
	return ctx.side == Side.CLIENT ? Minecraft.getMinecraft().thePlayer : super.getPlayer(ctx);
}
}

 

Every tick i do this

package com.rpg.events;

import com.rpg.RPG;
import com.rpg.capabilities.player.IPlayerCapabilities;
import com.rpg.capabilities.player.PlayerCapabilitiesProvider;
import com.rpg.messages.PlayerCapabilitiesMessage;

import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.entity.player.EntityPlayerMP;
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
import net.minecraftforge.fml.common.gameevent.TickEvent.PlayerTickEvent;
import net.minecraftforge.fml.relauncher.Side;

public class EventPlayerTick {

@SubscribeEvent
public void onPlayerTick(PlayerTickEvent event) {
	if(event.side == Side.SERVER) {
		EntityPlayer player = event.player;
        IPlayerCapabilities capabilities = player.getCapability(PlayerCapabilitiesProvider.PLAYER_CAP, null);
		RPG.NETWORK.sendTo(new PlayerCapabilitiesMessage(capabilities), (EntityPlayerMP) player);
	}	
}
}

 

As i said server side there are no problems at all, it's just that in GUI isn't displayed the correct value. How can i fix this? :)

Don't blame me if i always ask for your help. I just want to learn to be better :)

Link to comment
Share on other sites

Why are you registering the Message Handler for server adn clietn, only the client needs it? And the EventPlayerTick  get only registered on the CLient but this is needed on the server because you send the Message from the Server to the CLient.

catch(Exception e)

{

 

}

Yay, Pokémon exception handling, gotta catch 'em all (and then do nothing with 'em).

Link to comment
Share on other sites

Woops, i've changed that so now the Tick Handler is registered in the common proxy and the Message Handler is only registered in the pre-init event, but i got the same issue. Also debugging i noticed that in the message, when i read the value, this return null, even if i specify a capability in the constructor of that message :/

 

Don't blame me if i always ask for your help. I just want to learn to be better :)

Link to comment
Share on other sites

Ok, after doing some changes now it works and the value si displayed correctly. But now i'm having some troubles with the right click event and a GUI. First at all it looks like the right click event is fired twice

This is the event code

@SubscribeEvent
public void onRightClick(PlayerInteractEvent.RightClickBlock event) {
	if(!event.getWorld().isRemote) {
		EntityPlayer player = event.getEntityPlayer();
        IPlayerCapabilities capabilities = player.getCapability(PlayerCapabilitiesProvider.PLAYER_CAP, null);
        if(capabilities != null) {
        	capabilities.removeMana(1);
	        event.getEntityPlayer().addChatMessage(new TextComponentString(capabilities.getMana() + ""));
	        RPG.NETWORK.sendTo(new PlayerCapabilitiesMessage(capabilities), (EntityPlayerMP) player);
        }
	}
}

 

This event should be fired only server side and will send a chat message to the player with the current amount of mana. But for some reason, if for example i have 100 mana, when i right click a block the player got 2 chat messages and the mana goes to 98, meaning that the code is called twice and i don't know why this happen :/

For the GUI i have this GUI

package com.rpg.gui;

import java.io.IOException;

import org.lwjgl.opengl.GL11;

import com.rpg.RPG;
import com.rpg.capabilities.player.IPlayerCapabilities;
import com.rpg.capabilities.player.PlayerCapabilitiesProvider;

import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.GuiButton;
import net.minecraft.client.gui.GuiMerchant;
import net.minecraft.client.gui.GuiScreen;
import net.minecraft.client.renderer.GlStateManager;
import net.minecraft.client.renderer.OpenGlHelper;
import net.minecraft.client.renderer.RenderHelper;
import net.minecraft.client.renderer.entity.RenderManager;
import net.minecraft.client.resources.I18n;
import net.minecraft.entity.EntityLivingBase;
import net.minecraft.util.ResourceLocation;
import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly;

public class GuiTalents extends GuiScreen {

private static final ResourceLocation TALENTS = new ResourceLocation(RPG.MODID, "textures/gui/talents.png");

public GuiTalents() {

}

/** The old x position of the mouse pointer */
private float oldMouseX;
/** The old y position of the mouse pointer */
private float oldMouseY;

@Override
public void drawScreen(int mouseX, int mouseY, float partialTicks) {

	GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
	GL11.glDisable(GL11.GL_LIGHTING);
	this.mc.getTextureManager().bindTexture(this.TALENTS);

	int xPos = width / 2 - 87;
	int yPos = height / 2 - 87;
	this.drawTexturedModalRect(xPos, yPos, 0, 0, 176, 185);
	this.oldMouseX = (float) mouseX;
	this.oldMouseY = (float) mouseY;
	IPlayerCapabilities capabilities = Minecraft.getMinecraft().thePlayer
			.getCapability(PlayerCapabilitiesProvider.PLAYER_CAP, null);
	if (capabilities != null) {
		drawEntityOnScreen(xPos + 31, yPos + 75, 30, (float) (xPos + 31) - this.oldMouseX,
				(float) (yPos + 75 - 50) - this.oldMouseY, this.mc.thePlayer);
		this.fontRendererObj.drawString(Minecraft.getMinecraft().thePlayer.getName(), xPos + 80, yPos + 10,
				4210752);

		this.fontRendererObj.drawString(I18n.format("gui.talents.mana") + ": ", xPos + 80, yPos + 28, 4210752);
		this.fontRendererObj.drawString(I18n.format("gui.talents.level") + ": ", xPos + 80, yPos + 48, 4210752);
		this.fontRendererObj.drawString(I18n.format("gui.talents.class") + ": ", xPos + 80, yPos + 68, 4210752);
		this.fontRendererObj.drawString(I18n.format("gui.talents.vitality") + ": ", xPos + 30, yPos + 88, 4210752);
		this.fontRendererObj.drawString(I18n.format("gui.talents.strength") + ": ", xPos + 30, yPos + 108, 4210752);
		this.fontRendererObj.drawString(I18n.format("gui.talents.skill") + ": ", xPos + 30, yPos + 128, 4210752);
		this.fontRendererObj.drawString(I18n.format("gui.talents.speed") + ": ", xPos + 30, yPos + 148, 4210752);
		this.fontRendererObj.drawString(I18n.format("gui.talents.resistance") + ": ", xPos + 30, yPos + 168,
				4210752);

		this.fontRendererObj.drawString(String.valueOf(capabilities.getMana() + "/100"), xPos + 116, yPos + 28,
				4210752);
		this.fontRendererObj.drawString(String.valueOf(capabilities.getLevel() + "/30"), xPos + 116, yPos + 48,
				4210752);
		this.fontRendererObj.drawString(String.valueOf("No Class"), xPos + 116, yPos + 68, 4210752);
		this.fontRendererObj.drawString(String.valueOf(capabilities.getVitality() + "/10"), xPos + 116, yPos + 88,
				4210752);
		this.fontRendererObj.drawString(String.valueOf(capabilities.getStrength() + "/10"), xPos + 116, yPos + 108,
				4210752);
		this.fontRendererObj.drawString(String.valueOf(capabilities.getSkill() + "/10"), xPos + 116, yPos + 128,
				4210752);
		this.fontRendererObj.drawString(String.valueOf(capabilities.getSpeed() + "/10"), xPos + 116, yPos + 148,
				4210752);
		this.fontRendererObj.drawString(String.valueOf(capabilities.getResistance() + "/10"), xPos + 116,
				yPos + 168, 4210752);

		int points = capabilities.getStrength() + capabilities.getVitality() + capabilities.getResistance()
				+ capabilities.getSkill() + capabilities.getSpeed();

		if (points <= capabilities.getLevel()) {
			this.buttonList.add(new UpgradeButton(1, xPos + 116 + 40, yPos + 88));
			this.buttonList.add(new UpgradeButton(2, xPos + 116 + 40, yPos + 108));
			this.buttonList.add(new UpgradeButton(3, xPos + 116 + 40, yPos + 128));
			this.buttonList.add(new UpgradeButton(4, xPos + 116 + 40, yPos + 148));
			this.buttonList.add(new UpgradeButton(5, xPos + 116 + 40, yPos + 168));
		}
	}
	super.drawScreen(mouseX, mouseY, partialTicks);
}

@Override
public boolean doesGuiPauseGame() {
	return false;
}

@Override
protected void actionPerformed(GuiButton button) throws IOException {
	IPlayerCapabilities capabilities = Minecraft.getMinecraft().thePlayer
			.getCapability(PlayerCapabilitiesProvider.PLAYER_CAP, null);
	if (capabilities != null) {
		if (button.id == 1) {
			capabilities.addVitality(1);
			return;
		}
	}

	super.actionPerformed(button);
}

public static void drawEntityOnScreen(int posX, int posY, int scale, float mouseX, float mouseY,
		EntityLivingBase ent) {
	GlStateManager.enableColorMaterial();
	GlStateManager.pushMatrix();
	GlStateManager.translate((float) posX, (float) posY, 50.0F);
	GlStateManager.scale((float) (-scale), (float) scale, (float) scale);
	GlStateManager.rotate(180.0F, 0.0F, 0.0F, 1.0F);
	float f = ent.renderYawOffset;
	float f1 = ent.rotationYaw;
	float f2 = ent.rotationPitch;
	float f3 = ent.prevRotationYawHead;
	float f4 = ent.rotationYawHead;
	GlStateManager.rotate(135.0F, 0.0F, 1.0F, 0.0F);
	RenderHelper.enableStandardItemLighting();
	GlStateManager.rotate(-135.0F, 0.0F, 1.0F, 0.0F);
	GlStateManager.rotate(-((float) Math.atan((double) (mouseY / 40.0F))) * 20.0F, 1.0F, 0.0F, 0.0F);
	ent.renderYawOffset = (float) Math.atan((double) (mouseX / 40.0F)) * 20.0F;
	ent.rotationYaw = (float) Math.atan((double) (mouseX / 40.0F)) * 40.0F;
	ent.rotationPitch = -((float) Math.atan((double) (mouseY / 40.0F))) * 20.0F;
	ent.rotationYawHead = ent.rotationYaw;
	ent.prevRotationYawHead = ent.rotationYaw;
	GlStateManager.translate(0.0F, 0.0F, 0.0F);
	RenderManager rendermanager = Minecraft.getMinecraft().getRenderManager();
	rendermanager.setPlayerViewY(180.0F);
	rendermanager.setRenderShadow(false);
	rendermanager.doRenderEntity(ent, 0.0D, 0.0D, 0.0D, 0.0F, 1.0F, false);
	rendermanager.setRenderShadow(true);
	ent.renderYawOffset = f;
	ent.rotationYaw = f1;
	ent.rotationPitch = f2;
	ent.prevRotationYawHead = f3;
	ent.rotationYawHead = f4;
	GlStateManager.popMatrix();
	RenderHelper.disableStandardItemLighting();
	GlStateManager.disableRescaleNormal();
	GlStateManager.setActiveTexture(OpenGlHelper.lightmapTexUnit);
	GlStateManager.disableTexture2D();
	GlStateManager.setActiveTexture(OpenGlHelper.defaultTexUnit);
}

@SideOnly(Side.CLIENT)
static class UpgradeButton extends GuiButton {

	public UpgradeButton(int buttonID, int x, int y) {
		super(buttonID, x, y, 11, 7, "");
		this.visible = true;
		this.enabled = true;
	}

	/**
	 * Draws this button to the screen.
	 */
	public void drawButton(Minecraft mc, int mouseX, int mouseY) {
		mc.getTextureManager().bindTexture(GuiTalents.TALENTS);
		GlStateManager.color(1.0F, 1.0F, 1.0F, 1.0F);
		this.hovered = mouseX >= this.xPosition && mouseY >= this.yPosition && mouseX < this.xPosition + 11
				&& mouseY < this.yPosition + 7;
		if (this.hovered)
			this.drawTexturedModalRect(this.xPosition, this.yPosition, 14, 194, 11, 7);
		else
			this.drawTexturedModalRect(this.xPosition, this.yPosition, 0, 194, 11, 7);
	}
}

}

 

But when i click on a button the value is not incremented by 1 (instead goes from 12 to 45!) and also when i reload the world the value goes back to 0. Now i think this is because this modification is handled client side (in the GUI) but i don't know what should i send to the server (the same message that i send to the client?). Please help me understand why this happen, since it's the very first time i work with capabilities and networking in general :)

Don't blame me if i always ask for your help. I just want to learn to be better :)

Link to comment
Share on other sites

First at all it looks like the right click event is fired twice

 

Once for each hand.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • I have been trying to make a server with forge but I keep running into an issue. I have jdk 22 installed as well as Java 8. here is the debug file  
    • it crashed again     What the console says : [00:02:03] [Server thread/INFO] [Easy NPC/]: [EntityManager] Server started! [00:02:03] [Server thread/INFO] [co.gi.al.ic.IceAndFire/]: {iceandfire:fire_dragon_roost=true, iceandfire:fire_lily=true, iceandfire:spawn_dragon_skeleton_fire=true, iceandfire:lightning_dragon_roost=true, iceandfire:spawn_dragon_skeleton_lightning=true, iceandfire:ice_dragon_roost=true, iceandfire:ice_dragon_cave=true, iceandfire:lightning_dragon_cave=true, iceandfire:cyclops_cave=true, iceandfire:spawn_wandering_cyclops=true, iceandfire:spawn_sea_serpent=true, iceandfire:frost_lily=true, iceandfire:hydra_cave=true, iceandfire:lightning_lily=true, iceandfireixie_village=true, iceandfire:myrmex_hive_jungle=true, iceandfire:myrmex_hive_desert=true, iceandfire:silver_ore=true, iceandfire:siren_island=true, iceandfire:spawn_dragon_skeleton_ice=true, iceandfire:spawn_stymphalian_bird=true, iceandfire:fire_dragon_cave=true, iceandfire:sapphire_ore=true, iceandfire:spawn_hippocampus=true, iceandfire:spawn_death_worm=true} [00:02:03] [Server thread/INFO] [co.gi.al.ic.IceAndFire/]: {TROLL_S=true, HIPPOGRYPH=true, AMPHITHERE=true, COCKATRICE=true, TROLL_M=true, DREAD_LICH=true, TROLL_F=true} [00:02:03] [Server thread/INFO] [ne.be.lo.WeaponRegistry/]: Encoded Weapon Attribute registry size (with package overhead): 41976 bytes (in 5 string chunks with the size of 10000) [00:02:03] [Server thread/INFO] [patchouli/]: Sending reload packet to clients [00:02:03] [Server thread/WARN] [voicechat/]: [voicechat] Running in offline mode - Voice chat encryption is not secure! [00:02:03] [VoiceChatServerThread/INFO] [voicechat/]: [voicechat] Using server-ip as bind address: 0.0.0.0 [00:02:03] [Server thread/WARN] [ModernFix/]: Dedicated server took 22.521 seconds to load [00:02:03] [VoiceChatServerThread/INFO] [voicechat/]: [voicechat] Voice chat server started at 0.0.0.0:25565 [00:02:03] [Server thread/WARN] [minecraft/SynchedEntityData]: defineId called for: class net.minecraft.world.entity.player.Player from class tschipp.carryon.common.carry.CarryOnDataManager [00:02:03] [Server thread/INFO] [ne.mi.co.AdvancementLoadFix/]: Using new advancement loading for net.minecraft.server.PlayerAdvancements@2941ffd5 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 0 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 1 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 2 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 3 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 4 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 5 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 6 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 7 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 8 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 9 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 10 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 11 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 12 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 13 [00:02:10] [Netty Epoll Server IO #2/INFO] [Calio/]: Received acknowledgment for login packet with id 14 [00:02:19] [Server thread/INFO] [ne.mi.co.AdvancementLoadFix/]: Using new advancement loading for net.minecraft.server.PlayerAdvancements@ebc7ef2 [00:02:19] [Server thread/INFO] [minecraft/PlayerList]: ZacAdos[/90.2.17.162:49242] logged in with entity id 1062 at (-1848.6727005281205, 221.0, -3054.2468255848935) [00:02:19] [Server thread/ERROR] [ModernFix/]: Skipping entity ID sync for com.talhanation.smallships.world.entity.ship.Ship: java.lang.NoClassDefFoundError: net/minecraft/client/CameraType [00:02:19] [Server thread/INFO] [minecraft/MinecraftServer]: - Gloop - ZacAdos joined the game [00:02:19] [Server thread/INFO] [xa.pa.OpenPartiesAndClaims/]: Updating all forceload tickets for cc56befd-d376-3526-a760-340713c478bd [00:02:19] [Server thread/INFO] [se.mi.te.da.DataManager/]: Sending data to client: ZacAdos [00:02:19] [Server thread/INFO] [voicechat/]: [voicechat] Received secret request of - Gloop - ZacAdos (17) [00:02:19] [Server thread/INFO] [voicechat/]: [voicechat] Sent secret to - Gloop - ZacAdos [00:02:21] [VoiceChatPacketProcessingThread/INFO] [voicechat/]: [voicechat] Successfully authenticated player cc56befd-d376-3526-a760-340713c478bd [00:02:22] [VoiceChatPacketProcessingThread/INFO] [voicechat/]: [voicechat] Successfully validated connection of player cc56befd-d376-3526-a760-340713c478bd [00:02:22] [VoiceChatPacketProcessingThread/INFO] [voicechat/]: [voicechat] Player - Gloop - ZacAdos (cc56befd-d376-3526-a760-340713c478bd) successfully connected to voice chat stop [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: Stopping the server [00:02:34] [Server thread/INFO] [mo.pl.ar.ArmourersWorkshop/]: stop local service [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: Stopping server [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: Saving players [00:02:34] [Server thread/INFO] [minecraft/ServerGamePacketListenerImpl]: ZacAdos lost connection: Server closed [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: - Gloop - ZacAdos left the game [00:02:34] [Server thread/INFO] [xa.pa.OpenPartiesAndClaims/]: Updating all forceload tickets for cc56befd-d376-3526-a760-340713c478bd [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: Saving worlds [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: Saving chunks for level 'ServerLevel[world]'/minecraft:overworld [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: Saving chunks for level 'ServerLevel[world]'/minecraft:the_end [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: Saving chunks for level 'ServerLevel[world]'/minecraft:the_nether [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: ThreadedAnvilChunkStorage (world): All chunks are saved [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: ThreadedAnvilChunkStorage (DIM1): All chunks are saved [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: ThreadedAnvilChunkStorage (DIM-1): All chunks are saved [00:02:34] [Server thread/INFO] [minecraft/MinecraftServer]: ThreadedAnvilChunkStorage: All dimensions are saved [00:02:34] [Server thread/INFO] [xa.pa.OpenPartiesAndClaims/]: Stopping IO worker... [00:02:34] [Server thread/INFO] [xa.pa.OpenPartiesAndClaims/]: Stopped IO worker! [00:02:34] [Server thread/INFO] [Calio/]: Removing Dynamic Registries for: net.minecraft.server.dedicated.DedicatedServer@7dc879e1 [MineStrator Daemon]: Checking server disk space usage, this could take a few seconds... [MineStrator Daemon]: Updating process configuration files... [MineStrator Daemon]: Ensuring file permissions are set correctly, this could take a few seconds... [MineStrator Daemon]: Pulling Docker container image, this could take a few minutes to complete... [MineStrator Daemon]: Finished pulling Docker container image container@pterodactyl~ java -version openjdk version "17.0.10" 2024-01-16 OpenJDK Runtime Environment Temurin-17.0.10+7 (build 17.0.10+7) OpenJDK 64-Bit Server VM Temurin-17.0.10+7 (build 17.0.10+7, mixed mode, sharing) container@pterodactyl~ java -Xms128M -Xmx6302M -Dterminal.jline=false -Dterminal.ansi=true -Djline.terminal=jline.UnsupportedTerminal -p libraries/cpw/mods/bootstraplauncher/1.1.2/bootstraplauncher-1.1.2.jar:libraries/cpw/mods/securejarhandler/2.1.4/securejarhandler-2.1.4.jar:libraries/org/ow2/asm/asm-commons/9.5/asm-commons-9.5.jar:libraries/org/ow2/asm/asm-util/9.5/asm-util-9.5.jar:libraries/org/ow2/asm/asm-analysis/9.5/asm-analysis-9.5.jar:libraries/org/ow2/asm/asm-tree/9.5/asm-tree-9.5.jar:libraries/org/ow2/asm/asm/9.5/asm-9.5.jar:libraries/net/minecraftforge/JarJarFileSystems/0.3.16/JarJarFileSystems-0.3.16.jar --add-modules ALL-MODULE-PATH --add-opens java.base/java.util.jar=cpw.mods.securejarhandler --add-opens java.base/java.lang.invoke=cpw.mods.securejarhandler --add-exports java.base/sun.security.util=cpw.mods.securejarhandler --add-exports jdk.naming.dns/com.sun.jndi.dns=java.naming -Djava.net.preferIPv6Addresses=system -DignoreList=bootstraplauncher-1.1.2.jar,securejarhandler-2.1.4.jar,asm-commons-9.5.jar,asm-util-9.5.jar,asm-analysis-9.5.jar,asm-tree-9.5.jar,asm-9.5.jar,JarJarFileSystems-0.3.16.jar -DlibraryDirectory=libraries -DlegacyClassPath=libraries/cpw/mods/securejarhandler/2.1.4/securejarhandler-2.1.4.jar:libraries/org/ow2/asm/asm/9.5/asm-9.5.jar:libraries/org/ow2/asm/asm-commons/9.5/asm-commons-9.5.jar:libraries/org/ow2/asm/asm-tree/9.5/asm-tree-9.5.jar:libraries/org/ow2/asm/asm-util/9.5/asm-util-9.5.jar:libraries/org/ow2/asm/asm-analysis/9.5/asm-analysis-9.5.jar:libraries/net/minecraftforge/accesstransformers/8.0.4/accesstransformers-8.0.4.jar:libraries/org/antlr/antlr4-runtime/4.9.1/antlr4-runtime-4.9.1.jar:libraries/net/minecraftforge/eventbus/6.0.3/eventbus-6.0.3.jar:libraries/net/minecraftforge/forgespi/6.0.0/forgespi-6.0.0.jar:libraries/net/minecraftforge/coremods/5.0.1/coremods-5.0.1.jar:libraries/cpw/mods/modlauncher/10.0.8/modlauncher-10.0.8.jar:libraries/net/minecraftforge/unsafe/0.2.0/unsafe-0.2.0.jar:libraries/com/electronwill/night-config/core/3.6.4/core-3.6.4.jar:libraries/com/electronwill/night-config/toml/3.6.4/toml-3.6.4.jar:libraries/org/apache/maven/maven-artifact/3.8.5/maven-artifact-3.8.5.jar:libraries/net/jodah/typetools/0.8.3/typetools-0.8.3.jar:libraries/net/minecrell/terminalconsoleappender/1.2.0/terminalconsoleappender-1.2.0.jar:libraries/org/jline/jline-reader/3.12.1/jline-reader-3.12.1.jar:libraries/org/jline/jline-terminal/3.12.1/jline-terminal-3.12.1.jar:libraries/org/spongepowered/mixin/0.8.5/mixin-0.8.5.jar:libraries/org/openjdk/nashorn/nashorn-core/15.3/nashorn-core-15.3.jar:libraries/net/minecraftforge/JarJarSelector/0.3.16/JarJarSelector-0.3.16.jar:libraries/net/minecraftforge/JarJarMetadata/0.3.16/JarJarMetadata-0.3.16.jar:libraries/net/minecraftforge/fmlloader/1.19.2-43.3.0/fmlloader-1.19.2-43.3.0.jar:libraries/net/minecraft/server/1.19.2-20220805.130853/server-1.19.2-20220805.130853-extra.jar:libraries/com/github/oshi/oshi-core/5.8.5/oshi-core-5.8.5.jar:libraries/com/google/code/gson/gson/2.8.9/gson-2.8.9.jar:libraries/com/google/guava/failureaccess/1.0.1/failureaccess-1.0.1.jar:libraries/com/google/guava/guava/31.0.1-jre/guava-31.0.1-jre.jar:libraries/com/mojang/authlib/3.11.49/authlib-3.11.49.jar:libraries/com/mojang/brigadier/1.0.18/brigadier-1.0.18.jar:libraries/com/mojang/datafixerupper/5.0.28/datafixerupper-5.0.28.jar:libraries/com/mojang/javabridge/1.2.24/javabridge-1.2.24.jar:libraries/com/mojang/logging/1.0.0/logging-1.0.0.jar:libraries/commons-io/commons-io/2.11.0/commons-io-2.11.0.jar:libraries/io/netty/netty-buffer/4.1.77.Final/netty-buffer-4.1.77.Final.jar:libraries/io/netty/netty-codec/4.1.77.Final/netty-codec-4.1.77.Final.jar:libraries/io/netty/netty-common/4.1.77.Final/netty-common-4.1.77.Final.jar:libraries/io/netty/netty-handler/4.1.77.Final/netty-handler-4.1.77.Final.jar:libraries/io/netty/netty-resolver/4.1.77.Final/netty-resolver-4.1.77.Final.jar:libraries/io/netty/netty-transport/4.1.77.Final/netty-transport-4.1.77.Final.jar:libraries/io/netty/netty-transport-classes-epoll/4.1.77.Final/netty-transport-classes-epoll-4.1.77.Final.jar:libraries/io/netty/netty-transport-native-epoll/4.1.77.Final/netty-transport-native-epoll-4.1.77.Final-linux-x86_64.jar:libraries/io/netty/netty-transport-native-epoll/4.1.77.Final/netty-transport-native-epoll-4.1.77.Final-linux-aarch_64.jar:libraries/io/netty/netty-transport-native-unix-common/4.1.77.Final/netty-transport-native-unix-common-4.1.77.Final.jar:libraries/it/unimi/dsi/fastutil/8.5.6/fastutil-8.5.6.jar:libraries/net/java/dev/jna/jna/5.10.0/jna-5.10.0.jar:libraries/net/java/dev/jna/jna-platform/5.10.0/jna-platform-5.10.0.jar:libraries/net/sf/jopt-simple/jopt-simple/5.0.4/jopt-simple-5.0.4.jar:libraries/org/apache/commons/commons-lang3/3.12.0/commons-lang3-3.12.0.jar:libraries/org/apache/logging/log4j/log4j-api/2.17.0/log4j-api-2.17.0.jar:libraries/org/apache/logging/log4j/log4j-core/2.17.0/log4j-core-2.17.0.jar:libraries/org/apache/logging/log4j/log4j-slf4j18-impl/2.17.0/log4j-slf4j18-impl-2.17.0.jar:libraries/org/slf4j/slf4j-api/1.8.0-beta4/slf4j-api-1.8.0-beta4.jar cpw.mods.bootstraplauncher.BootstrapLauncher --launchTarget forgeserver --fml.forgeVersion 43.3.0 --fml.mcVersion 1.19.2 --fml.forgeGroup net.minecraftforge --fml.mcpVersion 20220805.130853 [00:02:42] [main/INFO] [cp.mo.mo.Launcher/MODLAUNCHER]: ModLauncher running: args [--launchTarget, forgeserver, --fml.forgeVersion, 43.3.0, --fml.mcVersion, 1.19.2, --fml.forgeGroup, net.minecraftforge, --fml.mcpVersion, 20220805.130853] [00:02:42] [main/INFO] [cp.mo.mo.Launcher/MODLAUNCHER]: ModLauncher 10.0.8+10.0.8+main.0ef7e830 starting: java version 17.0.10 by Eclipse Adoptium; OS Linux arch amd64 version 6.1.0-12-amd64 [00:02:43] [main/INFO] [mixin/]: SpongePowered MIXIN Subsystem Version=0.8.5 Source=union:/home/container/libraries/org/spongepowered/mixin/0.8.5/mixin-0.8.5.jar%2363!/ Service=ModLauncher Env=SERVER [00:02:43] [main/WARN] [ne.mi.fm.lo.mo.ModFileParser/LOADING]: Mod file /home/container/libraries/net/minecraftforge/fmlcore/1.19.2-43.3.0/fmlcore-1.19.2-43.3.0.jar is missing mods.toml file [00:02:43] [main/WARN] [ne.mi.fm.lo.mo.ModFileParser/LOADING]: Mod file /home/container/libraries/net/minecraftforge/javafmllanguage/1.19.2-43.3.0/javafmllanguage-1.19.2-43.3.0.jar is missing mods.toml file [00:02:43] [main/WARN] [ne.mi.fm.lo.mo.ModFileParser/LOADING]: Mod file /home/container/libraries/net/minecraftforge/lowcodelanguage/1.19.2-43.3.0/lowcodelanguage-1.19.2-43.3.0.jar is missing mods.toml file [00:02:43] [main/WARN] [ne.mi.fm.lo.mo.ModFileParser/LOADING]: Mod file /home/container/libraries/net/minecraftforge/mclanguage/1.19.2-43.3.0/mclanguage-1.19.2-43.3.0.jar is missing mods.toml file [00:02:44] [main/WARN] [ne.mi.ja.se.JarSelector/]: Attempted to select two dependency jars from JarJar which have the same identification: Mod File: and Mod File: . Using Mod File: [00:02:44] [main/WARN] [ne.mi.ja.se.JarSelector/]: Attempted to select a dependency jar for JarJar which was passed in as source: resourcefullib. Using Mod File: /home/container/mods/resourcefullib-forge-1.19.2-1.1.24.jar [00:02:44] [main/INFO] [ne.mi.fm.lo.mo.JarInJarDependencyLocator/]: Found 13 dependencies adding them to mods collection Latest log [29Mar2024 00:02:42.803] [main/INFO] [cpw.mods.modlauncher.Launcher/MODLAUNCHER]: ModLauncher running: args [--launchTarget, forgeserver, --fml.forgeVersion, 43.3.0, --fml.mcVersion, 1.19.2, --fml.forgeGroup, net.minecraftforge, --fml.mcpVersion, 20220805.130853] [29Mar2024 00:02:42.805] [main/INFO] [cpw.mods.modlauncher.Launcher/MODLAUNCHER]: ModLauncher 10.0.8+10.0.8+main.0ef7e830 starting: java version 17.0.10 by Eclipse Adoptium; OS Linux arch amd64 version 6.1.0-12-amd64 [29Mar2024 00:02:43.548] [main/INFO] [mixin/]: SpongePowered MIXIN Subsystem Version=0.8.5 Source=union:/home/container/libraries/org/spongepowered/mixin/0.8.5/mixin-0.8.5.jar%2363!/ Service=ModLauncher Env=SERVER [29Mar2024 00:02:43.876] [main/WARN] [net.minecraftforge.fml.loading.moddiscovery.ModFileParser/LOADING]: Mod file /home/container/libraries/net/minecraftforge/fmlcore/1.19.2-43.3.0/fmlcore-1.19.2-43.3.0.jar is missing mods.toml file [29Mar2024 00:02:43.877] [main/WARN] [net.minecraftforge.fml.loading.moddiscovery.ModFileParser/LOADING]: Mod file /home/container/libraries/net/minecraftforge/javafmllanguage/1.19.2-43.3.0/javafmllanguage-1.19.2-43.3.0.jar is missing mods.toml file [29Mar2024 00:02:43.877] [main/WARN] [net.minecraftforge.fml.loading.moddiscovery.ModFileParser/LOADING]: Mod file /home/container/libraries/net/minecraftforge/lowcodelanguage/1.19.2-43.3.0/lowcodelanguage-1.19.2-43.3.0.jar is missing mods.toml file [29Mar2024 00:02:43.878] [main/WARN] [net.minecraftforge.fml.loading.moddiscovery.ModFileParser/LOADING]: Mod file /home/container/libraries/net/minecraftforge/mclanguage/1.19.2-43.3.0/mclanguage-1.19.2-43.3.0.jar is missing mods.toml file [29Mar2024 00:02:44.033] [main/WARN] [net.minecraftforge.jarjar.selection.JarSelector/]: Attempted to select two dependency jars from JarJar which have the same identification: Mod File: and Mod File: . Using Mod File: [29Mar2024 00:02:44.034] [main/WARN] [net.minecraftforge.jarjar.selection.JarSelector/]: Attempted to select a dependency jar for JarJar which was passed in as source: resourcefullib. Using Mod File: /home/container/mods/resourcefullib-forge-1.19.2-1.1.24.jar [29Mar2024 00:02:44.034] [main/INFO] [net.minecraftforge.fml.loading.moddiscovery.JarInJarDependencyLocator/]: Found 13 dependencies adding them to mods collection
    • I am unable to do that. Brigadier is a mojang library that parses commands.
    • Hi, i appreciate the answer. I would love to do that, but we have active players with all their belongings in SSN. Also this mod is really handy and they would be mad if we removed it. Are you really certain that SSN is causing this? It would require lots of work to test it and SSN was not really an issue before we removed Fast Suite. Can it be related somehow? I will provide you with log before removing FS. PasteBin: https://pastebin.com/Y5EpLpNe (crash before removing Fast Suite, which I suspected to be a problem from some crash before)
  • Topics

×
×
  • Create New...

Important Information

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