Posted August 18, 20178 yr I haven't used ObjectHolders before, but I've seen a lot of people both use and recommend them, so I tried to use them myself. I am not very experienced with these, though, and I am currently crashing with an IllegalStateException. Crash log ModBlocksModItems The linked files are the only files containing the ObjectHolder annotation.
August 18, 20178 yr Uh. You're not using them correctly. http://mcforge.readthedocs.io/en/latest/concepts/registries/#injecting-registry-values-into-fields public static final Block diamond_block = null; // public static final is required. // Type Block means that the Block registry will be queried. // diamond_block is the field name, and as the field is not annotated it is taken to be the resource path. // As there is no explicit domain, "minecraft" is inherited from the class. // Object to be injected: "minecraft:diamond_block" from the Block registry. Notice how the field is null. Notice how the field is of type Block. Notice how the field name equals the registry name. Edited August 18, 20178 yr by Draco18s 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.
August 18, 20178 yr Author How do I instantiate it if the field is null? I want to have multiple instances of BlockHardenedOre with different values in its constructor.
August 18, 20178 yr 7 minutes ago, That_Martin_Guy said: How do I instantiate it if the field is null? I want to have multiple instances of BlockHardenedOre with different values in its constructor. That's what the ObjectHolder annotation is for! Edited August 18, 20178 yr by Draco18s 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.
August 18, 20178 yr Author Then how do I instantiate it this way? As far as I can tell the docs only tell you how to annotate a class or field properly, not how to instantiate it.
August 18, 20178 yr Local variables. 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.
August 19, 20178 yr Author Right now I crash with a NullPointerException, and I'm confused as to why. Shouldn't the field be occupied by the time the item registry event is fired? ModBlocks
August 19, 20178 yr Author BlockBase (which BlockHardenedOre inherits from) sets the registry name in it's constructor as the first parameter like this: public BlockBase(String name, @Nullable CreativeTabs creativeTab, Material materialIn) { ... this.setName(name); ... } private void setName(String name) { this.setRegistryName(name); super.setUnlocalizedName(this.getRegistryName().toString()); } . So in this case the hardened coal's registry name is blockhardenedcoal. Is this incorrect?
August 19, 20178 yr Author I thought that I would be able to make some sort of wildcard version of the object, but I can see now that this doesn't really make sense. Works now! Thanks. Working ModBlocks
August 19, 20178 yr I thought I said that... 17 hours ago, Draco18s said: Notice how the field name equals the registry name. Oh, I did. 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.
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.