mirror of
https://github.com/essentials/Essentials.git
synced 2025-10-01 08:36:48 +02:00
Extract user match looping
This commit is contained in:
@@ -0,0 +1,126 @@
|
||||
package com.earth2me.essentials.commands;
|
||||
|
||||
import com.earth2me.essentials.ChargeException;
|
||||
import com.earth2me.essentials.User;
|
||||
import java.util.List;
|
||||
import org.bukkit.Server;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
|
||||
public abstract class EssentialsLoopCommand extends EssentialsCommand
|
||||
{
|
||||
public EssentialsLoopCommand(String command)
|
||||
{
|
||||
super(command);
|
||||
}
|
||||
|
||||
protected void loopOfflinePlayers(final Server server, final CommandSender sender, final boolean multipleStringMatches, final String searchTerm, final String[] commandArgs)
|
||||
throws PlayerNotFoundException, NotEnoughArgumentsException, PlayerExemptException, ChargeException
|
||||
{
|
||||
if (searchTerm.isEmpty())
|
||||
{
|
||||
throw new PlayerNotFoundException();
|
||||
}
|
||||
|
||||
if (searchTerm.contentEquals("**"))
|
||||
{
|
||||
for (String sUser : ess.getUserMap().getAllUniqueUsers())
|
||||
{
|
||||
final User matchedUser = ess.getUser(sUser);
|
||||
updatePlayer(server, sender, matchedUser, commandArgs);
|
||||
}
|
||||
}
|
||||
else if (searchTerm.contentEquals("*"))
|
||||
{
|
||||
boolean skipHidden = sender instanceof Player && !ess.getUser(sender).isAuthorized("essentials.vanish.interact");
|
||||
for (Player onlinePlayer : server.getOnlinePlayers())
|
||||
{
|
||||
final User onlineUser = ess.getUser(onlinePlayer);
|
||||
if (skipHidden && onlineUser.isHidden())
|
||||
{
|
||||
continue;
|
||||
}
|
||||
updatePlayer(server, sender, onlineUser, commandArgs);
|
||||
}
|
||||
}
|
||||
else if (multipleStringMatches)
|
||||
{
|
||||
if (searchTerm.trim().length() < 3)
|
||||
{
|
||||
throw new PlayerNotFoundException();
|
||||
}
|
||||
final List<Player> matchedPlayers = server.matchPlayer(searchTerm);
|
||||
if (matchedPlayers.isEmpty())
|
||||
{
|
||||
final User matchedUser = getPlayer(server, searchTerm, true, true);
|
||||
updatePlayer(server, sender, matchedUser, commandArgs);
|
||||
}
|
||||
for (Player matchPlayer : matchedPlayers)
|
||||
{
|
||||
final User matchedUser = ess.getUser(matchPlayer);
|
||||
updatePlayer(server, sender, matchedUser, commandArgs);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
final User user = getPlayer(server, searchTerm, true, true);
|
||||
updatePlayer(server, sender, user, commandArgs);
|
||||
}
|
||||
}
|
||||
|
||||
protected void loopOnlinePlayers(final Server server, final CommandSender sender, final boolean multipleStringMatches, final String searchTerm, final String[] commandArgs)
|
||||
throws PlayerNotFoundException, NotEnoughArgumentsException, PlayerExemptException, ChargeException
|
||||
{
|
||||
if (searchTerm.isEmpty())
|
||||
{
|
||||
throw new PlayerNotFoundException();
|
||||
}
|
||||
|
||||
boolean skipHidden = sender instanceof Player && !ess.getUser(sender).isAuthorized("essentials.vanish.interact");
|
||||
|
||||
if (searchTerm.contentEquals("**") || searchTerm.contentEquals("*"))
|
||||
{
|
||||
for (Player onlinePlayer : server.getOnlinePlayers())
|
||||
{
|
||||
final User onlineUser = ess.getUser(onlinePlayer);
|
||||
if (skipHidden && onlineUser.isHidden())
|
||||
{
|
||||
continue;
|
||||
}
|
||||
updatePlayer(server, sender, onlineUser, commandArgs);
|
||||
}
|
||||
}
|
||||
else if (multipleStringMatches)
|
||||
{
|
||||
if (searchTerm.trim().length() < 2)
|
||||
{
|
||||
throw new PlayerNotFoundException();
|
||||
}
|
||||
boolean foundUser = false;
|
||||
final List<Player> matchedPlayers = server.matchPlayer(searchTerm);
|
||||
for (Player matchPlayer : matchedPlayers)
|
||||
{
|
||||
final User player = ess.getUser(matchPlayer);
|
||||
if (skipHidden && player.isHidden())
|
||||
{
|
||||
continue;
|
||||
}
|
||||
foundUser = true;
|
||||
updatePlayer(server, sender, player, commandArgs);
|
||||
}
|
||||
if (!foundUser)
|
||||
{
|
||||
throw new PlayerNotFoundException();
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
final User player = getPlayer(server, searchTerm, skipHidden, false);
|
||||
updatePlayer(server, sender, player, commandArgs);
|
||||
}
|
||||
}
|
||||
|
||||
protected abstract void updatePlayer(Server server, CommandSender sender, User user, String[] args)
|
||||
throws NotEnoughArgumentsException, PlayerExemptException, ChargeException;
|
||||
}
|
Reference in New Issue
Block a user