aboutsummaryrefslogtreecommitdiff
path: root/mod/src/main/java/moe/ymc/acron/mixin/PlayerManagerMixin.java
diff options
context:
space:
mode:
Diffstat (limited to 'mod/src/main/java/moe/ymc/acron/mixin/PlayerManagerMixin.java')
-rw-r--r--mod/src/main/java/moe/ymc/acron/mixin/PlayerManagerMixin.java27
1 files changed, 27 insertions, 0 deletions
diff --git a/mod/src/main/java/moe/ymc/acron/mixin/PlayerManagerMixin.java b/mod/src/main/java/moe/ymc/acron/mixin/PlayerManagerMixin.java
new file mode 100644
index 0000000..2137a52
--- /dev/null
+++ b/mod/src/main/java/moe/ymc/acron/mixin/PlayerManagerMixin.java
@@ -0,0 +1,27 @@
+package moe.ymc.acron.mixin;
+
+import moe.ymc.acron.s2c.Entity;
+import moe.ymc.acron.s2c.EventQueue;
+import moe.ymc.acron.s2c.event.EventPlayerJoined;
+import net.minecraft.network.ClientConnection;
+import net.minecraft.server.PlayerManager;
+import net.minecraft.server.network.ServerPlayerEntity;
+import org.apache.logging.log4j.LogManager;
+import org.apache.logging.log4j.Logger;
+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(PlayerManager.class)
+public class PlayerManagerMixin {
+ private static final Logger AC_LOGGER = LogManager.getLogger();
+
+ @Inject(at = @At("RETURN"),
+ method = "onPlayerConnect")
+ public void onPlayerConnect(ClientConnection connection, ServerPlayerEntity player, CallbackInfo ci) {
+ AC_LOGGER.debug("onPlayerConnect: {}",
+ player.getUuid());
+ EventQueue.enqueue(new EventPlayerJoined(new Entity(player)));
+ }
+}