Jump to content

Recommended Posts

Posted (edited)

Hi, I'm trying to get into Mixin.

My test code accesses the private attribute fps in the Minecraft class.
In the development environment (IntelliJ), it outputs the FPS, as I expected it would.
But when I try it in the normal Minecraft, it crashes, and I'm not sure why.

The Mixin Code:

@Mixin(Minecraft.class)
public interface MinecraftMixin {

    @Accessor("fps")
    int getFps();
}

How I call the mixin code:

@SubscribeEvent
public void onTick(ClientTickEvent event) {

    if (Minecraft.getInstance().player == null) {
        return;
    }

    if (Minecraft.getInstance().player.isCrouching()) {
        int test = ((MinecraftMixin)Minecraft.getInstance()).getFps();
        LOGGER.info(String.valueOf(test));
    }
}

Crashlog:

https://paste.ee/p/PtO7B

Edited by Top-Set98

🐟🐠🐡

Posted
On 5/28/2024 at 5:55 PM, a_random_something said:

Having the same problem. Could you let me know if you ever figure it out? :)

If I find something, of course.

 

I have tried a bit but I can't get mixin to run on 1.20.6 even with the latest version: 1.20.6 - 50.1.1.

🐟🐠🐡

  • 2 weeks later...
Posted (edited)

I figured it out! Here's how I solved it:

I added:

"refmap": "<your_mod_id>.mixins.refmap.json" to my mixin json file and that solved it. You'll also need to add:

add sourceSets.main, '<your_mod_id>.mixins.refmap.json' to your build.gradle in the "mixin" block

 

my mixin file looks like this:

 

{
  "required": true,
  "minVersion": "0.8",
  "package": "<your_package>.<your_modid>.mixin",
  "compatibilityLevel": "JAVA_16",
  "refmap": "<your_mod_id>.mixins.refmap.json",
  "mixins": [
    "YourMixin1",
    "YourMixin2"
  ],
  "client": [
  ],
  "injectors": {
    "defaultRequire": 1
  }
}

This was in 1.19.2, but I don't think it should be too different

Edited by a_random_something
Posted (edited)

My sample mod has the refmap in the mixin json file as well as "add sourceSets.main" in the "mixin" block. It is like in the documentation.

 

mixin json:

{
    "required": true,
    "minVersion": "0.8",
    "package": "com.example.examplemod.mixin",
    "compatibilityLevel": "JAVA_17",
    "refmap": "mixins.ExampleMod.refmap.json",
    "mixins": [
      "MinecraftMixin"
    ],
    "injectors": {
      "defaultRequire": 1
    }
  }

 

mixin block in build.gradle


mixin {
    // MixinGradle Settings
    add sourceSets.main, 'mixins.ExampleMod.refmap.json'
    config 'mixins.ExampleMod.json'
}

 

On 6/18/2024 at 12:41 AM, a_random_something said:

This was in 1.19.2, but I don't think it should be too different


I tried it on another Minecraft version (1.19.2 and 1.20.1) and it works.
As soon as I try Minecraft version 1.20.6 or higher it does not work anymore.

Edited by Top-Set98

🐟🐠🐡

  • 3 weeks later...
Posted

Try modify the build.gradle by:

1. Add 

'MixinConfigs'            : "${mod_id}.mixins.json"

to the attributes array

tasks.named('jar', Jar).configure {
    manifest {
        attributes([
				....
		  ])
    }
}

2. Add a new block after the mixin block

sourceSets {
    main {
        ext.refMap = "${modid}.refmap.json"
    }
}

 

  • Thanks 1
Posted

Thank you very much!

After adding MixinConfigs to the attributes array, it works now.

Does the development environment load the MixinConfigs automatically or why is it only needed for normal Minecraft?

🐟🐠🐡

Posted
On 7/13/2024 at 3:13 AM, Top-Set98 said:

Does the development environment load the MixinConfigs automatically or why is it only needed for normal Minecraft?

The compiler seems could auto load the MixinConfigs in the version below 1.20.6, but it didnt work from 1.20.6. I just modified the jar file to zip and found the META-INF/MANIFEST.MF is lack of "MixinConfigs" compared with the lower version, while the build.gradle are same. So I manual added it to fix the problem.

