diff options
author | Sebastien Helleu <flashcode@flashtux.org> | 2010-10-09 21:56:14 +0200 |
---|---|---|
committer | Sebastien Helleu <flashcode@flashtux.org> | 2010-10-09 21:56:14 +0200 |
commit | 85f6444fefb3d4c8a73791bc9383604e6f57ac11 (patch) | |
tree | 0591e9089fa28528e441e427bc5c7f1756f0677f /src/gui | |
parent | e1ffb1f70f0822bffc92a9fa7533ed0027088654 (diff) | |
download | weechat-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.c | 39 | ||||
-rw-r--r-- | src/gui/gui-chat.h | 2 |
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) |