summaryrefslogtreecommitdiff
path: root/src/main/java/lv/enes/mc/eris_alchemy/mixin/ContainerOpenersCounterMixin.java
diff options
context:
space:
mode:
authorGravatar Uko Kokņevičs2024-01-10 17:41:07 +0100
committerGravatar Uko Kokņevičs2024-01-10 17:41:07 +0100
commit000b84e87eaedb94fb87ccb11e376c51f99a1d07 (patch)
treedd9519e7dadf613a71e01b04cac7be9c121a9f18 /src/main/java/lv/enes/mc/eris_alchemy/mixin/ContainerOpenersCounterMixin.java
parentMove out common chest logic to separate files also in client code (diff)
downloadmc-eris-alchemy-000b84e87eaedb94fb87ccb11e376c51f99a1d07.tar.gz
mc-eris-alchemy-000b84e87eaedb94fb87ccb11e376c51f99a1d07.tar.xz
mc-eris-alchemy-000b84e87eaedb94fb87ccb11e376c51f99a1d07.zip
Added Energy Condenser
Diffstat (limited to 'src/main/java/lv/enes/mc/eris_alchemy/mixin/ContainerOpenersCounterMixin.java')
-rw-r--r--src/main/java/lv/enes/mc/eris_alchemy/mixin/ContainerOpenersCounterMixin.java56
1 files changed, 56 insertions, 0 deletions
diff --git a/src/main/java/lv/enes/mc/eris_alchemy/mixin/ContainerOpenersCounterMixin.java b/src/main/java/lv/enes/mc/eris_alchemy/mixin/ContainerOpenersCounterMixin.java
new file mode 100644
index 0000000..13b8669
--- /dev/null
+++ b/src/main/java/lv/enes/mc/eris_alchemy/mixin/ContainerOpenersCounterMixin.java
@@ -0,0 +1,56 @@
1package lv.enes.mc.eris_alchemy.mixin;
2
3import jakarta.annotation.Nonnull;
4import lv.enes.mc.eris_alchemy.utils.ContainerOpenersCounterUtil;
5import net.minecraft.core.BlockPos;
6import net.minecraft.server.level.ServerPlayer;
7import net.minecraft.world.entity.player.Player;
8import net.minecraft.world.level.Level;
9import net.minecraft.world.level.block.entity.ContainerOpenersCounter;
10import net.minecraft.world.level.block.state.BlockState;
11import net.minecraft.world.level.entity.EntityTypeTest;
12import net.minecraft.world.phys.AABB;
13import org.spongepowered.asm.mixin.Mixin;
14import org.spongepowered.asm.mixin.Shadow;
15import org.spongepowered.asm.mixin.Unique;
16import org.spongepowered.asm.mixin.injection.At;
17import org.spongepowered.asm.mixin.injection.Inject;
18import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
19
20import java.util.List;
21import java.util.Map;
22import java.util.WeakHashMap;
23
24@Mixin(ContainerOpenersCounter.class)
25public abstract class ContainerOpenersCounterMixin
26 implements ContainerOpenersCounterUtil.ContainerOpenersCounterSuper {
27 @Shadow protected abstract boolean isOwnContainer(Player player);
28
29 @Unique
30 private final static Map<ContainerOpenersCounterMixin, List<ServerPlayer>> openers = new WeakHashMap<>();
31
32 @Inject(method = "recheckOpeners", at = @At("RETURN"))
33 public void onRecheckOpeners(Level world, BlockPos pos, BlockState state, CallbackInfo ci) {
34 int x = pos.getX();
35 int y = pos.getY();
36 int z = pos.getZ();
37 var boundingBox = new AABB(
38 x - 5.0, y - 5.0, z - 5.0,
39 x + 5.0, y + 5.0, z + 5.0
40 );
41 var players = world.getEntities(EntityTypeTest.forClass(ServerPlayer.class), boundingBox, this::isOwnContainer);
42 if (openers.containsKey(this)) {
43 var list = openers.get(this);
44 list.clear();
45 list.addAll(players);
46 } else {
47 openers.put(this, players);
48 }
49 }
50
51 @Nonnull
52 @Override
53 public List<ServerPlayer> lv_enes_mc$getOpeners() {
54 return openers.getOrDefault(this, List.of());
55 }
56}