diff options
author | Jilles Tjoelker <jilles@irssi.org> | 2007-12-23 16:48:24 +0000 |
---|---|---|
committer | jilles <jilles@dbcabf3a-b0e7-0310-adc4-f8d773084564> | 2007-12-23 16:48:24 +0000 |
commit | 7d30a05879e228ef62e3598122063945be6e816e (patch) | |
tree | 539b30e16fe5590acead39558da586db0f40a5bb /src | |
parent | 6331ffdc2bfbdce5d51678c57332f867ce54d0d3 (diff) | |
download | irssi-7d30a05879e228ef62e3598122063945be6e816e.zip |
Apply -usermode before -autosendcmd.
The -usermode is now implicitly treated as a requested
usermode change; the MODE command setting it is not
redirected. This is good because user MODE may or may
not give a reply and this could be confused with the MODE
message indicating the initial usermode.
Possible issue here: '-' modes in -usermode persist only
until you change your umode via /mode.
Bug #548
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@4668 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src')
-rw-r--r-- | src/irc/core/irc-servers.c | 39 |
1 files changed, 9 insertions, 30 deletions
diff --git a/src/irc/core/irc-servers.c b/src/irc/core/irc-servers.c index 89bc59de..028d1601 100644 --- a/src/irc/core/irc-servers.c +++ b/src/irc/core/irc-servers.c @@ -475,34 +475,6 @@ char *irc_server_get_channels(IRC_SERVER_REC *server) return ret; } -static int sig_set_user_mode(IRC_SERVER_REC *server) -{ - const char *mode; - char *newmode, *args; - - if (!IS_IRC_SERVER(server) || g_slist_find(servers, server) == NULL) - return 0; /* not an irc server or got disconnected */ - - mode = server->connrec->usermode; - newmode = server->usermode == NULL ? NULL : - modes_join(NULL, server->usermode, mode, FALSE); - - if (newmode == NULL || strcmp(newmode, server->usermode) != 0) { - /* change the user mode. we used to do some trickery to - get rid of unwanted modes at reconnect time, but that's - more trouble than worth. (eg. we don't want to remove - some good default server modes, but we don't want to - set back +r, etc..) */ - args = g_strdup_printf((*mode == '+' || *mode == '-') ? "%s %s" : - "%s +%s", server->nick, mode); - signal_emit("command mode", 3, args, server, NULL); - g_free(args); - } - - g_free_not_null(newmode); - return 0; -} - static void event_connected(IRC_SERVER_REC *server, const char *data, const char *from) { char *params, *nick; @@ -533,8 +505,15 @@ static void event_connected(IRC_SERVER_REC *server, const char *data, const char memcpy(&server->wait_cmd, &now, sizeof(GTimeVal)); if (server->connrec->usermode != NULL) { - /* wait a second and then send the user mode */ - g_timeout_add(1000, (GSourceFunc) sig_set_user_mode, server); + /* Send the user mode, before the autosendcmd. + * Do not pass this through cmd_mode because it + * is not known whether the resulting MODE message + * (if any) is the initial umode or a reply to this. + */ + irc_send_cmdv(server, "MODE %s %s", server->nick, + server->connrec->usermode); + g_free_not_null(server->wanted_usermode); + server->wanted_usermode = g_strdup(server->connrec->usermode); } signal_emit("event connected", 1, server); |