1
0
mirror of https://github.com/irssi/irssi.git synced 2025-01-03 14:56:47 -05:00

Merge pull request #1093 from ailin-nemui/cap-setname

request the setname capability
This commit is contained in:
ailin-nemui 2019-08-14 23:44:52 +02:00 committed by GitHub
commit c87919235a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 29 additions and 1 deletions

View File

@ -1045,6 +1045,7 @@ void irc_commands_init(void)
command_bind_irc("wallops", NULL, (SIGNAL_FUNC) command_1self); command_bind_irc("wallops", NULL, (SIGNAL_FUNC) command_1self);
command_bind_irc("kickban", NULL, (SIGNAL_FUNC) cmd_kickban); command_bind_irc("kickban", NULL, (SIGNAL_FUNC) cmd_kickban);
command_bind_irc("knockout", NULL, (SIGNAL_FUNC) cmd_knockout); command_bind_irc("knockout", NULL, (SIGNAL_FUNC) cmd_knockout);
command_bind_irc("setname", NULL, (SIGNAL_FUNC) command_1self);
command_bind_irc("server purge", NULL, (SIGNAL_FUNC) cmd_server_purge); command_bind_irc("server purge", NULL, (SIGNAL_FUNC) cmd_server_purge);
signal_add("channel destroyed", (SIGNAL_FUNC) sig_channel_destroyed); signal_add("channel destroyed", (SIGNAL_FUNC) sig_channel_destroyed);
@ -1111,6 +1112,7 @@ void irc_commands_deinit(void)
command_unbind("wait", (SIGNAL_FUNC) cmd_wait); command_unbind("wait", (SIGNAL_FUNC) cmd_wait);
command_unbind("wallops", (SIGNAL_FUNC) command_1self); command_unbind("wallops", (SIGNAL_FUNC) command_1self);
command_unbind("kickban", (SIGNAL_FUNC) cmd_kickban); command_unbind("kickban", (SIGNAL_FUNC) cmd_kickban);
command_unbind("setname", (SIGNAL_FUNC) command_1self);
command_unbind("knockout", (SIGNAL_FUNC) cmd_knockout); command_unbind("knockout", (SIGNAL_FUNC) cmd_knockout);
command_unbind("server purge", (SIGNAL_FUNC) cmd_server_purge); command_unbind("server purge", (SIGNAL_FUNC) cmd_server_purge);

View File

@ -446,6 +446,27 @@ static void event_userhost(SERVER_REC *server, const char *data)
g_free(params); g_free(params);
} }
static void event_setname(SERVER_REC *server, const char *data, const char *nick, const char *address)
{
GSList *nicks, *tmp;
NICK_REC *rec;
if (!IS_IRC_SERVER(server))
return;
g_return_if_fail(data != NULL);
if (*data == ':') data++;
nicks = nicklist_get_same(server, nick);
for (tmp = nicks; tmp != NULL; tmp = tmp->next->next) {
rec = tmp->next->data;
g_free(rec->realname);
rec->realname = g_strdup(data);
}
g_slist_free(nicks);
}
static void sig_usermode(SERVER_REC *server) static void sig_usermode(SERVER_REC *server)
{ {
g_return_if_fail(IS_SERVER(server)); g_return_if_fail(IS_SERVER(server));
@ -487,6 +508,7 @@ void irc_nicklist_init(void)
signal_add_first("event 437", (SIGNAL_FUNC) event_target_unavailable); signal_add_first("event 437", (SIGNAL_FUNC) event_target_unavailable);
signal_add_first("event 302", (SIGNAL_FUNC) event_userhost); signal_add_first("event 302", (SIGNAL_FUNC) event_userhost);
signal_add("userhost event", (SIGNAL_FUNC) event_userhost); signal_add("userhost event", (SIGNAL_FUNC) event_userhost);
signal_add("event setname", (SIGNAL_FUNC) event_setname);
signal_add("user mode changed", (SIGNAL_FUNC) sig_usermode); signal_add("user mode changed", (SIGNAL_FUNC) sig_usermode);
signal_add("server connected", (SIGNAL_FUNC) sig_connected); signal_add("server connected", (SIGNAL_FUNC) sig_connected);
} }
@ -509,6 +531,7 @@ void irc_nicklist_deinit(void)
signal_remove("event 437", (SIGNAL_FUNC) event_target_unavailable); signal_remove("event 437", (SIGNAL_FUNC) event_target_unavailable);
signal_remove("event 302", (SIGNAL_FUNC) event_userhost); signal_remove("event 302", (SIGNAL_FUNC) event_userhost);
signal_remove("userhost event", (SIGNAL_FUNC) event_userhost); signal_remove("userhost event", (SIGNAL_FUNC) event_userhost);
signal_remove("event setname", (SIGNAL_FUNC) event_setname);
signal_remove("user mode changed", (SIGNAL_FUNC) sig_usermode); signal_remove("user mode changed", (SIGNAL_FUNC) sig_usermode);
signal_remove("server connected", (SIGNAL_FUNC) sig_connected); signal_remove("server connected", (SIGNAL_FUNC) sig_connected);
} }

View File

@ -229,11 +229,13 @@ static void server_init(IRC_SERVER_REC *server)
g_free(cmd); g_free(cmd);
} }
if (conn->sasl_mechanism != SASL_MECHANISM_NONE) if (conn->sasl_mechanism != SASL_MECHANISM_NONE) {
irc_cap_toggle(server, CAP_SASL, TRUE); irc_cap_toggle(server, CAP_SASL, TRUE);
}
irc_cap_toggle(server, CAP_MULTI_PREFIX, TRUE); irc_cap_toggle(server, CAP_MULTI_PREFIX, TRUE);
irc_cap_toggle(server, CAP_EXTENDED_JOIN, TRUE); irc_cap_toggle(server, CAP_EXTENDED_JOIN, TRUE);
irc_cap_toggle(server, CAP_SETNAME, TRUE);
irc_send_cmd_now(server, "CAP LS " CAP_LS_VERSION); irc_send_cmd_now(server, "CAP LS " CAP_LS_VERSION);

View File

@ -18,6 +18,7 @@
#define CAP_SASL "sasl" #define CAP_SASL "sasl"
#define CAP_MULTI_PREFIX "multi-prefix" #define CAP_MULTI_PREFIX "multi-prefix"
#define CAP_EXTENDED_JOIN "extended-join" #define CAP_EXTENDED_JOIN "extended-join"
#define CAP_SETNAME "draft/setname"
/* returns IRC_SERVER_REC if it's IRC server, NULL if it isn't */ /* returns IRC_SERVER_REC if it's IRC server, NULL if it isn't */
#define IRC_SERVER(server) \ #define IRC_SERVER(server) \