Jump to content

[1.20.1] Custom Anvil Block "Index 0 out of bounds for length 0" thrown when GUI opened or changed


Recommended Posts

Posted (edited)

Hey all, I'm trying to make a custom anvil that does all anvil actions for free (for fun, and testing).

The anvil opens the screen in game. I can put items in the two slots and type anything in the text box with no cost.

The item in the output slot can't be taken, but has enchantments (yet the name in the box isn't applied to the item) from the other slots and text box. When I change anything while the anvil screen is open, I get a "index out of bounds" error in the console but no crash. The log hints at an Array somewhere along the line related to a slot being the issue...

But I can't figure out WHICH variable (or where it is) that the error is talking about. I'm trying to use vanilla-ish code with some "light modification". But I can't go further unless I know what I broke. If what I'm doing is impossibly difficult to accomplish, or requires some easy little fix, please help.

 

The registry for the menu looks like this:

public static final RegistryObject<MenuType<NetheriteAnvilMenu>> NETHERITE_ANVIL_MENU =
            MENU_TYPES.register("netherite_anvil_menu",()->IForgeMenuType.create(NetheriteAnvilMenu::new));

The registry for the menutype (in the setupClient method) looks like this in my main mod class:

MenuScreens.register(ThingamajigsMenuTypes.NETHERITE_ANVIL_MENU.get(), NetheriteAnvilScreen::new);

 

Error log snippet: https://pastebin.com/BnxcH5Ft

Vanilla-based code for Anvil Block: https://mega.nz/file/pGRC3TAR#dWqJnzN9akEcYKK4ZaTtkkHGNRvlRkl2yTVRmdjveXU

Vanilla-based code for Anvil screen: https://mega.nz/file/QOpwHZwQ#S6cZzGhFQPGq4r_VLJSm2skFSRI24P9vz7Lm29j4yvM

Vanilla-based code for Anvil Menu: https://mega.nz/file/gDAX3bIR#Je9kdiT_rsl_SUnZYgOrEPcy9bCV-ZVmcFTIJdnB7Jk

Thingamajigs mod Ref class snippet used by Custom Anvil: https://mega.nz/file/EXQ0hYxY#BUUnp0URKpC8cQzs6U-je68YsDSjt-CSGRk70_kJHXw

I can't paste vanilla code here (too long and still WIP to be unique from vanilla) so I've provided links to downloads separately that will be removed once the issue is solved.

Here is a screenshot of the screen in game: https://mega.nz/file/Jf4BQR4A#S1DEjhg9MC497o8tEfSQ80rQHky45lz7gZYnaHxI_UM

Hope this is enough info and such to help identify the issue.

Edited by CreativeMasterBonin
added more clarification
  • Guest changed the title to [1.20.1] Custom Anvil Block "Index 0 out of bounds for length 0" thrown when GUI opened or changed

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

    • The problem occurs also in 1.20.1 Forge, but with an "Error executing task on client" instead. I have "Sinytra Connector" installed. On 1.21.5 Fabric, there is no problem. When this happens, the chat message before the death screen appears gets sent, with an extra dash added.
    • Well, as usual, it was user error. Naming mismatch in sounds.json.  Please delete this post if you find it necessary. 
    • Hello Forge community.  I'm running into an issue with a mod I'm working on.  To preface, I can call /playsound modId:name music @a and I can hear the sound I registered being played in game. Great!  However, I cannot get it to trigger via my mod code.    Registration: public static final RegistryObject<SoundEvent> A_WORLD_OF_MADNESS = SOUND_EVENTS.register("a_world_of_madness", () -> new SoundEvent(new ResourceLocation("tetheredsouls", "a_world_of_madness")));   Playback: Minecraft mc = Minecraft.getInstance(); if (!(mc.player instanceof LocalPlayer) || mc.level == null) return; LocalPlayer player = (LocalPlayer) mc.player; BlockPos pos = player.blockPosition(); SoundEvent track = ModSounds.A_WORLD_OF_MADNESS.get(); System.out.println(track); System.out.println(pos); System.out.println(player); // play exactly like the tutorial: client-only, at the player's position try { mc.level.playLocalSound( player.getX(), player.getY(), player.getZ(), track, SoundSource.MUSIC, // Or MASTER if needed 1f, 1f, false ); System.out.println("[DEBUG] playSound success: " + track.getLocation()); } catch (Exception e) { System.err.println("[ERROR] Failed to play sound: " + track.getLocation()); e.printStackTrace(); } Sounds.json:   { "theme_of_laura": { "category": "music", "sounds": [ { "name": "tetheredsouls:a_world_of_madness", "stream": true } ] } } Things I have tried: - multiple .ogg files. Short .ogg files (5 seconds, <100KB).  - default minecraft sounds imported from import net.minecraft.sounds.SoundEvents; These work given my code. No idea why these are different.  - playSound() method, as well as several others in past iterations that did not work   I would be forever grateful if somebody could point me in the right direction. I've looked at several mod github repositories and found extremely similar code to what I'm doing. I've also found several threads in this forum that did not solve my issue. I just cannot figure out what I'm doing differently, and why I'm able to queue sounds manually with playsound but the code won't play it (despite confirming the code is being run with the debug statements.)
    • Delete the tensura-reincarnated/common.toml file (config folder)
  • Topics

×
×
  • Create New...

Important Information

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