mirror of
https://github.com/ViaVersion/ViaFabricPlus.git
synced 2025-01-05 19:09:02 +01:00
Merge remote-tracking branch 'origin/main' into 1.20-recode
This commit is contained in:
commit
dd4b4c1910
@ -14,7 +14,7 @@
|
|||||||
# Why another protocol translator?
|
# Why another protocol translator?
|
||||||
ViaFabricPlus is intended to replace [multiconnect](https://github.com/Earthcomputer/multiconnect), and it also promises more compactness and stability. ViaFabricPlus can do everything multiconnect could do, but supports more Minecraft versions (listed below) and has more protocol changes implemented.
|
ViaFabricPlus is intended to replace [multiconnect](https://github.com/Earthcomputer/multiconnect), and it also promises more compactness and stability. ViaFabricPlus can do everything multiconnect could do, but supports more Minecraft versions (listed below) and has more protocol changes implemented.
|
||||||
### Supported Server versions
|
### Supported Server versions
|
||||||
- Release (1.0.0 - 1.20 [23w14a])
|
- Release (1.0.0 - 1.20 [1.20-pre1])
|
||||||
- Beta (b1.0 - b1.8.1)
|
- Beta (b1.0 - b1.8.1)
|
||||||
- Alpha (a1.0.15 - a1.2.6)
|
- Alpha (a1.0.15 - a1.2.6)
|
||||||
- Classic (c0.0.15 - c0.30 including [CPE](https://wiki.vg/Classic_Protocol_Extension))
|
- Classic (c0.0.15 - c0.30 including [CPE](https://wiki.vg/Classic_Protocol_Extension))
|
||||||
@ -28,6 +28,7 @@ ViaFabricPlus is intended to replace [multiconnect](https://github.com/Earthcomp
|
|||||||
## Known incompatibilities
|
## Known incompatibilities
|
||||||
- ***[ViaFabric](https://github.com/ViaVersion/ViaFabric)***
|
- ***[ViaFabric](https://github.com/ViaVersion/ViaFabric)***
|
||||||
- ***[multiconnect](https://github.com/Earthcomputer/multiconnect)***
|
- ***[multiconnect](https://github.com/Earthcomputer/multiconnect)***
|
||||||
|
- ***[krypton](https://github.com/astei/krypton)***
|
||||||
|
|
||||||
## List of all clientside related fixes
|
## List of all clientside related fixes
|
||||||
<details>
|
<details>
|
||||||
|
39
build.gradle
39
build.gradle
@ -7,8 +7,8 @@ version = project.mod_version
|
|||||||
group = project.maven_group
|
group = project.maven_group
|
||||||
|
|
||||||
configurations {
|
configurations {
|
||||||
implementation.extendsFrom libs
|
implementation.extendsFrom library
|
||||||
api.extendsFrom libs
|
api.extendsFrom library
|
||||||
}
|
}
|
||||||
|
|
||||||
allprojects {
|
allprojects {
|
||||||
@ -51,41 +51,46 @@ dependencies {
|
|||||||
|
|
||||||
modImplementation "net.fabricmc:fabric-loader:${project.loader_version}"
|
modImplementation "net.fabricmc:fabric-loader:${project.loader_version}"
|
||||||
modImplementation "net.fabricmc.fabric-api:fabric-api:${project.fabric_api_version}"
|
modImplementation "net.fabricmc.fabric-api:fabric-api:${project.fabric_api_version}"
|
||||||
|
modImplementation "com.terraformersmc:modmenu:${project.mod_menu_version}"
|
||||||
|
|
||||||
libs "com.github.FlorianMichael:ViaLoadingBase:${project.vialoadingbase_version}"
|
library "com.github.FlorianMichael:ViaLoadingBase:${project.vialoadingbase_version}"
|
||||||
libs "com.github.FlorianMichael:Classic4J:${project.classic4j_version}"
|
library "com.github.FlorianMichael:Classic4J:${project.classic4j_version}"
|
||||||
|
|
||||||
libs "com.viaversion:viaversion:${project.viaversion_version}"
|
library "com.viaversion:viaversion:${project.viaversion_version}"
|
||||||
libs "com.viaversion:viabackwards-common:${project.viabackwards_version}"
|
library ("com.viaversion:viabackwards-common:${project.viabackwards_version}") {
|
||||||
libs "org.yaml:snakeyaml:${project.snake_yml_version}"
|
exclude group: "com.viaversion", module: "viaversion"
|
||||||
|
exclude group: "io.netty", module: "netty-all"
|
||||||
|
exclude group: "com.google.guava", module: "guava"
|
||||||
|
}
|
||||||
|
library "org.yaml:snakeyaml:${project.snake_yml_version}"
|
||||||
|
|
||||||
libs ("net.raphimc:ViaLegacy:${project.vialegacy_version}") {
|
library ("net.raphimc:ViaLegacy:${project.vialegacy_version}") {
|
||||||
exclude group: "net.lenni0451.mcstructs", module: "text"
|
exclude group: "net.lenni0451.mcstructs", module: "text"
|
||||||
}
|
}
|
||||||
libs "net.raphimc:ViaAprilFools:${project.viaaprilfools_version}"
|
library "net.raphimc:ViaAprilFools:${project.viaaprilfools_version}"
|
||||||
libs ("net.raphimc:ViaBedrock:${project.viabedrock_version}") {
|
library ("net.raphimc:ViaBedrock:${project.viabedrock_version}") {
|
||||||
exclude group: "net.lenni0451.mcstructs", module: "text"
|
exclude group: "net.lenni0451.mcstructs", module: "text"
|
||||||
exclude group: "io.jsonwebtoken", module: "jjwt-impl"
|
exclude group: "io.jsonwebtoken", module: "jjwt-impl"
|
||||||
exclude group: "io.jsonwebtoken", module: "jjwt-gson"
|
exclude group: "io.jsonwebtoken", module: "jjwt-gson"
|
||||||
}
|
}
|
||||||
libs ("net.raphimc:MinecraftAuth:${project.minecraftauth_version}") {
|
library ("net.raphimc:MinecraftAuth:${project.minecraftauth_version}") {
|
||||||
exclude group: "com.google.code.gson", module: "gson"
|
exclude group: "com.google.code.gson", module: "gson"
|
||||||
exclude group: "org.slf4j", module: "slf4j-api"
|
exclude group: "org.slf4j", module: "slf4j-api"
|
||||||
}
|
}
|
||||||
|
|
||||||
libs("org.cloudburstmc.netty:netty-transport-raknet:${project.raknet_transport_version}") {
|
library("org.cloudburstmc.netty:netty-transport-raknet:${project.raknet_transport_version}") {
|
||||||
exclude group: "io.netty", module: "netty-common"
|
exclude group: "io.netty", module: "netty-common"
|
||||||
exclude group: "io.netty", module: "netty-buffer"
|
exclude group: "io.netty", module: "netty-buffer"
|
||||||
exclude group: "io.netty", module: "netty-codec"
|
exclude group: "io.netty", module: "netty-codec"
|
||||||
exclude group: "io.netty", module: "netty-transport"
|
exclude group: "io.netty", module: "netty-transport"
|
||||||
}
|
}
|
||||||
|
|
||||||
libs ("net.lenni0451.mcstructs:text:${project.mcstructs_text_version}") {
|
library ("net.lenni0451.mcstructs:text:${project.mcstructs_text_version}") {
|
||||||
exclude group: "com.google.code.gson", module: "gson"
|
exclude group: "com.google.code.gson", module: "gson"
|
||||||
}
|
}
|
||||||
libs "net.lenni0451:Reflect:${project.reflect_version}"
|
library "net.lenni0451:Reflect:${project.reflect_version}"
|
||||||
|
|
||||||
modImplementation "com.terraformersmc:modmenu:${project.mod_menu_version}"
|
include implementation(annotationProcessor("com.github.llamalad7.mixinextras:mixinextras-fabric:${project.mixin_extras_version}"))
|
||||||
}
|
}
|
||||||
|
|
||||||
processResources {
|
processResources {
|
||||||
@ -108,10 +113,10 @@ java {
|
|||||||
}
|
}
|
||||||
|
|
||||||
jar {
|
jar {
|
||||||
dependsOn configurations.libs
|
dependsOn configurations.library
|
||||||
from {
|
from {
|
||||||
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
|
duplicatesStrategy = DuplicatesStrategy.EXCLUDE
|
||||||
configurations.libs.collect {
|
configurations.library.collect {
|
||||||
zipTree(it)
|
zipTree(it)
|
||||||
}
|
}
|
||||||
} {
|
} {
|
||||||
|
@ -9,7 +9,7 @@ loader_version=0.14.19
|
|||||||
fabric_api_version=0.80.1+1.20
|
fabric_api_version=0.80.1+1.20
|
||||||
|
|
||||||
# viafabricplus
|
# viafabricplus
|
||||||
mod_version=2.7.1
|
mod_version=2.7.2
|
||||||
maven_group=de.florianmichael
|
maven_group=de.florianmichael
|
||||||
archives_base_name=viafabricplus
|
archives_base_name=viafabricplus
|
||||||
|
|
||||||
@ -19,8 +19,8 @@ raknet_transport_version=1.0.0.CR1-SNAPSHOT
|
|||||||
classic4j_version=1.2.0
|
classic4j_version=1.2.0
|
||||||
|
|
||||||
# viaversion (and required) libs
|
# viaversion (and required) libs
|
||||||
viaversion_version=4.7.0-23w18a-SNAPSHOT
|
viaversion_version=4.7.0-1.20-pre1-SNAPSHOT
|
||||||
viabackwards_version=4.7.0-23w18a-SNAPSHOT
|
viabackwards_version=4.7.0-1.20-pre1-SNAPSHOT
|
||||||
snake_yml_version=2.0
|
snake_yml_version=2.0
|
||||||
|
|
||||||
# raphimc libs
|
# raphimc libs
|
||||||
@ -36,3 +36,4 @@ reflect_version=1.1.0
|
|||||||
# other libs
|
# other libs
|
||||||
mod_menu_version=7.0.0-beta.1
|
mod_menu_version=7.0.0-beta.1
|
||||||
netty_codec_http_version=4.1.90.Final
|
netty_codec_http_version=4.1.90.Final
|
||||||
|
mixin_extras_version=0.2.0-beta.7
|
||||||
|
2
gradle/wrapper/gradle-wrapper.properties
vendored
2
gradle/wrapper/gradle-wrapper.properties
vendored
@ -1,6 +1,6 @@
|
|||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.0.2-bin.zip
|
distributionUrl=https\://services.gradle.org/distributions/gradle-8.1.1-bin.zip
|
||||||
networkTimeout=10000
|
networkTimeout=10000
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
|
@ -8,4 +8,3 @@ pluginManagement {
|
|||||||
gradlePluginPortal()
|
gradlePluginPortal()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,7 +44,9 @@ public class ChatLengthCalculation {
|
|||||||
});
|
});
|
||||||
|
|
||||||
LoadClassicProtocolExtensionCallback.EVENT.register(classicProtocolExtension -> {
|
LoadClassicProtocolExtensionCallback.EVENT.register(classicProtocolExtension -> {
|
||||||
if (classicProtocolExtension == ClassicProtocolExtension.LONGER_MESSAGES) INSTANCE.maxLength = Short.MAX_VALUE * 2;
|
if (classicProtocolExtension == ClassicProtocolExtension.LONGER_MESSAGES) {
|
||||||
|
INSTANCE.maxLength = Short.MAX_VALUE * 2;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
*/
|
*/
|
||||||
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft;
|
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft;
|
||||||
|
|
||||||
|
import com.llamalad7.mixinextras.injector.WrapWithCondition;
|
||||||
import com.mojang.authlib.GameProfile;
|
import com.mojang.authlib.GameProfile;
|
||||||
import com.viaversion.viaversion.api.protocol.version.ProtocolVersion;
|
import com.viaversion.viaversion.api.protocol.version.ProtocolVersion;
|
||||||
import de.florianmichael.viafabricplus.ViaFabricPlus;
|
import de.florianmichael.viafabricplus.ViaFabricPlus;
|
||||||
@ -109,11 +110,9 @@ public abstract class MixinClientPlayNetworkHandler {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Redirect(method = "onPlayerSpawnPosition", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/screen/DownloadingTerrainScreen;setReady()V"))
|
@WrapWithCondition(method = "onPlayerSpawnPosition", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/screen/DownloadingTerrainScreen;setReady()V"))
|
||||||
public void moveDownloadingTerrainClosing(DownloadingTerrainScreen instance) {
|
public boolean moveDownloadingTerrainClosing(DownloadingTerrainScreen instance) {
|
||||||
if (ProtocolHack.getTargetVersion().isNewerThanOrEqualTo(ProtocolVersion.v1_19)) {
|
return ProtocolHack.getTargetVersion().isNewerThanOrEqualTo(ProtocolVersion.v1_19);
|
||||||
instance.setReady();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Inject(method = "onPlayerPositionLook", at = @At("RETURN"))
|
@Inject(method = "onPlayerPositionLook", at = @At("RETURN"))
|
||||||
@ -132,11 +131,9 @@ public abstract class MixinClientPlayNetworkHandler {
|
|||||||
return constant;
|
return constant;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Redirect(method = "onPlayerList", at = @At(value = "INVOKE", target = "Lorg/slf4j/Logger;warn(Ljava/lang/String;Ljava/lang/Object;)V", remap = false))
|
@WrapWithCondition(method = "onPlayerList", at = @At(value = "INVOKE", target = "Lorg/slf4j/Logger;warn(Ljava/lang/String;Ljava/lang/Object;)V", remap = false))
|
||||||
public void removeNewWarning(Logger instance, String s, Object o) {
|
public boolean removeWarning(Logger instance, String s, Object o) {
|
||||||
if (ProtocolHack.getTargetVersion().isNewerThanOrEqualTo(ProtocolVersion.v1_19_3)) {
|
return ProtocolHack.getTargetVersion().isNewerThanOrEqualTo(ProtocolVersion.v1_19_3);
|
||||||
instance.warn(s, o);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Redirect(method = "onKeepAlive", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayNetworkHandler;sendPacket(Lnet/minecraft/network/packet/Packet;Ljava/util/function/BooleanSupplier;Ljava/time/Duration;)V"))
|
@Redirect(method = "onKeepAlive", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayNetworkHandler;sendPacket(Lnet/minecraft/network/packet/Packet;Ljava/util/function/BooleanSupplier;Ljava/time/Duration;)V"))
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
*/
|
*/
|
||||||
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft;
|
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft;
|
||||||
|
|
||||||
|
import com.llamalad7.mixinextras.injector.WrapWithCondition;
|
||||||
import com.viaversion.viaversion.api.connection.UserConnection;
|
import com.viaversion.viaversion.api.connection.UserConnection;
|
||||||
import com.viaversion.viaversion.api.minecraft.item.Item;
|
import com.viaversion.viaversion.api.minecraft.item.Item;
|
||||||
import com.viaversion.viaversion.api.protocol.packet.PacketWrapper;
|
import com.viaversion.viaversion.api.protocol.packet.PacketWrapper;
|
||||||
@ -29,7 +30,6 @@ import de.florianmichael.viafabricplus.injection.access.IScreenHandler;
|
|||||||
import de.florianmichael.viafabricplus.protocolhack.ProtocolHack;
|
import de.florianmichael.viafabricplus.protocolhack.ProtocolHack;
|
||||||
import de.florianmichael.viafabricplus.protocolhack.provider.viaversion.ViaFabricPlusHandItemProvider;
|
import de.florianmichael.viafabricplus.protocolhack.provider.viaversion.ViaFabricPlusHandItemProvider;
|
||||||
import de.florianmichael.viafabricplus.protocolhack.usage.ItemTranslator;
|
import de.florianmichael.viafabricplus.protocolhack.usage.ItemTranslator;
|
||||||
import de.florianmichael.viafabricplus.protocolhack.ProtocolHack;
|
|
||||||
import net.minecraft.client.MinecraftClient;
|
import net.minecraft.client.MinecraftClient;
|
||||||
import net.minecraft.client.network.ClientPlayNetworkHandler;
|
import net.minecraft.client.network.ClientPlayNetworkHandler;
|
||||||
import net.minecraft.client.network.ClientPlayerEntity;
|
import net.minecraft.client.network.ClientPlayerEntity;
|
||||||
@ -61,9 +61,12 @@ public abstract class MixinClientPlayerInteractionManager {
|
|||||||
@Final
|
@Final
|
||||||
private MinecraftClient client;
|
private MinecraftClient client;
|
||||||
|
|
||||||
@Shadow protected abstract ActionResult interactBlockInternal(ClientPlayerEntity player, Hand hand, BlockHitResult hitResult);
|
@Shadow
|
||||||
|
protected abstract ActionResult interactBlockInternal(ClientPlayerEntity player, Hand hand, BlockHitResult hitResult);
|
||||||
|
|
||||||
@Shadow @Final private ClientPlayNetworkHandler networkHandler;
|
@Shadow
|
||||||
|
@Final
|
||||||
|
private ClientPlayNetworkHandler networkHandler;
|
||||||
|
|
||||||
@Unique
|
@Unique
|
||||||
private ItemStack viafabricplus_oldCursorStack;
|
private ItemStack viafabricplus_oldCursorStack;
|
||||||
@ -99,8 +102,8 @@ public abstract class MixinClientPlayerInteractionManager {
|
|||||||
return type == SlotActionType.PICKUP && slot == -999;
|
return type == SlotActionType.PICKUP && slot == -999;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Redirect(method = "clickSlot", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayNetworkHandler;sendPacket(Lnet/minecraft/network/packet/Packet;)V"))
|
@WrapWithCondition(method = "clickSlot", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayNetworkHandler;sendPacket(Lnet/minecraft/network/packet/Packet;)V"))
|
||||||
private void modifySlotClickPacket(ClientPlayNetworkHandler instance, Packet<?> packet) {
|
private boolean modifySlotClickPacket(ClientPlayNetworkHandler instance, Packet<?> packet) {
|
||||||
if (ProtocolHack.getTargetVersion().isOlderThanOrEqualTo(ProtocolVersion.v1_16_4) && packet instanceof ClickSlotC2SPacket clickSlot) {
|
if (ProtocolHack.getTargetVersion().isOlderThanOrEqualTo(ProtocolVersion.v1_16_4) && packet instanceof ClickSlotC2SPacket clickSlot) {
|
||||||
ItemStack slotItemBeforeModification;
|
ItemStack slotItemBeforeModification;
|
||||||
|
|
||||||
@ -131,25 +134,22 @@ public abstract class MixinClientPlayerInteractionManager {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
clickSlotPacket.sendToServer(Protocol1_17To1_16_4.class);
|
clickSlotPacket.sendToServer(Protocol1_17To1_16_4.class);
|
||||||
} catch (Exception ignored) {}
|
} catch (Exception ignored) {
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
viafabricplus_oldCursorStack = null;
|
viafabricplus_oldCursorStack = null;
|
||||||
viafabricplus_oldItems = null;
|
viafabricplus_oldItems = null;
|
||||||
|
return false;
|
||||||
return;
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
instance.sendPacket(packet);
|
@WrapWithCondition(method = "interactItem", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayNetworkHandler;sendPacket(Lnet/minecraft/network/packet/Packet;)V", ordinal = 0),
|
||||||
}
|
|
||||||
|
|
||||||
@Redirect(method = "interactItem", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayNetworkHandler;sendPacket(Lnet/minecraft/network/packet/Packet;)V", ordinal = 0),
|
|
||||||
slice = @Slice(from = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayerInteractionManager;syncSelectedSlot()V"),
|
slice = @Slice(from = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayerInteractionManager;syncSelectedSlot()V"),
|
||||||
to = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayerInteractionManager;sendSequencedPacket(Lnet/minecraft/client/world/ClientWorld;Lnet/minecraft/client/network/SequencedPacketCreator;)V", ordinal = 0)))
|
to = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayerInteractionManager;sendSequencedPacket(Lnet/minecraft/client/world/ClientWorld;Lnet/minecraft/client/network/SequencedPacketCreator;)V", ordinal = 0)))
|
||||||
private void redirectInteractItem(ClientPlayNetworkHandler clientPlayNetworkHandler, Packet<?> packet) {
|
private boolean redirectInteractItem(ClientPlayNetworkHandler instance, Packet<?> packet) {
|
||||||
if (ProtocolHack.getTargetVersion().isNewerThanOrEqualTo(ProtocolVersion.v1_17)) {
|
return ProtocolHack.getTargetVersion().isNewerThanOrEqualTo(ProtocolVersion.v1_17);
|
||||||
clientPlayNetworkHandler.sendPacket(packet);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Inject(method = "interactItem", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayNetworkHandler;sendPacket(Lnet/minecraft/network/packet/Packet;)V", ordinal = 0, shift = At.Shift.BEFORE))
|
@Inject(method = "interactItem", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayNetworkHandler;sendPacket(Lnet/minecraft/network/packet/Packet;)V", ordinal = 0, shift = At.Shift.BEFORE))
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
*/
|
*/
|
||||||
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft;
|
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft;
|
||||||
|
|
||||||
|
import com.llamalad7.mixinextras.injector.ModifyExpressionValue;
|
||||||
import de.florianmichael.viafabricplus.base.settings.groups.VisualSettings;
|
import de.florianmichael.viafabricplus.base.settings.groups.VisualSettings;
|
||||||
import net.minecraft.client.gui.DrawContext;
|
import net.minecraft.client.gui.DrawContext;
|
||||||
import net.minecraft.client.gui.hud.InGameHud;
|
import net.minecraft.client.gui.hud.InGameHud;
|
||||||
@ -63,10 +64,10 @@ public abstract class MixinInGameHud {
|
|||||||
|
|
||||||
// Moving down all remaining elements
|
// Moving down all remaining elements
|
||||||
|
|
||||||
@Redirect(method = "renderStatusBars", at = @At(value = "FIELD", target = "Lnet/minecraft/client/gui/hud/InGameHud;scaledHeight:I", opcode = Opcodes.GETFIELD))
|
@ModifyExpressionValue(method = "renderStatusBars", at = @At(value = "FIELD", target = "Lnet/minecraft/client/gui/hud/InGameHud;scaledHeight:I", opcode = Opcodes.GETFIELD))
|
||||||
private int moveHealthDown(InGameHud instance) {
|
private int moveHealthDown(int originalValue) {
|
||||||
if (VisualSettings.INSTANCE.removeNewerHudElements.getValue()) return scaledHeight + 6;
|
if (VisualSettings.INSTANCE.removeNewerHudElements.getValue()) return originalValue + 6;
|
||||||
return scaledHeight;
|
return originalValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ModifyArg(method = "renderStatusBars", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/DrawContext;drawTexture(Lnet/minecraft/util/Identifier;IIIIII)V"), slice = @Slice(
|
@ModifyArg(method = "renderStatusBars", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/DrawContext;drawTexture(Lnet/minecraft/util/Identifier;IIIIII)V"), slice = @Slice(
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
*/
|
*/
|
||||||
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft;
|
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft;
|
||||||
|
|
||||||
|
import com.llamalad7.mixinextras.injector.WrapWithCondition;
|
||||||
import com.viaversion.viaversion.api.connection.UserConnection;
|
import com.viaversion.viaversion.api.connection.UserConnection;
|
||||||
import com.viaversion.viaversion.api.protocol.packet.PacketWrapper;
|
import com.viaversion.viaversion.api.protocol.packet.PacketWrapper;
|
||||||
import com.viaversion.viaversion.api.type.Type;
|
import com.viaversion.viaversion.api.type.Type;
|
||||||
@ -56,13 +57,11 @@ public abstract class MixinMinecraftClient implements IMinecraftClient {
|
|||||||
|
|
||||||
@Shadow @Nullable public abstract ClientPlayNetworkHandler getNetworkHandler();
|
@Shadow @Nullable public abstract ClientPlayNetworkHandler getNetworkHandler();
|
||||||
|
|
||||||
@Redirect(method = "doItemUse",
|
@WrapWithCondition(method = "doItemUse",
|
||||||
slice = @Slice(from = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayerInteractionManager;interactItem(Lnet/minecraft/entity/player/PlayerEntity;Lnet/minecraft/util/Hand;)Lnet/minecraft/util/ActionResult;")),
|
slice = @Slice(from = @At(value = "INVOKE", target = "Lnet/minecraft/client/network/ClientPlayerInteractionManager;interactItem(Lnet/minecraft/entity/player/PlayerEntity;Lnet/minecraft/util/Hand;)Lnet/minecraft/util/ActionResult;")),
|
||||||
at = @At(value = "INVOKE", target = "Lnet/minecraft/client/render/item/HeldItemRenderer;resetEquipProgress(Lnet/minecraft/util/Hand;)V", ordinal = 0))
|
at = @At(value = "INVOKE", target = "Lnet/minecraft/client/render/item/HeldItemRenderer;resetEquipProgress(Lnet/minecraft/util/Hand;)V", ordinal = 0))
|
||||||
private void redirectDoItemUse(HeldItemRenderer heldItemRenderer, Hand hand) {
|
public boolean removeEquipProgressReset(HeldItemRenderer instance, Hand hand) {
|
||||||
if (ProtocolHack.getTargetVersion().isNewerThan(ProtocolVersion.v1_8) || !(player.getStackInHand(hand).getItem() instanceof SwordItem)) {
|
return ProtocolHack.getTargetVersion().isNewerThan(ProtocolVersion.v1_8) || !(player.getStackInHand(hand).getItem() instanceof SwordItem);
|
||||||
heldItemRenderer.resetEquipProgress(hand);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Redirect(method = "doItemUse",
|
@Redirect(method = "doItemUse",
|
||||||
|
@ -89,7 +89,6 @@ public class MixinServerResourcePackProvider {
|
|||||||
if (ProtocolHack.getTargetVersion().isOlderThanOrEqualTo(ProtocolVersion.v1_8)) {
|
if (ProtocolHack.getTargetVersion().isOlderThanOrEqualTo(ProtocolVersion.v1_8)) {
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
return instance.toLowerCase(locale);
|
return instance.toLowerCase(locale);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft;
|
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft;
|
||||||
|
|
||||||
import de.florianmichael.viafabricplus.definition.ChatLengthCalculation;
|
import de.florianmichael.viafabricplus.definition.ChatLengthCalculation;
|
||||||
|
import net.minecraft.client.MinecraftClient;
|
||||||
import net.minecraft.util.StringHelper;
|
import net.minecraft.util.StringHelper;
|
||||||
import org.spongepowered.asm.mixin.Mixin;
|
import org.spongepowered.asm.mixin.Mixin;
|
||||||
import org.spongepowered.asm.mixin.injection.Constant;
|
import org.spongepowered.asm.mixin.injection.Constant;
|
||||||
@ -28,6 +29,9 @@ public class MixinStringHelper {
|
|||||||
|
|
||||||
@ModifyConstant(method = "truncateChat", constant = @Constant(intValue = 256))
|
@ModifyConstant(method = "truncateChat", constant = @Constant(intValue = 256))
|
||||||
private static int expandChatLength(int constant) {
|
private static int expandChatLength(int constant) {
|
||||||
|
if (MinecraftClient.getInstance().isInSingleplayer()) {
|
||||||
|
return 256;
|
||||||
|
}
|
||||||
return ChatLengthCalculation.INSTANCE.getMaxLength();
|
return ChatLengthCalculation.INSTANCE.getMaxLength();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
*/
|
*/
|
||||||
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft.entity;
|
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft.entity;
|
||||||
|
|
||||||
|
import com.llamalad7.mixinextras.injector.WrapWithCondition;
|
||||||
import com.viaversion.viaversion.api.protocol.version.ProtocolVersion;
|
import com.viaversion.viaversion.api.protocol.version.ProtocolVersion;
|
||||||
import de.florianmichael.viafabricplus.protocolhack.ProtocolHack;
|
import de.florianmichael.viafabricplus.protocolhack.ProtocolHack;
|
||||||
import de.florianmichael.viafabricplus.base.settings.groups.ExperimentalSettings;
|
import de.florianmichael.viafabricplus.base.settings.groups.ExperimentalSettings;
|
||||||
@ -88,13 +89,11 @@ public abstract class MixinLivingEntity extends Entity {
|
|||||||
return movingDown;
|
return movingDown;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Redirect(method = "travel",
|
@WrapWithCondition(method = "travel",
|
||||||
slice = @Slice(from = @At(value = "FIELD", target = "Lnet/minecraft/entity/effect/StatusEffects;LEVITATION:Lnet/minecraft/entity/effect/StatusEffect;", ordinal = 0)),
|
slice = @Slice(from = @At(value = "FIELD", target = "Lnet/minecraft/entity/effect/StatusEffects;LEVITATION:Lnet/minecraft/entity/effect/StatusEffect;", ordinal = 0)),
|
||||||
at = @At(value = "INVOKE", target = "Lnet/minecraft/entity/LivingEntity;onLanding()V", ordinal = 0))
|
at = @At(value = "INVOKE", target = "Lnet/minecraft/entity/LivingEntity;onLanding()V", ordinal = 0))
|
||||||
private void dontResetLevitationFallDistance(LivingEntity instance) {
|
private boolean dontResetLevitationFallDistance(LivingEntity instance) {
|
||||||
if (ProtocolHack.getTargetVersion().isNewerThan(ProtocolVersion.v1_12_2)) {
|
return ProtocolHack.getTargetVersion().isNewerThan(ProtocolVersion.v1_12_2);
|
||||||
instance.onLanding();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Redirect(method = "travel", at = @At(value = "INVOKE", target = "Lnet/minecraft/entity/LivingEntity;isSprinting()Z", ordinal = 0))
|
@Redirect(method = "travel", at = @At(value = "INVOKE", target = "Lnet/minecraft/entity/LivingEntity;isSprinting()Z", ordinal = 0))
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft.packet;
|
package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft.packet;
|
||||||
|
|
||||||
import de.florianmichael.viafabricplus.definition.ChatLengthCalculation;
|
import de.florianmichael.viafabricplus.definition.ChatLengthCalculation;
|
||||||
|
import net.minecraft.client.MinecraftClient;
|
||||||
import net.minecraft.network.packet.c2s.play.ChatMessageC2SPacket;
|
import net.minecraft.network.packet.c2s.play.ChatMessageC2SPacket;
|
||||||
import org.spongepowered.asm.mixin.Mixin;
|
import org.spongepowered.asm.mixin.Mixin;
|
||||||
import org.spongepowered.asm.mixin.injection.At;
|
import org.spongepowered.asm.mixin.injection.At;
|
||||||
@ -28,6 +29,9 @@ public class MixinChatMessageC2SPacket {
|
|||||||
|
|
||||||
@ModifyArg(method = "write", at = @At(value = "INVOKE", target = "Lnet/minecraft/network/PacketByteBuf;writeString(Ljava/lang/String;I)Lnet/minecraft/network/PacketByteBuf;"))
|
@ModifyArg(method = "write", at = @At(value = "INVOKE", target = "Lnet/minecraft/network/PacketByteBuf;writeString(Ljava/lang/String;I)Lnet/minecraft/network/PacketByteBuf;"))
|
||||||
public int modifyChatLength(int maxLength) {
|
public int modifyChatLength(int maxLength) {
|
||||||
|
if (MinecraftClient.getInstance().isInSingleplayer()) {
|
||||||
|
return 256;
|
||||||
|
}
|
||||||
return ChatLengthCalculation.INSTANCE.getMaxLength();
|
return ChatLengthCalculation.INSTANCE.getMaxLength();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -19,6 +19,7 @@ package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft.screen;
|
|||||||
|
|
||||||
import de.florianmichael.viafabricplus.definition.ChatLengthCalculation;
|
import de.florianmichael.viafabricplus.definition.ChatLengthCalculation;
|
||||||
import de.florianmichael.viafabricplus.base.settings.groups.VisualSettings;
|
import de.florianmichael.viafabricplus.base.settings.groups.VisualSettings;
|
||||||
|
import net.minecraft.client.MinecraftClient;
|
||||||
import net.minecraft.client.gui.hud.ChatHud;
|
import net.minecraft.client.gui.hud.ChatHud;
|
||||||
import net.minecraft.client.gui.hud.MessageIndicator;
|
import net.minecraft.client.gui.hud.MessageIndicator;
|
||||||
import net.minecraft.client.gui.screen.ChatScreen;
|
import net.minecraft.client.gui.screen.ChatScreen;
|
||||||
@ -37,8 +38,10 @@ public class MixinChatScreen {
|
|||||||
|
|
||||||
@Inject(method = "init", at = @At("RETURN"))
|
@Inject(method = "init", at = @At("RETURN"))
|
||||||
public void changeChatLength(CallbackInfo ci) {
|
public void changeChatLength(CallbackInfo ci) {
|
||||||
|
if (!MinecraftClient.getInstance().isInSingleplayer()) {
|
||||||
this.chatField.setMaxLength(ChatLengthCalculation.INSTANCE.getMaxLength());
|
this.chatField.setMaxLength(ChatLengthCalculation.INSTANCE.getMaxLength());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Redirect(method = "render", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/hud/ChatHud;getIndicatorAt(DD)Lnet/minecraft/client/gui/hud/MessageIndicator;"))
|
@Redirect(method = "render", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/hud/ChatHud;getIndicatorAt(DD)Lnet/minecraft/client/gui/hud/MessageIndicator;"))
|
||||||
public MessageIndicator removeIndicator(ChatHud instance, double mouseX, double mouseY) {
|
public MessageIndicator removeIndicator(ChatHud instance, double mouseX, double mouseY) {
|
||||||
|
@ -36,6 +36,8 @@ public class MixinStructureBlockScreen_1 extends TextFieldWidget {
|
|||||||
|
|
||||||
@Inject(method = "charTyped(CI)Z", at = @At("HEAD"), cancellable = true)
|
@Inject(method = "charTyped(CI)Z", at = @At("HEAD"), cancellable = true)
|
||||||
private void onCharTyped(char chr, int keyCode, CallbackInfoReturnable<Boolean> ci) {
|
private void onCharTyped(char chr, int keyCode, CallbackInfoReturnable<Boolean> ci) {
|
||||||
if (ProtocolHack.getTargetVersion().isOlderThanOrEqualTo(ProtocolVersion.v1_12_2)) ci.setReturnValue(super.charTyped(chr, keyCode));
|
if (ProtocolHack.getTargetVersion().isOlderThanOrEqualTo(ProtocolVersion.v1_12_2)) {
|
||||||
|
ci.setReturnValue(super.charTyped(chr, keyCode));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -45,7 +45,7 @@ public abstract class MixinProtocolVersion {
|
|||||||
viafabricplus_remaps.put("1.16.4/5", new Pair<>("1.16.4-1.16.5", null));
|
viafabricplus_remaps.put("1.16.4/5", new Pair<>("1.16.4-1.16.5", null));
|
||||||
viafabricplus_remaps.put("1.18/1.18.1", new Pair<>("1.18-1.18.1", null));
|
viafabricplus_remaps.put("1.18/1.18.1", new Pair<>("1.18-1.18.1", null));
|
||||||
viafabricplus_remaps.put("1.19.1/2", new Pair<>("1.19.1-1.19.2", null));
|
viafabricplus_remaps.put("1.19.1/2", new Pair<>("1.19.1-1.19.2", null));
|
||||||
viafabricplus_remaps.put("1.20", new Pair<>("23w18a", null));
|
viafabricplus_remaps.put("1.20", new Pair<>("1.20-pre1", null));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Redirect(method = "<clinit>", at = @At(value = "INVOKE", target = "Lcom/viaversion/viaversion/api/protocol/version/ProtocolVersion;register(ILjava/lang/String;)Lcom/viaversion/viaversion/api/protocol/version/ProtocolVersion;"))
|
@Redirect(method = "<clinit>", at = @At(value = "INVOKE", target = "Lcom/viaversion/viaversion/api/protocol/version/ProtocolVersion;register(ILjava/lang/String;)Lcom/viaversion/viaversion/api/protocol/version/ProtocolVersion;"))
|
||||||
|
@ -32,7 +32,7 @@ public class PackFormatsMappings {
|
|||||||
private final static Map<Integer, GameVersion> protocolMap = new HashMap<>();
|
private final static Map<Integer, GameVersion> protocolMap = new HashMap<>();
|
||||||
|
|
||||||
public static void load() {
|
public static void load() {
|
||||||
registerVersion(ProtocolVersion.v1_20, 15, "23w18a");
|
registerVersion(ProtocolVersion.v1_20, 15, "1.20-pre1");
|
||||||
registerVersion(ProtocolVersion.v1_19_4, 13, "1.19.4");
|
registerVersion(ProtocolVersion.v1_19_4, 13, "1.19.4");
|
||||||
registerVersion(ProtocolVersion.v1_19_3, 12, "1.19.3");
|
registerVersion(ProtocolVersion.v1_19_3, 12, "1.19.3");
|
||||||
registerVersion(ProtocolVersion.v1_19_1, 9, "1.19.2");
|
registerVersion(ProtocolVersion.v1_19_1, 9, "1.19.2");
|
||||||
|
@ -33,7 +33,7 @@ public class ViaFabricPlusViaCommandSender implements ViaCommandSender {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean hasPermission(String s) {
|
public boolean hasPermission(String s) {
|
||||||
return source.hasPermissionLevel(4);
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
"words.viafabricplus.online": "Онлайн режим",
|
"words.viafabricplus.online": "Онлайн режим",
|
||||||
"words.viafabricplus.reset": "Зкинути",
|
"words.viafabricplus.reset": "Зкинути",
|
||||||
"words.viafabricplus.copy": "Зкопіювати код",
|
"words.viafabricplus.copy": "Зкопіювати код",
|
||||||
|
"words.viafabricplus.error": "Щось пішло не так! Спробуйте будь ласка пізніше",
|
||||||
|
|
||||||
"general.viafabricplus.secret": "Показувати Супер Секретні Налаштування",
|
"general.viafabricplus.secret": "Показувати Супер Секретні Налаштування",
|
||||||
"general.viafabricplus.extrainformation": "Показувати додаткову інформацію на екрані відладки",
|
"general.viafabricplus.extrainformation": "Показувати додаткову інформацію на екрані відладки",
|
||||||
|
Loading…
Reference in New Issue
Block a user