Jump to content

[Not solved but im done.]How to save integers to a file.


deadrecon98

Recommended Posts

  • Replies 87
  • Created
  • Last Reply

Top Posters In This Topic

Seriously go learn Java!!!

 

Or at least learn to google basic java questions..

This has little to do with the forge API and is purely a Java question, a basic such as well..

 

Here ya go anyways -_-

[lmgtfy=save int to file java]Saving ints to file[/lmgtfy]

If you guys dont get it.. then well ya.. try harder...

Link to comment
Share on other sites

Seriously go learn Java!!!

 

Or at least learn to google basic java questions..

This has little to do with the forge API and is purely a Java question, a basic such as well..

 

Here ya go anyways -_-

[lmgtfy=save int to file java]Saving ints to file[/lmgtfy]

 

Im trying my best here dude, no need to be rude. And I have googled that at least 6 different ways and nothing I try works.

Link to comment
Share on other sites

I'm pretty sure that's about as non-rude as I could get..

And I also gave you the link which would answer your questions I believe?

 

If they didn't work, then why not mention what you tried and what failed, and since it's not within the scope of this board to do java basics why not use stackexchange or some other page which is made around dealing with basic/general java/programming questions? :)

 

The method in one of the top links using writer works I have used it before in some of my programs.

And this from another of the top hits also works fine:

http://www.java-examples.com/write-int-file-using-dataoutputstream

 

If you can't get them to work I suggest you open a new project and try to just get this function to work as you wish, then do the reading part as well, after that you should be able to open your modding project and do the same there :)

 

 

 

 

If you guys dont get it.. then well ya.. try harder...

Link to comment
Share on other sites

I'm pretty sure that's about as non-rude as I could get..

And I also gave you the link which would answer your questions I believe?

 

If they didn't work, then why not mention what you tried and what failed, and since it's not within the scope of this board to do java basics why not use stackexchange or some other page which is made around dealing with basic/general java/programming questions? :)

 

The method in one of the top links using writer works I have used it before in some of my programs.

And this from another of the top hits also works fine:

http://www.java-examples.com/write-int-file-using-dataoutputstream

 

If you can't get them to work I suggest you open a new project and try to just get this function to work as you wish, then do the reading part as well, after that you should be able to open your modding project and do the same there :)

 

Heres the code im trying to set up to save and get.

 

package mods.cyphereion.cyphscape.levels;

import java.io.FileWriter;
import java.io.Writer;

import org.lwjgl.input.Keyboard;

import cpw.mods.fml.common.registry.GameRegistry;
import mods.cyphereion.cyphscape.blocks.BlockCopper;
import mods.cyphereion.cyphscape.core.Core;
import mods.cyphereion.cyphscape.core.CyphScapeMaterials;
import net.minecraft.block.Block;
import net.minecraft.entity.EntityLiving;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;
import net.minecraft.potion.Potion;
import net.minecraft.potion.PotionEffect;
import net.minecraft.src.ModLoader;
import net.minecraft.world.World;

public class Levels {

public static int MiningLevel;
public static int MiningXp;

public void levelCap(EntityPlayer par1EntityPlayer){
	if(MiningLevel > 100){
		MiningLevel = 100;
	}
}

public void onUpdate(EntityPlayer par1EntityPlayer) {
	for (int i = 0; i < 61; i++) {
		if (MiningXp / 50 == i) {
			MiningLevel = i;

		}

	}
}

public int getMiningLevel() {
	for (int i = 0; i < 61; i++) {
		if (MiningXp / 50 == i) {
			return MiningLevel = i;
		}
	}
	return 0;

}
}

Link to comment
Share on other sites

I'm pretty sure that's about as non-rude as I could get..

And I also gave you the link which would answer your questions I believe?

 

If they didn't work, then why not mention what you tried and what failed, and since it's not within the scope of this board to do java basics why not use stackexchange or some other page which is made around dealing with basic/general java/programming questions? :)

 

The method in one of the top links using writer works I have used it before in some of my programs.

And this from another of the top hits also works fine:

http://www.java-examples.com/write-int-file-using-dataoutputstream

 

