diff options
| author | Magnus Auvinen <magnus.auvinen@gmail.com> | 2008-03-29 17:20:21 +0000 |
|---|---|---|
| committer | Magnus Auvinen <magnus.auvinen@gmail.com> | 2008-03-29 17:20:21 +0000 |
| commit | 370cbbe79f8dbc8ef00dca28e27480c05789670f (patch) | |
| tree | f8adbab00c2a8e8e506f0f47beb753c47d592fb2 /src/engine/client/ec_srvbrowse.c | |
| parent | fcd9709c36ff014c270ef14f236e0141c8266695 (diff) | |
| download | zcatch-370cbbe79f8dbc8ef00dca28e27480c05789670f.tar.gz zcatch-370cbbe79f8dbc8ef00dca28e27480c05789670f.zip | |
server browser improvements. much improved quick search. sorted the player list.
Diffstat (limited to 'src/engine/client/ec_srvbrowse.c')
| -rw-r--r-- | src/engine/client/ec_srvbrowse.c | 26 |
1 files changed, 24 insertions, 2 deletions
diff --git a/src/engine/client/ec_srvbrowse.c b/src/engine/client/ec_srvbrowse.c index c4fe3080..fcab2fc8 100644 --- a/src/engine/client/ec_srvbrowse.c +++ b/src/engine/client/ec_srvbrowse.c @@ -128,7 +128,7 @@ static int client_serverbrowse_sort_compare_numplayers(const void *ai, const voi static void client_serverbrowse_filter() { - int i = 0; + int i = 0, p = 0; num_sorted_servers = 0; /* allocate the sorted list */ @@ -159,7 +159,29 @@ static void client_serverbrowse_filter() filtered = 1; else if(config.b_filter_string[0] != 0) { - if(strstr(serverlist[i]->info.name, config.b_filter_string) == 0) + int matchfound = 0; + + serverlist[i]->info.quicksearch_hit = 0; + + /* match against server name */ + if(str_find_nocase(serverlist[i]->info.name, config.b_filter_string)) + { + matchfound = 1; + serverlist[i]->info.quicksearch_hit |= BROWSEQUICK_SERVERNAME; + } + + /* match against players */ + for(p = 0; p < serverlist[i]->info.num_players; p++) + { + if(str_find_nocase(serverlist[i]->info.players[p].name, config.b_filter_string)) + { + matchfound = 1; + serverlist[i]->info.quicksearch_hit |= BROWSEQUICK_PLAYERNAME; + break; + } + } + + if(!matchfound) filtered = 1; } |