Jump to content

Configuration file not initializing properly?


Geforce

Recommended Posts

Hey guys, im trying to add a config file to my mod, SecurityCraft, and for some reason, its (the config file) not setting the variables correctly. Heres the error report:

 

 


---- Minecraft Crash Report ----
// Why did you do that?

Time: 9/16/13 2:12 PM
Description: Initializing game

java.lang.ExceptionInInitializerError
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Unknown Source)
at cpw.mods.fml.common.FMLModContainer.constructMod(FMLModContainer.java:457)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at com.google.common.eventbus.EventHandler.handleEvent(EventHandler.java:74)
at com.google.common.eventbus.SynchronizedEventHandler.handleEvent(SynchronizedEventHandler.java:45)
at com.google.common.eventbus.EventBus.dispatch(EventBus.java:313)
at com.google.common.eventbus.EventBus.dispatchQueuedEvents(EventBus.java:296)
at com.google.common.eventbus.EventBus.post(EventBus.java:267)
at cpw.mods.fml.common.LoadController.sendEventToModContainer(LoadController.java:193)
at cpw.mods.fml.common.LoadController.propogateStateMessage(LoadController.java:173)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at com.google.common.eventbus.EventHandler.handleEvent(EventHandler.java:74)
at com.google.common.eventbus.SynchronizedEventHandler.handleEvent(SynchronizedEventHandler.java:45)
at com.google.common.eventbus.EventBus.dispatch(EventBus.java:313)
at com.google.common.eventbus.EventBus.dispatchQueuedEvents(EventBus.java:296)
at com.google.common.eventbus.EventBus.post(EventBus.java:267)
at cpw.mods.fml.common.LoadController.distributeStateMessage(LoadController.java:104)
at cpw.mods.fml.common.Loader.loadMods(Loader.java:510)
at cpw.mods.fml.client.FMLClientHandler.beginMinecraftLoading(FMLClientHandler.java:172)
at net.minecraft.client.Minecraft.startGame(Minecraft.java:470)
at net.minecraft.client.Minecraft.func_99999_d(Minecraft.java:796)
at net.minecraft.client.main.Main.main(Main.java:93)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at net.minecraft.launchwrapper.Launch.launch(Launch.java:57)
at net.minecraft.launchwrapper.Launch.main(Launch.java:18)
Caused by: java.lang.IllegalArgumentException: Slot 0 is already occupied by SecurityCraft.forge.blocks.BlockLaserBlock@41d0af66 when adding SecurityCraft.forge.blocks.BlockLaser@6bab734b
at net.minecraft.block.Block.<init>(Block.java:351)
at SecurityCraft.forge.blocks.BlockLaser.<init>(BlockLaser.java:24)
at SecurityCraft.forge.mod_SecurityCraft.<clinit>(mod_SecurityCraft.java:83)
... 35 more


A detailed walkthrough of the error, its code path and all known details is as follows:
---------------------------------------------------------------------------------------

-- Head --
Stacktrace:
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Unknown Source)
at cpw.mods.fml.common.FMLModContainer.constructMod(FMLModContainer.java:457)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at com.google.common.eventbus.EventHandler.handleEvent(EventHandler.java:74)
at com.google.common.eventbus.SynchronizedEventHandler.handleEvent(SynchronizedEventHandler.java:45)
at com.google.common.eventbus.EventBus.dispatch(EventBus.java:313)
at com.google.common.eventbus.EventBus.dispatchQueuedEvents(EventBus.java:296)
at com.google.common.eventbus.EventBus.post(EventBus.java:267)
at cpw.mods.fml.common.LoadController.sendEventToModContainer(LoadController.java:193)
at cpw.mods.fml.common.LoadController.propogateStateMessage(LoadController.java:173)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at com.google.common.eventbus.EventHandler.handleEvent(EventHandler.java:74)
at com.google.common.eventbus.SynchronizedEventHandler.handleEvent(SynchronizedEventHandler.java:45)
at com.google.common.eventbus.EventBus.dispatch(EventBus.java:313)
at com.google.common.eventbus.EventBus.dispatchQueuedEvents(EventBus.java:296)
at com.google.common.eventbus.EventBus.post(EventBus.java:267)
at cpw.mods.fml.common.LoadController.distributeStateMessage(LoadController.java:104)
at cpw.mods.fml.common.Loader.loadMods(Loader.java:510)
at cpw.mods.fml.client.FMLClientHandler.beginMinecraftLoading(FMLClientHandler.java:172)
at net.minecraft.client.Minecraft.startGame(Minecraft.java:470)