If you can't get them to work I suggest you open a new project and try to just get this function to work as you wish, then do the reading part as well, after that you should be able to open your modding project and do the same there :)

 

Heres the code im trying to set up to save and get.

 

package mods.cyphereion.cyphscape.levels;

import java.io.FileWriter;
import java.io.Writer;

import org.lwjgl.input.Keyboard;

import cpw.mods.fml.common.registry.GameRegistry;
import mods.cyphereion.cyphscape.blocks.BlockCopper;
import mods.cyphereion.cyphscape.core.Core;
import mods.cyphereion.cyphscape.core.CyphScapeMaterials;
import net.minecraft.block.Block;
import net.minecraft.entity.EntityLiving;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;
import net.minecraft.potion.Potion;
import net.minecraft.potion.PotionEffect;
import net.minecraft.src.ModLoader;
import net.minecraft.world.World;

public class Levels {

public static int MiningLevel;
public static int MiningXp;

public void levelCap(EntityPlayer par1EntityPlayer){
	if(MiningLevel > 100){
		MiningLevel = 100;
	}
}

public void onUpdate(EntityPlayer par1EntityPlayer) {
	for (int i = 0; i < 61; i++) {
		if (MiningXp / 50 == i) {
			MiningLevel = i;

		}

	}
}

public int getMiningLevel() {
	for (int i = 0; i < 61; i++) {
		if (MiningXp / 50 == i) {
			return MiningLevel = i;
		}
	}
	return 0;

}
}

That's going to cause problems if you try to use it on a server. You don't want to save that in a Configuration; you want to use EntityPlayer.registerExtendedProperties().

BEWARE OF GOD

---

Co-author of Pentachoron Labs' SBFP Tech.

Link to comment
Share on other sites

I'm pretty sure that's about as non-rude as I could get..

And I also gave you the link which would answer your questions I believe?

 

If they didn't work, then why not mention what you tried and what failed, and since it's not within the scope of this board to do java basics why not use stackexchange or some other page which is made around dealing with basic/general java/programming questions? :)

 

The method in one of the top links using writer works I have used it before in some of my programs.

And this from another of the top hits also works fine:

http://www.java-examples.com/write-int-file-using-dataoutputstream

 

If you can't get them to work I suggest you open a new project and try to just get this function to work as you wish, then do the reading part as well, after that you should be able to open your modding project and do the same there :)

 

Heres the code im trying to set up to save and get.

 

package mods.cyphereion.cyphscape.levels;

import java.io.FileWriter;
import java.io.Writer;

import org.lwjgl.input.Keyboard;

import cpw.mods.fml.common.registry.GameRegistry;
import mods.cyphereion.cyphscape.blocks.BlockCopper;
import mods.cyphereion.cyphscape.core.Core;
import mods.cyphereion.cyphscape.core.CyphScapeMaterials;
import net.minecraft.block.Block;
import net.minecraft.entity.EntityLiving;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;
import net.minecraft.potion.Potion;
import net.minecraft.potion.PotionEffect;
import net.minecraft.src.ModLoader;
import net.minecraft.world.World;

public class Levels {

public static int MiningLevel;
public static int MiningXp;

public void levelCap(EntityPlayer par1EntityPlayer){
	if(MiningLevel > 100){
		MiningLevel = 100;
	}
}

public void onUpdate(EntityPlayer par1EntityPlayer) {
	for (int i = 0; i < 61; i++) {
		if (MiningXp / 50 == i) {
			MiningLevel = i;

		}

	}
}

public int getMiningLevel() {
	for (int i = 0; i < 61; i++) {
		if (MiningXp / 50 == i) {
			return MiningLevel = i;
		}
	}
	return 0;

}
}

That's going to cause problems if you try to use it on a server. You don't want to save that in a Configuration; you want to use EntityPlayer.registerExtendedProperties().

 

Its strictly singleplayer.

Link to comment
Share on other sites

I'm pretty sure that's about as non-rude as I could get..

And I also gave you the link which would answer your questions I believe?

 

If they didn't work, then why not mention what you tried and what failed, and since it's not within the scope of this board to do java basics why not use stackexchange or some other page which is made around dealing with basic/general java/programming questions? :)

 

The method in one of the top links using writer works I have used it before in some of my programs.

