diff options
-rw-r--r-- | src/irc/core/servers-redirect.c | 49 |
1 files changed, 37 insertions, 12 deletions
diff --git a/src/irc/core/servers-redirect.c b/src/irc/core/servers-redirect.c index 42e31fa4..6f1ec454 100644 --- a/src/irc/core/servers-redirect.c +++ b/src/irc/core/servers-redirect.c @@ -50,10 +50,11 @@ struct _REDIRECT_REC { unsigned int destroyed:1; unsigned int aborted:1; unsigned int remote:1; + unsigned int first_signal_sent:1; char *arg; int count; - char *failure_signal, *default_signal; + char *failure_signal, *default_signal, *first_signal, *last_signal; GSList *signals; /* event, signal, ... */ }; @@ -207,14 +208,33 @@ void server_redirect_event(IRC_SERVER_REC *server, const char *command, failure_signal, signals); } +/* Find specified event from signals list. If it's found, remove it from the + list and return it's target signal. */ +static char *signal_list_move(GSList **signals, const char *event) +{ + GSList *link; + char *linkevent, *linksignal; + + link = gslist_find_string(*signals, event); + if (link == NULL) + return NULL; + + linkevent = link->data; + linksignal = link->next->data; + + *signals = g_slist_remove(*signals, linkevent); + *signals = g_slist_remove(*signals, linksignal); + + g_free(linkevent); + return linksignal; +} + void server_redirect_event_list(IRC_SERVER_REC *server, const char *command, int count, const char *arg, int remote, const char *failure_signal, GSList *signals) { REDIRECT_CMD_REC *cmdrec; REDIRECT_REC *rec; - GSList *default_signal; - char *default_signal_key; g_return_if_fail(IS_IRC_SERVER(server)); g_return_if_fail(command != NULL); @@ -236,15 +256,9 @@ void server_redirect_event_list(IRC_SERVER_REC *server, const char *command, rec->remote = remote != -1 ? remote : cmdrec->remote; rec->failure_signal = g_strdup(failure_signal); - default_signal = gslist_find_string(signals, ""); - if (default_signal != NULL) { - default_signal_key = default_signal->data; - rec->default_signal = default_signal->next->data; - - signals = g_slist_remove(signals, default_signal_key); - signals = g_slist_remove(signals, rec->default_signal); - g_free(default_signal_key); - } + rec->default_signal = signal_list_move(&signals, ""); + rec->first_signal = signal_list_move(&signals, "redirect first"); + rec->last_signal = signal_list_move(&signals, "redirect last"); rec->signals = signals; if (server->redirect_next != NULL) @@ -407,7 +421,11 @@ static void redirect_abort(IRC_SERVER_REC *server, REDIRECT_REC *rec) if (rec->failure_signal != NULL) signal_emit(rec->failure_signal, 1, server); + } else if (rec->last_signal != NULL) { + /* emit the last signal */ + signal_emit(rec->last_signal, 1, server); } + server_redirect_destroy(rec); } @@ -501,6 +519,13 @@ server_redirect_get(IRC_SERVER_REC *server, const char *event, } } + if (*redirect != NULL && (*redirect)->first_signal != NULL && + !(*redirect)->first_signal_sent) { + /* emit the first_signal */ + (*redirect)->first_signal_sent = TRUE; + signal_emit((*redirect)->first_signal, 1, server); + } + return signal; } |