Omit filler keys if no channel's using them

This commit is contained in:
Berke Viktor 2013-05-15 23:52:14 +02:00
parent 0020f81e79
commit 2ff8e74061
1 changed files with 14 additions and 4 deletions

View File

@ -119,7 +119,7 @@ irc_join (server *serv, char *channel, char *key)
} }
static void static void
irc_join_list_flush (server *serv, GString *channels, GString *keys) irc_join_list_flush (server *serv, GString *channels, GString *keys, int send_keys)
{ {
char *chanstr; char *chanstr;
char *keystr; char *keystr;
@ -127,7 +127,14 @@ irc_join_list_flush (server *serv, GString *channels, GString *keys)
chanstr = g_string_free (channels, FALSE); /* convert our strings to char arrays */ chanstr = g_string_free (channels, FALSE); /* convert our strings to char arrays */
keystr = g_string_free (keys, FALSE); keystr = g_string_free (keys, FALSE);
if (send_keys)
{
tcp_sendf (serv, "JOIN %s %s\r\n", chanstr, keystr); /* send the actual command */ tcp_sendf (serv, "JOIN %s %s\r\n", chanstr, keystr); /* send the actual command */
}
else
{
tcp_sendf (serv, "JOIN %s\r\n", chanstr); /* send the actual command */
}
g_free (chanstr); g_free (chanstr);
g_free (keystr); g_free (keystr);
@ -141,6 +148,7 @@ static void
irc_join_list (server *serv, GSList *favorites) irc_join_list (server *serv, GSList *favorites)
{ {
int first_item = 1; /* determine whether we add commas or not */ int first_item = 1; /* determine whether we add commas or not */
int send_keys = 0; /* if none of our channels have keys, we can omit the 'x' fillers altogether */
int len = 9; /* JOIN<space>channels<space>keys\r\n\0 */ int len = 9; /* JOIN<space>channels<space>keys\r\n\0 */
favchannel *fav; favchannel *fav;
GString *chanlist = g_string_new (NULL); GString *chanlist = g_string_new (NULL);
@ -161,13 +169,14 @@ irc_join_list (server *serv, GSList *favorites)
if (len >= 512) /* command length exceeds the IRC hard limit, flush it and start from scratch */ if (len >= 512) /* command length exceeds the IRC hard limit, flush it and start from scratch */
{ {
irc_join_list_flush (serv, chanlist, keylist); irc_join_list_flush (serv, chanlist, keylist, send_keys);
chanlist = g_string_new (NULL); chanlist = g_string_new (NULL);
keylist = g_string_new (NULL); keylist = g_string_new (NULL);
len = 9; len = 9;
first_item = 1; /* list dumped, omit commas once again */ first_item = 1; /* list dumped, omit commas once again */
send_keys = 0; /* also omit keys until we actually find one */
} }
if (!first_item) if (!first_item)
@ -188,6 +197,7 @@ irc_join_list (server *serv, GSList *favorites)
if (fav->key && strlen (fav->key)) /* strlen() is required since key can be '' for session->channelkey */ if (fav->key && strlen (fav->key)) /* strlen() is required since key can be '' for session->channelkey */
{ {
g_string_append (keylist, fav->key); g_string_append (keylist, fav->key);
send_keys = 1;
} }
else else
{ {
@ -198,7 +208,7 @@ irc_join_list (server *serv, GSList *favorites)
favlist = favlist->next; favlist = favlist->next;
} }
irc_join_list_flush (serv, chanlist, keylist); irc_join_list_flush (serv, chanlist, keylist, send_keys);
g_slist_free (favlist); g_slist_free (favlist);
} }