And this from another of the top hits also works fine:

http://www.java-examples.com/write-int-file-using-dataoutputstream

 

If you can't get them to work I suggest you open a new project and try to just get this function to work as you wish, then do the reading part as well, after that you should be able to open your modding project and do the same there :)

 

Heres the code im trying to set up to save and get.

 

package mods.cyphereion.cyphscape.levels;

import java.io.FileWriter;
import java.io.Writer;

import org.lwjgl.input.Keyboard;

import cpw.mods.fml.common.registry.GameRegistry;
import mods.cyphereion.cyphscape.blocks.BlockCopper;
import mods.cyphereion.cyphscape.core.Core;
import mods.cyphereion.cyphscape.core.CyphScapeMaterials;
import net.minecraft.block.Block;
import net.minecraft.entity.EntityLiving;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;
import net.minecraft.potion.Potion;
import net.minecraft.potion.PotionEffect;
import net.minecraft.src.ModLoader;
import net.minecraft.world.World;

public class Levels {

public static int MiningLevel;
public static int MiningXp;

public void levelCap(EntityPlayer par1EntityPlayer){
	if(MiningLevel > 100){
		MiningLevel = 100;
	}
}

public void onUpdate(EntityPlayer par1EntityPlayer) {
	for (int i = 0; i < 61; i++) {
		if (MiningXp / 50 == i) {
			MiningLevel = i;

		}

	}
}

public int getMiningLevel() {
	for (int i = 0; i < 61; i++) {
		if (MiningXp / 50 == i) {
			return MiningLevel = i;
		}
	}
	return 0;

}
}

That's going to cause problems if you try to use it on a server. You don't want to save that in a Configuration; you want to use EntityPlayer.registerExtendedProperties().

 

If a config won't work then a hashmap maybe?

Link to comment
Share on other sites

Why do you need it saved to a file?? Oh right, you need some way of doing NBT saves.

 

Try doing something like so:

