mirror of
https://github.com/YouHaveTrouble/PreventStabby.git
synced 2026-05-11 21:06:55 +00:00
more fixes for #15
This commit is contained in:
+5
@@ -3,6 +3,7 @@ package me.youhavetrouble.preventstabby.listeners.pets;
|
|||||||
import me.youhavetrouble.preventstabby.PreventStabby;
|
import me.youhavetrouble.preventstabby.PreventStabby;
|
||||||
import me.youhavetrouble.preventstabby.players.SmartCache;
|
import me.youhavetrouble.preventstabby.players.SmartCache;
|
||||||
import me.youhavetrouble.preventstabby.util.PreventStabbyListener;
|
import me.youhavetrouble.preventstabby.util.PreventStabbyListener;
|
||||||
|
import me.youhavetrouble.preventstabby.util.PvpState;
|
||||||
import me.youhavetrouble.preventstabby.util.Util;
|
import me.youhavetrouble.preventstabby.util.Util;
|
||||||
import org.bukkit.entity.Entity;
|
import org.bukkit.entity.Entity;
|
||||||
import org.bukkit.entity.Tameable;
|
import org.bukkit.entity.Tameable;
|
||||||
@@ -14,8 +15,12 @@ import org.bukkit.event.Listener;
|
|||||||
@PreventStabbyListener
|
@PreventStabbyListener
|
||||||
public class PetTargettingMountListener implements Listener {
|
public class PetTargettingMountListener implements Listener {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TODO - this needs to pass canDamage() in the future, for now it just checks forced pvp state directly
|
||||||
|
*/
|
||||||
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
||||||
public void onWolfAttackMount(org.bukkit.event.entity.EntityDamageByEntityEvent event) {
|
public void onWolfAttackMount(org.bukkit.event.entity.EntityDamageByEntityEvent event) {
|
||||||
|
if (PreventStabby.getPlugin().getPlayerManager().getForcedPvpState() == PvpState.ENABLED) return;
|
||||||
if (!(event.getDamager() instanceof Tameable) || event.getEntity().getPassengers().isEmpty()) return;
|
if (!(event.getDamager() instanceof Tameable) || event.getEntity().getPassengers().isEmpty()) return;
|
||||||
Tameable damager = (Tameable) event.getDamager();
|
Tameable damager = (Tameable) event.getDamager();
|
||||||
Entity victim = event.getEntity();
|
Entity victim = event.getEntity();
|
||||||
|
|||||||
+12
-12
@@ -1,7 +1,9 @@
|
|||||||
package me.youhavetrouble.preventstabby.listeners.pets;
|
package me.youhavetrouble.preventstabby.listeners.pets;
|
||||||
|
|
||||||
import me.youhavetrouble.preventstabby.PreventStabby;
|
import me.youhavetrouble.preventstabby.PreventStabby;
|
||||||
|
import me.youhavetrouble.preventstabby.config.ConfigCache;
|
||||||
import me.youhavetrouble.preventstabby.players.SmartCache;
|
import me.youhavetrouble.preventstabby.players.SmartCache;
|
||||||
|
import me.youhavetrouble.preventstabby.util.CombatTimer;
|
||||||
import me.youhavetrouble.preventstabby.util.PreventStabbyListener;
|
import me.youhavetrouble.preventstabby.util.PreventStabbyListener;
|
||||||
import org.bukkit.entity.Tameable;
|
import org.bukkit.entity.Tameable;
|
||||||
import org.bukkit.entity.Wolf;
|
import org.bukkit.entity.Wolf;
|
||||||
@@ -14,23 +16,21 @@ public class PetTargettingPetListener implements Listener {
|
|||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
||||||
public void onWolfAttackWolf(org.bukkit.event.entity.EntityDamageByEntityEvent event) {
|
public void onWolfAttackWolf(org.bukkit.event.entity.EntityDamageByEntityEvent event) {
|
||||||
if (event.getDamager() instanceof Tameable && event.getEntity() instanceof Tameable) {
|
if (!(event.getDamager() instanceof Tameable) || !(event.getEntity() instanceof Tameable)) return;
|
||||||
Tameable damager = (Tameable) event.getDamager();
|
Tameable damager = (Tameable) event.getDamager();
|
||||||
Tameable victim = (Tameable) event.getEntity();
|
Tameable victim = (Tameable) event.getEntity();
|
||||||
if (damager.getOwner() == null || victim.getOwner() == null) return;
|
if (damager.getOwner() == null || victim.getOwner() == null) return;
|
||||||
|
|
||||||
SmartCache smartCache = PreventStabby.getPlugin().getSmartCache();
|
if (!PreventStabby.getPlugin().getPlayerManager()
|
||||||
boolean damagerPvpEnabled = smartCache.getPlayerData(damager.getOwner().getUniqueId()).isPvpEnabled();
|
.canDamage(
|
||||||
boolean victimPvpEnabled = smartCache.getPlayerData(victim.getOwner().getUniqueId()).isPvpEnabled();
|
damager.getUniqueId(),
|
||||||
|
victim.getUniqueId(),
|
||||||
if (!victimPvpEnabled || !damagerPvpEnabled) {
|
false,
|
||||||
if (damager instanceof Wolf) {
|
false
|
||||||
Wolf wolf = (Wolf) damager;
|
))
|
||||||
wolf.setAngry(false);
|
|
||||||
}
|
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
+12
-13
@@ -23,7 +23,7 @@ public class PlayerHitPetWithProjectileListener implements Listener {
|
|||||||
*/
|
*/
|
||||||
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true)
|
||||||
public void onPlayerHitPetWithProjectile(org.bukkit.event.entity.EntityDamageByEntityEvent event) {
|
public void onPlayerHitPetWithProjectile(org.bukkit.event.entity.EntityDamageByEntityEvent event) {
|
||||||
if (event.getEntity() instanceof Tameable && event.getDamager() instanceof Projectile) {
|
if (!(event.getEntity() instanceof Tameable) || !(event.getDamager() instanceof Projectile)) return;
|
||||||
Projectile projectile = (Projectile) event.getDamager();
|
Projectile projectile = (Projectile) event.getDamager();
|
||||||
if (!(projectile.getShooter() instanceof Player)) return;
|
if (!(projectile.getShooter() instanceof Player)) return;
|
||||||
Tameable tameable = (Tameable) event.getEntity();
|
Tameable tameable = (Tameable) event.getEntity();
|
||||||
@@ -35,20 +35,19 @@ public class PlayerHitPetWithProjectileListener implements Listener {
|
|||||||
if (damager.equals(victim)) return;
|
if (damager.equals(victim)) return;
|
||||||
|
|
||||||
ConfigCache config = PreventStabby.getPlugin().getConfigCache();
|
ConfigCache config = PreventStabby.getPlugin().getConfigCache();
|
||||||
SmartCache smartCache = PreventStabby.getPlugin().getSmartCache();
|
|
||||||
|
|
||||||
if (!smartCache.getPlayerData(damager).isPvpEnabled()) {
|
if (PreventStabby.getPlugin().getPlayerManager()
|
||||||
PluginMessages.sendActionBar(damager, config.getCannot_attack_pets_attacker());
|
.canDamage(
|
||||||
event.setCancelled(true);
|
damager,
|
||||||
return;
|
victim,
|
||||||
}
|
config.getCannot_attack_pets_attacker(),
|
||||||
if (!smartCache.getPlayerData(victim).isPvpEnabled()) {
|
config.getCannot_attack_pets_victim(),
|
||||||
PluginMessages.sendActionBar(damager, config.getCannot_attack_pets_victim());
|
false
|
||||||
event.setCancelled(true);
|
))
|
||||||
return;
|
|
||||||
}
|
|
||||||
CombatTimer.refreshPlayersCombatTime(damager);
|
CombatTimer.refreshPlayersCombatTime(damager);
|
||||||
|
else
|
||||||
|
event.setCancelled(true);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|||||||
Reference in New Issue
Block a user