about summary refs log tree commit diff
path: root/src/engine/client
diff options
context:
space:
mode:
authorMagnus Auvinen <magnus.auvinen@gmail.com>2008-09-03 21:02:30 +0000
committerMagnus Auvinen <magnus.auvinen@gmail.com>2008-09-03 21:02:30 +0000
commit171ca682d3edbe641ccc26cba7f5991206ae9041 (patch)
tree9755d7b9cba5ec6f12c31d2e77dfba9cb1121b96 /src/engine/client
parent53da3f0d40ff9eb171b3d8eaaeed148e9ddd2f8b (diff)
downloadzcatch-171ca682d3edbe641ccc26cba7f5991206ae9041.tar.gz
zcatch-171ca682d3edbe641ccc26cba7f5991206ae9041.zip
added saving of favorites
Diffstat (limited to 'src/engine/client')
-rw-r--r--src/engine/client/ec_client.c11
-rw-r--r--src/engine/client/ec_srvbrowse.c13
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);
+	}
+}