[urlhttps://github.com/ModderPenguin/MinePG/blob/master/source/minepg/rpg_common/rpg/playerinfo/PlayerInformation.java[/url]

I am Mew. The Legendary Psychic. I behave oddly and am always playing practical jokes.

 

I have also found that I really love making extremely long and extremely but sometimes not so descriptive variables. Sort of like what I just did there xD

Link to comment
Share on other sites

Why do you need it saved to a file?? Oh right, you need some way of doing NBT saves.

 

Try doing something like so:

[urlhttps://github.com/ModderPenguin/MinePG/blob/master/source/minepg/rpg_common/rpg/playerinfo/PlayerInformation.java[/url]

That source code is a bust, its very hard to understand someone elses coding when it gets to that level. I need someone to explain this to me so that Im learning. Not being a scriptkitty, im trying to get out of that.

Link to comment
Share on other sites

That source code is a bust, its very hard to understand someone elses coding when it gets to that level. I need someone to explain this to me so that Im learning. Not being a scriptkitty, im trying to get out of that.

 

I also am not being rude, but you should never accuse anyone of being rude when asking for help through a text means... that is actually rude in itself, but forgivable as it is frustrating getting something to work. If you cannot be bothered reading other peoples code then no one will want to help you... I don't think that's what you meant at all but if you are seriously considering modding, then you'll need to read a lot of other peoples code, and it will sometimes be very long and complex but should be well documented with comments. This API is not official and it's very obscured still. I understand your need to learn to gain the satisfaction of progress however, as you probably know, we all cannot help as much as we might like as we are working on projects, feeding family, working, and doing other things important to our own progress. Keep that in mind first and foremost when asking a question. Also, give a very good indication of your current skills, knowledge, and exactly what it is you want to achieve in your code. Saving an int to a file is generic. It would help to know what the purpose of doing so is and think how that feature may evolve later.

 

It's good to want to get better but I'd have to know a lot more about your current knowledge of java and forge to help teach you something. Have you done all of the Basic tutorials? http://www.minecraftforge.net/wiki/Tutorials. Indispensable. If it becomes frustrating to follow just keep trying. You can teach yourself anything if you apply yourself and do not allow frustration to set in. I have a feeling if you have a decent enough base knowledge of java that following the basic tutorials will allow you to intuitively discover your solutions for quite sometime. I do understand the frustration that can come if you are just getting into things as a new coder. I guess the idea is that if someone does it for you you won't learn anything, but no one should have a problem if you don't understand a particular class, in giving you some ideas or help.

 

If you are simply wanting persistent data that saves and loads on a save game, you should grok the classes for NBTTagCompounds.  This is how Vanilla saves most of it's persistent/unique data when the game saves. If you have something else in mind that minecraft doesn't already do then you may need your own data file system... however I doubt it would be necessary. It does require knowledge of java's file input/output classes. If you don't understand them, I suggest you try a basic java app first then play with the classes. If your knowledge of java is up to snuff then I'd master all the knowledge gained from the Basic Tutorials then amaze yourself at how much can be learned with a bit of patience and persistence.

 

Also, let the vanilla source guide you. ctrl+H in eclipse will let you search for text in all the packages open in your project. It's probably done me more good than the tutorials...

 

Update:

I just remembered something important. I understand that you are making a SSP mod. It is important to understand that a client and server are running even in SSP. Not much gets sent to the Client but rendering data. Even the levels, skills, other info would be on the server and the server value would be passed to the client either through a datawatcher or packet. I think the concept works best mentally if you say that the client cannot be trusted. The server is the master in this case and does all the saving of data. It's probably less intuitive but things got easier for me when dealing with Server/Client relations when I thought of it that way. But that could just be me.

Link to comment
Share on other sites

Dude I've tried literally everything that I can think of. Hashmap's, NBT, FileWriter. But none of it seems to work for me. I've just never worked with these elements before and can't find anyone who knows or is willing to help me here. And btw I did read that guys code, actually I stripped it down and tried it then but it was still broken.

Link to comment
Share on other sites

Step 1: get a reference to the player (object type EntityPlayer)

Step 2: get a reference to the player's NBT data:

player.getEntityData()

Step 3: write an integer to it:

nbt.setInteger("MiningLevel",lv);

Step 4: anywhere you need to reference the mining level, read it from the NBT:

nbt.getInteger("MiningLevel");

Step 5: if it changes, go to step 3.

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

Step 1: get a reference to the player (object type EntityPlayer)

Step 2: get a reference to the player's NBT data:

player.getEntityData()

Step 3: write an integer to it:

nbt.setInteger("MiningLevel",lv);

Step 4: anywhere you need to reference the mining level, read it from the NBT:

nbt.getInteger("MiningLevel");

Step 5: if it changes, go to step 3.

 

Is there anything that I am missing here?

 public static void hashSaving(EntityPlayer player){
    	player.getEntityData();
    	map.put("MiningXp", MiningXp);
    	map.put("MiningLevel", MiningLevel);
    	map.put("SmithingXp", SmithingXp);
    	map.put("SmithingLevel", SmithingLevel);
    }
    
    public void getMiningXp(){
    	map.get("MiningXp");
    }
    public void getSmithingXp(){
    	map.get("SmithingXp");
    }

 

Note: I can change the integer values but they don't save.

Link to comment
Share on other sites

Is there anything that I am missing here?

 public static void hashSaving(EntityPlayer player){
    	player.getEntityData();
    	map.put("MiningXp", MiningXp);
    	map.put("MiningLevel", MiningLevel);
    	map.put("SmithingXp", SmithingXp);
    	map.put("SmithingLevel", SmithingLevel);
    }
    
    public void getMiningXp(){
    	map.get("MiningXp");
    }
    public void getSmithingXp(){
    	map.get("SmithingXp");
    }

 

Note: I can change the integer values but they don't save.

 

Well you're kinda missing the entire read/write nbt parts...

 

 public static void hashSaving(EntityPlayer player){
              NBTTagCompound nbt = player.getEntityData();
              nbt.setInteger("MiningXp", MiningXp);
              nbt.setInteger("MiningLevel", MiningLevel);
              nbt.setInteger("SmithingXp", SmithingXp);
              nbt.setInteger("SmithingLevel", SmithingLevel);
    }
    
    public int getMiningXp(EntityPlayer player){
              NBTTagCompound nbt = player.getEntityData();
              return nbt.getInteger("MiningXp");
    }
    public int getSmithingXp(EntityPlayer player){
              NBTTagCompound nbt = player.getEntityData();
              return nbt.getInteger("SmithingXp");
    }

 

Edit: Tab-space derp

Link to comment
Share on other sites

deadrecon, I don't suppose I could see the whole class could I? I'm trying to figure out the whole NBT on the player thing atm, can't quite figure it out... :P

 

Yes you may see it. If you need anything else just ask, I really want to get this done so that I can start working on the modding API for it :P

 

package mods.cyphereion.cyphscape.levels;

import java.util.HashMap;
import java.util.Set;

import net.minecraft.entity.Entity;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.nbt.NBTTagList;
import net.minecraft.world.World;
import net.minecraftforge.common.IExtendedEntityProperties;

public final class Levels {
  
/**
 * Creates the hashmap.
 */
public static HashMap map = new HashMap();

 /**
     * The total Mining Experience.
     */
    public static int MiningXp = 0;
    
    /**
     * The total Mining Level.
     */
    public static int MiningLevel = 0;
    
    /**
     * The total smithing xp.
     */
    public static int SmithingXp = 0;
    
    /**
     * The total smithing Level.
     */
    public static int SmithingLevel = 0;
    
    public static void hashSaving(EntityPlayer player, World par2World){
    	player.getEntityData();
    	map.put("MiningXp", MiningXp);
    	map.put("MiningLevel", MiningLevel);
    	map.put("SmithingXp", SmithingXp);
    	map.put("SmithingLevel", SmithingLevel);
    }
    
    public void getMiningXp(){
    	map.get("MiningXp");
    }
    public void getSmithingXp(){
    	map.get("SmithingXp");
    }
}

 

Btw im not using nbt im attempting to use a hashmap

Link to comment
Share on other sites

Is there anything that I am missing here?

 public static void hashSaving(EntityPlayer player){
    	player.getEntityData();
    	map.put("MiningXp", MiningXp);
    	map.put("MiningLevel", MiningLevel);
    	map.put("SmithingXp", SmithingXp);
    	map.put("SmithingLevel", SmithingLevel);
    }
    
    public void getMiningXp(){
    	map.get("MiningXp");
    }
    public void getSmithingXp(){
    	map.get("SmithingXp");
    }

 

Note: I can change the integer values but they don't save.

 

Well you're kinda missing the entire read/write nbt parts...

 

 public static void hashSaving(EntityPlayer player){
              NBTTagCompound nbt = player.getEntityData();
              nbt.setInteger("MiningXp", MiningXp);
              nbt.setInteger("MiningLevel", MiningLevel);
              nbt.setInteger("SmithingXp", SmithingXp);
              nbt.setInteger("SmithingLevel", SmithingLevel);
    }
    
    public int getMiningXp(EntityPlayer player){
              NBTTagCompound nbt = player.getEntityData();
              return nbt.getInteger("MiningXp");
    }
    public int getSmithingXp(EntityPlayer player){
              NBTTagCompound nbt = player.getEntityData();
              return nbt.getInteger("SmithingXp");
    }

 

Edit: Tab-space derp

 

.... thats a hashmap dude not an nbt compound

Link to comment
Share on other sites

You don't need the hashmap though, if you're saving and getting from the NBT compound!

 

package mods.cyphereion.cyphscape.levels;

import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.nbt.NBTTagCompound;

public final class Levels {
    /**
     * The total Mining Experience.
     */
    public static int MiningXp = 0;

    /**
     * The total Mining Level.
     */
    public static int MiningLevel = 0;

    /**
     * The total smithing xp.
     */
    public static int SmithingXp = 0;

    /**
     * The total smithing Level.
     */
    public static int SmithingLevel = 0;

    public static void saveLevelDataForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        nbt.setInteger("MiningXp", MiningXp);
        nbt.setInteger("MiningLevel", MiningLevel);
        nbt.setInteger("SmithingXp", SmithingXp);
        nbt.setInteger("SmithingLevel", SmithingLevel);
    }
    
    public static void getLevelDataForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        MiningXp = nbt.getInteger("MiningXp");
        MiningLevel = nbt.getInteger("MiningLevel");
        SmithingXp = nbt.getInteger("SmithingXp");
        SmithingLevel = nbt.getInteger("SmithingLevel");
    }

    public int getMiningXpForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        return nbt.getInteger("MiningXp");
    }

    public void saveMiningXpForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        nbt.setInteger("MiningXp", MiningXp);
    }
    
    public int getSmithingXpForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        return nbt.getInteger("SmithingXp");
    }

    public void saveSmithingXpForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        nbt.setInteger("SmithingXp", SmithingXp);
    }
}

