summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2008-04-19 11:30:15 +0200
committerSebastien Helleu <flashcode@flashtux.org>2008-04-19 11:30:15 +0200
commit30b0e2d7777027384626bdd2a7f1030c329145c7 (patch)
treea5217d5ca4c8a51dd4ef3d2cb804ecf92b7430b0 /src
parent49a9e6f79a3bce96e72b05f884d5f30d7afacb75 (diff)
downloadweechat-30b0e2d7777027384626bdd2a7f1030c329145c7.zip
Fixed output of names on channels (now it's sorted/grouped/colored, like v0.2.6) (bug #22935), added "nicklist" infolist
Diffstat (limited to 'src')
-rw-r--r--src/core/wee-string.c11
-rw-r--r--src/gui/gui-chat.c20
-rw-r--r--src/gui/gui-chat.h2
-rw-r--r--src/gui/gui-color.c33
-rw-r--r--src/gui/gui-color.h3
-rw-r--r--src/gui/gui-nicklist.c6
-rw-r--r--src/plugins/irc/irc-nick.h4
-rw-r--r--src/plugins/irc/irc-protocol.c91
-rw-r--r--src/plugins/irc/irc-server.c11
-rw-r--r--src/plugins/logger/logger.c37
-rw-r--r--src/plugins/plugin-api.c89
-rw-r--r--src/plugins/scripts/script-api.c31
12 files changed, 277 insertions, 61 deletions
diff --git a/src/core/wee-string.c b/src/core/wee-string.c
index 1c6a33669..f3d05be67 100644
--- a/src/core/wee-string.c
+++ b/src/core/wee-string.c
@@ -992,15 +992,20 @@ void
string_iconv_fprintf (FILE *file, char *data, ...)
{
va_list argptr;
- static char buf[4096];
- char *buf2;
+ char *buf, *buf2;
+
+ buf = malloc (128 * 1024);
+ if (!buf)
+ return;
va_start (argptr, data);
- vsnprintf (buf, sizeof (buf) - 1, data, argptr);
+ vsnprintf (buf, 128 * 1024, data, argptr);
va_end (argptr);
buf2 = string_iconv_from_internal (NULL, buf);
fprintf (file, "%s", (buf2) ? buf2 : buf);
+
+ free (buf);
if (buf2)
free (buf2);
}
diff --git a/src/gui/gui-chat.c b/src/gui/gui-chat.c
index 42c08b144..921699d4e 100644
--- a/src/gui/gui-chat.c
+++ b/src/gui/gui-chat.c
@@ -794,7 +794,7 @@ void
gui_chat_printf_date_tags (struct t_gui_buffer *buffer, time_t date,
char *tags, char *message, ...)
{
- char buf[8192];
+ char *buf;
va_list argptr;
time_t date_printed;
int display_time;
@@ -819,8 +819,12 @@ gui_chat_printf_date_tags (struct t_gui_buffer *buffer, time_t date,
return;
}
+ buf = malloc (GUI_CHAT_BUFFER_PRINTF_SIZE);
+ if (!buf)
+ return;
+
va_start (argptr, message);
- vsnprintf (buf, sizeof (buf) - 1, message, argptr);
+ vsnprintf (buf, GUI_CHAT_BUFFER_PRINTF_SIZE, message, argptr);
va_end (argptr);
utf8_normalize (buf, '?');
@@ -896,6 +900,8 @@ gui_chat_printf_date_tags (struct t_gui_buffer *buffer, time_t date,
gui_status_refresh_needed = 1;
}
}
+
+ free (buf);
}
/*
@@ -907,7 +913,7 @@ gui_chat_printf_date_tags (struct t_gui_buffer *buffer, time_t date,
void
gui_chat_printf_y (struct t_gui_buffer *buffer, int y, char *message, ...)
{
- char buf[8192];
+ char *buf;
va_list argptr;
struct t_gui_line *ptr_line;
@@ -944,8 +950,12 @@ gui_chat_printf_y (struct t_gui_buffer *buffer, int y, char *message, ...)
else
{
/* with message: create line or merge content with existing line */
+ buf = malloc (GUI_CHAT_BUFFER_PRINTF_SIZE);
+ if (!buf)
+ return;
+
va_start (argptr, message);
- vsnprintf (buf, sizeof (buf) - 1, message, argptr);
+ vsnprintf (buf, GUI_CHAT_BUFFER_PRINTF_SIZE, message, argptr);
va_end (argptr);
utf8_normalize (buf, '?');
@@ -957,5 +967,7 @@ gui_chat_printf_y (struct t_gui_buffer *buffer, int y, char *message, ...)
}
else
string_iconv_fprintf (stdout, "%s\n", buf);
+
+ free (buf);
}
}
diff --git a/src/gui/gui-chat.h b/src/gui/gui-chat.h
index 685d9fb94..dcf0617f4 100644
--- a/src/gui/gui-chat.h
+++ b/src/gui/gui-chat.h
@@ -26,6 +26,8 @@ struct t_gui_window;
struct t_gui_buffer;
struct t_gui_line;
+#define GUI_CHAT_BUFFER_PRINTF_SIZE (128*1024)
+
#define gui_chat_printf(buffer, argz...) \
gui_chat_printf_date_tags(buffer, 0, NULL, ##argz)
diff --git a/src/gui/gui-color.c b/src/gui/gui-color.c
index 2df69ca80..0cb4b5261 100644
--- a/src/gui/gui-color.c
+++ b/src/gui/gui-color.c
@@ -43,12 +43,12 @@ struct t_gui_color *gui_color[GUI_COLOR_NUM_COLORS]; /* GUI colors */
/*
- * gui_color_search_config: search a color with configuration option name
- * return color found (number >= 0), -1 if not found
+ * gui_color_search_config_int: search a color with configuration option name
+ * return color found (number >= 0), -1 if not found
*/
int
-gui_color_search_config (char *color_name)
+gui_color_search_config_int (char *color_name)
{
struct t_config_section *ptr_section;
struct t_config_option *ptr_option;
@@ -73,6 +73,33 @@ gui_color_search_config (char *color_name)
}
/*
+ * gui_color_search_config_str: search a color configuration name with number
+ * return color configuration name, NULL if not found
+ */
+
+char *
+gui_color_search_config_str (int color_number)
+{
+ struct t_config_section *ptr_section;
+ struct t_config_option *ptr_option;
+
+ ptr_section = config_file_search_section (weechat_config_file,
+ "color");
+ if (ptr_section)
+ {
+ for (ptr_option = ptr_section->options; ptr_option;
+ ptr_option = ptr_option->next_option)
+ {
+ if (ptr_option->min == color_number)
+ return ptr_option->name;
+ }
+ }
+
+ /* color not found */
+ return NULL;
+}
+
+/*
* gui_color_decode: parses a message and remove WeeChat color codes
* After use, string returned has to be free()
*/
diff --git a/src/gui/gui-color.h b/src/gui/gui-color.h
index e36660f08..513d77206 100644
--- a/src/gui/gui-color.h
+++ b/src/gui/gui-color.h
@@ -145,7 +145,8 @@ extern struct t_gui_color *gui_color[];
/* color functions */
-extern int gui_color_search_config (char *color_name);
+extern int gui_color_search_config_int (char *color_name);
+extern char *gui_color_search_config_str (int color_number);
extern unsigned char *gui_color_decode (unsigned char *string);
extern void gui_color_free (struct t_gui_color *color);
diff --git a/src/gui/gui-nicklist.c b/src/gui/gui-nicklist.c
index 63ab79fb1..b3b0cd1e9 100644
--- a/src/gui/gui-nicklist.c
+++ b/src/gui/gui-nicklist.c
@@ -163,7 +163,7 @@ gui_nicklist_add_group (struct t_gui_buffer *buffer,
if (color)
{
- num_color = gui_color_search_config (color);
+ num_color = gui_color_search_config_int (color);
if (num_color < 0)
num_color = GUI_COLOR_NICKLIST;
}
@@ -310,7 +310,7 @@ gui_nicklist_add_nick (struct t_gui_buffer *buffer,
if (color)
{
- num_color = gui_color_search_config (color);
+ num_color = gui_color_search_config_int (color);
if (num_color < 0)
num_color = GUI_COLOR_NICKLIST;
}
@@ -319,7 +319,7 @@ gui_nicklist_add_nick (struct t_gui_buffer *buffer,
if (prefix_color)
{
- num_color_prefix = gui_color_search_config (prefix_color);
+ num_color_prefix = gui_color_search_config_int (prefix_color);
if (num_color_prefix < 0)
num_color_prefix = GUI_COLOR_NICKLIST;
}
diff --git a/src/plugins/irc/irc-nick.h b/src/plugins/irc/irc-nick.h
index cd34d39d8..329cf87c5 100644
--- a/src/plugins/irc/irc-nick.h
+++ b/src/plugins/irc/irc-nick.h
@@ -56,6 +56,10 @@ struct t_irc_nick
struct t_irc_nick *next_nick; /* link to next nick on channel */
};
+extern void irc_nick_get_gui_infos (struct t_gui_buffer *buffer,
+ struct t_irc_nick *nick,
+ char *prefix, int *color_prefix,
+ struct t_gui_nick_group **group);
extern struct t_irc_nick *irc_nick_new (struct t_irc_server *server,
struct t_irc_channel *channel,
char *nick_name, int is_chanowner,
diff --git a/src/plugins/irc/irc-protocol.c b/src/plugins/irc/irc-protocol.c
index d1d592576..d4ac892d9 100644
--- a/src/plugins/irc/irc-protocol.c
+++ b/src/plugins/irc/irc-protocol.c
@@ -3975,20 +3975,22 @@ irc_protocol_cmd_353 (struct t_irc_server *server, char *command,
}
}
}
-
- weechat_printf_tags ((ptr_channel && ptr_channel->nicks) ?
- ptr_channel->buffer : server->buffer,
- irc_protocol_tags (command, "irc_numeric"),
- _("%sNicks %s%s%s: %s[%s%s%s]"),
- weechat_prefix ("network"),
- IRC_COLOR_CHAT_CHANNEL,
- pos_channel,
- IRC_COLOR_CHAT,
- IRC_COLOR_CHAT_DELIMITERS,
- IRC_COLOR_CHAT,
- (argv_eol[args][0] == ':') ?
- argv_eol[args] + 1 : argv_eol[args],
- IRC_COLOR_CHAT_DELIMITERS);
+
+ if (!ptr_channel)
+ {
+ weechat_printf_tags (server->buffer,
+ irc_protocol_tags (command, "irc_numeric"),
+ _("%sNicks %s%s%s: %s[%s%s%s]"),
+ weechat_prefix ("network"),
+ IRC_COLOR_CHAT_CHANNEL,
+ pos_channel,
+ IRC_COLOR_CHAT,
+ IRC_COLOR_CHAT_DELIMITERS,
+ IRC_COLOR_CHAT,
+ (argv_eol[args][0] == ':') ?
+ argv_eol[args] + 1 : argv_eol[args],
+ IRC_COLOR_CHAT_DELIMITERS);
+ }
return WEECHAT_RC_OK;
}
@@ -4003,7 +4005,9 @@ irc_protocol_cmd_366 (struct t_irc_server *server, char *command,
int highlight)
{
struct t_irc_channel *ptr_channel;
- int num_nicks, num_op, num_halfop, num_voice, num_normal;
+ struct t_plugin_infolist *infolist;
+ int num_nicks, num_op, num_halfop, num_voice, num_normal, length, i;
+ char *string, *prefix;
/* 366 message looks like:
:server 366 mynick #channel :End of /NAMES list.
@@ -4017,6 +4021,63 @@ irc_protocol_cmd_366 (struct t_irc_server *server, char *command,
ptr_channel = irc_channel_search (server, argv[3]);
if (ptr_channel && ptr_channel->nicks)
{
+ /* display users on channel */
+ infolist = weechat_infolist_get ("nicklist", ptr_channel->buffer, NULL);
+ if (infolist)
+ {
+ length = 0;
+ while (weechat_infolist_next (infolist))
+ {
+ if (strcmp (weechat_infolist_string (infolist, "type"),
+ "nick") == 0)
+ {
+ length +=
+ strlen (weechat_infolist_string (infolist, "prefix_color")) +
+ strlen (weechat_infolist_string (infolist, "prefix")) +
+ strlen (IRC_COLOR_CHAT) +
+ strlen (weechat_infolist_string (infolist, "name")) + 1;
+ }
+ }
+ string = malloc (length);
+ if (string)
+ {
+ string[0] = '\0';
+ i = 0;
+ while (weechat_infolist_next (infolist))
+ {
+ if (strcmp (weechat_infolist_string (infolist, "type"),
+ "nick") == 0)
+ {
+ if (i > 0)
+ strcat (string, " ");
+ prefix = weechat_infolist_string (infolist, "prefix");
+ if (prefix[0] && (prefix[0] != ' '))
+ {
+ strcat (string,
+ weechat_color (weechat_infolist_string (infolist,
+ "prefix_color")));
+ strcat (string, prefix);
+ }
+ strcat (string, IRC_COLOR_CHAT);
+ strcat (string, weechat_infolist_string (infolist, "name"));
+ i++;
+ }
+ }
+ weechat_printf_tags (ptr_channel->buffer,
+ irc_protocol_tags (command, "irc_numeric"),
+ _("%sNicks %s%s%s: %s[%s%s]"),
+ weechat_prefix ("network"),
+ IRC_COLOR_CHAT_CHANNEL,
+ ptr_channel->name,
+ IRC_COLOR_CHAT,
+ IRC_COLOR_CHAT_DELIMITERS,
+ string,
+ IRC_COLOR_CHAT_DELIMITERS);
+ free (string);
+ }
+ weechat_infolist_free (infolist);
+ }
+
/* display number of nicks, ops, halfops & voices on the channel */
irc_nick_count (ptr_channel, &num_nicks, &num_op, &num_halfop,
&num_voice, &num_normal);
diff --git a/src/plugins/irc/irc-server.c b/src/plugins/irc/irc-server.c
index 3e0326a9d..eb12f0abe 100644
--- a/src/plugins/irc/irc-server.c
+++ b/src/plugins/irc/irc-server.c
@@ -1123,10 +1123,10 @@ irc_server_outqueue_send (struct t_irc_server *server)
server->outqueue->message_after_mod);
if (pos)
pos[0] = '\r';
+ irc_server_send (server, server->outqueue->message_after_mod,
+ strlen (server->outqueue->message_after_mod));
+ server->last_user_message = time_now;
}
- irc_server_send (server, server->outqueue->message_after_mod,
- strlen (server->outqueue->message_after_mod));
- server->last_user_message = time_now;
irc_server_outqueue_free (server, server->outqueue);
}
}
@@ -1687,12 +1687,11 @@ int
irc_server_recv_cb (void *arg_server)
{
struct t_irc_server *server;
-
- server = (struct t_irc_server *)arg_server;
-
static char buffer[4096 + 2];
int num_read;
+ server = (struct t_irc_server *)arg_server;
+
if (!server)
return WEECHAT_RC_ERROR;
diff --git a/src/plugins/logger/logger.c b/src/plugins/logger/logger.c
index df6be59f3..add0c81a3 100644
--- a/src/plugins/logger/logger.c
+++ b/src/plugins/logger/logger.c
@@ -283,7 +283,7 @@ void
logger_write_line (struct t_logger_buffer *logger_buffer, char *format, ...)
{
va_list argptr;
- char buf[4096], *charset, *message;
+ char *buf, *charset, *message;
time_t seconds;
struct tm *date_tmp;
char buf_time[256];
@@ -304,9 +304,10 @@ logger_write_line (struct t_logger_buffer *logger_buffer, char *format, ...)
logger_buffer->log_filename);
free (logger_buffer->log_filename);
logger_buffer->log_filename = NULL;
+ free (buf);
return;
}
-
+
if (logger_option_info_lines)
{
seconds = time (NULL);
@@ -326,19 +327,25 @@ logger_write_line (struct t_logger_buffer *logger_buffer, char *format, ...)
free (message);
}
}
-
- va_start (argptr, format);
- vsnprintf (buf, sizeof (buf) - 1, format, argptr);
- va_end (argptr);
-
- message = (charset) ?
- weechat_iconv_from_internal (charset, buf) : NULL;
-
- fprintf (logger_buffer->log_file,
- "%s\n", (message) ? message : buf);
- fflush (logger_buffer->log_file);
- if (message)
- free (message);
+
+ buf = malloc (128 * 1024);
+ if (buf)
+ {
+ va_start (argptr, format);
+ vsnprintf (buf, 128 * 1024, format, argptr);
+ va_end (argptr);
+
+ message = (charset) ?
+ weechat_iconv_from_internal (charset, buf) : NULL;
+
+ fprintf (logger_buffer->log_file,
+ "%s\n", (message) ? message : buf);
+ fflush (logger_buffer->log_file);
+ if (message)
+ free (message);
+
+ free (buf);
+ }
}
}
diff --git a/src/plugins/plugin-api.c b/src/plugins/plugin-api.c
index 8416d0fbb..e335dde8c 100644
--- a/src/plugins/plugin-api.c
+++ b/src/plugins/plugin-api.c
@@ -42,6 +42,7 @@
#include "../gui/gui-filter.h"
#include "../gui/gui-infobar.h"
#include "../gui/gui-keyboard.h"
+#include "../gui/gui-nicklist.h"
#include "../gui/gui-window.h"
#include "plugin.h"
#include "plugin-config.h"
@@ -231,7 +232,7 @@ plugin_api_color (char *color_name)
return GUI_NO_COLOR;
/* name is a weechat color option ? => then return this color */
- num_color = gui_color_search_config (color_name);
+ num_color = gui_color_search_config_int (color_name);
if (num_color >= 0)
return GUI_COLOR(num_color);
@@ -307,7 +308,7 @@ plugin_api_infobar_printf (struct t_weechat_plugin *plugin, int delay,
buf2 = string_iconv_to_internal (plugin->charset, buf);
if (color_name && color_name[0])
{
- num_color = gui_color_search_config (color_name);
+ num_color = gui_color_search_config_int (color_name);
if (num_color < 0)
num_color = GUI_COLOR_INFOBAR;
}
@@ -511,6 +512,71 @@ plugin_api_infolist_get_add_buffer_line (struct t_plugin_infolist *infolist,
}
/*
+ * plugin_api_infolist_get_add_nicklist: add a nicklist
+ * return 1 if ok, 0 if error
+ */
+
+int
+plugin_api_infolist_get_add_nicklist (struct t_plugin_infolist *infolist,
+ struct t_gui_buffer *buffer)
+{
+ struct t_plugin_infolist_item *ptr_item;
+ struct t_gui_nick_group *ptr_group;
+ struct t_gui_nick *ptr_nick;
+ char prefix[2];
+
+ if (!infolist || !buffer)
+ return 0;
+
+ ptr_group = NULL;
+ ptr_nick = NULL;
+ gui_nicklist_get_next_item (buffer, &ptr_group, &ptr_nick);
+ while (ptr_group || ptr_nick)
+ {
+ ptr_item = plugin_infolist_new_item (infolist);
+ if (!ptr_item)
+ return 0;
+
+ if (ptr_nick)
+ {
+ if (!plugin_infolist_new_var_string (ptr_item, "type", "nick"))
+ return 0;
+ if (!plugin_infolist_new_var_string (ptr_item, "name", ptr_nick->name))
+ return 0;
+ if (!plugin_infolist_new_var_string (ptr_item, "color",
+ gui_color_search_config_str (ptr_nick->color)))
+ return 0;
+ prefix[0] = ptr_nick->prefix;
+ prefix[1] = '\0';
+ if (!plugin_infolist_new_var_string (ptr_item, "prefix", prefix))
+ return 0;
+ if (!plugin_infolist_new_var_string (ptr_item, "prefix_color",
+ gui_color_search_config_str (ptr_nick->prefix_color)))
+ return 0;
+ if (!plugin_infolist_new_var_integer (ptr_item, "visible", ptr_nick->visible))
+ return 0;
+ }
+ else
+ {
+ if (!plugin_infolist_new_var_string (ptr_item, "type", "group"))
+ return 0;
+ if (!plugin_infolist_new_var_string (ptr_item, "name", ptr_group->name))
+ return 0;
+ if (!plugin_infolist_new_var_string (ptr_item, "color",
+ gui_color_search_config_str (ptr_group->color)))
+ return 0;
+ if (!plugin_infolist_new_var_integer (ptr_item, "visible", ptr_group->visible))
+ return 0;
+ if (!plugin_infolist_new_var_integer (ptr_item, "level", ptr_group->level))
+ return 0;
+ }
+ gui_nicklist_get_next_item (buffer, &ptr_group, &ptr_nick);
+ }
+
+ return 1;
+}
+
+/*
* plugin_api_infolist_get_add_window: add a window in a list
* return 1 if ok, 0 if error
*/
@@ -885,7 +951,24 @@ plugin_api_infolist_get (char *name, void *pointer, char *arguments)
return ptr_infolist;
}
}
- if (string_strcasecmp (name, "window") == 0)
+ else if (string_strcasecmp (name, "nicklist") == 0)
+ {
+ /* invalid buffer pointer ? */
+ if (!pointer || (!gui_buffer_valid (pointer)))
+ return NULL;
+
+ ptr_infolist = plugin_infolist_new ();
+ if (ptr_infolist)
+ {
+ if (!plugin_api_infolist_get_add_nicklist (ptr_infolist, pointer))
+ {
+ plugin_infolist_free (ptr_infolist);
+ return NULL;
+ }
+ return ptr_infolist;
+ }
+ }
+ else if (string_strcasecmp (name, "window") == 0)
{
/* invalid window pointer ? */
if (pointer && (!gui_window_valid (pointer)))
diff --git a/src/plugins/scripts/script-api.c b/src/plugins/scripts/script-api.c
index be88a356b..0d89b1569 100644
--- a/src/plugins/scripts/script-api.c
+++ b/src/plugins/scripts/script-api.c
@@ -454,16 +454,21 @@ script_api_printf (struct t_weechat_plugin *weechat_plugin,
struct t_gui_buffer *buffer, char *format, ...)
{
va_list argptr;
- char buf[8192];
- char *buf2;
+ char *buf, *buf2;
+
+ buf = malloc (128 * 1024);
+ if (!buf)
+ return;
va_start (argptr, format);
- vsnprintf (buf, sizeof (buf) - 1, format, argptr);
+ vsnprintf (buf, 128 * 1024, format, argptr);
va_end (argptr);
buf2 = (script->charset && script->charset[0]) ?
weechat_iconv_to_internal (script->charset, buf) : NULL;
weechat_printf (buffer, "%s", (buf2) ? buf2 : buf);
+
+ free (buf);
if (buf2)
free (buf2);
}
@@ -479,17 +484,22 @@ script_api_printf_date_tags (struct t_weechat_plugin *weechat_plugin,
time_t date, char *tags, char *format, ...)
{
va_list argptr;
- char buf[8192];
- char *buf2;
+ char *buf, *buf2;
+
+ buf = malloc (128 * 1024);
+ if (!buf)
+ return;
va_start (argptr, format);
- vsnprintf (buf, sizeof (buf) - 1, format, argptr);
+ vsnprintf (buf, 128 * 1024, format, argptr);
va_end (argptr);
buf2 = (script->charset && script->charset[0]) ?
weechat_iconv_to_internal (script->charset, buf) : NULL;
weechat_printf_date_tags (buffer, date, tags,
"%s", (buf2) ? buf2 : buf);
+
+ free (buf);
if (buf2)
free (buf2);
}
@@ -505,8 +515,11 @@ script_api_printf_y (struct t_weechat_plugin *weechat_plugin,
char *format, ...)
{
va_list argptr;
- char buf[8192];
- char *buf2;
+ char *buf, *buf2;
+
+ buf = malloc (128 * 1024);
+ if (!buf)
+ return;
va_start (argptr, format);
vsnprintf (buf, sizeof (buf) - 1, format, argptr);
@@ -515,6 +528,8 @@ script_api_printf_y (struct t_weechat_plugin *weechat_plugin,
buf2 = (script->charset && script->charset[0]) ?
weechat_iconv_to_internal (script->charset, buf) : NULL;
weechat_printf_y (buffer, y, "%s", (buf2) ? buf2 : buf);
+
+ free (buf);
if (buf2)
free (buf2);
}