-- Initialization --
Details:
Stacktrace:
at net.minecraft.client.Minecraft.func_99999_d(Minecraft.java:796)
at net.minecraft.client.main.Main.main(Main.java:93)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at net.minecraft.launchwrapper.Launch.launch(Launch.java:57)
at net.minecraft.launchwrapper.Launch.main(Launch.java:18)

-- System Details --
Details:
Minecraft Version: 1.6.2
Operating System: Windows 7 (amd64) version 6.1
Java Version: 1.7.0, Oracle Corporation
Java VM Version: Java HotSpot(TM) 64-Bit Server VM (mixed mode), Oracle Corporation
Memory: 768876608 bytes (733 MB) / 1038876672 bytes (990 MB) up to 1038876672 bytes (990 MB)
JVM Flags: 3 total; -Xincgc -Xmx1024M -Xms1024M
AABB Pool Size: 0 (0 bytes; 0 MB) allocated, 0 (0 bytes; 0 MB) used
Suspicious classes: FML and Forge are installed
IntCache: cache: 0, tcache: 0, allocated: 0, tallocated: 0
FML: MCP v8.04 FML v6.2.19.789 Minecraft Forge 9.10.0.789 4 mods loaded, 4 mods active
mcp{8.04} [Minecraft Coder Pack] (minecraft.jar) Unloaded->Constructed
FML{6.2.19.789} [Forge Mod Loader] (coremods) Unloaded->Constructed
Forge{9.10.0.789} [Minecraft Forge] (coremods) Unloaded->Constructed
SecurityCraft{v1.3} [securityCraft] (bin) Unloaded
Launched Version: 1.6
LWJGL: 2.9.0
OpenGL: GeForce 8400GS/PCI/SSE2 GL version 3.3.0, NVIDIA Corporation
Is Modded: Definitely; Client brand changed to 'fml,forge'
Type: Client (map_client.txt)
Resource Pack: Default
Current Language: English (US)
Profiler Position: N/A (disabled)
Vec3 Pool Size: ~~ERROR~~ NullPointerException: null

 

 

 

And heres my main mod class and configuration handler classes:

 

(Main mod class):

 

package SecurityCraft.forge;


import java.util.Arrays;

import SecurityCraft.forge.blocks.BlockActiveKeypad;
import SecurityCraft.forge.blocks.BlockActiveLaser;
import SecurityCraft.forge.blocks.BlockBogusLava;
import SecurityCraft.forge.blocks.BlockBogusLavaBase;
import SecurityCraft.forge.blocks.BlockBogusWater;
import SecurityCraft.forge.blocks.BlockBogusWaterBase;
import SecurityCraft.forge.blocks.BlockIronTrapDoor;
import SecurityCraft.forge.blocks.BlockKeycardReader;
import SecurityCraft.forge.blocks.BlockKeypad;
import SecurityCraft.forge.blocks.BlockLaser;
import SecurityCraft.forge.blocks.BlockLaserBlock;
import SecurityCraft.forge.blocks.BlockMine;
import SecurityCraft.forge.blocks.BlockReinforcedDoor;
import SecurityCraft.forge.blocks.BlockRetinalScanner;
import SecurityCraft.forge.gui.GuiHandler;
import SecurityCraft.forge.items.ItemCodebreaker;
import SecurityCraft.forge.items.ItemDoorRemover;
import SecurityCraft.forge.items.ItemKeycardBase;
import SecurityCraft.forge.items.ItemReinforcedDoor;
import SecurityCraft.forge.mines.BlockFullMineBase;
import SecurityCraft.forge.mines.BlockFurnaceActiveMine;
import SecurityCraft.forge.mines.BlockFurnaceActiveMineBlinking;
import SecurityCraft.forge.mines.BlockFurnaceMine;
import SecurityCraft.forge.mines.TileEntityFurnaceMine;
import SecurityCraft.forge.tileentity.TileEntityKeycardReader;
import SecurityCraft.forge.tileentity.TileEntityKeypad;
import SecurityCraft.forge.tileentity.TileEntityReinforcedDoor;
import net.minecraft.block.Block;
import net.minecraft.block.BlockChest;
import net.minecraft.block.BlockDoor;
import net.minecraft.block.BlockFlowing;
import net.minecraft.block.BlockFluid;
import net.minecraft.block.BlockStationary;
import net.minecraft.block.BlockTrapDoor;
import net.minecraft.block.material.Material;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.item.Item;
import net.minecraft.item.ItemDoor;
import net.minecraft.item.ItemStack;
import net.minecraft.server.dedicated.PropertyManager;
import net.minecraftforge.common.Configuration;
import net.minecraftforge.common.Property;
import cpw.mods.fml.client.registry.RenderingRegistry;
import cpw.mods.fml.common.Mod;
import cpw.mods.fml.common.Mod.EventHandler;
import cpw.mods.fml.common.Mod.Instance;
import cpw.mods.fml.common.Mod.PreInit;
import cpw.mods.fml.common.ModMetadata;
import cpw.mods.fml.common.event.FMLInitializationEvent;
import cpw.mods.fml.common.event.FMLPostInitializationEvent;
import cpw.mods.fml.common.event.FMLPreInitializationEvent;
import cpw.mods.fml.common.network.NetworkMod;
import cpw.mods.fml.common.network.NetworkRegistry;
import cpw.mods.fml.common.registry.EntityRegistry;
import cpw.mods.fml.common.registry.GameRegistry;
import cpw.mods.fml.common.registry.LanguageRegistry;


