Omit filler keys if no channel's using them
This commit is contained in:
		
							parent
							
								
									0020f81e79
								
							
						
					
					
						commit
						2ff8e74061
					
				
					 1 changed files with 14 additions and 4 deletions
				
			
		|  | @ -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); | ||||||
| 
 | 
 | ||||||
| 	tcp_sendf (serv, "JOIN %s %s\r\n", chanstr, keystr);	/* send the actual command */ | 	if (send_keys) | ||||||
|  | 	{ | ||||||
|  | 		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); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue