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:
@@ -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)
|
||||
|
||||
@@ -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),
|
||||
|
||||
@@ -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)
|
||||
|
||||
@@ -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
@@ -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;
|
||||
}
|
||||
|
||||
@@ -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
@@ -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';
|
||||
|
||||
@@ -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);
|
||||
|
||||
@@ -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;
|
||||
|
||||
@@ -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"),
|
||||
"",
|
||||
|
||||
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user