Jump to content

Recommended Posts

Posted

Excuse this mess,

public class MIEventHandler {

@SubscribeEvent
public void onInterect(PlayerInteractEvent e) {
	//Following lines of code control creation of chiseled ruby/sapphire using chisel.
	EntityPlayer player = e.entityPlayer;
	ItemStack itemstack = player.getHeldItem();
	World world = e.world;
	int x = e.x;
	int y = e.y;
	int z = e.z;
		if(e.action == e.action.RIGHT_CLICK_BLOCK){
			if(itemstack == new ItemStack(MIMain.chisel)) {
				if(world.getBlock(x, y, z) != null) {
					if(world.getBlock(x, y, z) == MIMain.rubyBlock) {
						world.setBlock(x, y, z, MIMain.chiseledRuby);
						if(!player.capabilities.isCreativeMode) {
							itemstack.setItemDamage(itemstack.getItemDamage() - 1);
					}
				}	else if(world.getBlock(x, y, z) == MIMain.sapphireBlock) {
						world.setBlock(x, y, z, MIMain.chiseledSapphire);
						if(!player.capabilities.isCreativeMode) {
							itemstack.setItemDamage(itemstack.getItemDamage() - 1);
					}
				}
			}
		}

I'm trying to test whether the player has a chisel in their hand, and if they do, then it will check whether they have clicked a sapphire block or ruby block, and if it is, set it to a chiseled version of the block, however, it appears not to be working. Could anyone help me out here?

There's 10 types of people in this world; Those that understand binary and those that don't.

Posted

Excuse this mess,

public class MIEventHandler {

@SubscribeEvent
public void onInterect(PlayerInteractEvent e) {
	//Following lines of code control creation of chiseled ruby/sapphire using chisel.
	EntityPlayer player = e.entityPlayer;
	ItemStack itemstack = player.getHeldItem();
	World world = e.world;
	int x = e.x;
	int y = e.y;
	int z = e.z;
		if(e.action == e.action.RIGHT_CLICK_BLOCK){
			if(itemstack == new ItemStack(MIMain.chisel)) {
				if(world.getBlock(x, y, z) != null) {
					if(world.getBlock(x, y, z) == MIMain.rubyBlock) {
						world.setBlock(x, y, z, MIMain.chiseledRuby);
						if(!player.capabilities.isCreativeMode) {
							itemstack.setItemDamage(itemstack.getItemDamage() - 1);
					}
				}	else if(world.getBlock(x, y, z) == MIMain.sapphireBlock) {
						world.setBlock(x, y, z, MIMain.chiseledSapphire);
						if(!player.capabilities.isCreativeMode) {
							itemstack.setItemDamage(itemstack.getItemDamage() - 1);
					}
				}
			}
		}

I'm trying to test whether the player has a chisel in their hand, and if they do, then it will check whether they have clicked a sapphire block or ruby block, and if it is, set it to a chiseled version of the block, however, it appears not to be working. Could anyone help me out here?

What does not working mean?

Is there a crash?

Or does it just not do anything. If this is the case, put in debug comments and narrow down the problem.

One thing I can see wrong for certain is that you check it on both sides, the client and the server.

Use if(!world.isRemote) to see

I'm back from being gone for... I think its been about a year. I'm pretty sure nobody remembers me, but hello anybody who does!

Posted

I've already registered the EventHandler @charsmud,

 

I made a few changes to it, and now it fails to start (previously it would start).

 

[18:25:21] [main/INFO] [FML/]: Forge Mod Loader version 7.10.18.1180 for Minecraft 1.7.10 loading
[18:25:21] [main/INFO] [FML/]: Java is Java HotSpot(TM) 64-Bit Server VM, version 1.8.0_25, running on Windows 8.1:amd64:6.3, installed at C:\Program Files (x86)\Minecraft\runtime\jre-x64\1.8.0_25
[18:25:21] [main/DEBUG] [FML/]: Java classpath at launch is C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\net\minecraftforge\forge\1.7.10-10.13.0.1180\forge-1.7.10-10.13.0.1180.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\net\minecraft\launchwrapper\1.9\launchwrapper-1.9.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\ow2\asm\asm-all\4.1\asm-all-4.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\typesafe\akka\akka-actor_2.11\2.3.3\akka-actor_2.11-2.3.3.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\typesafe\config\1.2.1\config-1.2.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\scala-lang\scala-actors-migration_2.11\1.1.0\scala-actors-migration_2.11-1.1.0.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\scala-lang\scala-compiler\2.11.1\scala-compiler-2.11.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\scala-lang\plugins\scala-continuations-library_2.11\1.0.2\scala-continuations-library_2.11-1.0.2.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\scala-lang\plugins\scala-continuations-plugin_2.11.1\1.0.2\scala-continuations-plugin_2.11.1-1.0.2.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\scala-lang\scala-library\2.11.1\scala-library-2.11.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\scala-lang\scala-parser-combinators_2.11\1.0.1\scala-parser-combinators_2.11-1.0.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\scala-lang\scala-reflect\2.11.1\scala-reflect-2.11.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\scala-lang\scala-swing_2.11\1.0.1\scala-swing_2.11-1.0.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\scala-lang\scala-xml_2.11\1.0.2\scala-xml_2.11-1.0.2.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\net\sf\jopt-simple\jopt-simple\4.5\jopt-simple-4.5.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\lzma\lzma\0.0.1\lzma-0.0.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\mojang\realms\1.3.1\realms-1.3.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\apache\commons\commons-compress\1.8.1\commons-compress-1.8.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\apache\httpcomponents\httpclient\4.3.3\httpclient-4.3.3.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\commons-logging\commons-logging\1.1.3\commons-logging-1.1.3.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\apache\httpcomponents\httpcore\4.3.2\httpcore-4.3.2.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\java3d\vecmath\1.3.1\vecmath-1.3.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\net\sf\trove4j\trove4j\3.0.3\trove4j-3.0.3.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\ibm\icu\icu4j-core-mojang\51.2\icu4j-core-mojang-51.2.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\paulscode\codecjorbis\20101023\codecjorbis-20101023.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\paulscode\codecwav\20101023\codecwav-20101023.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\paulscode\libraryjavasound\20101123\libraryjavasound-20101123.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\paulscode\librarylwjglopenal\20100824\librarylwjglopenal-20100824.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\paulscode\soundsystem\20120107\soundsystem-20120107.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\io\netty\netty-all\4.0.10.Final\netty-all-4.0.10.Final.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\google\guava\guava\16.0\guava-16.0.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\apache\commons\commons-lang3\3.2.1\commons-lang3-3.2.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\commons-io\commons-io\2.4\commons-io-2.4.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\commons-codec\commons-codec\1.9\commons-codec-1.9.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\net\java\jinput\jinput\2.0.5\jinput-2.0.5.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\net\java\jutils\jutils\1.0.0\jutils-1.0.0.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\google\code\gson\gson\2.2.4\gson-2.2.4.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\com\mojang\authlib\1.5.16\authlib-1.5.16.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\apache\logging\log4j\log4j-api\2.0-beta9\log4j-api-2.0-beta9.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\apache\logging\log4j\log4j-core\2.0-beta9\log4j-core-2.0-beta9.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\lwjgl\lwjgl\lwjgl\2.9.1\lwjgl-2.9.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\org\lwjgl\lwjgl\lwjgl_util\2.9.1\lwjgl_util-2.9.1.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\libraries\tv\twitch\twitch\5.16\twitch-5.16.jar;C:\Users\Ryan\AppData\Roaming\.minecraft\versions\1.7.10-Forge10.13.0.1180\1.7.10-Forge10.13.0.1180.jar
[18:25:21] [main/DEBUG] [FML/]: Java library path at launch is C:\Users\Ryan\AppData\Roaming\.minecraft\versions\1.7.10-Forge10.13.0.1180\1.7.10-Forge10.13.0.1180-natives-441561050886975
[18:25:21] [main/DEBUG] [FML/]: Enabling runtime deobfuscation
[18:25:21] [main/DEBUG] [FML/]: Instantiating coremod class FMLCorePlugin
[18:25:21] [main/DEBUG] [FML/]: Added access transformer class cpw.mods.fml.common.asm.transformers.AccessTransformer to enqueued access transformers
[18:25:21] [main/DEBUG] [FML/]: Enqueued coremod FMLCorePlugin
[18:25:21] [main/DEBUG] [FML/]: Instantiating coremod class FMLForgePlugin
[18:25:21] [main/DEBUG] [FML/]: Added access transformer class net.minecraftforge.transformers.ForgeAccessTransformer to enqueued access transformers
[18:25:21] [main/DEBUG] [FML/]: Enqueued coremod FMLForgePlugin
[18:25:21] [main/DEBUG] [FML/]: All fundamental core mods are successfully located
[18:25:21] [main/DEBUG] [FML/]: Discovering coremods
[18:25:21] [main/DEBUG] [FML/]: Examining for coremod candidacy FNAF-1.7.10-0.0.1.jar
[18:25:21] [main/DEBUG] [FML/]: Not found coremod data in FNAF-1.7.10-0.0.1.jar
[18:25:21] [main/INFO] [LaunchWrapper/]: Loading tweak class name cpw.mods.fml.common.launcher.FMLInjectionAndSortingTweaker
[18:25:21] [main/INFO] [LaunchWrapper/]: Loading tweak class name cpw.mods.fml.common.launcher.FMLDeobfTweaker
[18:25:21] [main/INFO] [LaunchWrapper/]: Calling tweak class cpw.mods.fml.common.launcher.FMLInjectionAndSortingTweaker
[18:25:21] [main/ERROR] [LaunchWrapper/]: Unable to launch
java.util.ConcurrentModificationException
at java.util.ArrayList$Itr.checkForComodification(ArrayList.java:901) ~[?:1.8.0_25]
at java.util.ArrayList$Itr.remove(ArrayList.java:865) ~[?:1.8.0_25]
at net.minecraft.launchwrapper.Launch.launch(Launch.java:117) [launchwrapper-1.9.jar:?]
at net.minecraft.launchwrapper.Launch.main(Launch.java:28) [launchwrapper-1.9.jar:?]

 

public class MIEventHandler {

@SubscribeEvent
public void onInterect(PlayerInteractEvent e) {
	//Following lines of code control creation of chiseled ruby/sapphire using chisel.
	EntityPlayer player = e.entityPlayer;
	ItemStack itemstack = player.getHeldItem();
	World world = e.world;
	int x = e.x;
	int y = e.y;
	int z = e.z;
		if(e.action == e.action.RIGHT_CLICK_BLOCK){
			player.addChatComponentMessage(new ChatComponentText(EnumChatFormatting.AQUA + "Right click block check working."));
			if(!world.isRemote){
				player.addChatComponentMessage(new ChatComponentText(EnumChatFormatting.AQUA + "Side check working."));
				if(itemstack == new ItemStack(MIMain.chisel)) {
					player.addChatComponentMessage(new ChatComponentText(EnumChatFormatting.AQUA + "Chisel check working."));
					if(world.getBlock(x, y, z) != null) {
						if(world.getBlock(x, y, z) == MIMain.rubyBlock) {
							player.addChatComponentMessage(new ChatComponentText(EnumChatFormatting.AQUA + "Ruby block check working."));
							world.setBlock(x, y, z, MIMain.chiseledRuby);
							if(!player.capabilities.isCreativeMode) {
								itemstack.setItemDamage(itemstack.getItemDamage() - 1);
					}
				}	else if(world.getBlock(x, y, z) == MIMain.sapphireBlock) {
					player.addChatComponentMessage(new ChatComponentText(EnumChatFormatting.AQUA + "Sapphire block check working."));
						world.setBlock(x, y, z, MIMain.chiseledSapphire);
						if(!player.capabilities.isCreativeMode) {
							itemstack.setItemDamage(itemstack.getItemDamage() - 1);
					}
				}
			}
		}

There's 10 types of people in this world; Those that understand binary and those that don't.

Posted

Not that I know direct answer but there are few flaws in your code:

 

if(itemstack == new ItemStack(MIMain.chisel))

 

You should NEVER do this. Don't declare new ItemStack. you should:

if (stack != null) if (stack.getItem() == YourItemRegistry.itemChiselInstance)

 

As to main problem: Do you know how to use Debug mode in eclipse? Place breakpoint in your event (maybe even in EACH line) follow them and say when does it crash.

 

Last question: Are you sure you are using right event bus?

1.7.10 is no longer supported by forge, you are on your own.

Posted

I am aware of the debug mode in eclipse, however, I cannot use it for some reason (fails to start the client everytime).

 

I have just checked over myself, and it appears I had not registered my EventHandler. Should be resgistered now.

 

To answer your last question Ernio, I believe I am using the correct bus,

MinecraftForge.EVENT_BUS.register(new MIEventHandler());

 

There's 10 types of people in this world; Those that understand binary and those that don't.

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.