mirror of
https://github.com/TotalFreedomMC/TF-EssentialsX.git
synced 2025-08-03 11:06:08 +00:00
[Fix] Allow Feed to be used via console
Throw events when modifying heath or food levels.
This commit is contained in:
parent
aac9e4884d
commit
6e20275cc7
3 changed files with 74 additions and 10 deletions
|
@ -6,6 +6,7 @@ import java.util.List;
|
||||||
import org.bukkit.Server;
|
import org.bukkit.Server;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.entity.FoodLevelChangeEvent;
|
||||||
|
|
||||||
|
|
||||||
public class Commandfeed extends EssentialsCommand
|
public class Commandfeed extends EssentialsCommand
|
||||||
|
@ -24,13 +25,22 @@ public class Commandfeed extends EssentialsCommand
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
user.setFoodLevel(20);
|
feedPlayer(user, user);
|
||||||
user.setSaturation(10);
|
|
||||||
user.sendMessage(_("feed"));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void feedOtherPlayers(final Server server, final CommandSender sender, final String name) throws NotEnoughArgumentsException
|
@Override
|
||||||
|
protected void run(final Server server, final CommandSender sender, final String commandLabel, final String[] args) throws Exception
|
||||||
|
{
|
||||||
|
if (args.length < 1)
|
||||||
|
{
|
||||||
|
throw new NotEnoughArgumentsException();
|
||||||
|
}
|
||||||
|
|
||||||
|
feedOtherPlayers(server, sender, args[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void feedOtherPlayers(final Server server, final CommandSender sender, final String name) throws NotEnoughArgumentsException, QuietAbortException
|
||||||
{
|
{
|
||||||
boolean skipHidden = sender instanceof Player && !ess.getUser(sender).isAuthorized("essentials.vanish.interact");
|
boolean skipHidden = sender instanceof Player && !ess.getUser(sender).isAuthorized("essentials.vanish.interact");
|
||||||
boolean foundUser = false;
|
boolean foundUser = false;
|
||||||
|
@ -43,13 +53,28 @@ public class Commandfeed extends EssentialsCommand
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
foundUser = true;
|
foundUser = true;
|
||||||
matchPlayer.setFoodLevel(20);
|
feedPlayer(sender, matchPlayer);
|
||||||
matchPlayer.setSaturation(10);
|
|
||||||
sender.sendMessage(_("feedOther", matchPlayer.getDisplayName()));
|
|
||||||
}
|
}
|
||||||
if (!foundUser)
|
if (!foundUser)
|
||||||
{
|
{
|
||||||
throw new NotEnoughArgumentsException(_("playerNotFound"));
|
throw new NotEnoughArgumentsException(_("playerNotFound"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void feedPlayer(CommandSender sender, Player player) throws QuietAbortException
|
||||||
|
{
|
||||||
|
final int amount = 20;
|
||||||
|
|
||||||
|
final FoodLevelChangeEvent flce = new FoodLevelChangeEvent(player, amount);
|
||||||
|
ess.getServer().getPluginManager().callEvent(flce);
|
||||||
|
if (flce.isCancelled())
|
||||||
|
{
|
||||||
|
throw new QuietAbortException();
|
||||||
|
}
|
||||||
|
|
||||||
|
player.setFoodLevel(flce.getFoodLevel());
|
||||||
|
player.setSaturation(10);
|
||||||
|
sender.sendMessage(sender.equals(player) ? _("feed") : _("feedOther", player.getDisplayName()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,8 @@ import java.util.List;
|
||||||
import org.bukkit.Server;
|
import org.bukkit.Server;
|
||||||
import org.bukkit.command.CommandSender;
|
import org.bukkit.command.CommandSender;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.event.entity.EntityRegainHealthEvent;
|
||||||
|
import org.bukkit.event.entity.EntityRegainHealthEvent.RegainReason;
|
||||||
import org.bukkit.potion.PotionEffect;
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
|
||||||
|
|
||||||
|
@ -61,8 +63,15 @@ public class Commandheal extends EssentialsCommand
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
foundUser = true;
|
foundUser = true;
|
||||||
healPlayer(matchPlayer);
|
try
|
||||||
sender.sendMessage(_("healOther", matchPlayer.getDisplayName()));
|
{
|
||||||
|
healPlayer(matchPlayer);
|
||||||
|
sender.sendMessage(_("healOther", matchPlayer.getDisplayName()));
|
||||||
|
}
|
||||||
|
catch (QuietAbortException e)
|
||||||
|
{
|
||||||
|
//Handle Quietly
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (!foundUser)
|
if (!foundUser)
|
||||||
{
|
{
|
||||||
|
@ -76,7 +85,22 @@ public class Commandheal extends EssentialsCommand
|
||||||
{
|
{
|
||||||
throw new Exception(_("healDead"));
|
throw new Exception(_("healDead"));
|
||||||
}
|
}
|
||||||
player.setHealth(player.getMaxHealth());
|
|
||||||
|
final int amount = player.getMaxHealth() - player.getHealth();
|
||||||
|
final EntityRegainHealthEvent erhe = new EntityRegainHealthEvent(player, amount, RegainReason.CUSTOM);
|
||||||
|
ess.getServer().getPluginManager().callEvent(erhe);
|
||||||
|
if (erhe.isCancelled())
|
||||||
|
{
|
||||||
|
throw new QuietAbortException();
|
||||||
|
}
|
||||||
|
|
||||||
|
int newAmount = player.getHealth() + erhe.getAmount();
|
||||||
|
if (newAmount > player.getMaxHealth())
|
||||||
|
{
|
||||||
|
newAmount = player.getMaxHealth();
|
||||||
|
}
|
||||||
|
|
||||||
|
player.setHealth(newAmount);
|
||||||
player.setFoodLevel(20);
|
player.setFoodLevel(20);
|
||||||
player.setFireTicks(0);
|
player.setFireTicks(0);
|
||||||
player.sendMessage(_("heal"));
|
player.sendMessage(_("heal"));
|
||||||
|
|
|
@ -0,0 +1,15 @@
|
||||||
|
package com.earth2me.essentials.commands;
|
||||||
|
|
||||||
|
|
||||||
|
public class QuietAbortException extends Exception
|
||||||
|
{
|
||||||
|
public QuietAbortException()
|
||||||
|
{
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
public QuietAbortException(String message)
|
||||||
|
{
|
||||||
|
super(message);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue