Better implementation of matchPlayer(String) - return List of potential matches
Dieser Commit ist enthalten in:
Ursprung
1e3c5a393b
Commit
7d12239ab7
@ -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() {
|
||||||
|
In neuem Issue referenzieren
Einen Benutzer sperren