summaryrefslogtreecommitdiff
path: root/src/plugins/irc
diff options
context:
space:
mode:
authorSébastien Helleu <flashcode@flashtux.org>2023-10-19 23:31:49 +0200
committerSébastien Helleu <flashcode@flashtux.org>2023-10-19 23:38:28 +0200
commita88b8f7ed21ab796a7b041a138bc0f4fe2bba06a (patch)
tree860bb39cb3349f3ba2acaf97be6a07a9b21af330 /src/plugins/irc
parent1896c50c116919db882c40b778aa887035f5c11b (diff)
downloadweechat-a88b8f7ed21ab796a7b041a138bc0f4fe2bba06a.zip
irc: revert compute of nick colors to case sensitive way, deprecate again IRC nick color infos (issue #194, issue #2032)
Diffstat (limited to 'src/plugins/irc')
-rw-r--r--src/plugins/irc/irc-config.c3
-rw-r--r--src/plugins/irc/irc-ctcp.c4
-rw-r--r--src/plugins/irc/irc-info.c56
-rw-r--r--src/plugins/irc/irc-nick.c49
-rw-r--r--src/plugins/irc/irc-nick.h9
-rw-r--r--src/plugins/irc/irc-protocol.c18
6 files changed, 33 insertions, 106 deletions
diff --git a/src/plugins/irc/irc-config.c b/src/plugins/irc/irc-config.c
index 44e03b701..7da53f06a 100644
--- a/src/plugins/irc/irc-config.c
+++ b/src/plugins/irc/irc-config.c
@@ -248,8 +248,7 @@ irc_config_compute_nick_colors ()
{
if (ptr_nick->color)
free (ptr_nick->color);
- ptr_nick->color = irc_nick_find_color (ptr_server,
- ptr_nick->name);
+ ptr_nick->color = irc_nick_find_color (ptr_nick->name);
}
}
if (ptr_channel->pv_remote_nick_color)
diff --git a/src/plugins/irc/irc-ctcp.c b/src/plugins/irc/irc-ctcp.c
index a1423d654..8e0952bc8 100644
--- a/src/plugins/irc/irc-ctcp.c
+++ b/src/plugins/irc/irc-ctcp.c
@@ -1384,7 +1384,7 @@ irc_ctcp_recv (struct t_irc_protocol_ctxt *ctxt,
if (ptr_nick)
nick_color = strdup (ptr_nick->color);
else if (ctxt->nick)
- nick_color = irc_nick_find_color (ctxt->server, ctxt->nick);
+ nick_color = irc_nick_find_color (ctxt->nick);
else
nick_color = strdup (IRC_COLOR_CHAT_NICK);
if ((ctxt->num_params > 0)
@@ -1477,7 +1477,7 @@ irc_ctcp_recv (struct t_irc_protocol_ctxt *ctxt,
weechat_prefix ("action"),
(ctxt->nick_is_me) ?
IRC_COLOR_CHAT_NICK_SELF : irc_nick_color_for_pv (
- ctxt->server, ptr_channel, ctxt->nick),
+ ptr_channel, ctxt->nick),
ctxt->nick,
(pos_args) ? IRC_COLOR_RESET : "",
(pos_args) ? " " : "",
diff --git a/src/plugins/irc/irc-info.c b/src/plugins/irc/irc-info.c
index ebd0265cd..a95d95f1f 100644
--- a/src/plugins/irc/irc-info.c
+++ b/src/plugins/irc/irc-info.c
@@ -197,10 +197,6 @@ irc_info_info_irc_nick_color_cb (const void *pointer, void *data,
const char *info_name,
const char *arguments)
{
- char *pos_comma, *server;
- const char *pos_nick;
- struct t_irc_server *ptr_server;
-
/* make C compiler happy */
(void) pointer;
(void) data;
@@ -209,21 +205,7 @@ irc_info_info_irc_nick_color_cb (const void *pointer, void *data,
if (!arguments || !arguments[0])
return NULL;
- ptr_server = NULL;
- pos_nick = arguments;
- pos_comma = strchr (arguments, ',');
- if (pos_comma)
- {
- pos_nick = pos_comma + 1;
- server = weechat_strndup (arguments, pos_comma - arguments);
- if (server)
- {
- ptr_server = irc_server_search (server);
- free (server);
- }
- }
-
- return irc_nick_find_color (ptr_server, pos_nick);
+ return irc_nick_find_color (arguments);
}
/*
@@ -235,10 +217,6 @@ irc_info_info_irc_nick_color_name_cb (const void *pointer, void *data,
const char *info_name,
const char *arguments)
{
- char *pos_comma, *server;
- const char *pos_nick;
- struct t_irc_server *ptr_server;
-
/* make C compiler happy */
(void) pointer;
(void) data;
@@ -247,21 +225,7 @@ irc_info_info_irc_nick_color_name_cb (const void *pointer, void *data,
if (!arguments || !arguments[0])
return NULL;
- ptr_server = NULL;
- pos_nick = arguments;
- pos_comma = strchr (arguments, ',');
- if (pos_comma)
- {
- pos_nick = pos_comma + 1;
- server = weechat_strndup (arguments, pos_comma - arguments);
- if (server)
- {
- ptr_server = irc_server_search (server);
- free (server);
- }
- }
-
- return irc_nick_find_color_name (ptr_server, pos_nick);
+ return irc_nick_find_color_name (arguments);
}
/*
@@ -1259,19 +1223,15 @@ irc_info_init ()
&irc_info_info_irc_nick_from_host_cb, NULL, NULL);
weechat_hook_info (
"irc_nick_color",
- N_("get nick color code, ignoring case (this calls the info "
- "\"nick_color_ignore_case\" with appropriate range, according "
- "to the value of CASEMAPPING on the server, "
- "defaulting to \"rfc1459\" if the server is not given)"),
- N_("server,nickname (server is optional)"),
+ N_("get nick color code "
+ "(*deprecated* since version 1.5, replaced by \"nick_color\")"),
+ N_("nickname"),
&irc_info_info_irc_nick_color_cb, NULL, NULL);
weechat_hook_info (
"irc_nick_color_name",
- N_("get nick color name, ignoring case (this calls the info "
- "\"nick_color_name_ignore_case\" with appropriate range, according "
- "to the value of CASEMAPPING on the server, "
- "defaulting to \"rfc1459\" if the server is not given)"),
- N_("server,nickname (server is optional)"),
+ N_("get nick color name "
+ "(*deprecated* since version 1.5, replaced by \"nick_color_name\")"),
+ N_("nickname"),
&irc_info_info_irc_nick_color_name_cb, NULL, NULL);
weechat_hook_info (
"irc_buffer",
diff --git a/src/plugins/irc/irc-nick.c b/src/plugins/irc/irc-nick.c
index b56666ce2..1426ca10d 100644
--- a/src/plugins/irc/irc-nick.c
+++ b/src/plugins/irc/irc-nick.c
@@ -139,22 +139,9 @@ irc_nick_is_nick (struct t_irc_server *server, const char *string)
*/
char *
-irc_nick_find_color (struct t_irc_server *server, const char *nickname)
+irc_nick_find_color (const char *nickname)
{
- char str_args[4096];
- int casemapping, range;
-
- casemapping = (server) ? server->casemapping : -1;
- if ((casemapping < 0) || (casemapping >= IRC_SERVER_NUM_CASEMAPPING))
- casemapping = IRC_SERVER_CASEMAPPING_RFC1459;
- range = irc_server_casemapping_range[casemapping];
-
- snprintf (str_args, sizeof (str_args),
- "%s;%d",
- (nickname) ? nickname : "",
- range);
-
- return weechat_info_get ("nick_color_ignore_case", str_args);
+ return weechat_info_get ("nick_color", nickname);
}
/*
@@ -164,22 +151,9 @@ irc_nick_find_color (struct t_irc_server *server, const char *nickname)
*/
char *
-irc_nick_find_color_name (struct t_irc_server *server, const char *nickname)
+irc_nick_find_color_name (const char *nickname)
{
- char str_args[4096];
- int casemapping, range;
-
- casemapping = (server) ? server->casemapping : -1;
- if ((casemapping < 0) || (casemapping >= IRC_SERVER_NUM_CASEMAPPING))
- casemapping = IRC_SERVER_CASEMAPPING_RFC1459;
- range = irc_server_casemapping_range[casemapping];
-
- snprintf (str_args, sizeof (str_args),
- "%s;%d",
- (nickname) ? nickname: "",
- range);
-
- return weechat_info_get ("nick_color_name_ignore_case", str_args);
+ return weechat_info_get ("nick_color_name", nickname);
}
/*
@@ -422,7 +396,7 @@ irc_nick_get_color_for_nicklist (struct t_irc_server *server,
if (irc_server_strcasecmp (server, nick->name, server->nick) == 0)
return strdup (nick_color_self);
else
- return irc_nick_find_color_name (server, nick->name);
+ return irc_nick_find_color_name (nick->name);
}
return strdup (nick_color_bar_fg);
@@ -620,7 +594,7 @@ irc_nick_new (struct t_irc_server *server, struct t_irc_channel *channel,
if (irc_server_strcasecmp (server, new_nick->name, server->nick) == 0)
new_nick->color = strdup (IRC_COLOR_CHAT_NICK_SELF);
else
- new_nick->color = irc_nick_find_color (server, new_nick->name);
+ new_nick->color = irc_nick_find_color (new_nick->name);
/* add nick to end of list */
new_nick->prev_nick = channel->last_nick;
@@ -669,7 +643,7 @@ irc_nick_change (struct t_irc_server *server, struct t_irc_channel *channel,
if (nick_is_me)
nick->color = strdup (IRC_COLOR_CHAT_NICK_SELF);
else
- nick->color = irc_nick_find_color (server, nick->name);
+ nick->color = irc_nick_find_color (nick->name);
/* add nick in nicklist */
irc_nick_nicklist_add (server, channel, nick);
@@ -1011,7 +985,7 @@ irc_nick_as_prefix (struct t_irc_server *server, struct t_irc_nick *nick,
else if (nick)
color = strdup (nick->color);
else if (nickname)
- color = irc_nick_find_color (server, nickname);
+ color = irc_nick_find_color (nickname);
else
color = strdup (IRC_COLOR_CHAT_NICK);
@@ -1054,7 +1028,7 @@ irc_nick_color_for_msg (struct t_irc_server *server, int server_message,
{
return IRC_COLOR_CHAT_NICK_SELF;
}
- color_found = irc_nick_find_color (server, nickname);
+ color_found = irc_nick_find_color (nickname);
index_color = (index_color + 1) % 16;
snprintf (color[index_color], sizeof (color[index_color]),
"%s",
@@ -1072,13 +1046,12 @@ irc_nick_color_for_msg (struct t_irc_server *server, int server_message,
*/
const char *
-irc_nick_color_for_pv (struct t_irc_server *server,
- struct t_irc_channel *channel, const char *nickname)
+irc_nick_color_for_pv (struct t_irc_channel *channel, const char *nickname)
{
if (weechat_config_boolean (irc_config_look_color_pv_nick_like_channel))
{
if (!channel->pv_remote_nick_color)
- channel->pv_remote_nick_color = irc_nick_find_color (server, nickname);
+ channel->pv_remote_nick_color = irc_nick_find_color (nickname);
if (channel->pv_remote_nick_color)
return channel->pv_remote_nick_color;
}
diff --git a/src/plugins/irc/irc-nick.h b/src/plugins/irc/irc-nick.h
index 8d7ec911b..17c128165 100644
--- a/src/plugins/irc/irc-nick.h
+++ b/src/plugins/irc/irc-nick.h
@@ -49,10 +49,8 @@ struct t_irc_nick
extern int irc_nick_valid (struct t_irc_channel *channel,
struct t_irc_nick *nick);
extern int irc_nick_is_nick (struct t_irc_server *server, const char *string);
-extern char *irc_nick_find_color (struct t_irc_server *server,
- const char *nickname);
-extern char *irc_nick_find_color_name (struct t_irc_server *server,
- const char *nickname);
+extern char *irc_nick_find_color (const char *nickname);
+extern char *irc_nick_find_color_name (const char *nickname);
extern void irc_nick_set_host (struct t_irc_nick *nick, const char *host);
extern int irc_nick_is_op_or_higher (struct t_irc_server *server,
struct t_irc_nick *nick);
@@ -103,8 +101,7 @@ extern const char *irc_nick_color_for_msg (struct t_irc_server *server,
int server_message,
struct t_irc_nick *nick,
const char *nickname);
-extern const char * irc_nick_color_for_pv (struct t_irc_server *server,
- struct t_irc_channel *channel,
+extern const char * irc_nick_color_for_pv (struct t_irc_channel *channel,
const char *nickname);
extern char *irc_nick_default_ban_mask (struct t_irc_nick *nick);
extern struct t_hdata *irc_nick_hdata_nick_cb (const void *pointer,
diff --git a/src/plugins/irc/irc-protocol.c b/src/plugins/irc/irc-protocol.c
index 357d84da9..3d4888f5a 100644
--- a/src/plugins/irc/irc-protocol.c
+++ b/src/plugins/irc/irc-protocol.c
@@ -2281,8 +2281,8 @@ IRC_PROTOCOL_CALLBACK(nick)
{
if (weechat_config_boolean (irc_config_look_color_pv_nick_like_channel))
{
- old_color = irc_nick_find_color (ctxt->server, ctxt->nick);
- new_color = irc_nick_find_color (ctxt->server, ctxt->params[0]);
+ old_color = irc_nick_find_color (ctxt->nick);
+ new_color = irc_nick_find_color (ctxt->params[0]);
}
else
{
@@ -3144,7 +3144,6 @@ IRC_PROTOCOL_CALLBACK(privmsg)
else
{
color = irc_nick_find_color_name (
- ctxt->server,
(ptr_nick) ? ptr_nick->name : ctxt->nick);
str_color = irc_color_for_tags (color);
if (color)
@@ -3257,7 +3256,7 @@ IRC_PROTOCOL_CALLBACK(privmsg)
{
if (weechat_config_boolean (irc_config_look_color_pv_nick_like_channel))
{
- color = irc_nick_find_color_name (ctxt->server, ctxt->nick);
+ color = irc_nick_find_color_name (ctxt->nick);
str_color = irc_color_for_tags (color);
if (color)
free (color);
@@ -3310,8 +3309,7 @@ IRC_PROTOCOL_CALLBACK(privmsg)
irc_nick_as_prefix (
ctxt->server, NULL, ctxt->nick,
(ctxt->nick_is_me) ?
- IRC_COLOR_CHAT_NICK_SELF : irc_nick_color_for_pv (ctxt->server,
- ptr_channel,
+ IRC_COLOR_CHAT_NICK_SELF : irc_nick_color_for_pv (ptr_channel,
ctxt->nick)),
(msg_args2) ? msg_args2 : msg_args);
}
@@ -3404,7 +3402,7 @@ IRC_PROTOCOL_CALLBACK(quit)
_("%s%s%s%s%s%s%s%s%s%s has quit %s(%s%s%s)"),
weechat_prefix ("quit"),
(ptr_channel->type == IRC_CHANNEL_TYPE_PRIVATE) ?
- irc_nick_color_for_pv (ctxt->server, ptr_channel, ctxt->nick) :
+ irc_nick_color_for_pv (ptr_channel, ctxt->nick) :
irc_nick_color_for_msg (ctxt->server, 1, ptr_nick, ctxt->nick),
ctxt->nick,
IRC_COLOR_CHAT_DELIMITERS,
@@ -3438,7 +3436,7 @@ IRC_PROTOCOL_CALLBACK(quit)
_("%s%s%s%s%s%s%s%s%s%s has quit"),
weechat_prefix ("quit"),
(ptr_channel->type == IRC_CHANNEL_TYPE_PRIVATE) ?
- irc_nick_color_for_pv (ctxt->server, ptr_channel, ctxt->nick) :
+ irc_nick_color_for_pv (ptr_channel, ctxt->nick) :
irc_nick_color_for_msg (ctxt->server, 1, ptr_nick, ctxt->nick),
ctxt->nick,
IRC_COLOR_CHAT_DELIMITERS,
@@ -6255,7 +6253,7 @@ IRC_PROTOCOL_CALLBACK(353)
}
else
{
- color = irc_nick_find_color (ctxt->server, nickname);
+ color = irc_nick_find_color (nickname);
weechat_string_dyn_concat (str_nicks, color, -1);
if (color)
free (color);
@@ -6543,7 +6541,7 @@ irc_protocol_get_string_channel_nicks (struct t_irc_server *server,
}
else
{
- color = irc_nick_find_color (server, nickname);
+ color = irc_nick_find_color (nickname);
weechat_string_dyn_concat (str_nicks, color, -1);
if (color)
free (color);