Jump to content

[1.8][Solved]Updating "in-game NBTEdit" From 1.7 to 1.8 Object Reflections


nekpek

Recommended Posts

So I pulled hes project from https://github.com/DavidGoldman/NBTEdit

To update hes mod for personal use. After several fix's and patches i succeeded to remove the errors in Eclipse

however when i want to edit a chest with items it crashes with this error

Caused by: java.lang.ClassCastException: org.apache.logging.log4j.core.Logger cannot be cast to java.util.List
at com.mcf.davidee.nbtedit.NBTHelper.getTagAt(NBTHelper.java:39) ~[NBTHelper.class:?]
at com.mcf.davidee.nbtedit.nbt.NBTTree.addChildrenToTree(NBTTree.java:85) ~[NBTTree.class:?]
at com.mcf.davidee.nbtedit.nbt.NBTTree.addChildrenToTree(NBTTree.java:78) ~[NBTTree.class:?]
at com.mcf.davidee.nbtedit.nbt.NBTTree.construct(NBTTree.java:60) ~[NBTTree.class:?]
at com.mcf.davidee.nbtedit.nbt.NBTTree.<init>(NBTTree.java:27) ~[NBTTree.class:?]
at com.mcf.davidee.nbtedit.gui.GuiEditNBTTree.<init>(GuiEditNBTTree.java:41) ~[GuiEditNBTTree.class:?]
at com.mcf.davidee.nbtedit.forge.ClientProxy.openEditGUI(ClientProxy.java:52) ~[ClientProxy.class:?]
at com.mcf.davidee.nbtedit.packets.TileNBTPacket.handleClientSide(TileNBTPacket.java:57) ~[TileNBTPacket.class:?]
at com.mcf.davidee.nbtedit.packets.PacketPipeline.decode(PacketPipeline.java:70) ~[PacketPipeline.class:?]
at com.mcf.davidee.nbtedit.packets.PacketPipeline.decode(PacketPipeline.java:1) ~[PacketPipeline.class:?]
at io.netty.handler.codec.MessageToMessageCodec$2.decode(MessageToMessageCodec.java:81) ~[MessageToMessageCodec$2.class:4.0.15.Final]
at io.netty.handler.codec.MessageToMessageDecoder.channelRead(MessageToMessageDecoder.java:89) ~[MessageToMessageDecoder.class:4.0.15.Final]
... 24 more

The Section in question here is

 

    public static NBTBase getTagAt(NBTTagList tag, int index) {
        List<NBTBase> list = ReflectionHelper.getPrivateValue(NBTTagList.class, tag, 0);
        return list.get(index);
        
    }
}

I have also been looking into the other Class' which cast an error but nowhere do it look like its ever been a org.apache.logging.log4j.core.Logger type.

i have been trying to changing different things but all is casting the same error that Logger cant be cast into what i try.

 

The mod does however work if the chest is empty, but then crashes with the same error after i mannually add a TAGCompound. (like i would do it in 1.7)

 

 

Naturalis - The easy way for nature.!

Esquire - A helping hand for your adventure.

Jimanju - The Random Disasters!

Link to comment
Share on other sites

But what would i use if not ReflectionHelper?

 

Also index is just the TagCount looped in a For event. so i can get every tag

perhaps that is the problem but how do i know which tag is the "logger"

and why wasn't this(the logger) present in 1.7.10? (as this code is confirmed to compile and work in 1.7.10)

Naturalis - The easy way for nature.!

Esquire - A helping hand for your adventure.

Jimanju - The Random Disasters!

Link to comment
Share on other sites

when using

Field field = ReflectionHelper.findField(NBTTagList.class, tag.getStringTagAt(index));

 

I get this error

java.lang.NoSuchFieldException: {id:"minecraft:chest",Damage:0s,Count:1b,Slot:13b,}

The "id:"minecraft:chest",Damage:0s,Count:1b,Slot:13b," is the part that i want to return as a List<NBTBase>.

so how would i go to first fix the error and second make it into the desired type?

 

