summaryrefslogtreecommitdiff
path: root/src/main/java/lv/enes/mc/eris_alchemy/mixin
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/lv/enes/mc/eris_alchemy/mixin')
-rw-r--r--src/main/java/lv/enes/mc/eris_alchemy/mixin/ContainerOpenersCounterMixin.java56
-rw-r--r--src/main/java/lv/enes/mc/eris_alchemy/mixin/client/SheetsMixin.java7
2 files changed, 61 insertions, 2 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}
diff --git a/src/main/java/lv/enes/mc/eris_alchemy/mixin/client/SheetsMixin.java b/src/main/java/lv/enes/mc/eris_alchemy/mixin/client/SheetsMixin.java
index 46f7720..145a68c 100644
--- a/src/main/java/lv/enes/mc/eris_alchemy/mixin/client/SheetsMixin.java
+++ b/src/main/java/lv/enes/mc/eris_alchemy/mixin/client/SheetsMixin.java
@@ -1,7 +1,8 @@
1package lv.enes.mc.eris_alchemy.mixin.client; 1package lv.enes.mc.eris_alchemy.mixin.client;
2 2
3import lv.enes.mc.eris_alchemy.block.entity.EnergyCondenserEntity;
3import lv.enes.mc.eris_alchemy.client.ErisAlchemyMaterials; 4import lv.enes.mc.eris_alchemy.client.ErisAlchemyMaterials;
4import lv.enes.mc.eris_alchemy.block.entity.AlchemicalChestBlockEntity; 5import lv.enes.mc.eris_alchemy.block.entity.AlchemicalChestEntity;
5import net.minecraft.client.renderer.Sheets; 6import net.minecraft.client.renderer.Sheets;
6import net.minecraft.client.resources.model.Material; 7import net.minecraft.client.resources.model.Material;
7import net.minecraft.world.level.block.entity.BlockEntity; 8import net.minecraft.world.level.block.entity.BlockEntity;
@@ -24,8 +25,10 @@ public abstract class SheetsMixin {
24 boolean christmas, 25 boolean christmas,
25 CallbackInfoReturnable<Material> cir 26 CallbackInfoReturnable<Material> cir
26 ) { 27 ) {
27 if (entity instanceof AlchemicalChestBlockEntity) { 28 if (entity instanceof AlchemicalChestEntity) {
28 cir.setReturnValue(ErisAlchemyMaterials.ALCHEMICAL_CHEST); 29 cir.setReturnValue(ErisAlchemyMaterials.ALCHEMICAL_CHEST);
30 } else if (entity instanceof EnergyCondenserEntity) {
31 cir.setReturnValue(ErisAlchemyMaterials.ENERGY_CONDENSER);
29 } 32 }
30 } 33 }
31} 34}