Better implementation of matchPlayer(String) - return List of potential matches

Dieser Commit ist enthalten in:
Animosity 2011-01-07 10:42:53 +08:00 committet von Dinner Bone
Ursprung 1e3c5a393b
Commit 7d12239ab7

Datei anzeigen

@ -1,6 +1,7 @@
package org.bukkit.craftbukkit; package org.bukkit.craftbukkit;
import java.io.File; import java.io.File;
import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.logging.Level; import java.util.logging.Level;
import java.util.logging.Logger; import java.util.logging.Logger;
@ -81,28 +82,24 @@ public final class CraftServer implements Server {
return entity.a.getPlayer(); return entity.a.getPlayer();
} }
public Player matchPlayer(String wantedPlayerName) { public List<Player> matchPlayer(String partialName) {
Player wantedPlayer = null; List<Player> matchedPlayers = new ArrayList<Player>();
for (Player iterPlayer : this.getOnlinePlayers()) { for (Player iterPlayer : this.getOnlinePlayers()) {
String iterPlayerName = iterPlayer.getName(); String iterPlayerName = iterPlayer.getName();
if (wantedPlayerName.equalsIgnoreCase(iterPlayerName)) { if (partialName.equalsIgnoreCase(iterPlayerName)) {
// Exact match // Exact match
wantedPlayer = this.getPlayer(wantedPlayerName); matchedPlayers.add(iterPlayer);
break; break;
} }
if (wantedPlayerName.toLowerCase().indexOf(iterPlayerName.toLowerCase()) != -1) { if (iterPlayerName.toLowerCase().indexOf(partialName.toLowerCase()) != -1) {
// Partial match // Partial match
if (wantedPlayer != null) { matchedPlayers.add(iterPlayer);
// Multiple matches
return null;
}
wantedPlayer = iterPlayer;
} }
} }
return wantedPlayer; return matchedPlayers;
} }
public PluginManager getPluginManager() { public PluginManager getPluginManager() {