Jump to content

Help Editing Vanilla Blocks and Items


xTekBlue

Recommended Posts

You may have seen me on hear often, i am fairly new to Java and i have been working on a test mod with Minecraft to help self teach me like i have done in the past with other languages. I am trying to add a method to the Obsidian block but i have no idea where to start, i have created a class that has the method inside with a Override and it extends "BlockObsidian". The class on its own obviously does nothing but i don't know either where to run the code or what i need to do to replace the vanilla Obsidian. 

Link to comment
Share on other sites

Just because you extended the class doesn't mean you've replaced it. Minecraft vanilla (which is immutable) still calls new BlockObsidian(), not your class.

 

To create any block, you need to register it (I recommend reading the documentation), and if you do as Jabelar says, you can replace the vanilla entry, but this is due to how the registration system works and is not a standard feature of Java. I also recommend learning Java (or at least, some other object oriented language) before modding.

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

package xtekblue.mod.objects.blocks;

import net.minecraft.block.BlockObsidian;
import net.minecraft.block.SoundType;
import net.minecraft.block.state.IBlockState;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.ItemStack;
import net.minecraft.util.EnumFacing;
import net.minecraft.util.EnumHand;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.World;
import net.minecraftforge.oredict.OreDictionary;
import xtekblue.mod.init.ItemInit;

public class OBA extends BlockObsidian {
	
	public OBA(String name){
		setUnlocalizedName(name);
		setRegistryName(name);
		setHardness(50.0F);
		setResistance(2000.0F);
		setSoundType(SoundType.STONE);
	}

	@Override
	public boolean onBlockActivated(World worldIn, BlockPos pos, IBlockState state, EntityPlayer playerIn, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ) {
		if(playerIn.getHeldItem(hand) == new ItemStack(ItemInit.ENCHANTED_SAW)) {
			worldIn.destroyBlock(pos, false);
			playerIn.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
			return true;
		}else if(playerIn.getHeldItem(hand) == new ItemStack(ItemInit.INGOT_SAW, 1, OreDictionary.WILDCARD_VALUE)) {
			if(playerIn.getHeldItem(hand).getMaxDamage() == playerIn.getHeldItem(hand).getItemDamage()) {
				playerIn.inventory.deleteStack(playerIn.getHeldItem(hand));
				worldIn.destroyBlock(pos, false);
				playerIn.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
				return true;
			}else {
				playerIn.getHeldItem(hand).setItemDamage(playerIn.getHeldItem(hand).getItemDamage() + 1);
				worldIn.destroyBlock(pos, false);
				playerIn.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
				return true;
			}
		}else
		return false;
	}
}

This is my custom class that takes from obsidian and adds onBlockActivated() to the class.

package xtekblue.mod.init;

import java.util.ArrayList;
import java.util.List;

import net.minecraft.block.Block;
import net.minecraft.block.BlockDirt;
import net.minecraft.block.SoundType;
import net.minecraft.block.material.Material;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.init.Blocks;
import xtekblue.mod.objects.blocks.BlockBase;
import xtekblue.mod.objects.blocks.BlockMud;
import xtekblue.mod.objects.blocks.OBA;
import xtekblue.mod.objects.blocks.OreBase;
import xtekblue.mod.objects.blocks.SmoothObsidian;
import xtekblue.mod.objects.blocks.RGBlock;

public class BlockInit {

	public static final List<Block> BLOCKS = new ArrayList<Block>();
	
	//Basic Blocks
	public static final Block SMOOTH_OBSIDIAN = new SmoothObsidian("smooth_obsidian", Material.ROCK);
	public static final Block MUD_BRICK = new BlockMud("mud_brick", Material.CLAY, SoundType.STONE);
	public static final Block REDSTONE_GLOWSTONE = new RGBlock("redstone_glowstone", false);
	public static final Block REDSTONE_GLOWSTONE_LIT = new RGBlock("redstone_glowstone_lit", true);
	public static final Block OBSIDIAN = new OBA("obsidian");
	
	//Ore Gen Blocks
	public static final Block ORE_OVERWORLD = new OreBase("ore_overworld", "overworld");	
	public static final Block MUD_BLOCK = new BlockMud("mud_block", Material.CLAY, SoundType.GROUND);
	//public static final Block BLOCK_REDSTONE_GLOWSTONE = new BlockRG("block_redstone_glowstone", false).setCreativeTab(CreativeTabs.REDSTONE);
	//public static final Block BLOCK_REDSTONE_GLOWSTONE_LIT = new BlockRG("block_redstone_glowstone_lit", true);
	//public static final Block TROPHY = new BlockTrophy("trophy");
	//public static final Block BLOCK_REDSTONE_GLOWSTONE = new BlockBase("block_redstone_glowstone", Material.GLASS);
	