@Mod(modid = "SecurityCraft", name = "SecurityCraft", version = "v1.3")
@NetworkMod(clientSideRequired = true, serverSideRequired = false, channels={"SecurityCraft", "ReverseBlock", "GetPass", "SetLV"}, packetHandler = PacketHandler.class)
public class mod_SecurityCraft {

//TODO CHANGE VERSION
@Instance
    public static mod_SecurityCraft instance = new mod_SecurityCraft();

public static ConfigurationHandler configHandler = new ConfigurationHandler();


public static CreativeTabs tabSecurityCraft = new CreativeTabSecurityCraft(CreativeTabs.getNextI(),"tabSecurityCraft");

private GuiHandler GuiHandler = new GuiHandler();




public static Block LaserBlock = new BlockLaserBlock(configHandler.LaserBlockID, Material.iron).setHardness(5F).setResistance(1000).setStepSound(Block.soundMetalFootstep).setCreativeTab(mod_SecurityCraft.tabSecurityCraft).setUnlocalizedName("Laser Tripwire Block");
public static Block Laser = new BlockLaser(configHandler.LaserID).setBlockUnbreakable().setResistance(1000F).setUnlocalizedName("Laser");
public static Block Keypad = new BlockKeypad(configHandler.KeypadID, Material.circuits).setHardness(10F).setResistance(1000).setStepSound(Block.soundStoneFootstep).setCreativeTab(mod_SecurityCraft.tabSecurityCraft).setUnlocalizedName("Keypad");

                  //I have much more blocks being made here, but i used these three to test the config file
    @EventHandler
public void preInit(FMLPreInitializationEvent event){
	this.configHandler.setupConfiguration(event);

	ModMetadata modMeta = event.getModMetadata();
        modMeta.authorList = Arrays.asList(new String[] {
            "Geforce132"
        });
        modMeta.autogenerated = false;
        modMeta.credits = "Thanks to all of you guys for your support!";
        modMeta.description = "Adds a load of things to keep your house safe with.\nIf you like this mod, hit the green arrow\nin the corner of the forums thread!\nPlease visit the URL above for help.";
        modMeta.url = "http://geforce.freeforums.org";
       
  
        
	//LanguageRegistrys
	LanguageRegistry.addName(LaserBlock, "Laser Block");
	LanguageRegistry.addName(Laser, "Laser");
	LanguageRegistry.addName(Keypad, "Keypad");
	LanguageRegistry.addName(KeypadActive, "KeypadActive");
	LanguageRegistry.addName(Mine, "Mine");
	LanguageRegistry.addName(MineCut, "Mine");
	LanguageRegistry.addName(Codebreaker, "Codebreaker");
	LanguageRegistry.addName(DirtMine, "Dirt Mine");
	LanguageRegistry.addName(StoneMine, "Stone Mine");
	LanguageRegistry.addName(CobblestoneMine, "Cobblestone Mine");
	LanguageRegistry.addName(DiamondOreMine, "Diamond Ore Mine");
	LanguageRegistry.addName(SandMine, "Sand Mine");
	LanguageRegistry.addName(FurnaceMine, "Furnace Mine");
	LanguageRegistry.addName(FurnaceMineActive, "Furnace Mine");
	//LanguageRegistry.addName(RetinalScanner, "Retinal Scanner");
	LanguageRegistry.addName(doorIndestructableIron, "Reinforced Iron Door");
	LanguageRegistry.addName(doorIndestructableIronItem, "Reinforced Iron Door");
	LanguageRegistry.addName(doorRemover, "Door Remover");
	LanguageRegistry.addName(bogusLava, "Fake Lava");
	LanguageRegistry.addName(bogusWater, "Fake Water");
	LanguageRegistry.addName(keycardReader, "Keycard Reader");
	LanguageRegistry.addName(keycardLV1, "Level 1 Keycard");
	LanguageRegistry.addName(keycardLV2, "Level 2 Keycard");
	LanguageRegistry.addName(keycardLV3, "Level 3 Keycard");
	LanguageRegistry.addName(masterCard, "Master Card");
	LanguageRegistry.addName(ironTrapdoor, "Iron Trapdoor");

}

@EventHandler
public void init(FMLInitializationEvent event){

	GameRegistry.registerBlock(LaserBlock);
	GameRegistry.registerBlock(Laser);
	GameRegistry.registerBlock(Keypad);
	GameRegistry.registerBlock(KeypadActive);
	GameRegistry.registerBlock(Mine);
	GameRegistry.registerBlock(MineCut);
	GameRegistry.registerBlock(DirtMine);
	GameRegistry.registerBlock(StoneMine);
	GameRegistry.registerBlock(CobblestoneMine);
	GameRegistry.registerBlock(DiamondOreMine);
	GameRegistry.registerBlock(SandMine);
	GameRegistry.registerBlock(FurnaceMine);
	GameRegistry.registerBlock(FurnaceMineActive);
	GameRegistry.registerBlock(FurnaceMineActiveBlinking);
	//GameRegistry.registerBlock(RetinalScanner);
	GameRegistry.registerBlock(bogusLava);
	//GameRegistry.registerBlock(doorIndestructableIron);
	GameRegistry.registerBlock(bogusLavaFlowing);
	GameRegistry.registerBlock(bogusWater);
	GameRegistry.registerBlock(bogusWaterFlowing);
	GameRegistry.registerBlock(keycardReader);
	GameRegistry.registerBlock(ironTrapdoor);


    
    
	GameRegistry.registerTileEntity(TileEntityKeypad.class, "keypad");
	GameRegistry.registerTileEntity(TileEntityFurnaceMine.class, "furnaceMine");
	GameRegistry.registerTileEntity(TileEntityReinforcedDoor.class, "reinforcedDoor");
	GameRegistry.registerTileEntity(TileEntityKeycardReader.class, "keycardReader");

	NetworkRegistry.instance().registerGuiHandler(this, GuiHandler );

	//recipes here
}


}

 

 