Link to comment
Share on other sites

You don't need the hashmap though, if you're saving and getting from the NBT compound!

 

package mods.cyphereion.cyphscape.levels;

import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.nbt.NBTTagCompound;

public final class Levels {
    /**
     * The total Mining Experience.
     */
    public static int MiningXp = 0;

    /**
     * The total Mining Level.
     */
    public static int MiningLevel = 0;

    /**
     * The total smithing xp.
     */
    public static int SmithingXp = 0;

    /**
     * The total smithing Level.
     */
    public static int SmithingLevel = 0;

    public static void saveLevelDataForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        nbt.setInteger("MiningXp", MiningXp);
        nbt.setInteger("MiningLevel", MiningLevel);
        nbt.setInteger("SmithingXp", SmithingXp);
        nbt.setInteger("SmithingLevel", SmithingLevel);
    }
    
    public static void getLevelDataForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        MiningXp = nbt.getInteger("MiningXp");
        MiningLevel = nbt.getInteger("MiningLevel");
        SmithingXp = nbt.getInteger("SmithingXp");
        SmithingLevel = nbt.getInteger("SmithingLevel");
    }

    public int getMiningXpForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        return nbt.getInteger("MiningXp");
    }

    public void saveMiningXpForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        nbt.setInteger("MiningXp", MiningXp);
    }
    
    public int getSmithingXpForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        return nbt.getInteger("SmithingXp");
    }

    public void saveSmithingXpForPlayer(EntityPlayer player){
        NBTTagCompound nbt = player.getEntityData();
        nbt.setInteger("SmithingXp", SmithingXp);
    }
}

 