	//public static final Block BLOCK_REDSTONE_GLOWSTONE_LIT = new BlockRGLit("block_redstone_glowstone_lit");
}

As you can see i have OBSIDIAN registered under that new class i created. My handler should run it like normal but it still seems to do nothing. Im sure im doing something wrong i just cant figure it out still.

This is my registry handler.

package xtekblue.mod.util.handlers;

import net.minecraft.block.Block;
import net.minecraft.block.material.Material;
import net.minecraft.block.state.IBlockState;
import net.minecraft.entity.EntityLivingBase;
import net.minecraft.init.Blocks;
import net.minecraft.init.Items;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;
import net.minecraft.item.crafting.Ingredient;
import net.minecraft.util.ResourceLocation;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.IBlockAccess;
import net.minecraft.world.World;
import net.minecraftforge.client.event.ModelRegistryEvent;
import net.minecraftforge.event.RegistryEvent;
import net.minecraftforge.fml.common.Mod.EventBusSubscriber;
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
import net.minecraftforge.fml.common.registry.GameRegistry;
import net.minecraftforge.oredict.OreDictionary;
import xtekblue.mod.init.BlockInit;
import xtekblue.mod.init.ItemInit;
import xtekblue.mod.util.IHasModel;
import xtekblue.mod.world.gen.WorldGenCustomOres;

@EventBusSubscriber
public class RegistryHandler {

	@SubscribeEvent
	public static void onItemRegister(RegistryEvent.Register<Item> event) {
		
		event.getRegistry().registerAll(ItemInit.ITEMS.toArray(new Item[0]));
	}
	
	@SubscribeEvent
	public static void onBlockRegister(RegistryEvent.Register<Block> event) {
		
		event.getRegistry().registerAll(BlockInit.BLOCKS.toArray(new Block[0]));
	}
	
	@SubscribeEvent
	public static void onModelRegister(ModelRegistryEvent event) {
		for(Item item : ItemInit.ITEMS) {
			if(item instanceof IHasModel) {
				((IHasModel)item).registerModels();
			}
		}
		for(Block block : BlockInit.BLOCKS) {
			if(block instanceof IHasModel) {
				((IHasModel)block).registerModels();
			}
		}
	}
	
	public static void initRegisteries() {
	}
	
	public static void recipeRegistries() {
		GameRegistry.addShapelessRecipe(new ResourceLocation("xi:obsidian_ingot"), new ResourceLocation("xi:obsidian_ingot"), new ItemStack(ItemInit.OBSIDIAN_INGOT, 2), new Ingredient[]{Ingredient.fromStacks(new ItemStack(ItemInit.INGOT_SAW, 1, OreDictionary.WILDCARD_VALUE)), Ingredient.fromStacks(new ItemStack(Blocks.OBSIDIAN, 1))});
		GameRegistry.addShapelessRecipe(new ResourceLocation("xi:obsidian_ingot2"), new ResourceLocation("xi:obsidian_ingot2"), new ItemStack(ItemInit.OBSIDIAN_INGOT, 2), new Ingredient[]{Ingredient.fromStacks(new ItemStack(ItemInit.ENCHANTED_SAW, 1)), Ingredient.fromStacks(new ItemStack(Blocks.OBSIDIAN, 1))});
		GameRegistry.addShapelessRecipe(new ResourceLocation("xi:obsidian_ingot3"), new ResourceLocation("xi:obsidian_ingot3"), new ItemStack(ItemInit.OBSIDIAN_INGOT, 9), new Ingredient[]{Ingredient.fromStacks(new ItemStack(BlockInit.SMOOTH_OBSIDIAN, 1))});
	}
	
	public static void otherRegistries() {
		GameRegistry.registerWorldGenerator(new WorldGenCustomOres(), 0);
	}

}

 

Link to comment
Share on other sites

