From be7266210062e9bfdce4b5948f67e1250a96d9d9 Mon Sep 17 00:00:00 2001 From: Jonas Herzig Date: Thu, 2 May 2024 11:49:31 +0200 Subject: [PATCH] AbstractTextInput: Hard-code isAllowedCharacter It shouldn't ever change and this way the same Vigilance build continues to be compatible on 1.20.5+ where the MC method was moved to another class. GitHub: #85 --- gradle/libs.versions.toml | 2 +- .../vigilance/gui/common/input/AbstractTextInput.kt | 9 ++++++++- src/main/kotlin/gg/essential/vigilance/impl/Platform.kt | 2 -- .../java/gg/essential/vigilance/impl/PlatformImpl.java | 6 ------ 4 files changed, 9 insertions(+), 10 deletions(-) diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 4022d7f1..60afbe4e 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -1,7 +1,7 @@ [versions] kotlin = "1.5.10" jetbrains-annotations = "23.0.0" -elementa = "507" +elementa = "638" nightconfig = "3.6.0" [libraries] diff --git a/src/main/kotlin/gg/essential/vigilance/gui/common/input/AbstractTextInput.kt b/src/main/kotlin/gg/essential/vigilance/gui/common/input/AbstractTextInput.kt index 3b49ccb9..af972beb 100644 --- a/src/main/kotlin/gg/essential/vigilance/gui/common/input/AbstractTextInput.kt +++ b/src/main/kotlin/gg/essential/vigilance/gui/common/input/AbstractTextInput.kt @@ -112,7 +112,7 @@ internal abstract class AbstractTextInput( val operationToRedo = redoStack.pop() operationToRedo.redo() undoStack.push(operationToRedo) - } else if (platform.isAllowedInChat(typedChar)) { // Most of the ASCII characters + } else if (isAllowedCharacter(typedChar)) { // Most of the ASCII characters commitTextAddition(typedChar.toString()) } else if (keyCode == UKeyboard.KEY_LEFT) { val holdingShift = UKeyboard.isShiftKeyDown() @@ -1006,4 +1006,11 @@ internal abstract class AbstractTextInput( removeTextOperation.undo() } } + + private companion object { + // Mirroring ChatAllowedCharacters.isAllowedCharacter + private fun isAllowedCharacter(chr: Char): Boolean { + return chr.code != 167 && chr >= ' ' && chr.code != 127 + } + } } diff --git a/src/main/kotlin/gg/essential/vigilance/impl/Platform.kt b/src/main/kotlin/gg/essential/vigilance/impl/Platform.kt index 62b7857a..569075a7 100644 --- a/src/main/kotlin/gg/essential/vigilance/impl/Platform.kt +++ b/src/main/kotlin/gg/essential/vigilance/impl/Platform.kt @@ -8,8 +8,6 @@ interface Platform { fun i18n(key: String): String - fun isAllowedInChat(char: Char): Boolean - @ApiStatus.Internal companion object { internal val platform: Platform = diff --git a/versions/src/main/java/gg/essential/vigilance/impl/PlatformImpl.java b/versions/src/main/java/gg/essential/vigilance/impl/PlatformImpl.java index b067da1d..f294b1a5 100644 --- a/versions/src/main/java/gg/essential/vigilance/impl/PlatformImpl.java +++ b/versions/src/main/java/gg/essential/vigilance/impl/PlatformImpl.java @@ -1,7 +1,6 @@ package gg.essential.vigilance.impl; import net.minecraft.client.resources.I18n; -import net.minecraft.util.ChatAllowedCharacters; import org.jetbrains.annotations.ApiStatus; import org.jetbrains.annotations.NotNull; @@ -14,9 +13,4 @@ public class PlatformImpl implements Platform { public String i18n(@NotNull String key) { return I18n.format(key); } - - @Override - public boolean isAllowedInChat(char c) { - return ChatAllowedCharacters.isAllowedCharacter(c); - } }