Since i thought it might be caused cause the Tag.getStringtagAt

i thought perhaps i could get the entire "field" using

Field field = ReflectionHelper.findField(NBTTagList.class)

but this gets me

"Caused by: net.minecraftforge.fml.relauncher.ReflectionHelper$UnableToFindFieldException"

 

I dont think i understand the findField, and when i looked up how it was coded it reminded a bit of getPrivateValue so i dont really know how it would be "better."

Naturalis - The easy way for nature.!

Esquire - A helping hand for your adventure.

Jimanju - The Random Disasters!

Link to comment
Share on other sites

  • 4 months later...

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

    • When I try to install the forge installer it comes with several files instead of just one in executable java format
    • 0 I have recently started with Java and the implementation of Minecraft mods. I am currently working on a mod for 1.20.4-49.0.31 I'm trying to get the content of each slot in the console to be displayed when the inventory is opened, which works. In addition, I wanted to do the same with chests (in this case containers). However, I get in the output that there is Air at every slot of the chest, even if the chest is filled. Does anyone have experience with similar problems and could help me? package net.kaan.sortingmod; import net.minecraft.client.Minecraft; import net.minecraft.client.gui.screens.Screen; import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen; import net.minecraft.client.gui.screens.inventory.InventoryScreen; import net.minecraft.client.gui.screens.inventory.ContainerScreen; import net.minecraft.client.gui.screens.inventory.FurnaceScreen; import net.minecraft.world.entity.player.Player; import net.minecraft.world.inventory.AbstractContainerMenu; import net.minecraft.world.inventory.InventoryMenu; import net.minecraft.world.item.ItemStack; import net.minecraftforge.api.distmarker.Dist; import net.minecraftforge.client.event.ScreenEvent; import net.minecraftforge.common.MinecraftForge; import net.minecraftforge.eventbus.api.SubscribeEvent; import net.minecraftforge.fml.common.Mod; import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent; import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext; @Mod(SortingMod.MODID) public class SortingMod { public static final String MODID = "sortingmod"; public SortingMod() { // Register the client setup method FMLJavaModLoadingContext.get().getModEventBus().addListener(this::doClientStuff); // Register this class for Forge events MinecraftForge.EVENT_BUS.register(this); } private void doClientStuff(final FMLClientSetupEvent event) { // Any client-side setup can be done here } @SubscribeEvent public void onScreenOpen(ScreenEvent.Opening event) { Screen screen = event.getScreen(); if (screen instanceof InventoryScreen) { System.out.println("Player opened their inventory."); assert Minecraft.getInstance().player != null; printInventoryItems(Minecraft.getInstance().player); } else if (screen instanceof ContainerScreen) { System.out.println("Player opened a chest."); printContainerItems((ContainerScreen) screen); } } private void printInventoryItems(Player player) { AbstractContainerMenu menu = player.inventoryMenu; for (int i = 0; i < menu.slots.size(); i++) { ItemStack stack = menu.getSlot(i).getItem(); if (!stack.isEmpty()) { System.out.println("Slot " + i + ": " + stack.getCount() + "x " + stack.getHoverName().getString()); } } } private void printContainerItems(ContainerScreen screen) { AbstractContainerMenu menu = screen.getMenu(); System.out.println(menu.slots.size()); for (int i = 0; i < menu.slots.size(); i++) { ItemStack stack = menu.getSlot(i).getItem(); System.out.println("Slot " + i + ": " + stack.getCount() + "x " + stack.getHoverName().getString()); } } }  
    • I am wanting to add an axe to my mod though I do not want it to have a recipe, the reason for this being that I want you to only be able to find it in a structure. I have looked on both here and elsewhere on the internet and have found nothing... How would this be done?    (Video for reference.)    
    • file log:file:///C:/Users/natal/AppData/Roaming/.minecraft/logs/latest.log   Aternos log: https://mclo.gs/kzPaflO
  • Topics

×
×
  • Create New...

Important Information

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