2012-05-13 11:44:41 +00:00
|
|
|
package com.earth2me.essentials.commands;
|
|
|
|
|
|
|
|
import static com.earth2me.essentials.I18n._;
|
|
|
|
import com.earth2me.essentials.User;
|
|
|
|
import com.earth2me.essentials.Util;
|
|
|
|
import com.earth2me.essentials.craftbukkit.SetExpFix;
|
|
|
|
import org.bukkit.Server;
|
|
|
|
import org.bukkit.entity.Player;
|
|
|
|
|
2012-05-19 20:52:54 +00:00
|
|
|
|
2012-05-13 11:44:41 +00:00
|
|
|
public class Commandexp extends EssentialsCommand
|
|
|
|
{
|
|
|
|
public Commandexp()
|
|
|
|
{
|
|
|
|
super("exp");
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2012-05-17 12:39:40 +00:00
|
|
|
public void run(final Server server, final User user, final String commandLabel, final String[] args) throws Exception
|
2012-05-13 11:44:41 +00:00
|
|
|
{
|
2012-05-17 12:39:40 +00:00
|
|
|
if (args.length == 0)
|
2012-05-19 20:52:54 +00:00
|
|
|
{
|
|
|
|
showExp(user, user);
|
2012-05-17 12:39:40 +00:00
|
|
|
}
|
2012-05-19 21:02:42 +00:00
|
|
|
else if (args[0].equalsIgnoreCase("set") && user.isAuthorized("essentials.exp.set"))
|
2012-05-13 11:44:41 +00:00
|
|
|
{
|
2012-05-19 21:02:42 +00:00
|
|
|
if (args.length == 3 && user.isAuthorized("essentials.exp.set.others"))
|
2012-05-13 11:44:41 +00:00
|
|
|
{
|
2012-06-10 23:14:19 +00:00
|
|
|
boolean foundUser = false;
|
2012-05-19 20:52:54 +00:00
|
|
|
for (Player matchPlayer : server.matchPlayer(args[1]))
|
2012-05-13 11:44:41 +00:00
|
|
|
{
|
2012-05-19 20:52:54 +00:00
|
|
|
User target = ess.getUser(matchPlayer);
|
|
|
|
setExp(user, target, args[2], false);
|
|
|
|
foundUser = true;
|
2012-05-17 12:39:40 +00:00
|
|
|
}
|
2012-05-19 20:52:54 +00:00
|
|
|
if (foundUser == false)
|
2012-05-17 12:39:40 +00:00
|
|
|
{
|
2012-05-19 20:52:54 +00:00
|
|
|
throw new NoSuchFieldException(_("playerNotFound"));
|
2012-05-13 11:44:41 +00:00
|
|
|
}
|
2012-05-19 20:52:54 +00:00
|
|
|
return;
|
2012-05-17 12:39:40 +00:00
|
|
|
}
|
2012-05-19 20:52:54 +00:00
|
|
|
setExp(user, user, args[1], false);
|
|
|
|
}
|
|
|
|
else if (args[0].equalsIgnoreCase("give") && user.isAuthorized("essentials.exp.give"))
|
|
|
|
{
|
2012-05-19 21:02:42 +00:00
|
|
|
if (args.length == 3 && user.isAuthorized("essentials.exp.give.others"))
|
2012-05-17 12:39:40 +00:00
|
|
|
{
|
2012-06-10 23:14:19 +00:00
|
|
|
boolean foundUser = false;
|
2012-05-19 20:52:54 +00:00
|
|
|
for (Player matchPlayer : server.matchPlayer(args[1]))
|
2012-05-13 11:44:41 +00:00
|
|
|
{
|
2012-05-19 20:52:54 +00:00
|
|
|
User target = ess.getUser(matchPlayer);
|
|
|
|
setExp(user, target, args[2], true);
|
|
|
|
foundUser = true;
|
2012-05-13 11:44:41 +00:00
|
|
|
}
|
2012-05-19 20:52:54 +00:00
|
|
|
if (foundUser == false)
|
|
|
|
{
|
|
|
|
throw new NoSuchFieldException(_("playerNotFound"));
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
setExp(user, user, args[1], true);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
String search = args[0].trim();
|
|
|
|
if (args.length == 2)
|
|
|
|
{
|
|
|
|
search = args[1].trim();
|
2012-05-17 12:39:40 +00:00
|
|
|
}
|
2012-05-19 20:52:54 +00:00
|
|
|
if (search.equalsIgnoreCase("show") || !user.isAuthorized("essentials.exp.others"))
|
2012-05-17 12:39:40 +00:00
|
|
|
{
|
2012-05-19 20:52:54 +00:00
|
|
|
showExp(user, user);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
for (Player matchPlayer : server.matchPlayer(search))
|
|
|
|
{
|
|
|
|
User target = ess.getUser(matchPlayer);
|
|
|
|
showExp(user, target);
|
2012-05-13 11:44:41 +00:00
|
|
|
}
|
2012-05-17 12:39:40 +00:00
|
|
|
}
|
2012-05-19 20:52:54 +00:00
|
|
|
}
|
2012-05-19 21:02:42 +00:00
|
|
|
|
|
|
|
private void showExp(final User user, final User target)
|
|
|
|
{
|
|
|
|
final int totalExp = SetExpFix.getTotalExperience(target);
|
|
|
|
final int expLeft = (int)Util.roundDouble(((((3.5 * target.getLevel()) + 6.7) - (totalExp - ((1.75 * (target.getLevel() * target.getLevel())) + (5.00 * target.getLevel())))) + 1));
|
|
|
|
user.sendMessage(_("exp", target.getDisplayName(), SetExpFix.getTotalExperience(target), target.getLevel(), expLeft));
|
|
|
|
}
|
|
|
|
|
|
|
|
private void setExp(final User user, final User target, final String strAmount, final boolean give)
|
|
|
|
{
|
|
|
|
Long amount = Long.parseLong(strAmount);
|
|
|
|
if (give)
|
|
|
|
{
|
|
|
|
amount += SetExpFix.getTotalExperience(target);
|
|
|
|
}
|
|
|
|
if (amount > Integer.MAX_VALUE)
|
|
|
|
{
|
|
|
|
amount = (long)Integer.MAX_VALUE;
|
|
|
|
}
|
|
|
|
SetExpFix.setTotalExperience(target, amount.intValue());
|
|
|
|
user.sendMessage(_("expSet", target.getDisplayName(), amount));
|
|
|
|
}
|
2012-05-13 11:44:41 +00:00
|
|
|
}
|