Fixed code behaviour

This commit is contained in:
FlorianMichael 2024-03-22 11:04:43 +01:00
parent ca828d2bc2
commit 973a3df00c
No known key found for this signature in database
GPG Key ID: C2FB87E71C425126
5 changed files with 10 additions and 11 deletions

View File

@ -27,7 +27,7 @@ public interface IServerInfo {
void viaFabricPlus$forceVersion(final ProtocolVersion version); void viaFabricPlus$forceVersion(final ProtocolVersion version);
boolean viaFabricPlus$passedDirectConnectScreen(); boolean viaFabricPlus$passedDirectConnectScreen();
void viaFabricPlus$passDirectConnectScreen(); void viaFabricPlus$passDirectConnectScreen(final boolean state);
ProtocolVersion viaFabricPlus$translatingVersion(); ProtocolVersion viaFabricPlus$translatingVersion();
void viaFabricPlus$setTranslatingVersion(final ProtocolVersion version); void viaFabricPlus$setTranslatingVersion(final ProtocolVersion version);

View File

@ -64,6 +64,7 @@ public abstract class MixinConnectScreen_1 {
ProtocolVersion targetVersion = ProtocolTranslator.getTargetVersion(); ProtocolVersion targetVersion = ProtocolTranslator.getTargetVersion();
if (mixinServerInfo.viaFabricPlus$forcedVersion() != null && !mixinServerInfo.viaFabricPlus$passedDirectConnectScreen()) { if (mixinServerInfo.viaFabricPlus$forcedVersion() != null && !mixinServerInfo.viaFabricPlus$passedDirectConnectScreen()) {
targetVersion = mixinServerInfo.viaFabricPlus$forcedVersion(); targetVersion = mixinServerInfo.viaFabricPlus$forcedVersion();
mixinServerInfo.viaFabricPlus$passDirectConnectScreen(false); // reset state
} }
if (targetVersion == ProtocolTranslator.AUTO_DETECT_PROTOCOL) { if (targetVersion == ProtocolTranslator.AUTO_DETECT_PROTOCOL) {
this.field_2416.setStatus(Text.translatable("base.viafabricplus.detecting_server_version")); this.field_2416.setStatus(Text.translatable("base.viafabricplus.detecting_server_version"));

View File

@ -35,7 +35,7 @@ public abstract class MixinMultiplayerScreen {
@WrapOperation(method = "directConnect", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/screen/multiplayer/MultiplayerScreen;connect(Lnet/minecraft/client/network/ServerInfo;)V")) @WrapOperation(method = "directConnect", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/gui/screen/multiplayer/MultiplayerScreen;connect(Lnet/minecraft/client/network/ServerInfo;)V"))
private void storeDirectConnectionPhase(MultiplayerScreen instance, ServerInfo entry, Operation<Void> original) { private void storeDirectConnectionPhase(MultiplayerScreen instance, ServerInfo entry, Operation<Void> original) {
((IServerInfo) entry).viaFabricPlus$passDirectConnectScreen(); ((IServerInfo) entry).viaFabricPlus$passDirectConnectScreen(true);
original.call(instance, entry); original.call(instance, entry);
} }

View File

@ -46,9 +46,9 @@ public abstract class MixinMultiplayerServerListPinger {
@Redirect(method = "add", at = @At(value = "INVOKE", target = "Lnet/minecraft/network/ClientConnection;connect(Ljava/net/InetSocketAddress;ZLnet/minecraft/util/profiler/PerformanceLog;)Lnet/minecraft/network/ClientConnection;")) @Redirect(method = "add", at = @At(value = "INVOKE", target = "Lnet/minecraft/network/ClientConnection;connect(Ljava/net/InetSocketAddress;ZLnet/minecraft/util/profiler/PerformanceLog;)Lnet/minecraft/network/ClientConnection;"))
private ClientConnection setForcedVersion(InetSocketAddress address, boolean useEpoll, PerformanceLog packetSizeLog, @Local(argsOnly = true) ServerInfo serverInfo) { private ClientConnection setForcedVersion(InetSocketAddress address, boolean useEpoll, PerformanceLog packetSizeLog, @Local(argsOnly = true) ServerInfo serverInfo) {
final ProtocolVersion forcedVersion = ((IServerInfo) serverInfo).viaFabricPlus$forcedVersion(); final IServerInfo mixinServerInfo = (IServerInfo) serverInfo;
if (forcedVersion != null && !((IServerInfo) serverInfo).viaFabricPlus$passedDirectConnectScreen()) { if (mixinServerInfo.viaFabricPlus$forcedVersion() != null && !mixinServerInfo.viaFabricPlus$passedDirectConnectScreen()) {
// We use the PerformanceLog field to store the forced version since it's always null when pinging a server // We use the PerformanceLog field to store the forced version since it's always null when pinging a server
// So we can create a dummy instance, store the forced version in it and later destroy the instance again // So we can create a dummy instance, store the forced version in it and later destroy the instance again
// To avoid any side effects, we also support cases where a mod is also creating a PerformanceLog instance // To avoid any side effects, we also support cases where a mod is also creating a PerformanceLog instance
@ -57,7 +57,8 @@ public abstract class MixinMultiplayerServerListPinger {
} }
// Attach the forced version to the PerformanceLog instance // Attach the forced version to the PerformanceLog instance
((IPerformanceLog) packetSizeLog).viaFabricPlus$setForcedVersion(forcedVersion); ((IPerformanceLog) packetSizeLog).viaFabricPlus$setForcedVersion(mixinServerInfo.viaFabricPlus$forcedVersion());
mixinServerInfo.viaFabricPlus$passDirectConnectScreen(false);
} }
return ClientConnection.connect(address, useEpoll, packetSizeLog); return ClientConnection.connect(address, useEpoll, packetSizeLog);

View File

@ -81,15 +81,12 @@ public abstract class MixinServerInfo implements IServerInfo {
@Override @Override
public boolean viaFabricPlus$passedDirectConnectScreen() { public boolean viaFabricPlus$passedDirectConnectScreen() {
final boolean previous = viaFabricPlus$passedDirectConnectScreen; return viaFabricPlus$passedDirectConnectScreen;
viaFabricPlus$passedDirectConnectScreen = false;
return previous;
} }
@Override @Override
public void viaFabricPlus$passDirectConnectScreen() { public void viaFabricPlus$passDirectConnectScreen(boolean state) {
viaFabricPlus$passedDirectConnectScreen = true; viaFabricPlus$passedDirectConnectScreen = state;
} }
@Override @Override