summaryrefslogtreecommitdiff
path: root/src/gui
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2010-10-09 21:56:14 +0200
committerSebastien Helleu <flashcode@flashtux.org>2010-10-09 21:56:14 +0200
commit85f6444fefb3d4c8a73791bc9383604e6f57ac11 (patch)
tree0591e9089fa28528e441e427bc5c7f1756f0677f /src/gui
parente1ffb1f70f0822bffc92a9fa7533ed0027088654 (diff)
downloadweechat-85f6444fefb3d4c8a73791bc9383604e6f57ac11.zip
Use local buffer in print functions, so that they are reentrant
Diffstat (limited to 'src/gui')
-rw-r--r--src/gui/gui-chat.c39
-rw-r--r--src/gui/gui-chat.h2
2 files changed, 11 insertions, 30 deletions
diff --git a/src/gui/gui-chat.c b/src/gui/gui-chat.c
index 734e7228a..a14d9255a 100644
--- a/src/gui/gui-chat.c
+++ b/src/gui/gui-chat.c
@@ -48,7 +48,6 @@
#include "gui-window.h"
-char *gui_chat_buffer = NULL; /* buffer for printf */
char *gui_chat_prefix[GUI_CHAT_NUM_PREFIXES]; /* prefixes */
char gui_chat_prefix_empty[] = ""; /* empty prefix */
int gui_chat_time_length = 0; /* length of time for each line (in chars) */
@@ -455,7 +454,7 @@ gui_chat_printf_date_tags (struct t_gui_buffer *buffer, time_t date,
va_list argptr;
time_t date_printed;
int display_time, length, at_least_one_message_printed;
- char *pos, *pos_prefix, *pos_tab, *pos_end;
+ char strbuf[8192], *pos, *pos_prefix, *pos_tab, *pos_end;
char *modifier_data, *new_msg, *ptr_msg;
struct t_gui_line *ptr_line;
@@ -486,16 +485,11 @@ gui_chat_printf_date_tags (struct t_gui_buffer *buffer, time_t date,
&& (gui_chat_mute_buffer == buffer)))
return;
- if (!gui_chat_buffer)
- gui_chat_buffer = malloc (GUI_CHAT_BUFFER_PRINTF_SIZE);
- if (!gui_chat_buffer)
- return;
-
va_start (argptr, message);
- vsnprintf (gui_chat_buffer, GUI_CHAT_BUFFER_PRINTF_SIZE, message, argptr);
+ vsnprintf (strbuf, sizeof (strbuf) - 1, message, argptr);
va_end (argptr);
- utf8_normalize (gui_chat_buffer, '?');
+ utf8_normalize (strbuf, '?');
date_printed = time (NULL);
if (date <= 0)
@@ -503,7 +497,7 @@ gui_chat_printf_date_tags (struct t_gui_buffer *buffer, time_t date,
at_least_one_message_printed = 0;
- pos = gui_chat_buffer;
+ pos = strbuf;
while (pos)
{
/* display until next end of line */
@@ -621,6 +615,7 @@ gui_chat_printf_y (struct t_gui_buffer *buffer, int y, const char *message, ...)
{
va_list argptr;
struct t_gui_line *ptr_line;
+ char strbuf[8192];
if (gui_init_ok)
{
@@ -634,19 +629,14 @@ gui_chat_printf_y (struct t_gui_buffer *buffer, int y, const char *message, ...)
return;
}
- if (!gui_chat_buffer)
- gui_chat_buffer = malloc (GUI_CHAT_BUFFER_PRINTF_SIZE);
- if (!gui_chat_buffer)
- return;
-
va_start (argptr, message);
- vsnprintf (gui_chat_buffer, GUI_CHAT_BUFFER_PRINTF_SIZE, message, argptr);
+ vsnprintf (strbuf, sizeof (strbuf) - 1, message, argptr);
va_end (argptr);
- utf8_normalize (gui_chat_buffer, '?');
-
+ utf8_normalize (strbuf, '?');
+
/* no message: delete line */
- if (!gui_chat_buffer[0])
+ if (!strbuf[0])
{
if (gui_init_ok)
{
@@ -667,11 +657,11 @@ gui_chat_printf_y (struct t_gui_buffer *buffer, int y, const char *message, ...)
{
if (gui_init_ok)
{
- gui_line_add_y (buffer, y, gui_chat_buffer);
+ gui_line_add_y (buffer, y, strbuf);
gui_buffer_ask_chat_refresh (buffer, 1);
}
else
- string_iconv_fprintf (stdout, "%s\n", gui_chat_buffer);
+ string_iconv_fprintf (stdout, "%s\n", strbuf);
}
}
@@ -684,13 +674,6 @@ gui_chat_end ()
{
int i;
- /* free buffer used by chat functions */
- if (gui_chat_buffer)
- {
- free (gui_chat_buffer);
- gui_chat_buffer = NULL;
- }
-
/* free prefixes */
for (i = 0; i < GUI_CHAT_NUM_PREFIXES; i++)
{
diff --git a/src/gui/gui-chat.h b/src/gui/gui-chat.h
index 5851b6535..0f6ed04b7 100644
--- a/src/gui/gui-chat.h
+++ b/src/gui/gui-chat.h
@@ -24,8 +24,6 @@ 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)