diff options
| author | Magnus Auvinen <magnus.auvinen@gmail.com> | 2008-09-03 21:02:30 +0000 |
|---|---|---|
| committer | Magnus Auvinen <magnus.auvinen@gmail.com> | 2008-09-03 21:02:30 +0000 |
| commit | 171ca682d3edbe641ccc26cba7f5991206ae9041 (patch) | |
| tree | 9755d7b9cba5ec6f12c31d2e77dfba9cb1121b96 /src/engine/client | |
| parent | 53da3f0d40ff9eb171b3d8eaaeed148e9ddd2f8b (diff) | |
| download | zcatch-171ca682d3edbe641ccc26cba7f5991206ae9041.tar.gz zcatch-171ca682d3edbe641ccc26cba7f5991206ae9041.zip | |
added saving of favorites
Diffstat (limited to 'src/engine/client')
| -rw-r--r-- | src/engine/client/ec_client.c | 11 | ||||
| -rw-r--r-- | src/engine/client/ec_srvbrowse.c | 13 |
2 files changed, 24 insertions, 0 deletions
diff --git a/src/engine/client/ec_client.c b/src/engine/client/ec_client.c index bc76edfd..1d514d95 100644 --- a/src/engine/client/ec_client.c +++ b/src/engine/client/ec_client.c @@ -44,6 +44,7 @@ NETCLIENT *net; /* TODO: ugly, fix me */ extern void client_serverbrowse_set(NETADDR *addr, int request, int token, SERVER_INFO *info); +extern void client_serverbrowse_save(); static int snapshot_part; static int64 local_start_time; @@ -1496,6 +1497,13 @@ static void con_rcon(void *result, void *user_data) client_rcon(console_arg_string(result, 0)); } +static void con_addfavorite(void *result, void *user_data) +{ + NETADDR addr; + if(net_addr_from_str(&addr, console_arg_string(result, 0)) == 0) + client_serverbrowse_addfavorite(addr); +} + static void client_register_commands() { MACRO_REGISTER_COMMAND("quit", "", con_quit, 0x0); @@ -1504,6 +1512,8 @@ static void client_register_commands() MACRO_REGISTER_COMMAND("ping", "", con_ping, 0x0); MACRO_REGISTER_COMMAND("screenshot", "", con_screenshot, 0x0); MACRO_REGISTER_COMMAND("rcon", "r", con_rcon, 0x0); + + MACRO_REGISTER_COMMAND("add_favorite", "s", con_addfavorite, 0x0); } void client_save_line(const char *line) @@ -1552,6 +1562,7 @@ int main(int argc, char **argv) if(engine_config_write_start() == 0) { config_save(); + client_serverbrowse_save(); modc_save_config(); engine_config_write_stop(); } diff --git a/src/engine/client/ec_srvbrowse.c b/src/engine/client/ec_srvbrowse.c index f9807174..ccf0ea87 100644 --- a/src/engine/client/ec_srvbrowse.c +++ b/src/engine/client/ec_srvbrowse.c @@ -589,3 +589,16 @@ void client_serverbrowse_removefavorite(NETADDR addr) } } } + +void client_serverbrowse_save() +{ + int i; + char addrstr[128]; + char buffer[256]; + for(i = 0; i < num_favorite_servers; i++) + { + net_addr_str(&favorite_servers[i], addrstr, sizeof(addrstr)); + str_format(buffer, sizeof(buffer), "add_favorite %s", addrstr); + engine_config_write_line(buffer); + } +} |