But with nbt you cant load it from another class file wich is what I need to do.

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

    • Hello, I'm trying to modify the effects of native enchantments for bows and arrows in Minecraft. After using a decompilation tool, I found that the specific implementations of native bow and arrow enchantments (including `ArrowDamageEnchantment`, `ArrowKnockbackEnchantment`, `ArrowFireEnchantment`, `ArrowInfiniteEnchantment`, `ArrowPiercingEnchantment`) do not contain any information about the enchantment effects (such as the `getDamageProtection` function for `ProtectionEnchantment`, `getDamageBonus` function for `DamageEnchantment`, etc.). Upon searching for the base class of arrows, `AbstractArrow`, I found a function named setEnchantmentEffectsFromEntity`, which seems to be used to retrieve the enchantment levels of the tool held by a `LivingEntity` and calculate the specific values of the enchantment effects. However, after testing with the following code, I found that this function is not being called:   @Mixin(AbstractArrow.class) public class ModifyArrowEnchantmentEffects {     private static final Logger LOGGER = LogUtils.getLogger();     @Inject(         method = "setEnchantmentEffectsFromEntity",         at = @At("HEAD")     )     private void logArrowEnchantmentEffectsFromEntity(CallbackInfo ci) {         LOGGER.info("Arrow enchantment effects from entity");     } }   Upon further investigation, I found that within the onHitEntity method, there are several lines of code:               if (!this.level().isClientSide &amp;&amp; entity1 instanceof LivingEntity) {                EnchantmentHelper.doPostHurtEffects(livingentity, entity1);                EnchantmentHelper.doPostDamageEffects((LivingEntity)entity1, livingentity);             }   These lines of code actually call the doPostHurt and doPostAttack methods of each enchantment in the enchantment list. However, this leads back to the issue because native bow and arrow enchantments do not implement these functions. Although their base class defines the functions, they are empty. At this point, I'm completely stumped and seeking assistance. Thank you.
    • 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.
  • Topics

×
×
  • Create New...

Important Information

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