diff options
Diffstat (limited to 'src/main/java/com/ambientaddons/mixin/MixinNetworkManager.java')
-rw-r--r-- | src/main/java/com/ambientaddons/mixin/MixinNetworkManager.java | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/main/java/com/ambientaddons/mixin/MixinNetworkManager.java b/src/main/java/com/ambientaddons/mixin/MixinNetworkManager.java new file mode 100644 index 0000000..f13b41c --- /dev/null +++ b/src/main/java/com/ambientaddons/mixin/MixinNetworkManager.java @@ -0,0 +1,20 @@ +package com.ambientaddons.mixin; + +import com.ambientaddons.events.ReceivePacketEvent; +import io.netty.channel.ChannelHandlerContext; +import net.minecraft.network.NetworkManager; +import net.minecraft.network.Packet; +import net.minecraftforge.common.MinecraftForge; +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; + +// credit Harry282/Skyblock-Client, under AGPL 3.0 +@Mixin(NetworkManager.class) +public class MixinNetworkManager { + @Inject(method = "channelRead0*", at = @At("HEAD"), cancellable = true) + private void onReceivePacket(ChannelHandlerContext context, Packet<?> packet, CallbackInfo ci) { + if (MinecraftForge.EVENT_BUS.post(new ReceivePacketEvent(packet))) ci.cancel(); + } +} |