You're setting the registry name to "obsidian". As this does not contain a domain ID (i.e. your mod name), forge adds it for you, based on whatever's in your @mod annotation (I'll assume "xtekblue" for the moment). This means the registry name is actually "xtekblue:obsidian". In order to overwrite vanilla's obsidian, you need to set the registry name to "minecraft:obsidian"

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

	@Override
	public boolean onBlockActivated(World worldIn, BlockPos pos, IBlockState state, EntityPlayer playerIn, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ) {
		if(playerIn.getHeldItem(hand) == new ItemStack(ItemInit.ENCHANTED_SAW)) {
			worldIn.destroyBlock(pos, false);
			playerIn.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
			return true;
		}else if(playerIn.getHeldItem(hand) == new ItemStack(ItemInit.INGOT_SAW, 1, OreDictionary.WILDCARD_VALUE)) {
			if(playerIn.getHeldItem(hand).getMaxDamage() == playerIn.getHeldItem(hand).getItemDamage()) {
				playerIn.inventory.deleteStack(playerIn.getHeldItem(hand));
				worldIn.destroyBlock(pos, false);
				playerIn.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
				return true;
			}else {
				playerIn.getHeldItem(hand).setItemDamage(playerIn.getHeldItem(hand).getItemDamage() + 1);
				worldIn.destroyBlock(pos, false);
				playerIn.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
				return true;
			}
		}else
		return false;
	}

Also does this not work, that could be the reason i believe its not working, i want the obsidian to break and drop two "Obsidian_ingots" when right clicked with a "ingot_saw", also damage the ingot saw when right clicking with it.

Link to comment
Share on other sites

14 minutes ago, xTekBlue said:

would "setRegistryName("minecraft", name);" not work?

Did I say it would not? No I did not say that.

In fact I said you must do that.

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

package xtekblue.mod.objects.blocks;

import net.minecraft.block.BlockObsidian;
import net.minecraft.block.SoundType;
import net.minecraft.block.state.IBlockState;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.item.ItemBlock;
import net.minecraft.item.ItemStack;
import net.minecraft.util.EnumFacing;
import net.minecraft.util.EnumHand;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.World;
import net.minecraftforge.oredict.OreDictionary;
import xtekblue.mod.init.BlockInit;
import xtekblue.mod.init.ItemInit;

public class OBA extends BlockObsidian {
	
	public OBA(String name){
		setUnlocalizedName(name);
		setRegistryName("minecraft", name);
		setHardness(50.0F);
		setResistance(2000.0F);
		setSoundType(SoundType.STONE);
	}

	@Override
	public boolean onBlockActivated(World worldIn, BlockPos pos, IBlockState state, EntityPlayer playerIn, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ) {
		if(playerIn.getHeldItemMainhand() != (new ItemStack(ItemInit.INGOT_SAW, 1, OreDictionary.WILDCARD_VALUE))) {
			return false;
		}else if(playerIn.getHeldItemMainhand() != (new ItemStack(ItemInit.ENCHANTED_SAW, 1))) {
			return false;
		}else {
			return this.DoDropsOB(worldIn, pos, state, playerIn);
		}
	}
	
	private boolean DoDropsOB(World worldIn, BlockPos pos, IBlockState state, EntityPlayer player) {
		if(player.isCreative() && player.getHeldItemMainhand() == new ItemStack(ItemInit.INGOT_SAW, 1, OreDictionary.WILDCARD_VALUE)) {
			worldIn.destroyBlock(pos, false);
			player.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
			return true;
		}else if(player.isCreative() && player.getHeldItemMainhand() == new ItemStack(ItemInit.ENCHANTED_SAW, 1)) {
			worldIn.destroyBlock(pos, false);
			player.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
			return true;
		}else if(!player.isCreative() && player.getHeldItemMainhand() == new ItemStack(ItemInit.INGOT_SAW, 1, OreDictionary.WILDCARD_VALUE)) {
			worldIn.destroyBlock(pos, false);
			if(player.getHeldItemMainhand().getItemDamage() == player.getHeldItemMainhand().getMaxDamage()) {
				player.inventory.deleteStack(player.getHeldItemMainhand());
			}else {
				player.getHeldItemMainhand().setItemDamage(player.getHeldItemMainhand().getItemDamage() + 1);
			}
			player.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
			return true;
		}else if(!player.isCreative() && player.getHeldItemMainhand() == new ItemStack(ItemInit.ENCHANTED_SAW, 1)) {
			worldIn.destroyBlock(pos, false);
			player.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
			return true;
		}else {
			return false;
		}
	}
}

New code and still have no idea why this is not working.

Link to comment
Share on other sites

1 hour ago, xTekBlue said:

which caused a crash

Always post your errors when you have them.

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

The crash had to do with 2 setRegistryName() methods on the same block going to different paths, thats fixed and was not big of a deal. But currently the 

onBlockActivated

is not working how id like it to be and i dont understand why, any idea?

 

Link to comment
Share on other sites

Have you tried the debugger?

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

debugger shows nothing besides bad checks on chunk loading 

[22:25:49] [Server thread/WARN] [FML]: XtraItems loaded a new chunk [-38, 18] in dimension 0 (overworld) while populating chunk [-37, 18], causing cascading worldgen lag.
[22:25:49] [Server thread/WARN] [FML]: Please report this to the mod's issue tracker. This log can be disabled in the Forge config.

EXAMPLE ^^^

I use eclipse btw

Edited by xTekBlue
Link to comment
Share on other sites

That's not the debugger, that's the log.

 

http://www.vogella.com/tutorials/EclipseDebugging/article.html

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

1 hour ago, xTekBlue said:

onBlockActivated

first get your registration working, then try to make your block do something.

Off the top of my head onBlockActivated is called when you right-click the block and is used to usually open GUIs. If you do anything inside onBlockActivated, return true. otherwise return false

 

For example:

Crafting Tables open the crafting table GUI and return true. 

 

Heres the code from the base Block.class

 

/**
     * Called when the block is right clicked by a player.
     */
    public boolean onBlockActivated(World worldIn, BlockPos pos, IBlockState state, EntityPlayer playerIn, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ)
    {
        return false;
    }

 

and from BlockWorkbench.class

/**

     * Called when the block is right clicked by a player.

     */

@Override

    public boolean onBlockActivated(World worldIn, BlockPos pos, IBlockState state, EntityPlayer playerIn, EnumHand hand, EnumFacing facing, float hitX, float hitY, float hitZ)

    {

        if (worldIn.isRemote)

        {

            return true;

        }

        else

        {

            playerIn.displayGui(new BlockWorkbench.InterfaceCraftingTable(worldIn, pos));

            playerIn.addStat(StatList.CRAFTING_TABLE_INTERACTION);

            return true;

        }

    }

Edited by Cadiboo
added code

About Me

Spoiler

My Discord - Cadiboo#8887

My WebsiteCadiboo.github.io

My ModsCadiboo.github.io/projects

My TutorialsCadiboo.github.io/tutorials

Versions below 1.14.4 are no longer supported on this forum. Use the latest version to receive support.

When asking support remember to include all relevant log files (logs are found in .minecraft/logs/), code if applicable and screenshots if possible.

Only download mods from trusted sites like CurseForge (minecraft.curseforge.com). A list of bad sites can be found here, with more information available at stopmodreposts.org

Edit your own signature at www.minecraftforge.net/forum/settings/signature/ (Make sure to check its compatibility with the Dark Theme)

Link to comment
Share on other sites

Still seems to not work, no idea why its not. i do not understand the debugger at all so i'm going to post it on the github and see if someone can debug it properly or if someones willing to show me a video of how to use it thoroughly then that will also work. 

 

https://github.com/EzGunzBlazzinn/XtraItems

Edited by xTekBlue
Link to comment
Share on other sites

I mean i get the debugger its just i don't understand where i need to place break points and watch points as such. I also do not know how to read the debugger correctly. The link is fine and will take me sometime to go over it but a video would be clearer than a few screenshots with limited knowledge/text.

Link to comment
Share on other sites

1 hour ago, xTekBlue said:

i don't understand where i need to place break points

Here:

On 4/24/2018 at 6:25 PM, xTekBlue said:

But currently the 


onBlockActivated

is not working

If a method isn't working, you need to place a break point in it so you can figure out why.

If your breakpoint is never hit, even when you do the thing that should call it, then your method is never called and you need to figure out why.

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

16 minutes ago, xTekBlue said:

How do you know when that breakpoint is hit? If i know this then debugging will be easier to understand.

To use the debugger, you need to use the debug run configuration. If you do that, then the execution (for that thread) will actually stop when the breakpoint is reached. You can usually tell because in Eclipse instead of a bunch of updating the information will sort of stop updating. So if you had a breakpoint set for onBlockActivated() you would play the game and watch the debug window and then at the moment of the block activation you should see it sort of capture the information in the debug windows.

 

Once the execution is frozen, you can inspect the field values. That should be in another pane in the Eclipse debug interface. Then there are special buttons on the toolbar for stepping through the next lines of code. So you can go one line at a time. The difference between the various step buttons is sometimes you want to go right into the various methods and other times you trust a method so want to let it execute completely as a single step.

 

It's kinda complicated to explain, but should be sort of obvious if you do it and watch what is happening. Also, just look up tutorials on Eclipse debugger as this is just standard Java and has nothing to do with modding or Minecraft.

Check out my tutorials here: http://jabelarminecraft.blogspot.com/

Link to comment
Share on other sites

Wow, that actually helped a lot! Thanks. so now i can tell that 

	private boolean DoDropsOB(World worldIn, BlockPos pos, IBlockState state, EntityPlayer player, EnumHand hand) {
		if(player.getHeldItem(hand) == new ItemStack(ItemInit.INGOT_SAW, 1, OreDictionary.WILDCARD_VALUE)) {
			worldIn.destroyBlock(pos, false);
			player.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
			return true;
		}else {
			return true;
		}
	}

this method is being called but the "if" statement is being called regardless of having a "INGOT_SAW" in my hand or not, meaning any item will call true on this "if" statement. Any reason why.

 

EDIT: also when i changed the code to 

	private boolean DoDropsOB(World worldIn, BlockPos pos, IBlockState state, EntityPlayer player, EnumHand hand) {
			worldIn.destroyBlock(pos, false);
			player.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));
			return true;
	}

