Jump to content

Recommended Posts

Posted

hello, i am working on a configuration file and i want to know if it is possible to make a config for armor material:

i tried this:

 

in main class:

 

public static int PeanutHelmetC;

public static int PeanutBodyC;

public static int PeanutPantsC;

public static int PeanutBootsC;

 

public static ArmorMaterial PEANUT = EnumHelper.addArmorMaterial("PEANUT", 10, new int[] { PeanutlHelmetC, PeanutBodyC, PeanutPantsC, PeanutBootsC }, 12);

 

 

in Configuration class:

 

public class PeanutConfigHandler

{

public static void init(File configFile)

{

Configuration config = new Configuration(configFile);

 

config.load();

 

Peanut.PeanutHelmetC = config.get("armor health", "Peanuthelmet", 2).getInt();

Peanut.PeanutBodyC = config.get("armor health", "Peanutbody", 6).getInt();

Peanut.PeanutPantsC = config.get("armor health", "Peanutpants", 4).getInt();

Peanut.PeanutBootsC = config.get("armor health", "Peanutboots", 1).getInt();

 

config.save();

}

}

 

 

 

 

but  this doesnt work...  ):

anyone knows what i have to do?

 

 

Posted

Ok, i've put this:

public static int PeanutHelmetC;

public static int PeanutBodyC;

public static int PeanutPantsC;

public static int PeanutBootsC;

 

public static ArmorMaterial PEANUT = EnumHelper.addArmorMaterial("PEANUT", 10, new int[] { PeanutlHelmetC, PeanutBodyC, PeanutPantsC, PeanutBootsC }, 12);

 

 

at the bottom of the main class but it still doesnt work );

 

Posted

Ok, i've put this:

public static int PeanutHelmetC;

public static int PeanutBodyC;

public static int PeanutPantsC;

public static int PeanutBootsC;

 

public static ArmorMaterial PEANUT = EnumHelper.addArmorMaterial("PEANUT", 10, new int[] { PeanutlHelmetC, PeanutBodyC, PeanutPantsC, PeanutBootsC }, 12);

 

 

at the bottom of the main class but it still doesnt work );

 

You should learn Java before you start modding...

Just because you put that now at the bottom doesn't mean it gets called after all methods in the class.

Don't ask for support per PM! They'll get ignored! | If a post helped you, click the "Thank You" button at the top right corner of said post! |

mah twitter

This thread makes me sad because people just post copy-paste-ready code when it's obvious that the OP has little to no programming experience. This is not how learning works.

Posted

Ok, i've put this:

public static int PeanutHelmetC;

public static int PeanutBodyC;

public static int PeanutPantsC;

public static int PeanutBootsC;

 

public static ArmorMaterial PEANUT = EnumHelper.addArmorMaterial("PEANUT", 10, new int[] { PeanutlHelmetC, PeanutBodyC, PeanutPantsC, PeanutBootsC }, 12);

 

 

at the bottom of the main class but it still doesnt work );

 

You should learn Java before you start modding...

Just because you put that now at the bottom doesn't mean it gets called after all methods in the class.

Aside: static initializers actually do get called in the order they appear in the code, according to Java docs: "The runtime system guarantees that static initialization blocks are called in the order that they appear in the source code." While that refers specifically to static blocks, it's true for all static initializations. More info.

 

@OP That doesn't negate the fact that you are doing it incorrectly. Your static PeanutPartC fields are all unitialized when you attempt to use them, which is something you should know as part of fundamental Java basics. As SanAndreasP suggests, I recommend you start there.

 

Your values need to be read from the config, correct? Whereever your config sets those values (i.e. in a method body) is where you need to put your ArmorMaterial initialization.

 

public static ArmorMaterial PEANUT = EnumHelper.OOPS. Config values have not been read here!!!

// declare:
public static ArmorMaterial PEANUT;

@EventHandler
public void preInit(FMLPreInitializationEvent event) {
// Config is read here

// Sweet, now the values should be set, and it is safe to initialize
PEANUT = EnumHelper.SUCCESS!
}

Posted

Ok, i've put this:

public static int PeanutHelmetC;

public static int PeanutBodyC;

public static int PeanutPantsC;

public static int PeanutBootsC;

 

public static ArmorMaterial PEANUT = EnumHelper.addArmorMaterial("PEANUT", 10, new int[] { PeanutlHelmetC, PeanutBodyC, PeanutPantsC, PeanutBootsC }, 12);

 

 

at the bottom of the main class but it still doesnt work );

 

You should learn Java before you start modding...

Just because you put that now at the bottom doesn't mean it gets called after all methods in the class.

Aside: static initializers actually do get called in the order they appear in the code, according to Java docs: "The runtime system guarantees that static initialization blocks are called in the order that they appear in the source code." While that refers specifically to static blocks, it's true for all static initializations. More info.

 

Indeed, you could look at all static initialization stuff in your class as a huge classload-initialization method.

Don't ask for support per PM! They'll get ignored! | If a post helped you, click the "Thank You" button at the top right corner of said post! |

mah twitter

This thread makes me sad because people just post copy-paste-ready code when it's obvious that the OP has little to no programming experience. This is not how learning works.

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



×
×
  • Create New...

Important Information

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