1
0
forked from bip/bip

channel order in conf honnored

This commit is contained in:
nohar 2005-05-30 18:35:49 +00:00
parent 811d7cb048
commit 36e809b889
3 changed files with 26 additions and 6 deletions

View File

@ -852,10 +852,13 @@ void ircize(list_t *ll)
struct c_channel *chan = struct c_channel *chan =
list_it_item(&chit); list_it_item(&chit);
struct chan_info *ci = chan_info_new(); struct chan_info *ci = chan_info_new();
printf("%s\n",chan->name);
ci->name = strdup(chan->name); ci->name = strdup(chan->name);
ci->key = strmaydup(chan->key); ci->key = strmaydup(chan->key);
hash_insert(&link->chan_infos, hash_insert(&link->chan_infos,
ci->name, ci); ci->name, ci);
list_add_last(&link->chan_infos_order,
ci);
} }
list_add_last(ll, link); list_add_last(ll, link);
} else { } else {

View File

@ -281,10 +281,10 @@ void irc_lag_init(struct link_server *is)
static void irc_server_join(struct link_server *s) static void irc_server_join(struct link_server *s)
{ {
hash_iterator_t it; list_iterator_t it;
for (hash_it_init(&LINK(s)->chan_infos, &it); hash_it_item(&it); for (list_it_init(&LINK(s)->chan_infos_order, &it); list_it_item(&it);
hash_it_next(&it)) { list_it_next(&it)) {
struct chan_info *ci = hash_it_item(&it); struct chan_info *ci = list_it_item(&it);
if (!ci->key) if (!ci->key)
WRITE_LINE1(CONN(s), NULL, "JOIN", ci->name); WRITE_LINE1(CONN(s), NULL, "JOIN", ci->name);
else else
@ -629,10 +629,23 @@ static int irc_cli_startup(struct link_client *ic, struct line *line,
return OK_FORGET; return OK_FORGET;
} }
/* join channels, step one, those in conf, in order */
list_iterator_t li;
for (list_it_init(&LINK(ic)->chan_infos_order, &li);
list_it_item(&li); list_it_next(&li)) {
struct chan_info *ci = (struct chan_info *)list_it_item(&li);
struct channel *chan;
if ((chan = hash_get(&LINK(ic)->l_server->channels, ci->name)))
irc_send_join(ic, chan);
}
/* step two, those not in conf */
hash_iterator_t hi; hash_iterator_t hi;
for (hash_it_init(&LINK(ic)->l_server->channels, &hi); for (hash_it_init(&LINK(ic)->l_server->channels, &hi);
hash_it_item(&hi); hash_it_next(&hi)) { hash_it_item(&hi); hash_it_next(&hi)) {
irc_send_join(ic, (struct channel *)hash_it_item(&hi)); struct channel *chan = (struct channel *)hash_it_item(&hi);
if (!hash_get(&LINK(ic)->chan_infos, chan->name))
irc_send_join(ic, chan);
} }
/* backlog privates */ /* backlog privates */
@ -799,6 +812,7 @@ void irc_add_channel_info(struct link_server *ircs, char *chan, char *key)
ci->name = strdup(chan); ci->name = strdup(chan);
ci->key = key ? strdup(key) : NULL; ci->key = key ? strdup(key) : NULL;
hash_insert(&LINK(ircs)->chan_infos, chan, ci); hash_insert(&LINK(ircs)->chan_infos, chan, ci);
list_add_last(&LINK(ircs)->chan_infos_order, ci);
} else { } else {
if (ci->key) { if (ci->key) {
free(ci->key); free(ci->key);
@ -865,6 +879,7 @@ static int irc_cli_part(struct link_client *irc, struct line *line)
struct chan_info *ci; struct chan_info *ci;
if ((ci = hash_remove_if_exists(&LINK(irc)->chan_infos, if ((ci = hash_remove_if_exists(&LINK(irc)->chan_infos,
line->elemv[1])) != NULL) { line->elemv[1])) != NULL) {
list_remove(&LINK(irc)->chan_infos_order, ci);
free(ci->name); free(ci->name);
if (ci->key) if (ci->key)
free(ci->key); free(ci->key);
@ -2200,6 +2215,7 @@ struct link *irc_link_new()
fatal("calloc"); fatal("calloc");
hash_init(&link->chan_infos, HASH_NOCASE); hash_init(&link->chan_infos, HASH_NOCASE);
list_init(&link->chan_infos_order, list_ptr_cmp);
return link; return link;
} }

View File

@ -78,6 +78,7 @@ struct link {
char *on_connect_send; char *on_connect_send;
char *away_nick; char *away_nick;
hash_t chan_infos; /* channels we want */ hash_t chan_infos; /* channels we want */
list_t chan_infos_order; /* for order only */
/** client connection static data **/ /** client connection static data **/