Jump to content

Crash on world load, java out of bounds exception


Deco

Recommended Posts

I was trying to add a food that gives the player instant damage I upon consumption, but I was only able to give the 'harm' effect for one second. When I came back to the project in the morning, the game would run but crash when the world would load. This is the error it gives me:

 

Stack trace? Crash Report? New to this, sorry.

https://gist.github.com/anonymous/f6a9c0426f713a7fef53

 

My main class code:

https://gist.github.com/anonymous/1e30ea376d8f3a93573e

 

I'm afraid I may have accidentally messed with some of the default code, but I'm not certain. Any ideas?

 

Also, I don't know what would help you guys help me. Please tell me what you need.

Link to comment
Share on other sites

Hi

 

java.lang.ArrayIndexOutOfBoundsException: 117

potionTypes[this.potionID]

 

so potionID is out of range (117 but the maximum allowed is 31)

 

The only place that potionID is set is during construction of PotionEffect.

 

If it crashed after world load, this might means that PotionEffect is not reloading from the NBT properly?

 

    public static PotionEffect readCustomPotionEffectFromNBT(NBTTagCompound par0NBTTagCompound)
    {
        byte b0 = par0NBTTagCompound.getByte("Id");
        byte b1 = par0NBTTagCompound.getByte("Amplifier");
        int i = par0NBTTagCompound.getInteger("Duration");
        boolean flag = par0NBTTagCompound.getBoolean("Ambient");
        return new PotionEffect(b0, i, b1, flag);
    }

 

Could you post your code that does the application of the PotionEffect?

 

You could also try:

Add a statement to onUpdate and put a breakpoint on it, then wait for the breakpoint to trigger and step your way back out to see why potionID was set to 117.

 

    public boolean onUpdate(EntityLivingBase par1EntityLivingBase)
    {
        if (this.duration > 0)
        {
            if (this.potionID >= 32) {
               this.potionID = this.potionID;   // ADD A BREAKPOINT HERE
            } else if (Potion.potionTypes[this.potionID].isReady(this.duration, this.amplifier))

 

 

 

-TGG

Link to comment
Share on other sites

Where do I find the code that does the application of PotionEffect? I'm not entirely sure what you're asking, and I'm not using a custom potion effect. Here's the item's class anyways:

https://gist.github.com/anonymous/8801abbff03c4f0e36b5

 

Aight. So I followed all your jazz with breakpoints and such, only to have the game still crash and now the first line of the stack trace reads:

2013-11-07 22:26:50 [iNFO] [sTDOUT] 	at net.minecraft.potion.PotionHelper.calcPotionLiquidColor(PotionHelper.java:81)

 

Dang. I just set the breakpoint at the previous line, and now I'm back exactly where I was :(

 

Plus, I know what stepping backwards is, I just don't know how to debug in Eclipse.

Link to comment
Share on other sites

Hi

 

I was trying to add a food that gives the player instant damage I upon consumption, but I was only able to give the 'harm' effect for one second.

Not sure I understand - how did you manage to do this, if you didn't use a potion effect (eg .setPotionEffect)?

 

It's possible you did something during development that has applied a weird potionID to your player.  Every time the world reloads, it tries to use this saved potionID which causes the out of bounds.

 

Probably easiest to create a new world.  The problem will probably go away (unless something else in your code introduces it again).

 

-TGG

 

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

    • You shouldn't be extracting the mod .jar, just place it in your mods folder.
    • so basically another rundown of my probelm. Im the admin of a 1.20.1 modded server. Were using forge 47.2.0 but tested this issue in other forge versions too on sevrer and client side. so the forge version isnt the issue. The bug happens in following instances. Were using the attacks of the jujutsucraft mod by orca normally. And for everyone that stands there nothing changes. But everyone who wasnt in the chunks before or who relogins again those chunks will appear invisible for the most part. I tried fixing this be removing and adding following mods in many combinations. Embeddium, canary, memoryleakfix, ai improvements, Krypton reforges, better chunkloading, radium reforged, embeddium plus, farsight, betterchunkloading, oculus I tested most of these mods alone and in differents combinations with each other and without the mods. What i noticed is zhat when i removed  . most invisible chunks will return or semi return. and only ine or two chunks stay invisible. I rechanged those mids mostly on the cöient side but also some in the serveside. Ir most likely isnt an issue with another non performance mod since i noticed this thing with embeddium. Ans also the problem wasnt there im the beginning of the server. Granted since then we updated some of the mods that add content and their lib mod. But i went to every big mods discord and community that we have and i didnt find someone else havinf that chunk problem. Heres the link to a video of the Problem. https://streamable.com/9v1if2     heres the link to the modlist: https://ibb.co/myF8dtX     Pleaee im foghting for months with this problem. All the performance mods kn the modlist are for sure not the issue i tested without all of them.
    • It looks like you're only setting the health if the thing you are hitting is a player.  
    • It sounds like you accidentally have two items that are both named "orange". Ensure that you give items unique names in the string when you register them. That's one of the more annoying errors to track down if you don't know what's causing it, though.
    • when i tried downloading blockfront from curseforge for version 1.20.1 i get the winrar file  and that i extract and i just get the "manifest.json" file no mod when exctracted
  • Topics

×
×
  • Create New...

Important Information

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