From 4636ed267b17c14268636f852b7a69dc93c6117e Mon Sep 17 00:00:00 2001 From: Sollace Date: Wed, 21 Sep 2022 23:19:29 +0200 Subject: [PATCH] Pegasi can walk on powdered snow --- .../unicopia/mixin/MixinPowderSnowBlock.java | 22 +++++++++++++++++++ src/main/resources/unicopia.mixin.json | 1 + 2 files changed, 23 insertions(+) create mode 100644 src/main/java/com/minelittlepony/unicopia/mixin/MixinPowderSnowBlock.java diff --git a/src/main/java/com/minelittlepony/unicopia/mixin/MixinPowderSnowBlock.java b/src/main/java/com/minelittlepony/unicopia/mixin/MixinPowderSnowBlock.java new file mode 100644 index 00000000..2ecdc435 --- /dev/null +++ b/src/main/java/com/minelittlepony/unicopia/mixin/MixinPowderSnowBlock.java @@ -0,0 +1,22 @@ +package com.minelittlepony.unicopia.mixin; + +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.CallbackInfoReturnable; + +import com.minelittlepony.unicopia.Race; +import com.minelittlepony.unicopia.entity.player.Pony; + +import net.minecraft.block.PowderSnowBlock; +import net.minecraft.entity.Entity; + +@Mixin(PowderSnowBlock.class) +abstract class MixinPowderSnowBlock { + @Inject(method = "canWalkOnPowderSnow", at = @At("HEAD"), cancellable = true) + private static void onCanWalkOnPowderSnow(Entity entity, CallbackInfoReturnable info) { + if (Pony.of(entity).map(Pony::getSpecies).filter(Race::canFly).isPresent()) { + info.setReturnValue(true); + } + } +} diff --git a/src/main/resources/unicopia.mixin.json b/src/main/resources/unicopia.mixin.json index a58652d9..552c8bd8 100644 --- a/src/main/resources/unicopia.mixin.json +++ b/src/main/resources/unicopia.mixin.json @@ -22,6 +22,7 @@ "MixinMobEntity", "MixinPersistentProjectileEntity", "MixinPlayerEntity", + "MixinPowderSnowBlock", "MixinProjectileEntity", "MixinReachDistanceFix", "MixinServerPlayerEntity",