Server qol (#5534)
This commit is contained in:
committed by
GitHub
parent
4fdb817d4a
commit
789e354400
@@ -163,9 +163,9 @@ public class ServerControl implements ApplicationListener{
|
||||
Events.on(GameOverEvent.class, event -> {
|
||||
if(inExtraRound) return;
|
||||
if(state.rules.waves){
|
||||
info("Game over! Reached wave @ with @ players online on map @.", state.wave, Groups.player.size(), Strings.capitalize(state.map.name()));
|
||||
info("Game over! Reached wave @ with @ players online on map @.", state.wave, Groups.player.size(), Strings.capitalize(Strings.stripColors(state.map.name())));
|
||||
}else{
|
||||
info("Game over! Team @ is victorious with @ players online on map @.", event.winner.name, Groups.player.size(), Strings.capitalize(state.map.name()));
|
||||
info("Game over! Team @ is victorious with @ players online on map @.", event.winner.name, Groups.player.size(), Strings.capitalize(Strings.stripColors(state.map.name())));
|
||||
}
|
||||
|
||||
//set next map to be played
|
||||
@@ -174,14 +174,14 @@ public class ServerControl implements ApplicationListener{
|
||||
if(map != null){
|
||||
Call.infoMessage((state.rules.pvp
|
||||
? "[accent]The " + event.winner.name + " team is victorious![]\n" : "[scarlet]Game over![]\n")
|
||||
+ "\nNext selected map:[accent] " + map.name() + "[]"
|
||||
+ "\nNext selected map:[accent] " + Strings.stripColors(map.name()) + "[]"
|
||||
+ (map.tags.containsKey("author") && !map.tags.get("author").trim().isEmpty() ? " by[accent] " + map.author() + "[white]" : "") + "." +
|
||||
"\nNew game begins in " + roundExtraTime + " seconds.");
|
||||
|
||||
state.gameOver = true;
|
||||
Call.updateGameOver(event.winner);
|
||||
|
||||
info("Selected next map to be @.", map.name());
|
||||
info("Selected next map to be @.", Strings.stripColors(map.name()));
|
||||
|
||||
play(true, () -> world.loadMap(map, map.applyRules(lastMode)));
|
||||
}else{
|
||||
@@ -259,10 +259,20 @@ public class ServerControl implements ApplicationListener{
|
||||
}
|
||||
|
||||
protected void registerCommands(){
|
||||
handler.register("help", "Displays this command list.", arg -> {
|
||||
info("Commands:");
|
||||
for(Command command : handler.getCommandList()){
|
||||
info(" &b&lb " + command.text + (command.paramText.isEmpty() ? "" : " &lc&fi") + command.paramText + "&fr - &lw" + command.description);
|
||||
handler.register("help", "[command]", "Display the command list, or get help for a specific command.", arg -> {
|
||||
if(arg.length > 0){
|
||||
Command command = handler.getCommandList().find(c -> c.text.equalsIgnoreCase(arg[0]));
|
||||
if(command == null){
|
||||
err("Command " + arg[0] + " not found!");
|
||||
}else{
|
||||
info(command.text + ":");
|
||||
info(" &b&lb " + command.text + (command.paramText.isEmpty() ? "" : " &lc&fi") + command.paramText + "&fr - &lw" + command.description);
|
||||
}
|
||||
}else{
|
||||
info("Commands:");
|
||||
for(Command command : handler.getCommandList()){
|
||||
info(" &b&lb " + command.text + (command.paramText.isEmpty() ? "" : " &lc&fi") + command.paramText + "&fr - &lw" + command.description);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
@@ -306,7 +316,7 @@ public class ServerControl implements ApplicationListener{
|
||||
|
||||
Map result;
|
||||
if(arg.length > 0){
|
||||
result = maps.all().find(map -> map.name().equalsIgnoreCase(arg[0].replace('_', ' ')) || map.name().equalsIgnoreCase(arg[0]));
|
||||
result = maps.all().find(map -> Strings.stripColors(map.name().replace('_', ' ')).equalsIgnoreCase(Strings.stripColors(arg[0]).replace('_', ' ')));
|
||||
|
||||
if(result == null){
|
||||
err("No map with name '@' found.", arg[0]);
|
||||
@@ -335,14 +345,16 @@ public class ServerControl implements ApplicationListener{
|
||||
}
|
||||
});
|
||||
|
||||
handler.register("maps", "Display all available maps.", arg -> {
|
||||
handler.register("maps", "[all]", "Display available maps. 'all' to include default maps.", arg -> {
|
||||
boolean all = arg.length > 0 && arg[0].equalsIgnoreCase("all");
|
||||
if(!maps.all().isEmpty()){
|
||||
info("Maps:");
|
||||
for(Map map : maps.all()){
|
||||
for(Map map : all ? maps.all() : maps.customMaps()){
|
||||
String mapName = Strings.stripColors(map.name()).replace(' ', '_');
|
||||
if(map.custom){
|
||||
info(" @ (@): &fiCustom / @x@", map.name().replace(' ', '_'), map.file.name(), map.width, map.height);
|
||||
info(" @ (@): &fiCustom / @x@", mapName, map.file.name(), map.width, map.height);
|
||||
}else{
|
||||
info(" @: &fiDefault / @x@", map.name().replace(' ', '_'), map.width, map.height);
|
||||
info(" @: &fiDefault / @x@", mapName, map.width, map.height);
|
||||
}
|
||||
}
|
||||
}else{
|
||||
@@ -366,7 +378,7 @@ public class ServerControl implements ApplicationListener{
|
||||
info("Status: &rserver closed");
|
||||
}else{
|
||||
info("Status:");
|
||||
info(" Playing on map &fi@ / Wave @", Strings.capitalize(state.map.name()), state.wave);
|
||||
info(" Playing on map &fi@ / Wave @", Strings.capitalize(Strings.stripColors(state.map.name())), state.wave);
|
||||
|
||||
if(state.rules.waves){
|
||||
info(" @ enemies.", state.enemies);
|
||||
@@ -650,10 +662,10 @@ public class ServerControl implements ApplicationListener{
|
||||
});
|
||||
|
||||
handler.register("nextmap", "<mapname...>", "Set the next map to be played after a game-over. Overrides shuffling.", arg -> {
|
||||
Map res = maps.all().find(map -> map.name().equalsIgnoreCase(arg[0].replace('_', ' ')) || map.name().equalsIgnoreCase(arg[0]));
|
||||
Map res = maps.all().find(map -> Strings.stripColors(map.name().replace('_', ' ')).equalsIgnoreCase(Strings.stripColors(arg[0]).replace('_', ' ')));
|
||||
if(res != null){
|
||||
nextMapOverride = res;
|
||||
info("Next map set to '@'.", res.name());
|
||||
info("Next map set to '@'.", Strings.stripColors(res.name()));
|
||||
}else{
|
||||
err("No map '@' found.", arg[0]);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user