Add cooldowns
This commit is contained in:
@@ -7,15 +7,15 @@ import net.minecraft.registry.Registries;
|
||||
import net.minecraft.util.math.Direction;
|
||||
import org.spongepowered.asm.mixin.Debug;
|
||||
import org.spongepowered.asm.mixin.Mixin;
|
||||
import org.spongepowered.asm.mixin.gen.Accessor;
|
||||
import org.spongepowered.asm.mixin.gen.Invoker;
|
||||
import org.spongepowered.asm.mixin.injection.At;
|
||||
import org.spongepowered.asm.mixin.injection.Inject;
|
||||
import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable;
|
||||
import systems.brn.regexinghoppers.RegexingHoppers;
|
||||
|
||||
@Debug(export = true) // Enables exporting for the targets of this mixin
|
||||
@Mixin(HopperBlockEntity.class)
|
||||
public class RegexingHopperMixin {
|
||||
|
||||
@Inject(method = "transfer(Lnet/minecraft/inventory/Inventory;Lnet/minecraft/inventory/Inventory;Lnet/minecraft/item/ItemStack;ILnet/minecraft/util/math/Direction;)Lnet/minecraft/item/ItemStack;",
|
||||
at = @At(value = "HEAD"),
|
||||
cancellable = true
|
||||
@@ -25,14 +25,21 @@ public class RegexingHopperMixin {
|
||||
if(from != null) {
|
||||
if (RegexingHoppers.shouldNotMove(from, itemName)) {
|
||||
cir.setReturnValue(stack);
|
||||
if(from instanceof HopperBlockEntity) {
|
||||
((HopperBlockEntityInvoker) from).setTransferCooldown(8);
|
||||
}
|
||||
return;
|
||||
}
|
||||
}
|
||||
if(_to != null) {
|
||||
if (RegexingHoppers.shouldNotMove(_to, itemName)) {
|
||||
cir.setReturnValue(stack);
|
||||
if(_to instanceof HopperBlockEntity) {
|
||||
((HopperBlockEntityInvoker) _to).setTransferCooldown(8);
|
||||
}
|
||||
return;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user