diff options
-rw-r--r-- | src/fe-common/core/printtext.c | 38 |
1 files changed, 28 insertions, 10 deletions
diff --git a/src/fe-common/core/printtext.c b/src/fe-common/core/printtext.c index 3844174a..f5bde71d 100644 --- a/src/fe-common/core/printtext.c +++ b/src/fe-common/core/printtext.c @@ -39,6 +39,9 @@ static int signal_print_text_stripped; static int signal_print_text; static int signal_print_text_finished; static int signal_print_format; +static int signal_print_starting; + +static int sending_print_starting; static void print_line(TEXT_DEST_REC *dest, const char *text); @@ -65,6 +68,12 @@ static void printformat_module_dest(const char *module, TEXT_DEST_REC *dest, arglist, sizeof(arglist)/sizeof(char *), buffer, sizeof(buffer)); + if (!sending_print_starting) { + sending_print_starting = TRUE; + signal_emit_id(signal_print_starting, 1, dest); + sending_print_starting = FALSE; + } + signal_emit_id(signal_print_format, 5, theme, module, dest, GINT_TO_POINTER(formatnum), arglist); @@ -210,11 +219,25 @@ static char *printtext_get_args(TEXT_DEST_REC *dest, const char *str, va_list va return ret; } +void printtext_dest(TEXT_DEST_REC *dest, const char *text, va_list va) +{ + char *str; + + if (!sending_print_starting) { + sending_print_starting = TRUE; + signal_emit_id(signal_print_starting, 1, dest); + sending_print_starting = FALSE; + } + + str = printtext_get_args(dest, text, va); + print_line(dest, str); + g_free(str); +} + /* Write text to target - convert color codes */ void printtext(void *server, const char *target, int level, const char *text, ...) { TEXT_DEST_REC dest; - char *str; va_list va; g_return_if_fail(text != NULL); @@ -222,17 +245,13 @@ void printtext(void *server, const char *target, int level, const char *text, .. format_create_dest(&dest, server, target, level, NULL); va_start(va, text); - str = printtext_get_args(&dest, text, va); + printtext_dest(&dest, text, va); va_end(va); - - print_line(&dest, str); - g_free(str); } void printtext_window(WINDOW_REC *window, int level, const char *text, ...) { TEXT_DEST_REC dest; - char *str; va_list va; g_return_if_fail(text != NULL); @@ -241,11 +260,8 @@ void printtext_window(WINDOW_REC *window, int level, const char *text, ...) window != NULL ? window : active_win); va_start(va, text); - str = printtext_get_args(&dest, text, va); + printtext_dest(&dest, text, va); va_end(va); - - print_line(&dest, str); - g_free(str); } static void msg_beep_check(SERVER_REC *server, int level) @@ -319,11 +335,13 @@ void printtext_init(void) { settings_add_int("misc", "timestamp_timeout", 0); + sending_print_starting = FALSE; signal_gui_print_text = signal_get_uniq_id("gui print text"); signal_print_text_stripped = signal_get_uniq_id("print text stripped"); signal_print_text = signal_get_uniq_id("print text"); signal_print_text_finished = signal_get_uniq_id("print text finished"); signal_print_format = signal_get_uniq_id("print format"); + signal_print_starting = signal_get_uniq_id("print starting"); read_settings(); signal_add("print text", (SIGNAL_FUNC) sig_print_text); |