# HG changeset patch # User Ethan Blanton <elb@pidgin.im> # Date 1179944963 0 # Node ID d04b1617da3daec016b7c349088a64c70a7562c0 # Parent 51fff4d9869fe5430dc75d67920331510a7c959b This should suppress an annoying 477 numeric on channel joins if you aren't identified on freenode. It might cause problems with *real* 477s if you get disconnected, but I'm not sure -- someone scream if it does. diff -r 51fff4d9869f -r d04b1617da3d libpurple/protocols/irc/msgs.c --- a/libpurple/protocols/irc/msgs.c Wed May 23 15:28:54 2007 +0000 +++ b/libpurple/protocols/irc/msgs.c Wed May 23 18:29:23 2007 +0000 @@ -1089,11 +1089,21 @@ void irc_msg_regonly(struct irc_conn *irc, const char *name, const char *from, char **args) { PurpleConnection *gc = purple_account_get_connection(irc->account); + PurpleConversation *convo; char *msg; if (!args || !args[1] || !args[2] || !gc) return; + convo = purple_find_conversation_with_account(PURPLE_CONV_TYPE_CHAT, args[1], irc->account); + if (convo) { + /* This is a channel we're already in; for some reason, + * freenode feels the need to notify us that in some + * hypothetical other situation this might not have + * succeeded. Suppress that. */ + return; + } + msg = g_strdup_printf(_("Cannot join %s: Registration is required."), args[1]); purple_notify_error(gc, _("Cannot join channel"), msg, args[2]); g_free(msg);