ConfigurationHandler class:

 

package SecurityCraft.forge;

import net.minecraftforge.common.Configuration;
import cpw.mods.fml.common.event.FMLPreInitializationEvent;

public class ConfigurationHandler extends mod_SecurityCraft{
public static boolean allowCodebreakerItem;
public static boolean allowDoorRemover;


//Block/Item IDs
public static int LaserBlockID;
               public static int LaserID;
public static int KeypadID;


public void setupConfiguration(FMLPreInitializationEvent event) {
	Configuration config = new Configuration(event.getSuggestedConfigurationFile());
        config.load();

        
        allowCodebreakerItem = config.get("Options", "allow-codebreaker", true).getBoolean(true);
        allowDoorRemover = config.get("Options", "allow-door-remover", true).getBoolean(true);

        
        LaserBlockID = config.get("Block IDs", "laser-block-ID", 1000).getInt(1000);
        LaserID = config.get("Block IDs", "laser-ID", 1001).getInt(1001);
        KeypadID = config.get("Block IDs", "keypad-ID", 1002).getInt(1002);

        config.save();

}

}

 

 

 

Anyone know whats wrong? I would greatly appreciate any help you guys can give me! Thanks :).

Potato's have skin. I have skin. Therefore, i am a potato.

 

Follow me on Twitter!

http://www.twitter.com/I_Mod_Minecraft

Link to comment
Share on other sites

public class ConfigurationHandler extends mod_SecurityCraft{

 

extends mod_SecurityCraft

 

Uh.  What.

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

@Instance
    public static mod_SecurityCraft instance = new mod_SecurityCraft();
...
public static Block LaserBlock = new BlockLaserBlock(configHandler.LaserBlockID, Material.iron).setHardness(5F).setResistance(1000).setStepSound(Block.soundMetalFootstep).setCreativeTab(mod_SecurityCraft.tabSecurityCraft).setUnlocalizedName("Laser Tripwire Block");
public static Block Laser = new BlockLaser(configHandler.LaserID).setBlockUnbreakable().setResistance(1000F).setUnlocalizedName("Laser");
public static Block Keypad = new BlockKeypad(configHandler.KeypadID, Material.circuits).setHardness(10F).setResistance(1000).setStepSound(Block.soundStoneFootstep).setCreativeTab(mod_SecurityCraft.tabSecurityCraft).setUnlocalizedName("Keypad");

At least follow the basic tutorials in the wiki please.  :'(

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



×
×
  • Create New...

Important Information

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