summaryrefslogtreecommitdiff
path: root/src/main/java/fyresmodjam/blessings/standard/PorcupineBlessing.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/fyresmodjam/blessings/standard/PorcupineBlessing.java')
-rw-r--r--src/main/java/fyresmodjam/blessings/standard/PorcupineBlessing.java45
1 files changed, 45 insertions, 0 deletions
diff --git a/src/main/java/fyresmodjam/blessings/standard/PorcupineBlessing.java b/src/main/java/fyresmodjam/blessings/standard/PorcupineBlessing.java
new file mode 100644
index 0000000..a46c3d0
--- /dev/null
+++ b/src/main/java/fyresmodjam/blessings/standard/PorcupineBlessing.java
@@ -0,0 +1,45 @@
+package fyresmodjam.blessings.standard;
+
+import fyresmodjam.blessings.Blessing;
+import fyresmodjam.misc.DamageSources;
+import net.minecraft.entity.Entity;
+import net.minecraft.entity.EntityLivingBase;
+import net.minecraft.util.DamageSource;
+import net.minecraftforge.event.entity.living.LivingHurtEvent;
+
+public class PorcupineBlessing extends Blessing {
+
+ @Override
+ public String name() {
+ return "Porcupine";
+ }
+
+ @Override
+ public String description() {
+ return "Deal retaliation damage to melee attackers";
+ }
+
+ @Override
+ public float onIncomingDamage(LivingHurtEvent event,
+ float damageMultiplier) {
+ Entity trueSource = event.getSource().getTrueSource();
+
+ boolean isMeleeDamage = event.getSource().damageType
+ .equals("mob")
+ || event.getSource().getDamageType()
+ .equals("player");
+
+ if (trueSource != null
+ && trueSource instanceof EntityLivingBase
+ && !event.getSource().isProjectile()
+ && isMeleeDamage) {
+ DamageSource damage = DamageSources.retaliation;
+
+ ((EntityLivingBase) trueSource)
+ .attackEntityFrom(damage,
+ event.getAmount() * 0.07F);
+ }
+
+ return damageMultiplier;
+ }
+}