From f877ce10737f657fadab950d7fc7f5aee9e53d6c Mon Sep 17 00:00:00 2001 From: NopoTheGamer <40329022+NopoTheGamer@users.noreply.github.com> Date: Tue, 3 Oct 2023 06:15:40 +1100 Subject: Add game directory to crash reports (#847) * added /neudevtest crash * Add game directory to crash reports --- .../notenoughupdates/mixins/MixinCrashReport.java | 49 ++++++++++++++++++++++ .../commands/dev/DevTestCommand.kt | 10 +++++ src/main/resources/mixins.notenoughupdates.json | 3 +- 3 files changed, 61 insertions(+), 1 deletion(-) create mode 100644 src/main/java/io/github/moulberry/notenoughupdates/mixins/MixinCrashReport.java (limited to 'src') diff --git a/src/main/java/io/github/moulberry/notenoughupdates/mixins/MixinCrashReport.java b/src/main/java/io/github/moulberry/notenoughupdates/mixins/MixinCrashReport.java new file mode 100644 index 00000000..8d11f552 --- /dev/null +++ b/src/main/java/io/github/moulberry/notenoughupdates/mixins/MixinCrashReport.java @@ -0,0 +1,49 @@ +/* + * Copyright (C) 2023 NotEnoughUpdates contributors + * + * This file is part of NotEnoughUpdates. + * + * NotEnoughUpdates is free software: you can redistribute it + * and/or modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation, either + * version 3 of the License, or (at your option) any later version. + * + * NotEnoughUpdates is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with NotEnoughUpdates. If not, see . + */ + +package io.github.moulberry.notenoughupdates.mixins; + +import net.minecraft.client.Minecraft; +import net.minecraft.crash.CrashReport; +import net.minecraft.crash.CrashReportCategory; +import org.spongepowered.asm.mixin.Final; +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.Shadow; +import org.spongepowered.asm.mixin.injection.At; +import org.spongepowered.asm.mixin.injection.Inject; +import org.spongepowered.asm.mixin.injection.callback.CallbackInfo; + +import java.util.concurrent.Callable; + +@Mixin(CrashReport.class) +public class MixinCrashReport { + + @Final + @Shadow private CrashReportCategory theReportCategory; + @Inject(method = "populateEnvironment", at = @At(value = "HEAD")) + private void populateEnvironment(CallbackInfo ci) { + this.theReportCategory.addCrashSectionCallable("Game Directory", new Callable(){ + + @Override + public String call() throws Exception { + return Minecraft.getMinecraft().mcDataDir.getCanonicalPath(); + } + }); + } +} diff --git a/src/main/kotlin/io/github/moulberry/notenoughupdates/commands/dev/DevTestCommand.kt b/src/main/kotlin/io/github/moulberry/notenoughupdates/commands/dev/DevTestCommand.kt index e138b512..cf55416b 100644 --- a/src/main/kotlin/io/github/moulberry/notenoughupdates/commands/dev/DevTestCommand.kt +++ b/src/main/kotlin/io/github/moulberry/notenoughupdates/commands/dev/DevTestCommand.kt @@ -265,6 +265,16 @@ class DevTestCommand { NotEnoughUpdates.INSTANCE.config.hidden.customUserAgent = null } }.withHelp("Reset the custom user agent") + thenLiteral("crash") { + thenExecute { + throw object : Error("L") { + @Override + fun printStackTrace() { + throw Error("L") + } + } + } + }.withHelp("Crash the game") } hook.beforeCommand = Predicate { if (!canPlayerExecute(it.context.source)) { diff --git a/src/main/resources/mixins.notenoughupdates.json b/src/main/resources/mixins.notenoughupdates.json index 16b473fc..b72c1ba4 100644 --- a/src/main/resources/mixins.notenoughupdates.json +++ b/src/main/resources/mixins.notenoughupdates.json @@ -11,6 +11,7 @@ "AccessorGuiPlayerTabOverlay", "MixinAbstractClientPlayer", "MixinContainer", + "MixinCrashReport", "MixinEffectRenderer", "MixinEntity", "MixinEntityAgeable", @@ -37,8 +38,8 @@ "MixinMinecraft", "MixinMouseHelper", "MixinNetHandlerPlayClient", - "MixinOptifineCustomItems", "MixinOFDynamicLights", + "MixinOptifineCustomItems", "MixinPlayerControllerMP", "MixinRender", "MixinRendererLivingEntity", -- cgit