aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/me/shedaniel/mixins/MixinMinecraftClient.java
diff options
context:
space:
mode:
authorUnknown <shekwancheung0528@gmail.com>2018-12-31 13:12:25 +0800
committerUnknown <shekwancheung0528@gmail.com>2018-12-31 13:12:25 +0800
commitfee12aa0885da204ec874cd5ada371c42501c873 (patch)
tree880596f5f463e08762a56b1cb1d7008aaed1899d /src/main/java/me/shedaniel/mixins/MixinMinecraftClient.java
parent1b14c5142bb49db9af078b5c753bc22ce35a40cc (diff)
downloadRoughlyEnoughItems-fee12aa0885da204ec874cd5ada371c42501c873.tar.gz
RoughlyEnoughItems-fee12aa0885da204ec874cd5ada371c42501c873.tar.bz2
RoughlyEnoughItems-fee12aa0885da204ec874cd5ada371c42501c873.zip
packetadder wip
Diffstat (limited to 'src/main/java/me/shedaniel/mixins/MixinMinecraftClient.java')
-rw-r--r--src/main/java/me/shedaniel/mixins/MixinMinecraftClient.java40
1 files changed, 40 insertions, 0 deletions
diff --git a/src/main/java/me/shedaniel/mixins/MixinMinecraftClient.java b/src/main/java/me/shedaniel/mixins/MixinMinecraftClient.java
new file mode 100644
index 000000000..5b0b20961
--- /dev/null
+++ b/src/main/java/me/shedaniel/mixins/MixinMinecraftClient.java
@@ -0,0 +1,40 @@
+package me.shedaniel.mixins;
+
+import me.shedaniel.Core;
+import me.shedaniel.listenerdefinitions.ClientTickable;
+import me.shedaniel.listenerdefinitions.KeybindHandler;
+import net.minecraft.class_3689;
+import net.minecraft.client.MinecraftClient;
+import org.spongepowered.asm.mixin.Final;
+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(MinecraftClient.class)
+public class MixinMinecraftClient {
+
+ @Shadow
+ @Final
+ private class_3689 profiler;
+
+ @Inject(method = "tick", at = @At("RETURN"))
+ private void onTick(CallbackInfo ci) {
+ profiler.begin("mods");
+ for(ClientTickable tickable : Core.getListeners(ClientTickable.class)) {
+ profiler.begin(() -> tickable.getClass().getCanonicalName().replace('.', '/'));
+ tickable.clientTick();
+ profiler.end();
+ }
+ profiler.end();
+ }
+
+ @Inject(method = "method_1508", at = @At("HEAD"))
+ public void onProcessKeyBinds(CallbackInfo ci) {
+ for (KeybindHandler keybindHandler : Core.getListeners(KeybindHandler.class)) {
+ keybindHandler.processKeybinds();
+ }
+ }
+
+}