1
0
mirror of https://github.com/weechat/weechat.git synced 2026-07-05 09:13:14 +02:00

Fix bug with nick prefix '*' (chan founder) on some IRC servers (bug #29890)

This commit is contained in:
Sebastien Helleu
2010-05-29 09:18:19 +02:00
parent f93eec488e
commit b36ed39388
11 changed files with 131 additions and 72 deletions
+3 -1
View File
@@ -1,7 +1,7 @@
WeeChat ChangeLog
=================
FlashCode <flashcode@flashtux.org>
v0.3.3-dev, 2010-05-26
v0.3.3-dev, 2010-05-29
Version 0.3.3 (under dev!)
@@ -22,6 +22,8 @@ Version 0.3.3 (under dev!)
* irc: add new options irc.network.autoreconnect_delay_growing and
irc.network.autoreconnect_delay_max (task #10338)
* irc: add new option weechat.color.status_name_ssl (task #10339)
* irc: fix bug with nick prefix '*' (chan founder) on some IRC servers
(bug #29890)
* irc: fix bug with option irc.network.lag_check when value is 0 (zero)
* irc: try other nick when connecting to server and receiving message 437
(nick unavailable)
+2 -2
View File
@@ -434,8 +434,8 @@ irc_bar_item_input_prompt (void *data, struct t_gui_bar_item *item,
{
prefix[0] = '\0';
prefix[1] = '\0';
irc_nick_get_gui_infos (ptr_nick, &prefix[0], &prefix_color,
NULL, NULL);
irc_nick_get_gui_infos (server, ptr_nick,
&prefix[0], &prefix_color, NULL, NULL);
if (prefix[0] != ' ')
{
snprintf (str_prefix_color, sizeof (str_prefix_color),
+1 -1
View File
@@ -759,7 +759,7 @@ irc_channel_free (struct t_irc_server *server, struct t_irc_channel *channel)
free (channel->modes);
if (channel->key)
free (channel->key);
irc_nick_free_all (channel);
irc_nick_free_all (server, channel);
if (channel->away_message)
free (channel->away_message);
if (channel->pv_remote_nick_color)
+2 -1
View File
@@ -61,7 +61,8 @@ irc_input_user_message_display (struct t_gui_buffer *buffer, const char *text)
weechat_printf_tags (buffer,
irc_protocol_tags ("privmsg", "no_highlight"),
"%s%s",
irc_nick_as_prefix ((ptr_nick) ? ptr_nick : NULL,
irc_nick_as_prefix (ptr_server,
(ptr_nick) ? ptr_nick : NULL,
(ptr_nick) ? NULL : ptr_server->nick,
IRC_COLOR_CHAT_NICK_SELF),
(text_decoded) ? text_decoded : text);
+63 -20
View File
@@ -124,7 +124,7 @@ irc_mode_channel_set (struct t_irc_server *server,
case 'a': /* channel admin (unrealircd specific flag) */
ptr_arg = ((current_arg >= 0) && (current_arg < argc)) ?
argv[current_arg] : NULL;
mode = irc_mode_get_nick_prefix (server, "a", '~');
mode = irc_mode_get_nick_attr (server, "a", '~');
if (mode >= 0)
{
irc_mode_channel_set_nick (server, channel, ptr_arg,
@@ -140,7 +140,7 @@ irc_mode_channel_set (struct t_irc_server *server,
case 'h': /* half-op */
ptr_arg = ((current_arg >= 0) && (current_arg < argc)) ?
argv[current_arg] : NULL;
mode = irc_mode_get_nick_prefix (server, "h", '%');
mode = irc_mode_get_nick_attr (server, "h", '%');
if (mode >= 0)
{
irc_mode_channel_set_nick (server, channel, ptr_arg,
@@ -180,7 +180,7 @@ irc_mode_channel_set (struct t_irc_server *server,
case 'o': /* op */
ptr_arg = ((current_arg >= 0) && (current_arg < argc)) ?
argv[current_arg] : NULL;
mode = irc_mode_get_nick_prefix (server, "o", '@');
mode = irc_mode_get_nick_attr (server, "o", '@');
if (mode >= 0)
{
irc_mode_channel_set_nick (server, channel, ptr_arg,
@@ -191,7 +191,7 @@ irc_mode_channel_set (struct t_irc_server *server,
case 'q': /* channel owner (unrealircd specific flag) */
ptr_arg = ((current_arg >= 0) && (current_arg < argc)) ?
argv[current_arg] : NULL;
mode = irc_mode_get_nick_prefix (server, "q", '~');
mode = irc_mode_get_nick_attr (server, "q", '~');
if (mode >= 0)
{
irc_mode_channel_set_nick (server, channel, ptr_arg,
@@ -202,7 +202,7 @@ irc_mode_channel_set (struct t_irc_server *server,
case 'u': /* channel user */
ptr_arg = ((current_arg >= 0) && (current_arg < argc)) ?
argv[current_arg] : NULL;
mode = irc_mode_get_nick_prefix (server, "u", '-');
mode = irc_mode_get_nick_attr (server, "u", '-');
if (mode >= 0)
{
irc_mode_channel_set_nick (server, channel, ptr_arg,
@@ -213,7 +213,7 @@ irc_mode_channel_set (struct t_irc_server *server,
case 'v': /* voice */
ptr_arg = ((current_arg >= 0) && (current_arg < argc)) ?
argv[current_arg] : NULL;
mode = irc_mode_get_nick_prefix (server, "v", '+');
mode = irc_mode_get_nick_attr (server, "v", '+');
if (mode >= 0)
{
irc_mode_channel_set_nick (server, channel, ptr_arg,
@@ -328,12 +328,12 @@ irc_mode_user_set (struct t_irc_server *server, const char *modes)
}
/*
* irc_mode_get_prefix_value: get internal value for prefix
* return -1 if prefix is unknown
* irc_mode_prefix_to_nick_attr: get nick attribute for prefix
* return -1 if prefix is unknown
*/
int
irc_mode_get_prefix_value (char prefix)
irc_mode_prefix_to_nick_attr (char prefix)
{
switch (prefix)
{
@@ -341,6 +341,8 @@ irc_mode_get_prefix_value (char prefix)
return IRC_NICK_OP;
case '~': /* channel owner */
return IRC_NICK_CHANOWNER;
case '*': /* channel owner */
return IRC_NICK_CHANOWNER;
case '&': /* channel admin */
return IRC_NICK_CHANADMIN;
case '!': /* channel admin (2) */
@@ -357,16 +359,16 @@ irc_mode_get_prefix_value (char prefix)
}
/*
* irc_mode_get_nick_prefix: return nick prefix, if allowed by server
* return -1 if not allowed
* for example :
* IRC: 005 (...) PREFIX=(ov)@+
* => allowed prefixes: @+
* irc_mode_get_nick_attr: return nick attribute for mode, if allowed by server
* return -1 if not allowed
* for example :
* IRC: 005 (...) PREFIX=(ohv)@%+
* => allowed modes: ohv
*/
int
irc_mode_get_nick_prefix (struct t_irc_server *server, char *mode,
char prefix)
irc_mode_get_nick_attr (struct t_irc_server *server, char *mode,
char prefix)
{
char str[2], *pos, *ptr_prefixes, *pos_mode;
int index;
@@ -376,10 +378,10 @@ irc_mode_get_nick_prefix (struct t_irc_server *server, char *mode,
{
str[0] = prefix;
str[1] = '\0';
pos = strpbrk (str, IRC_NICK_DEFAULT_PREFIXES_LIST);
pos = strpbrk (str, IRC_MODE_NICK_DEFAULT_PREFIXES_LIST);
if (!pos)
return -1;
return irc_mode_get_prefix_value (pos[0]);
return irc_mode_prefix_to_nick_attr (pos[0]);
}
/* find start of prefixes, after "(...)" */
@@ -396,7 +398,7 @@ irc_mode_get_nick_prefix (struct t_irc_server *server, char *mode,
index = pos_mode - server->prefix - 1;
if (pos_mode && (index < (int)strlen (ptr_prefixes)))
{
return irc_mode_get_prefix_value (ptr_prefixes[index]);
return irc_mode_prefix_to_nick_attr (ptr_prefixes[index]);
}
}
}
@@ -408,5 +410,46 @@ irc_mode_get_nick_prefix (struct t_irc_server *server, char *mode,
if (!pos)
return -1;
return irc_mode_get_prefix_value (pos[0]);
return irc_mode_prefix_to_nick_attr (pos[0]);
}
/*
* irc_mode_get_prefix: return prefix for mode
* for example if prefixes are:
* IRC: 005 (...) PREFIX=(ohv)@%+
* 'o' will return '@'
* 'h' will return '%'
* 'v' will return '+'
*/
char
irc_mode_get_prefix (struct t_irc_server *server, char mode,
char default_prefix)
{
char *ptr_prefixes, *pos_mode;
int index;
if (!server->prefix)
return default_prefix;
/* find start of prefixes, after "(...)" */
ptr_prefixes = strchr (server->prefix, ')');
if (ptr_prefixes)
ptr_prefixes++;
if (!ptr_prefixes || !ptr_prefixes[0])
return default_prefix;
/* search prefix for mode */
pos_mode = strchr (server->prefix + 1, mode);
if (pos_mode && (pos_mode < ptr_prefixes))
{
index = pos_mode - server->prefix - 1;
if (pos_mode && (index < (int)strlen (ptr_prefixes)))
{
return ptr_prefixes[index];
}
}
return default_prefix;
}
+6 -2
View File
@@ -20,6 +20,8 @@
#ifndef __WEECHAT_IRC_MODE_H
#define __WEECHAT_IRC_MODE_H 1
#define IRC_MODE_NICK_DEFAULT_PREFIXES_LIST "@%+~*&!-"
struct t_irc_server;
struct t_irc_channel;
@@ -27,7 +29,9 @@ extern int irc_mode_channel_set (struct t_irc_server *server,
struct t_irc_channel *channel,
const char *modes);
extern void irc_mode_user_set (struct t_irc_server *server, const char *modes);
extern int irc_mode_get_nick_prefix (struct t_irc_server *server, char *mode,
char prefix);
extern int irc_mode_get_nick_attr (struct t_irc_server *server, char *mode,
char prefix);
extern char irc_mode_get_prefix (struct t_irc_server *server, char mode,
char default_prefix);
#endif /* irc-mode.h */
+26 -22
View File
@@ -31,6 +31,7 @@
#include "irc-nick.h"
#include "irc-color.h"
#include "irc-config.h"
#include "irc-mode.h"
#include "irc-server.h"
#include "irc-channel.h"
@@ -121,7 +122,8 @@ irc_nick_find_color (const char *nickname)
*/
void
irc_nick_get_gui_infos (struct t_irc_nick *nick,
irc_nick_get_gui_infos (struct t_irc_server *server,
struct t_irc_nick *nick,
char *prefix, int *prefix_color,
struct t_gui_buffer *buffer,
struct t_gui_nick_group **group)
@@ -129,7 +131,7 @@ irc_nick_get_gui_infos (struct t_irc_nick *nick,
if (nick->flags & IRC_NICK_CHANOWNER)
{
if (prefix)
prefix[0] = '~';
prefix[0] = irc_mode_get_prefix (server, 'q', '~');
if (prefix_color)
*prefix_color = 1;
if (buffer && group)
@@ -139,7 +141,7 @@ irc_nick_get_gui_infos (struct t_irc_nick *nick,
else if (nick->flags & IRC_NICK_CHANADMIN)
{
if (prefix)
prefix[0] = '&';
prefix[0] = irc_mode_get_prefix (server, 'a', '&');
if (prefix_color)
*prefix_color = 1;
if (buffer && group)
@@ -149,7 +151,7 @@ irc_nick_get_gui_infos (struct t_irc_nick *nick,
else if (nick->flags & IRC_NICK_CHANADMIN2)
{
if (prefix)
prefix[0] = '!';
prefix[0] = irc_mode_get_prefix (server, 'a', '!');
if (prefix_color)
*prefix_color = 1;
if (buffer && group)
@@ -159,7 +161,7 @@ irc_nick_get_gui_infos (struct t_irc_nick *nick,
else if (nick->flags & IRC_NICK_OP)
{
if (prefix)
prefix[0] = '@';
prefix[0] = irc_mode_get_prefix (server, 'o', '@');
if (prefix_color)
*prefix_color = 1;
if (buffer && group)
@@ -169,7 +171,7 @@ irc_nick_get_gui_infos (struct t_irc_nick *nick,
else if (nick->flags & IRC_NICK_HALFOP)
{
if (prefix)
prefix[0] = '%';
prefix[0] = irc_mode_get_prefix (server, 'h', '%');
if (prefix_color)
*prefix_color = 2;
if (buffer && group)
@@ -179,7 +181,7 @@ irc_nick_get_gui_infos (struct t_irc_nick *nick,
else if (nick->flags & IRC_NICK_VOICE)
{
if (prefix)
prefix[0] = '+';
prefix[0] = irc_mode_get_prefix (server, 'v', '+');
if (prefix_color)
*prefix_color = 3;
if (buffer && group)
@@ -189,7 +191,7 @@ irc_nick_get_gui_infos (struct t_irc_nick *nick,
else if (nick->flags & IRC_NICK_CHANUSER)
{
if (prefix)
prefix[0] = '-';
prefix[0] = irc_mode_get_prefix (server, 'u', '-');
if (prefix_color)
*prefix_color = 4;
if (buffer && group)
@@ -228,7 +230,7 @@ irc_nick_new (struct t_irc_server *server, struct t_irc_channel *channel,
if (ptr_nick)
{
/* remove old nick from nicklist */
irc_nick_get_gui_infos (ptr_nick, prefix,
irc_nick_get_gui_infos (server, ptr_nick, prefix,
&prefix_color, channel->buffer, &ptr_group);
weechat_nicklist_remove_nick (channel->buffer,
weechat_nicklist_search_nick (channel->buffer,
@@ -248,7 +250,7 @@ irc_nick_new (struct t_irc_server *server, struct t_irc_channel *channel,
/* add new nick in nicklist */
prefix[0] = ' ';
prefix[1] = '\0';
irc_nick_get_gui_infos (ptr_nick, prefix,
irc_nick_get_gui_infos (server, ptr_nick, prefix,
&prefix_color, channel->buffer, &ptr_group);
snprintf (str_prefix_color, sizeof (str_prefix_color),
"weechat.color.nicklist_prefix%d",
@@ -299,7 +301,7 @@ irc_nick_new (struct t_irc_server *server, struct t_irc_channel *channel,
/* add nick to buffer nicklist */
prefix[0] = ' ';
prefix[1] = '\0';
irc_nick_get_gui_infos (new_nick, prefix, &prefix_color,
irc_nick_get_gui_infos (server, new_nick, prefix, &prefix_color,
channel->buffer, &ptr_group);
snprintf (str_prefix_color, sizeof (str_prefix_color),
"weechat.color.nicklist_prefix%d",
@@ -327,7 +329,7 @@ irc_nick_change (struct t_irc_server *server, struct t_irc_channel *channel,
char prefix[2], str_prefix_color[64];
/* remove nick from nicklist */
irc_nick_get_gui_infos (nick, prefix, &prefix_color,
irc_nick_get_gui_infos (server, nick, prefix, &prefix_color,
channel->buffer, &ptr_group);
weechat_nicklist_remove_nick (channel->buffer,
weechat_nicklist_search_nick (channel->buffer,
@@ -351,7 +353,7 @@ irc_nick_change (struct t_irc_server *server, struct t_irc_channel *channel,
/* add nick in nicklist */
prefix[0] = ' ';
prefix[1] = '\0';
irc_nick_get_gui_infos (nick, prefix, &prefix_color,
irc_nick_get_gui_infos (server, nick, prefix, &prefix_color,
channel->buffer, &ptr_group);
snprintf (str_prefix_color, sizeof (str_prefix_color),
"weechat.color.nicklist_prefix%d",
@@ -376,7 +378,7 @@ irc_nick_set (struct t_irc_server *server, struct t_irc_channel *channel,
struct t_gui_nick_group *ptr_group;
/* remove nick from nicklist */
irc_nick_get_gui_infos (nick, prefix, &prefix_color,
irc_nick_get_gui_infos (server, nick, prefix, &prefix_color,
channel->buffer, &ptr_group);
weechat_nicklist_remove_nick (channel->buffer,
weechat_nicklist_search_nick (channel->buffer,
@@ -389,7 +391,7 @@ irc_nick_set (struct t_irc_server *server, struct t_irc_channel *channel,
/* add nick in nicklist */
prefix[0] = ' ';
prefix[1] = '\0';
irc_nick_get_gui_infos (nick, prefix, &prefix_color,
irc_nick_get_gui_infos (server, nick, prefix, &prefix_color,
channel->buffer, &ptr_group);
snprintf (str_prefix_color, sizeof (str_prefix_color),
"weechat.color.nicklist_prefix%d",
@@ -409,7 +411,8 @@ irc_nick_set (struct t_irc_server *server, struct t_irc_channel *channel,
*/
void
irc_nick_free (struct t_irc_channel *channel, struct t_irc_nick *nick)
irc_nick_free (struct t_irc_server *server, struct t_irc_channel *channel,
struct t_irc_nick *nick)
{
struct t_irc_nick *new_nicks;
char prefix;
@@ -420,7 +423,7 @@ irc_nick_free (struct t_irc_channel *channel, struct t_irc_nick *nick)
return;
/* remove nick from nicklist */
irc_nick_get_gui_infos (nick, &prefix, &prefix_color,
irc_nick_get_gui_infos (server, nick, &prefix, &prefix_color,
channel->buffer, &ptr_group);
weechat_nicklist_remove_nick (channel->buffer,
weechat_nicklist_search_nick (channel->buffer,
@@ -460,7 +463,7 @@ irc_nick_free (struct t_irc_channel *channel, struct t_irc_nick *nick)
*/
void
irc_nick_free_all (struct t_irc_channel *channel)
irc_nick_free_all (struct t_irc_server *server, struct t_irc_channel *channel)
{
if (!channel)
return;
@@ -468,7 +471,7 @@ irc_nick_free_all (struct t_irc_channel *channel)
/* remove all nicks for the channel */
while (channel->nicks)
{
irc_nick_free (channel, channel->nicks);
irc_nick_free (server, channel, channel->nicks);
}
/* sould be zero, but prevent any bug :D */
@@ -560,8 +563,8 @@ irc_nick_set_away (struct t_irc_server *server, struct t_irc_channel *channel,
*/
char *
irc_nick_as_prefix (struct t_irc_nick *nick, const char *nickname,
const char *force_color)
irc_nick_as_prefix (struct t_irc_server *server, struct t_irc_nick *nick,
const char *nickname, const char *force_color)
{
static char result[256];
char prefix[2], str_prefix_color[64];
@@ -573,7 +576,8 @@ irc_nick_as_prefix (struct t_irc_nick *nick, const char *nickname,
{
if (nick)
{
irc_nick_get_gui_infos (nick, &prefix[0], &prefix_color, NULL, NULL);
irc_nick_get_gui_infos (server, nick, &prefix[0], &prefix_color,
NULL, NULL);
if ((prefix[0] == ' ')
&& !weechat_config_boolean (weechat_config_get ("weechat.look.nickmode_empty")))
prefix[0] = '\0';
+10 -6
View File
@@ -20,8 +20,7 @@
#ifndef __WEECHAT_IRC_NICK_H
#define __WEECHAT_IRC_NICK_H 1
#define IRC_NICK_DEFAULT_PREFIXES_LIST "@%+~&!-"
#define IRC_NICK_VALID_CHARS "abcdefghijklmnopqrstuvwxyzABCDEFGHI" \
#define IRC_NICK_VALID_CHARS "abcdefghijklmnopqrstuvwxyzABCDEFGHI" \
"JKLMNOPQRSTUVWXYZ0123456789-[]\\`_^{|}"
#define IRC_NICK_CHANOWNER 1
@@ -71,7 +70,8 @@ extern int irc_nick_valid (struct t_irc_channel *channel,
struct t_irc_nick *nick);
extern int irc_nick_is_nick (const char *string);
extern const char *irc_nick_find_color (const char *nickname);
extern void irc_nick_get_gui_infos (struct t_irc_nick *nick,
extern void irc_nick_get_gui_infos (struct t_irc_server *server,
struct t_irc_nick *nick,
char *prefix, int *prefix_color,
struct t_gui_buffer *buffer,
struct t_gui_nick_group **group);
@@ -92,9 +92,11 @@ extern void irc_nick_change (struct t_irc_server *server,
extern void irc_nick_set (struct t_irc_server *server,
struct t_irc_channel *channel,
struct t_irc_nick *nick, int set, int flag);
extern void irc_nick_free (struct t_irc_channel *channel,
extern void irc_nick_free (struct t_irc_server *server,
struct t_irc_channel *channel,
struct t_irc_nick *nick);
extern void irc_nick_free_all (struct t_irc_channel *channel);
extern void irc_nick_free_all (struct t_irc_server *server,
struct t_irc_channel *channel);
extern struct t_irc_nick *irc_nick_search (struct t_irc_channel *channel,
const char *nickname);
extern void irc_nick_count (struct t_irc_channel *channel, int *total,
@@ -103,7 +105,9 @@ extern void irc_nick_count (struct t_irc_channel *channel, int *total,
extern void irc_nick_set_away (struct t_irc_server *server,
struct t_irc_channel *channel,
struct t_irc_nick *nick, int is_away);
extern char *irc_nick_as_prefix (struct t_irc_nick *nick, const char *nickname,
extern char *irc_nick_as_prefix (struct t_irc_server *server,
struct t_irc_nick *nick,
const char *nickname,
const char *force_color);
extern const char * irc_nick_color_for_pv (struct t_irc_channel *channel,
const char *nickname);
+15 -12
View File
@@ -687,7 +687,7 @@ IRC_PROTOCOL_CALLBACK(kick)
* my nick was kicked => free all nicks, channel is not active any
* more
*/
irc_nick_free_all (ptr_channel);
irc_nick_free_all (server, ptr_channel);
if (IRC_SERVER_OPTION_INTEGER(server, IRC_SERVER_OPTION_AUTOREJOIN))
{
if (IRC_SERVER_OPTION_INTEGER(server, IRC_SERVER_OPTION_AUTOREJOIN_DELAY) == 0)
@@ -713,7 +713,7 @@ IRC_PROTOCOL_CALLBACK(kick)
* nick
*/
if (ptr_nick_kicked)
irc_nick_free (ptr_channel, ptr_nick_kicked);
irc_nick_free (server, ptr_channel, ptr_nick_kicked);
}
return WEECHAT_RC_OK;
@@ -782,7 +782,7 @@ IRC_PROTOCOL_CALLBACK(kill)
* my nick was killed => free all nicks, channel is not active any
* more
*/
irc_nick_free_all (ptr_channel);
irc_nick_free_all (server, ptr_channel);
}
else
{
@@ -791,7 +791,7 @@ IRC_PROTOCOL_CALLBACK(kill)
* nick
*/
if (ptr_nick_killed)
irc_nick_free (ptr_channel, ptr_nick_killed);
irc_nick_free (server, ptr_channel, ptr_nick_killed);
}
}
@@ -1096,7 +1096,7 @@ IRC_PROTOCOL_CALLBACK(notice)
irc_protocol_tags (command,
"notify_private"),
"%s%s",
irc_nick_as_prefix (NULL, nick,
irc_nick_as_prefix (server, NULL, nick,
irc_nick_color_for_pv (ptr_channel, nick)),
pos_args);
if ((ptr_channel->type == IRC_CHANNEL_TYPE_PRIVATE)
@@ -1259,7 +1259,7 @@ IRC_PROTOCOL_CALLBACK(part)
/* part request was issued by local client ? */
if (local_part)
{
irc_nick_free_all (ptr_channel);
irc_nick_free_all (server, ptr_channel);
/* cycling ? => rejoin channel immediately */
if (ptr_channel->cycle)
@@ -1291,7 +1291,7 @@ IRC_PROTOCOL_CALLBACK(part)
}
}
else
irc_nick_free (ptr_channel, ptr_nick);
irc_nick_free (server, ptr_channel, ptr_nick);
}
}
@@ -1402,7 +1402,7 @@ IRC_PROTOCOL_CALLBACK(privmsg)
irc_protocol_tags (command,
"notify_message"),
"%s%s",
irc_nick_as_prefix (ptr_nick,
irc_nick_as_prefix (server, ptr_nick,
(ptr_nick) ? NULL : nick,
NULL),
pos_args);
@@ -1470,8 +1470,7 @@ IRC_PROTOCOL_CALLBACK(privmsg)
"notify_private,no_highlight" :
"notify_private"),
"%s%s",
irc_nick_as_prefix (NULL,
nick,
irc_nick_as_prefix (server, NULL, nick,
(nick_is_me) ?
IRC_COLOR_CHAT_NICK_SELF : irc_nick_color_for_pv (ptr_channel, nick)),
pos_args);
@@ -1584,7 +1583,7 @@ IRC_PROTOCOL_CALLBACK(quit)
}
}
if (ptr_nick)
irc_nick_free (ptr_channel, ptr_nick);
irc_nick_free (server, ptr_channel, ptr_nick);
}
}
@@ -3268,7 +3267,7 @@ IRC_PROTOCOL_CALLBACK(353)
{
prefix_found = 0;
if (irc_mode_get_nick_prefix (server, NULL, pos_nick[0]) >= 0)
if (irc_mode_get_nick_attr (server, NULL, pos_nick[0]) >= 0)
{
prefix_found = 1;
switch (pos_nick[0])
@@ -3281,6 +3280,10 @@ IRC_PROTOCOL_CALLBACK(353)
is_chanowner = 1;
color = IRC_COLOR_NICKLIST_PREFIX1;
break;
case '*': /* channel owner */
is_chanowner = 1;
color = IRC_COLOR_NICKLIST_PREFIX1;
break;
case '&': /* channel admin */
is_chanadmin = 1;
color = IRC_COLOR_NICKLIST_PREFIX1;
+1 -1
View File
@@ -2996,7 +2996,7 @@ irc_server_disconnect (struct t_irc_server *server, int reconnect)
for (ptr_channel = server->channels; ptr_channel;
ptr_channel = ptr_channel->next_channel)
{
irc_nick_free_all (ptr_channel);
irc_nick_free_all (server, ptr_channel);
weechat_printf (ptr_channel->buffer,
_("%s%s: disconnected from server"),
"",
+2 -4
View File
@@ -82,10 +82,8 @@ enum t_irc_server_option
weechat_config_string(irc_config_server_default[__index]) \
: weechat_config_string_default(irc_config_server_default[__index])))
#define IRC_SERVER_DEFAULT_PORT 6667
#define IRC_SERVER_DEFAULT_PREFIXES_LIST "@%+~&!-"
#define IRC_SERVER_DEFAULT_NICKS "weechat1,weechat2,weechat3," \
"weechat4,weechat5"
#define IRC_SERVER_DEFAULT_PORT 6667
#define IRC_SERVER_DEFAULT_NICKS "weechat1,weechat2,weechat3,weechat4,weechat5"
#define IRC_SERVER_OUTQUEUE_PRIO_HIGH 1
#define IRC_SERVER_OUTQUEUE_PRIO_LOW 2