From d7902e06cd7285c72cd4ea2be6f18ead56a8775e Mon Sep 17 00:00:00 2001
From: Linnea Gräf <nea@nea.moe>
Date: Thu, 18 Jan 2024 00:10:25 +0100
Subject: Add Ancestral Spade solver

---
 .../firmament/mixins/SoundReceiveEventPatch.java   | 35 ++++++++++++++++++++++
 1 file changed, 35 insertions(+)
 create mode 100644 src/main/java/moe/nea/firmament/mixins/SoundReceiveEventPatch.java

(limited to 'src/main/java')

diff --git a/src/main/java/moe/nea/firmament/mixins/SoundReceiveEventPatch.java b/src/main/java/moe/nea/firmament/mixins/SoundReceiveEventPatch.java
new file mode 100644
index 0000000..64f8765
--- /dev/null
+++ b/src/main/java/moe/nea/firmament/mixins/SoundReceiveEventPatch.java
@@ -0,0 +1,35 @@
+/*
+ * SPDX-FileCopyrightText: 2024 Linnea Gräf <nea@nea.moe>
+ *
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ */
+
+package moe.nea.firmament.mixins;
+
+import moe.nea.firmament.events.SoundReceiveEvent;
+import net.minecraft.client.network.ClientPlayNetworkHandler;
+import net.minecraft.network.packet.s2c.play.PlaySoundS2CPacket;
+import net.minecraft.util.math.Vec3d;
+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(ClientPlayNetworkHandler.class)
+public class SoundReceiveEventPatch {
+    @Inject(method = "onPlaySound", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/world/ClientWorld;playSound(Lnet/minecraft/entity/player/PlayerEntity;DDDLnet/minecraft/registry/entry/RegistryEntry;Lnet/minecraft/sound/SoundCategory;FFJ)V"), cancellable = true)
+    private void postEventWhenSoundIsPlayed(PlaySoundS2CPacket packet, CallbackInfo ci) {
+        var event = new SoundReceiveEvent(
+            packet.getSound(),
+            packet.getCategory(),
+            new Vec3d(packet.getX(), packet.getY(), packet.getZ()),
+            packet.getPitch(),
+            packet.getVolume(),
+            packet.getSeed()
+        );
+        SoundReceiveEvent.Companion.publish(event);
+        if (event.getCancelled()) {
+            ci.cancel();
+        }
+    }
+}
-- 
cgit