Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 6 additions & 5 deletions build.gradle.kts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
plugins {
id("dev.isxander.modstitch.base") version "0.6.2-unstable"
id("dev.isxander.modstitch.base") version "0.7.1-unstable"
id("fabric-loom") version "1.13-SNAPSHOT" apply false
id("me.modmuss50.mod-publish-plugin") version "0.8.4"
`maven-publish`
id("org.ajoberstar.grgit") version "5.3.2"
Expand All @@ -8,11 +9,11 @@ plugins {
val debugifyVersion = "1.1"

modstitch {
minecraftVersion = "1.21.10"
minecraftVersion = "1.21.11"
modLoaderVersion = "0.18.0"

parchment {
mappingsVersion = "2025.10.12"
mappingsVersion = "2025.12.20"
}

metadata {
Expand Down Expand Up @@ -212,14 +213,14 @@ val generatePatchedTable by tasks.registering {

val previous = entries.filterIsInstance<PatchedFileEntry.Previous>()

val timestamp = `java.time`.LocalDateTime.now().format(`java.time.format`.DateTimeFormatter.ISO_DATE_TIME)
//val timestamp = `java.time`.LocalDateTime.now().format(`java.time.format`.DateTimeFormatter.ISO_DATE_TIME)

val markdownTable = """
- <!--
- !!!! DO NOT UPDATE THIS FILE MANUALLY !!!!
- Generated by `./gradlew generatePatchedTable`
- Sourced from `${inputFile.name}`
- Generated $timestamp
- Generated now
- -->
-
- # List of Patched Bugs
Expand Down
6 changes: 3 additions & 3 deletions gradle.properties
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,6 @@ curseforgeId=596224
githubProject=isXander/Debugify

# Libraries
fabricApiVersion=0.138.3+1.21.10
yaclVersion=3.8.0+1.21.9-fabric
modMenuVersion=16.0.0-rc.1
fabricApiVersion=0.139.4+1.21.11
yaclVersion=3.8.1+1.21.11-fabric
modMenuVersion=17.0.0-alpha.1
Binary file modified gradle/wrapper/gradle-wrapper.jar
Binary file not shown.
4 changes: 3 additions & 1 deletion gradle/wrapper/gradle-wrapper.properties
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.14.2-all.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-9.2.1-bin.zip
networkTimeout=10000
validateDistributionUrl=true
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
import net.minecraft.client.gui.components.Button;
import net.minecraft.client.gui.screens.Screen;
import net.minecraft.client.input.MouseButtonEvent;
import net.minecraft.client.multiplayer.chat.ChatListener;
import net.minecraft.network.chat.ClickEvent;
import net.minecraft.network.chat.CommonComponents;
import net.minecraft.network.chat.Component;
Expand Down Expand Up @@ -62,15 +63,14 @@ public void render(GuiGraphics graphics, int mouseX, int mouseY, float delta) {
}
}


@Override
/*@Override
public boolean mouseClicked(MouseButtonEvent mouseButtonEvent, boolean bl) {
if (super.mouseClicked(mouseButtonEvent, bl)) {
return true;
}

Style style = getStyle((int) mouseButtonEvent.x(), (int) mouseButtonEvent.y());
return handleComponentClicked(style);
return this.handleComponentClicked(style);
}

protected Style getStyle(int mouseX, int mouseY) {
Expand All @@ -84,5 +84,5 @@ protected Style getStyle(int mouseX, int mouseY) {
int x = mouseX - (width / 2 - font.width(text) / 2);

return font.getSplitter().componentStyleAtWidth(wrappedText.get(line), x);
}
}*/
}
Original file line number Diff line number Diff line change
@@ -1,50 +1,37 @@
package dev.isxander.debugify.client.helpers.mc237493;

import com.mojang.serialization.Codec;
import java.util.Arrays;
import java.util.Comparator;
import java.util.function.IntFunction;

import net.minecraft.network.chat.Component;
import net.minecraft.util.ByIdMap;
import net.minecraft.util.Mth;
import net.minecraft.util.OptionEnum;
import net.minecraft.util.StringRepresentable;

public enum DebugifyTelemetry implements OptionEnum {
public enum DebugifyTelemetry {
OFF(0, "options.telemetry.state.none", "debugify.mc_237493.tooltip.off"),
MINIMAL(1, "options.telemetry.state.minimal", "debugify.mc_237493.tooltip.minimal"),
ALL(2, "options.telemetry.state.all", "debugify.mc_237493.tooltip.all");

private static final DebugifyTelemetry[] VALUES = Arrays.stream(values())
.sorted(Comparator.comparingInt(DebugifyTelemetry::getId))
.toArray(DebugifyTelemetry[]::new);

private static final IntFunction<DebugifyTelemetry> BY_ID = ByIdMap.continuous(value -> value.id, values(), ByIdMap.OutOfBoundsStrategy.WRAP);
public static final Codec<DebugifyTelemetry> LEGACY_CODEC = Codec.INT.xmap(BY_ID::apply, value -> value.id);
private final int id;
private final String translationKey;
private final String tooltipTranslationKey;
private final Component caption;
private final Component tooltip;

DebugifyTelemetry(int id, String translationKey, String tooltipTranslationKey) {
DebugifyTelemetry(int id, final String key, final String translationKey) {
this.id = id;
this.translationKey = translationKey;
this.tooltipTranslationKey = tooltipTranslationKey;
}

@Override
public int getId() {
return this.id;
}

@Override
public String getKey() {
return this.translationKey;
}

public String getTooltipKey() {
return this.tooltipTranslationKey;
this.caption = Component.translatable(key);
this.tooltip = Component.translatable(translationKey);
}

public Component getTooltipText() {
return Component.translatable(getTooltipKey(), getCaption());
public Component caption() {
return this.caption;
}

public static DebugifyTelemetry byId(int id) {
return VALUES[Mth.positiveModulo(id, VALUES.length)];
public Component tooltip() {
return this.tooltip;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
import dev.isxander.debugify.fixes.FixCategory;
import net.minecraft.client.renderer.entity.SquidRenderer;
import net.minecraft.client.renderer.entity.state.SquidRenderState;
import net.minecraft.world.entity.animal.Squid;
import net.minecraft.world.entity.animal.squid.Squid;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.Unique;
import org.spongepowered.asm.mixin.injection.At;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,11 @@
import dev.isxander.debugify.fixes.FixCategory;
import dev.isxander.debugify.client.helpers.mc122477.KeyboardPollCounter;
import dev.isxander.debugify.fixes.OS;
import net.minecraft.Util;
import net.minecraft.client.gui.Font;
import net.minecraft.client.gui.components.EditBox;
import net.minecraft.client.input.CharacterEvent;
import net.minecraft.network.chat.Component;
import net.minecraft.util.Util;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
package dev.isxander.debugify.client.mixins.basic.mc197260;

import com.mojang.datafixers.util.Pair;
import dev.isxander.debugify.fixes.BugFix;
import dev.isxander.debugify.fixes.FixCategory;
import net.minecraft.client.Minecraft;
Expand All @@ -9,9 +8,7 @@
import net.minecraft.client.renderer.entity.state.ArmorStandRenderState;
import org.spongepowered.asm.mixin.Mixin;

import java.util.Comparator;
import java.util.stream.IntStream;
import net.minecraft.client.model.ArmorStandArmorModel;
import net.minecraft.client.model.object.armorstand.ArmorStandArmorModel;
import net.minecraft.client.renderer.LightTexture;
import net.minecraft.client.renderer.entity.ArmorStandRenderer;
import net.minecraft.core.BlockPos;
Expand Down Expand Up @@ -39,13 +36,14 @@ protected ArmorStandRendererMixin(EntityRendererProvider.Context context) {
BlockPos mainPos = BlockPos.containing(livingEntity.x, livingEntity.y, livingEntity.z);
ClientLevel level = Minecraft.getInstance().level;

livingEntity.lightCoords = IntStream.of(-1, 0, 2, 3)
.mapToObj(operand -> {
BlockPos pos = mainPos.offset(0, operand, 0);
return Pair.of(level.getBrightness(LightLayer.BLOCK, pos), pos);
})
.max(Comparator.comparingInt(Pair::getFirst))
.map(p -> LightTexture.pack(p.getFirst(), level.getBrightness(LightLayer.SKY, p.getSecond())))
.orElse(livingEntity.lightCoords);
int maxSkyLight = 0;
int maxBlockLight = 0;
for (int offset : new int[] { -1, 0, 2, 3 }) {
BlockPos pos = mainPos.offset(0, offset, 0);
maxSkyLight = Math.max(maxSkyLight, level.getBrightness(LightLayer.SKY, pos));
maxBlockLight = Math.max(maxBlockLight, level.getBrightness(LightLayer.BLOCK, pos));
}

livingEntity.lightCoords = LightTexture.pack(maxBlockLight, maxSkyLight);
}
}

This file was deleted.

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,9 @@ public abstract class OptionsMixin implements DebugifyTelemetryAccessor {
@Unique
private final OptionInstance<DebugifyTelemetry> debugifyTelemetry = new OptionInstance<>(
"options.telemetry.button",
value -> Tooltip.create(value.getTooltipText()),
OptionInstance.forOptionEnum(),
new OptionInstance.Enum<>(Arrays.asList(DebugifyTelemetry.values()), Codec.INT.xmap(DebugifyTelemetry::byId, DebugifyTelemetry::getId)),
value -> Tooltip.create(value.tooltip()),
(component, value) -> value.caption(),
new OptionInstance.Enum<>(Arrays.asList(DebugifyTelemetry.values()), DebugifyTelemetry.LEGACY_CODEC),
DebugifyTelemetry.OFF,
value -> telemetryOptInExtra().set(value == DebugifyTelemetry.ALL)
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,15 @@
import dev.isxander.debugify.fixes.BugFix;
import dev.isxander.debugify.fixes.FixCategory;
import net.minecraft.client.Options;
import net.minecraft.client.gui.components.AbstractWidget;
import net.minecraft.client.gui.layouts.LayoutElement;
import net.minecraft.client.gui.layouts.LinearLayout;
import net.minecraft.client.gui.screens.telemetry.TelemetryEventWidget;
import net.minecraft.client.gui.screens.telemetry.TelemetryInfoScreen;
import org.spongepowered.asm.mixin.Final;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.Overwrite;
import org.spongepowered.asm.mixin.Shadow;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Redirect;

@BugFix(id = "MC-237493", category = FixCategory.BASIC, env = BugFix.Env.CLIENT, modConflicts = "no-telemetry", description = "Telemetry cannot be disabled")
@Mixin(TelemetryInfoScreen.class)
Expand All @@ -25,8 +27,8 @@ public class TelemetryInfoScreenMixin {
* @author
* @reason
*/
@Overwrite
private AbstractWidget createTelemetryCheckbox() {
return ((DebugifyTelemetryAccessor) options).getTelemetryOption().createButton(options, 0, 0, 308, state -> telemetryEventWidget.onOptInChanged(state == DebugifyTelemetry.ALL));
@Redirect(method = "init", at = @At(ordinal = 5, value = "INVOKE", target = "Lnet/minecraft/client/gui/layouts/LinearLayout;addChild(Lnet/minecraft/client/gui/layouts/LayoutElement;)Lnet/minecraft/client/gui/layouts/LayoutElement;"))
private LayoutElement createTelemetryCheckbox(LinearLayout layout, LayoutElement child) {
return layout.addChild(((DebugifyTelemetryAccessor) options).getTelemetryOption().createButton(options, 0, 0, 308, state -> telemetryEventWidget.onOptInChanged(state == DebugifyTelemetry.ALL)));
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.Gui;
import net.minecraft.client.gui.GuiGraphics;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.resources.Identifier;
import org.spongepowered.asm.mixin.Final;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.Shadow;
Expand All @@ -21,8 +21,8 @@ public class GuiMixin {
private Minecraft minecraft;

// the FULL sprite never shows anyway so no need to wrap it
@WrapWithCondition(method = "renderCrosshair", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/GuiGraphics;blitSprite(Lcom/mojang/blaze3d/pipeline/RenderPipeline;Lnet/minecraft/resources/ResourceLocation;IIII)V", ordinal = 2))
private boolean fixAttackIndicatorFlashing(GuiGraphics instance, RenderPipeline renderPipeline, ResourceLocation resourceLocation, int i, int j, int k, int l) {
@WrapWithCondition(method = "renderCrosshair", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/GuiGraphics;blitSprite(Lcom/mojang/blaze3d/pipeline/RenderPipeline;Lnet/minecraft/resources/Identifier;IIII)V", ordinal = 2))
private boolean fixAttackIndicatorFlashing(GuiGraphics instance, RenderPipeline renderPipeline, Identifier resourceLocation, int i, int j, int k, int l) {
return this.minecraft.player.getAttackStrengthScale(0.0F) * 17F > 0;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,10 @@ public class AtmosphericFogEnvironmentMixin {
*/
@Definition(id = "rainFogMultiplier", field = "Lnet/minecraft/client/renderer/fog/environment/AtmosphericFogEnvironment;rainFogMultiplier:F")
@Definition(id = "rainLevel", local = @Local(type = float.class, ordinal = 3))
@Definition(id = "gtDeltaTicks", local = @Local(type = float.class, ordinal = 1))
@Definition(id = "gtDeltaTicks", local = @Local(type = float.class, ordinal = 0))
// `?.` instead of `this.` since the `this` is DUPed making it impossible to target
@Expression("?.rainFogMultiplier = ?.rainFogMultiplier + (rainLevel - ?.rainFogMultiplier) * @(gtDeltaTicks) * 0.2")
@ModifyExpressionValue(method = "setupFog", at = @At("MIXINEXTRAS:EXPRESSION"))
@ModifyExpressionValue(method = "updateRainFogState", at = @At("MIXINEXTRAS:EXPRESSION"))
private float clampFog(float original) {
// it's impossible to target `gtDeltaTicks * 0.2` since in bytecode
// it's `...) * gtDeltaTicks) * 0.2`. so instead just modify `gtDeltaTicks` with min 5, since 5 * 0.2 is 1
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,15 +5,15 @@
import dev.isxander.debugify.fixes.FixCategory;
import net.minecraft.client.Minecraft;
import net.minecraft.client.renderer.GameRenderer;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.resources.Identifier;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.injection.At;

@BugFix(id = "MC-46737", category = FixCategory.BASIC, env = BugFix.Env.CLIENT, description = "Entities' shaders are applied when beginning to spectate them in third person")
@Mixin(GameRenderer.class)
public class GameRendererMixin {
@WrapWithCondition(method = "checkEntityPostEffect", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/renderer/GameRenderer;setPostEffect(Lnet/minecraft/resources/ResourceLocation;)V"))
private boolean thirdPersonCheck(GameRenderer renderer, ResourceLocation location) {
@WrapWithCondition(method = "checkEntityPostEffect", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/renderer/GameRenderer;setPostEffect(Lnet/minecraft/resources/Identifier;)V"))
private boolean thirdPersonCheck(GameRenderer renderer, Identifier id) {
return Minecraft.getInstance().options.getCameraType().isFirstPerson();
}
}
Loading