Improve location and profile detection
This commit is contained in:
@@ -60,7 +60,7 @@ public class SectionBuilderRiser extends RiserUtils {
|
||||
return;
|
||||
}
|
||||
}
|
||||
new RuntimeException("Could not inject tesselation hook despite fabric renderer indigo being loaded").printStackTrace();
|
||||
System.err.println("Could not inject indigo rendering hook. Is a custom renderer installed (e.g. sodium)?");
|
||||
}
|
||||
|
||||
private void handleIndigo(MethodNode method) {
|
||||
|
||||
@@ -1,22 +0,0 @@
|
||||
|
||||
package moe.nea.firmament.mixins.custompayload;
|
||||
|
||||
import moe.nea.firmament.apis.ingame.FirmamentCustomPayload;
|
||||
import moe.nea.firmament.events.FirmamentCustomPayloadEvent;
|
||||
import net.minecraft.client.network.ClientCommonNetworkHandler;
|
||||
import net.minecraft.network.packet.s2c.common.CustomPayloadS2CPacket;
|
||||
import org.spongepowered.asm.mixin.Mixin;
|
||||
import org.spongepowered.asm.mixin.injection.At;
|
||||
import org.spongepowered.asm.mixin.injection.Inject;
|
||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
||||
|
||||
@Mixin(value = ClientCommonNetworkHandler.class, priority = 500)
|
||||
public class CustomPayloadEventDispatcher {
|
||||
@Inject(method = "onCustomPayload(Lnet/minecraft/network/packet/s2c/common/CustomPayloadS2CPacket;)V", at = @At("HEAD"), cancellable = true)
|
||||
private void handleFirmamentParsedPayload(CustomPayloadS2CPacket packet, CallbackInfo ci) {
|
||||
if (packet.payload() instanceof FirmamentCustomPayload customPayload) {
|
||||
FirmamentCustomPayloadEvent.Companion.publishSync(new FirmamentCustomPayloadEvent(customPayload));
|
||||
ci.cancel();
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,29 +0,0 @@
|
||||
|
||||
package moe.nea.firmament.mixins.custompayload;
|
||||
|
||||
import com.llamalad7.mixinextras.injector.wrapoperation.Operation;
|
||||
import com.llamalad7.mixinextras.injector.wrapoperation.WrapOperation;
|
||||
import moe.nea.firmament.apis.ingame.InGameCodecWrapper;
|
||||
import net.minecraft.network.PacketByteBuf;
|
||||
import net.minecraft.network.codec.PacketCodec;
|
||||
import net.minecraft.network.packet.CustomPayload;
|
||||
import net.minecraft.network.packet.c2s.common.CustomPayloadC2SPacket;
|
||||
import org.spongepowered.asm.mixin.Mixin;
|
||||
import org.spongepowered.asm.mixin.injection.At;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Mixin(priority = 1001, value = CustomPayloadC2SPacket.class)
|
||||
public class InjectCustomCodecIntoC2SCustomPayloadPacket {
|
||||
|
||||
@WrapOperation(method = "<clinit>", at = @At(value = "INVOKE", target = "Lnet/minecraft/network/packet/CustomPayload;createCodec(Lnet/minecraft/network/packet/CustomPayload$CodecFactory;Ljava/util/List;)Lnet/minecraft/network/codec/PacketCodec;"))
|
||||
private static PacketCodec<PacketByteBuf, CustomPayload> wrapFactory(
|
||||
CustomPayload.CodecFactory<PacketByteBuf> unknownCodecFactory,
|
||||
List<CustomPayload.Type<PacketByteBuf, ?>> types,
|
||||
Operation<PacketCodec<PacketByteBuf, CustomPayload>> original) {
|
||||
|
||||
var originalCodec = original.call(unknownCodecFactory, types);
|
||||
|
||||
return new InGameCodecWrapper(originalCodec, InGameCodecWrapper.Direction.C2S);
|
||||
}
|
||||
}
|
||||
@@ -1,29 +0,0 @@
|
||||
|
||||
package moe.nea.firmament.mixins.custompayload;
|
||||
|
||||
import com.llamalad7.mixinextras.injector.wrapoperation.Operation;
|
||||
import com.llamalad7.mixinextras.injector.wrapoperation.WrapOperation;
|
||||
import moe.nea.firmament.apis.ingame.InGameCodecWrapper;
|
||||
import net.minecraft.network.PacketByteBuf;
|
||||
import net.minecraft.network.codec.PacketCodec;
|
||||
import net.minecraft.network.packet.CustomPayload;
|
||||
import net.minecraft.network.packet.s2c.common.CustomPayloadS2CPacket;
|
||||
import org.spongepowered.asm.mixin.Mixin;
|
||||
import org.spongepowered.asm.mixin.injection.At;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Mixin(priority = 1001, value = CustomPayloadS2CPacket.class)
|
||||
public abstract class InjectCustomCodecIntoS2CCustomPayloadPacket {
|
||||
|
||||
@WrapOperation(method = "<clinit>", at = @At(value = "INVOKE", target = "Lnet/minecraft/network/packet/CustomPayload;createCodec(Lnet/minecraft/network/packet/CustomPayload$CodecFactory;Ljava/util/List;)Lnet/minecraft/network/codec/PacketCodec;"))
|
||||
private static PacketCodec<PacketByteBuf, CustomPayload> wrapFactory(
|
||||
CustomPayload.CodecFactory<PacketByteBuf> unknownCodecFactory,
|
||||
List<CustomPayload.Type<PacketByteBuf, ?>> types,
|
||||
Operation<PacketCodec<PacketByteBuf, CustomPayload>> original) {
|
||||
|
||||
var originalCodec = original.call(unknownCodecFactory, types);
|
||||
|
||||
return new InGameCodecWrapper(originalCodec, InGameCodecWrapper.Direction.S2C);
|
||||
}
|
||||
}
|
||||
@@ -1,28 +0,0 @@
|
||||
|
||||
package moe.nea.firmament.mixins.custompayload;
|
||||
|
||||
import moe.nea.firmament.apis.ingame.JoinedCustomPayload;
|
||||
import net.minecraft.network.listener.ClientCommonPacketListener;
|
||||
import net.minecraft.network.packet.CustomPayload;
|
||||
import net.minecraft.network.packet.s2c.common.CustomPayloadS2CPacket;
|
||||
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;
|
||||
|
||||
@Mixin(CustomPayloadS2CPacket.class)
|
||||
public abstract class SplitJoinedCustomPayload {
|
||||
|
||||
@Shadow
|
||||
public abstract CustomPayload payload();
|
||||
|
||||
@Inject(method = "apply(Lnet/minecraft/network/listener/ClientCommonPacketListener;)V", at = @At("HEAD"), cancellable = true)
|
||||
private void onApply(ClientCommonPacketListener clientCommonPacketListener, CallbackInfo ci) {
|
||||
if (payload() instanceof JoinedCustomPayload joinedCustomPayload) {
|
||||
new CustomPayloadS2CPacket(joinedCustomPayload.getOriginal()).apply(clientCommonPacketListener);
|
||||
new CustomPayloadS2CPacket(joinedCustomPayload.getSmuggled()).apply(clientCommonPacketListener);
|
||||
ci.cancel();
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user