this, it removed the block, gave me the itemstack but replaced the block. no idea why on that one either.

 

EDIT #2: The itemstack that is being added "OBSIDIAN_INGOT" is also not being put in the inventory, ill be using a video to demonstrate below

 

Spoiler

 

 

Edited by xTekBlue
Link to comment
Share on other sites

1 hour ago, xTekBlue said:

this method is being called but the "if" statement is being called regardless of having a "INGOT_SAW" in my hand or not, meaning any item will call true on this "if" statement. Any reason why.

Well, for one, that's not how you compare item stacks.

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

ok, any idea why the 

1 hour ago, xTekBlue said:

private boolean DoDropsOB(World worldIn, BlockPos pos, IBlockState state, EntityPlayer player, EnumHand hand) {

 worldIn.destroyBlock(pos, false); player.addItemStackToInventory(new ItemStack(ItemInit.OBSIDIAN_INGOT, 2));

 return true;

}

is not working?

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've been having a problem when launching minecraft forge. It just doesn't open the game, and leaves me with this "(exit code 1)" error. Both regular and optifine versions of minecraft launch just fine, tried both with 1.18.2 and 1.20.1. I can assure that my drivers are updated so that can't be it, and i've tried using Java 17, 18 and 21 to no avail. Even with no mods installed, the thing won't launch. I'll leave the log here, although it's in spanish: https://jmp.sh/s/FPqGBSi30fzKJDt2M1gc My specs are this: Ryzen 3 4100 || Radeon R9 280x || 16gb ram || Windows 10 I'd appreciate any help, thank you in advance.
    • Hey, Me and my friends decided to start up a Server with "a few" mods, the last few days everything went well we used all the items we wanted. Now our Game crashes the moment we touch a Lava Bucket inside our Inventory. It just instantly closes and gives me an "Alc Cleanup"  Crash screen (Using GDLauncher). I honestly dont have a clue how to resolve this error. If anyone could help id really appreciate it, I speak German and Englisch so you can choose whatever you speak more fluently. Thanks in Advance. Plus I dont know how to link my Crash Report help for that would be nice too whoops
    • I hosted a minecraft server and I modded it, and there is always an error on the console which closes the server. If someone knows how to repair it, it would be amazing. Thank you. I paste the crash report down here: ---- Minecraft Crash Report ---- WARNING: coremods are present:   llibrary (llibrary-core-1.0.11-1.12.2.jar)   WolfArmorCore (WolfArmorAndStorage-1.12.2-3.8.0-universal-signed.jar)   AstralCore (astralsorcery-1.12.2-1.10.27.jar)   CreativePatchingLoader (CreativeCore_v1.10.71_mc1.12.2.jar)   SecurityCraftLoadingPlugin ([1.12.2] SecurityCraft v1.9.8.jar)   ForgelinPlugin (Forgelin-1.8.4.jar)   midnight (themidnight-0.3.5.jar)   FutureMC (Future-MC-0.2.19.jar)   SpartanWeaponry-MixinLoader (SpartanWeaponry-1.12.2-1.5.3.jar)   Backpacked (backpacked-1.4.3-1.12.2.jar)   LoadingPlugin (Reskillable-1.12.2-1.13.0.jar)   LoadingPlugin (Bloodmoon-MC1.12.2-1.5.3.jar) Contact their authors BEFORE contacting forge // There are four lights! Time: 3/28/24 12:17 PM Description: Exception in server tick loop net.minecraftforge.fml.common.LoaderException: java.lang.NoClassDefFoundError: net/minecraft/client/multiplayer/WorldClient     at net.minecraftforge.fml.common.AutomaticEventSubscriber.inject(AutomaticEventSubscriber.java:89)     at net.minecraftforge.fml.common.FMLModContainer.constructMod(FMLModContainer.java:612)     at sun.reflect.GeneratedMethodAccessor10.invoke(Unknown Source)     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)     at java.lang.reflect.Method.invoke(Method.java:498)     at com.google.common.eventbus.Subscriber.invokeSubscriberMethod(Subscriber.java:91)     at com.google.common.eventbus.Subscriber$SynchronizedSubscriber.invokeSubscriberMethod(Subscriber.java:150)     at com.google.common.eventbus.Subscriber$1.run(Subscriber.java:76)     at com.google.common.util.concurrent.MoreExecutors$DirectExecutor.execute(MoreExecutors.java:399)     at com.google.common.eventbus.Subscriber.dispatchEvent(Subscriber.java:71)     at com.google.common.eventbus.Dispatcher$PerThreadQueuedDispatcher.dispatch(Dispatcher.java:116)     at com.google.common.eventbus.EventBus.post(EventBus.java:217)     at net.minecraftforge.fml.common.LoadController.sendEventToModContainer(LoadController.java:219)     at net.minecraftforge.fml.common.LoadController.propogateStateMessage(LoadController.java:197)     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)     at java.lang.reflect.Method.invoke(Method.java:498)     at com.google.common.eventbus.Subscriber.invokeSubscriberMethod(Subscriber.java:91)     at com.google.common.eventbus.Subscriber$SynchronizedSubscriber.invokeSubscriberMethod(Subscriber.java:150)     at com.google.common.eventbus.Subscriber$1.run(Subscriber.java:76)     at com.google.common.util.concurrent.MoreExecutors$DirectExecutor.execute(MoreExecutors.java:399)     at com.google.common.eventbus.Subscriber.dispatchEvent(Subscriber.java:71)     at com.google.common.eventbus.Dispatcher$PerThreadQueuedDispatcher.dispatch(Dispatcher.java:116)     at com.google.common.eventbus.EventBus.post(EventBus.java:217)     at net.minecraftforge.fml.common.LoadController.distributeStateMessage(LoadController.java:136)     at net.minecraftforge.fml.common.Loader.loadMods(Loader.java:595)     at net.minecraftforge.fml.server.FMLServerHandler.beginServerLoading(FMLServerHandler.java:98)     at net.minecraftforge.fml.common.FMLCommonHandler.onServerStart(FMLCommonHandler.java:333)     at net.minecraft.server.dedicated.DedicatedServer.func_71197_b(DedicatedServer.java:125)     at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:486)     at java.lang.Thread.run(Thread.java:750) Caused by: java.lang.NoClassDefFoundError: net/minecraft/client/multiplayer/WorldClient     at java.lang.Class.getDeclaredMethods0(Native Method)     at java.lang.Class.privateGetDeclaredMethods(Class.java:2701)     at java.lang.Class.privateGetPublicMethods(Class.java:2902)     at java.lang.Class.getMethods(Class.java:1615)     at net.minecraftforge.fml.common.eventhandler.EventBus.register(EventBus.java:82)     at net.minecraftforge.fml.common.AutomaticEventSubscriber.inject(AutomaticEventSubscriber.java:82)     ... 31 more Caused by: java.lang.ClassNotFoundException: net.minecraft.client.multiplayer.WorldClient     at net.minecraft.launchwrapper.LaunchClassLoader.findClass(LaunchClassLoader.java:191)     at java.lang.ClassLoader.loadClass(ClassLoader.java:418)     at java.lang.ClassLoader.loadClass(ClassLoader.java:351)     ... 37 more Caused by: net.minecraftforge.fml.common.asm.ASMTransformerWrapper$TransformerException: Exception in class transformer net.minecraftforge.fml.common.asm.transformers.SideTransformer@4e558728 from coremod FMLCorePlugin     at net.minecraftforge.fml.common.asm.ASMTransformerWrapper$TransformerWrapper.transform(ASMTransformerWrapper.java:260)     at net.minecraft.launchwrapper.LaunchClassLoader.runTransformers(LaunchClassLoader.java:279)     at net.minecraft.launchwrapper.LaunchClassLoader.findClass(LaunchClassLoader.java:176)     ... 39 more Caused by: java.lang.RuntimeException: Attempted to load class bsb for invalid side SERVER     at net.minecraftforge.fml.common.asm.transformers.SideTransformer.transform(SideTransformer.java:62)     at net.minecraftforge.fml.common.asm.ASMTransformerWrapper$TransformerWrapper.transform(ASMTransformerWrapper.java:256)     ... 41 more A detailed walkthrough of the error, its code path and all known details is as follows: --------------------------------------------------------------------------------------- -- System Details -- Details:     Minecraft Version: 1.12.2     Operating System: Linux (amd64) version 5.10.0-28-cloud-amd64     Java Version: 1.8.0_382, Temurin     Java VM Version: OpenJDK 64-Bit Server VM (mixed mode), Temurin     Memory: 948745536 bytes (904 MB) / 1564999680 bytes (1492 MB) up to 7635730432 bytes (7282 MB)     JVM Flags: 2 total; -Xmx8192M -Xms256M     IntCache: cache: 0, tcache: 0, allocated: 0, tallocated: 0     FML: MCP 9.42 Powered by Forge 14.23.5.2860 63 mods loaded, 63 mods active     States: 'U' = Unloaded 'L' = Loaded 'C' = Constructed 'H' = Pre-initialized 'I' = Initialized 'J' = Post-initialized 'A' = Available 'D' = Disabled 'E' = Errored     | State | ID                 | Version                 | Source                                                | Signature                                |     |:----- |:------------------ |:----------------------- |:----------------------------------------------------- |:---------------------------------------- |     | LC    | minecraft          | 1.12.2                  | minecraft.jar                                         | None                                     |     | LC    | mcp                | 9.42                    | minecraft.jar                                         | None                                     |     | LC    | FML                | 8.0.99.99               | forge-1.12.2-14.23.5.2860.jar                         | e3c3d50c7c986df74c645c0ac54639741c90a557 |     | LC    | forge              | 14.23.5.2860            | forge-1.12.2-14.23.5.2860.jar                         | e3c3d50c7c986df74c645c0ac54639741c90a557 |     | LC    | creativecoredummy  | 1.0.0                   | minecraft.jar                                         | None                                     |     | LC    | backpacked         | 1.4.2                   | backpacked-1.4.3-1.12.2.jar                           | None                                     |     | LC    | itemblacklist      | 1.4.3                   | ItemBlacklist-1.4.3.jar                               | None                                     |     | LC    | securitycraft      | v1.9.8                  | [1.12.2] SecurityCraft v1.9.8.jar                     | None                                     |     | LC    | aiimprovements     | 0.0.1.3                 | AIImprovements-1.12-0.0.1b3.jar                       | None                                     |     | LC    | jei                | 4.16.1.301              | jei_1.12.2-4.16.1.301.jar                             | None                                     |     | LC    | appleskin          | 1.0.14                  | AppleSkin-mc1.12-1.0.14.jar                           | None                                     |     | LC    | baubles            | 1.5.2                   | Baubles-1.12-1.5.2.jar                                | None                                     |     | LC    | astralsorcery      | 1.10.27                 | astralsorcery-1.12.2-1.10.27.jar                      | a0f0b759d895c15ceb3e3bcb5f3c2db7c582edf0 |     | LC    | attributefix       | 1.0.12                  | AttributeFix-Forge-1.12.2-1.0.12.jar                  | None                                     |     | LC    | atum               | 2.0.20                  | Atum-1.12.2-2.0.20.jar                                | None                                     |     | LC    | bloodmoon          | 1.5.3                   | Bloodmoon-MC1.12.2-1.5.3.jar                          | d72e0dd57935b3e9476212aea0c0df352dd76291 |     | LC    | forgelin           | 1.8.4                   | Forgelin-1.8.4.jar                                    | None                                     |     | LC    | bountiful          | 2.2.2                   | Bountiful-2.2.2.jar                                   | None                                     |     | LC    | camera             | 1.0.10                  | camera-1.0.10.jar                                     | None                                     |     | LC    | chisel             | MC1.12.2-1.0.2.45       | Chisel-MC1.12.2-1.0.2.45.jar                          | None                                     |     | LC    | collective         | 3.0                     | collective-1.12.2-3.0.jar                             | None                                     |     | LC    | reskillable        | 1.12.2-1.13.0           | Reskillable-1.12.2-1.13.0.jar                         | None                                     |     | LC    | compatskills       | 1.12.2-1.17.0           | CompatSkills-1.12.2-1.17.0.jar                        | None                                     |     | LC    | creativecore       | 1.10.0                  | CreativeCore_v1.10.71_mc1.12.2.jar                    | None                                     |     | LC    | customnpcs         | 1.12                    | CustomNPCs_1.12.2-(05Jul20).jar                       | None                                     |     | LC    | darknesslib        | 1.1.2                   | DarknessLib-1.12.2-1.1.2.jar                          | 220f10d3a93b3ff5fbaa7434cc629d863d6751b9 |     | LC    | dungeonsmod        | @VERSION@               | DungeonsMod-1.12.2-1.0.8.jar                          | None                                     |     | LC    | enhancedvisuals    | 1.3.0                   | EnhancedVisuals_v1.4.4_mc1.12.2.jar                   | None                                     |     | LC    | extrautils2        | 1.0                     | extrautils2-1.12-1.9.9.jar                            | None                                     |     | LC    | futuremc           | 0.2.6                   | Future-MC-0.2.19.jar                                  | None                                     |     | LC    | geckolib3          | 3.0.30                  | geckolib-forge-1.12.2-3.0.31.jar                      | None                                     |     | LC    | gottschcore        | 1.15.1                  | GottschCore-mc1.12.2-f14.23.5.2859-v1.15.1.jar        | None                                     |     | LC    | hardcorerevival    | 1.2.0                   | HardcoreRevival_1.12.2-1.2.0.jar                      | None                                     |     | LC    | waila              | 1.8.26                  | Hwyla-1.8.26-B41_1.12.2.jar                           | None                                     |     | LE    | imsm               | 1.12                    | Instant Massive Structures Mod 1.12.2.jar             | None                                     |     | L     | journeymap         | 1.12.2-5.7.1p2          | journeymap-1.12.2-5.7.1p2.jar                         | None                                     |     | L     | mobsunscreen       | @version@               | mobsunscreen-1.12.2-3.1.5.jar                         | None                                     |     | L     | morpheus           | 1.12.2-3.5.106          | Morpheus-1.12.2-3.5.106.jar                           | None                                     |     | L     | llibrary           | 1.7.20                  | llibrary-1.7.20-1.12.2.jar                            | None                                     |     | L     | mowziesmobs        | 1.5.8                   | mowziesmobs-1.5.8.jar                                 | None                                     |     | L     | nocubessrparmory   | 3.0.0                   | NoCubes_SRP_Combat_Addon_3.0.0.jar                    | None                                     |     | L     | nocubessrpnests    | 3.0.0                   | NoCubes_SRP_Nests_Addon_3.0.0.jar                     | None                                     |     | L     | nocubessrpsurvival | 3.0.0                   | NoCubes_SRP_Survival_Addon_3.0.0.jar                  | None                                     |     | L     | nocubesrptweaks    | V4.1                    | nocubesrptweaks-V4.1.jar                              | None                                     |     | L     | patchouli          | 1.0-23.6                | Patchouli-1.0-23.6.jar                                | None                                     |     | L     | artifacts          | 1.1.2                   | RLArtifacts-1.1.2.jar                                 | None                                     |     | L     | rsgauges           | 1.2.8                   | rsgauges-1.12.2-1.2.8.jar                             | None                                     |     | L     | rustic             | 1.1.7                   | rustic-1.1.7.jar                                      | None                                     |     | L     | silentlib          | 3.0.13                  | SilentLib-1.12.2-3.0.14+168.jar                       | None                                     |     | L     | scalinghealth      | 1.3.37                  | ScalingHealth-1.12.2-1.3.42+147.jar                   | None                                     |     | L     | lteleporters       | 1.12.2-3.0.2            | simpleteleporters-1.12.2-3.0.2.jar                    | None                                     |     | L     | spartanshields     | 1.5.5                   | SpartanShields-1.12.2-1.5.5.jar                       | None                                     |     | L     | spartanweaponry    | 1.5.3                   | SpartanWeaponry-1.12.2-1.5.3.jar                      | None                                     |     | L     | srparasites        | 1.9.18                  | SRParasites-1.12.2v1.9.18.jar                         | None                                     |     | L     | treasure2          | 2.2.0                   | Treasure2-mc1.12.2-f14.23.5.2859-v2.2.1.jar           | None                                     |     | L     | treeharvester      | 4.0                     | treeharvester_1.12.2-4.0.jar                          | None                                     |     | L     | twilightforest     | 3.11.1021               | twilightforest-1.12.2-3.11.1021-universal.jar         | None                                     |     | L     | variedcommodities  | 1.12.2                  | VariedCommodities_1.12.2-(31Mar23).jar                | None                                     |     | L     | voicechat          | 1.12.2-2.4.32           | voicechat-forge-1.12.2-2.4.32.jar                     | None                                     |     | L     | wolfarmor          | 3.8.0                   | WolfArmorAndStorage-1.12.2-3.8.0-universal-signed.jar | None                                     |     | L     | worldborder        | 2.3                     | worldborder_1.12.2-2.3.jar                            | None                                     |     | L     | midnight           | 0.3.5                   | themidnight-0.3.5.jar                                 | None                                     |     | L     | structurize        | 1.12.2-0.10.277-RELEASE | structurize-1.12.2-0.10.277-RELEASE.jar               | None                                     |     Loaded coremods (and transformers):  llibrary (llibrary-core-1.0.11-1.12.2.jar)   net.ilexiconn.llibrary.server.core.plugin.LLibraryTransformer   net.ilexiconn.llibrary.server.core.patcher.LLibraryRuntimePatcher WolfArmorCore (WolfArmorAndStorage-1.12.2-3.8.0-universal-signed.jar)    AstralCore (astralsorcery-1.12.2-1.10.27.jar)    CreativePatchingLoader (CreativeCore_v1.10.71_mc1.12.2.jar)    SecurityCraftLoadingPlugin ([1.12.2] SecurityCraft v1.9.8.jar)    ForgelinPlugin (Forgelin-1.8.4.jar)    midnight (themidnight-0.3.5.jar)   com.mushroom.midnight.core.transformer.MidnightClassTransformer FutureMC (Future-MC-0.2.19.jar)   thedarkcolour.futuremc.asm.CoreTransformer SpartanWeaponry-MixinLoader (SpartanWeaponry-1.12.2-1.5.3.jar)    Backpacked (backpacked-1.4.3-1.12.2.jar)   com.mrcrayfish.backpacked.asm.BackpackedTransformer LoadingPlugin (Reskillable-1.12.2-1.13.0.jar)   codersafterdark.reskillable.base.asm.ClassTransformer LoadingPlugin (Bloodmoon-MC1.12.2-1.5.3.jar)   lumien.bloodmoon.asm.ClassTransformer     Profiler Position: N/A (disabled)     Is Modded: Definitely; Server brand changed to 'fml,forge'     Type: Dedicated Server (map_server.txt)
    • When i add mods like falling leaves, visuality and kappas shaders, even if i restart Minecraft they dont show up in the mods menu and they dont work
    • Delete the forge-client.toml file in your config folder  
  • Topics

×
×
  • Create New...

Important Information

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