I dont know the implmentation of this process, but a different is in 1.20.6 the jar task deleted the reobfJar task, maybe this leads the problem?

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 am trying to make 2 recipes for a ruby. The first one is turning a block into a ruby and the other one is 9 nuggets into a ruby. But I keep on getting a error java.lang.IllegalStateException: Duplicate recipe rubymod:ruby   Any help would be great on how to fix it
    • Hello everyone, i'm new with programing Mods, and will need a lot of your help if possible,  Im trying to make a new GUI interface responsible to control the Droprate of game, it will control de loot drop and loot table for mobs and even blocks, but i try to make a simple Gui Screen, and wenever i try to use it, the game crash's with the error message in the subject, here is the code im using to:  IDE: IntelliJ Comunity - latest version Forge: 47.3.0 Minecraft version: 1.20.1 mapping_channel: parchment mapping_version=2023.09.03-1.20.1 Crash report link: https://pastebin.com/6dV8k1Fw   Code im using is:    package createchronical.droprateconfig; import com.mojang.blaze3d.systems.RenderSystem; import net.minecraft.client.gui.GuiGraphics; import net.minecraft.client.gui.components.Button; import net.minecraft.client.gui.screens.Screen; import net.minecraft.network.chat.Component; import net.minecraft.resources.ResourceLocation; import java.util.HashMap; import java.util.Map; public class ConfigScreen extends Screen { private static final ResourceLocation BACKGROUND_TEXTURE = new ResourceLocation("droprateconfig", "textures/gui/config_background.png"); // Mapa de mobs e itens com seus respectivos drop rates private final Map<String, Integer> dropRates = new HashMap<>(); public ConfigScreen() { super(Component.literal("Configurações de Drop Rate")); // Inicializa com valores de drop rate padrão dropRates.put("Zombie", 10); // Exemplo de mob dropRates.put("Creeper", 5); // Exemplo de mob dropRates.put("Iron Ore", 50); // Exemplo de item dropRates.put("Diamond", 2); // Exemplo de item } @Override protected void init() { // Cria um botão para cada mob/item e adiciona na tela int yOffset = this.height / 2 - 100; // Posicionamento inicial for (Map.Entry<String, Integer> entry : dropRates.entrySet()) { String itemName = entry.getKey(); int dropRate = entry.getValue(); // Cria um botão para cada mob/item this.addRenderableWidget(Button.builder( Component.literal(itemName + ": " + dropRate + "%"), button -> onDropRateButtonPressed(itemName) ).bounds(this.width / 2 - 100, yOffset, 200, 20).build()); yOffset += 25; // Incrementa a posição Y para o próximo botão } // Adiciona o botão de "Salvar Configurações" this.addRenderableWidget(Button.builder(Component.literal("Salvar Configurações"), button -> onSavePressed()) .bounds(this.width / 2 - 100, yOffset, 200, 20) .build()); } private void onDropRateButtonPressed(String itemName) { // Lógica para alterar o drop rate do item/mob selecionado // Aqui, vamos apenas incrementar o valor como exemplo int currentRate = dropRates.get(itemName); dropRates.put(itemName, currentRate + 5); // Aumenta o drop rate em 5% } private void onSavePressed() { // Lógica para salvar as configurações (temporariamente apenas na memória) // Vamos apenas imprimir para verificar dropRates.forEach((item, rate) -> { System.out.println("Item: " + item + " | Novo Drop Rate: " + rate + "%"); }); // Fecha a tela após salvar Screen pGuiScreen = null; assert this.minecraft != null; this.minecraft.setScreen(pGuiScreen); } @Override public void render(GuiGraphics guiGraphics, int mouseX, int mouseY, float partialTicks) { this.renderBackground(guiGraphics); guiGraphics.blit(BACKGROUND_TEXTURE, this.width / 2 - 128, this.height / 2 - 128, 0, 0, 256, 256, 256, 256); super.render(guiGraphics, mouseX, mouseY, partialTicks); } }  
    • Also add the latest.log from /logs/
    • I was hoping I could get some help with this weird crash. I've hosted many servers before and never had this issue. Now and then the server crashed with "Exception ticking world". Everywhere I looked I rarely found any info on it (usually found ticking entity instead). Any advice I did get (mostly from the modpack owner's discord) was "We don't know and it's near impossible to find out what it is". Here is the crash report:   Description: Exception ticking world java.util.ConcurrentModificationException     at java.util.HashMap$HashIterator.nextNode(Unknown Source)     at java.util.HashMap$KeyIterator.next(Unknown Source)     at net.minecraft.entity.EntityTracker.sendLeashedEntitiesInChunk(EntityTracker.java:386)     at net.minecraft.server.management.PlayerChunkMapEntry.sendToPlayers(PlayerChunkMapEntry.java:162)     at net.minecraft.server.management.PlayerChunkMap.tick(SourceFile:165)     at net.minecraft.world.WorldServer.tick(WorldServer.java:227)     at net.minecraft.server.MinecraftServer.updateTimeLightAndEntities(MinecraftServer.java:756)     at net.minecraft.server.dedicated.DedicatedServer.updateTimeLightAndEntities(DedicatedServer.java:397)     at net.minecraft.server.MinecraftServer.tick(MinecraftServer.java:668)     at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:526)     at java.lang.Thread.run(Unknown Source)   If you want the full version, I can link a pastebin if needed. Modpack link: https://www.curseforge.com/minecraft/modpacks/multiblock-madness Some helpful information is that: It seems to only happen when I leave my void world to enter the overworld. Only happens 5-10% of the time. Only happens when leaving the void world, and only the void world. I know it's a slim chance someone could help, but it'd be greatly appreciated.
    • thanks a lot bro i knew i shouldve gone on the actual website instead of the discord
  • Topics

×
×
  • Create New...

Important Information

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