summaryrefslogtreecommitdiff
path: root/src/fe-common
diff options
context:
space:
mode:
Diffstat (limited to 'src/fe-common')
-rw-r--r--src/fe-common/core/formats.c8
-rw-r--r--src/fe-common/core/formats.h2
-rw-r--r--src/fe-common/core/printtext.c78
-rw-r--r--src/fe-common/core/printtext.h25
4 files changed, 100 insertions, 13 deletions
diff --git a/src/fe-common/core/formats.c b/src/fe-common/core/formats.c
index b366cd3f..433defbc 100644
--- a/src/fe-common/core/formats.c
+++ b/src/fe-common/core/formats.c
@@ -55,7 +55,7 @@ int format_find_tag(const char *module, const char *tag)
return -1;
}
-int format_expand_styles(GString *out, char format, TEXT_DEST_REC *dest)
+int format_expand_styles(GString *out, char format)
{
static const char *backs = "04261537";
static const char *fores = "kbgcrmyw";
@@ -228,7 +228,7 @@ static char *format_get_text_args(TEXT_DEST_REC *dest,
while (*text != '\0') {
if (code == '%') {
/* color code */
- if (!format_expand_styles(out, *text, dest)) {
+ if (!format_expand_styles(out, *text)) {
g_string_append_c(out, '%');
g_string_append_c(out, '%');
g_string_append_c(out, *text);
@@ -465,6 +465,8 @@ char *format_get_line_start(THEME_REC *theme, TEXT_DEST_REC *dest, time_t t)
void format_newline(WINDOW_REC *window)
{
+ g_return_if_fail(window != NULL);
+
window->lines++;
if (window->lines != 1) {
signal_emit_id(signal_gui_print_text, 6, window,
@@ -789,7 +791,7 @@ void format_send_to_gui(TEXT_DEST_REC *dest, const char *text)
break;
case 27:
/* ansi color code */
- ptr = get_ansi_color(dest->window->theme == NULL ?
+ ptr = get_ansi_color(dest->window == NULL || dest->window->theme == NULL ?
current_theme : dest->window->theme,
ptr,
hide_text_style ? NULL : &fgcolor,
diff --git a/src/fe-common/core/formats.h b/src/fe-common/core/formats.h
index f2917d91..5be7a4b5 100644
--- a/src/fe-common/core/formats.h
+++ b/src/fe-common/core/formats.h
@@ -98,7 +98,7 @@ void format_send_to_gui(TEXT_DEST_REC *dest, const char *text);
#define FORMAT_STYLE_REVERSE (0x03 + FORMAT_STYLE_SPECIAL)
#define FORMAT_STYLE_INDENT (0x04 + FORMAT_STYLE_SPECIAL)
#define FORMAT_STYLE_DEFAULTS (0x05 + FORMAT_STYLE_SPECIAL)
-int format_expand_styles(GString *out, char format, TEXT_DEST_REC *dest);
+int format_expand_styles(GString *out, char format);
void formats_init(void);
void formats_deinit(void);
diff --git a/src/fe-common/core/printtext.c b/src/fe-common/core/printtext.c
index f197026d..f1c4d397 100644
--- a/src/fe-common/core/printtext.c
+++ b/src/fe-common/core/printtext.c
@@ -77,7 +77,8 @@ static void printformat_module_dest(const char *module, TEXT_DEST_REC *dest,
signal_emit_id(signal_print_format, 5, theme, module,
dest, GINT_TO_POINTER(formatnum), arglist);
- str = format_get_text_theme_charargs(theme, module, dest, formatnum, arglist);
+ str = format_get_text_theme_charargs(theme, module, dest,
+ formatnum, arglist);
if (*str != '\0') print_line(dest, str);
g_free(str);
}
@@ -92,7 +93,8 @@ void printformat_module_args(const char *module, void *server,
printformat_module_dest(module, &dest, formatnum, va);
}
-void printformat_module(const char *module, void *server, const char *target, int level, int formatnum, ...)
+void printformat_module(const char *module, void *server, const char *target,
+ int level, int formatnum, ...)
{
va_list va;
@@ -120,6 +122,38 @@ void printformat_module_window(const char *module, WINDOW_REC *window,
va_end(va);
}
+void printformat_module_gui_args(const char *module, int formatnum, va_list va)
+{
+ TEXT_DEST_REC dest;
+ char *arglist[MAX_FORMAT_PARAMS];
+ char buffer[DEFAULT_FORMAT_ARGLIST_SIZE];
+ FORMAT_REC *formats;
+ char *str;
+
+ g_return_if_fail(module != NULL);
+
+ memset(&dest, 0, sizeof(dest));
+
+ formats = g_hash_table_lookup(default_formats, module);
+ format_read_arglist(va, &formats[formatnum],
+ arglist, sizeof(arglist)/sizeof(char *),
+ buffer, sizeof(buffer));
+
+ str = format_get_text_theme_charargs(current_theme, module, &dest,
+ formatnum, arglist);
+ if (*str != '\0') format_send_to_gui(&dest, str);
+ g_free(str);
+}
+
+void printformat_module_gui(const char *module, int formatnum, ...)
+{
+ va_list va;
+
+ va_start(va, formatnum);
+ printformat_module_gui_args(module, formatnum, va);
+ va_end(va);
+}
+
static void print_line(TEXT_DEST_REC *dest, const char *text)
{
char *str, *tmp;
@@ -141,7 +175,8 @@ static void print_line(TEXT_DEST_REC *dest, const char *text)
}
/* append string to `out', expand newlines. */
-static void printtext_append_str(TEXT_DEST_REC *dest, GString *out, const char *str)
+static void printtext_append_str(TEXT_DEST_REC *dest, GString *out,
+ const char *str)
{
while (*str != '\0') {
if (*str != '\n')
@@ -154,7 +189,8 @@ static void printtext_append_str(TEXT_DEST_REC *dest, GString *out, const char *
}
}
-static char *printtext_get_args(TEXT_DEST_REC *dest, const char *str, va_list va)
+static char *printtext_get_args(TEXT_DEST_REC *dest, const char *str,
+ va_list va)
{
GString *out;
char *ret;
@@ -187,7 +223,8 @@ static char *printtext_get_args(TEXT_DEST_REC *dest, const char *str, va_list va
break;
}
case 'u': {
- unsigned int d = (unsigned int) va_arg(va, unsigned int);
+ unsigned int d =
+ (unsigned int) va_arg(va, unsigned int);
g_string_sprintfa(out, "%u", d);
break;
}
@@ -206,7 +243,7 @@ static char *printtext_get_args(TEXT_DEST_REC *dest, const char *str, va_list va
break;
}
default:
- if (!format_expand_styles(out, *str, dest)) {
+ if (!format_expand_styles(out, *str)) {
g_string_append_c(out, '%');
g_string_append_c(out, *str);
}
@@ -219,7 +256,7 @@ static char *printtext_get_args(TEXT_DEST_REC *dest, const char *str, va_list va
return ret;
}
-static char *printtext_expand_formats(TEXT_DEST_REC *dest, const char *str)
+static char *printtext_expand_formats(const char *str)
{
GString *out;
char *ret;
@@ -234,7 +271,7 @@ static char *printtext_expand_formats(TEXT_DEST_REC *dest, const char *str)
if (*++str == '\0')
break;
- if (!format_expand_styles(out, *str, dest)) {
+ if (!format_expand_styles(out, *str)) {
g_string_append_c(out, '%');
g_string_append_c(out, *str);
}
@@ -291,7 +328,7 @@ void printtext_string(void *server, const char *target, int level, const char *t
sending_print_starting = FALSE;
}
- str = printtext_expand_formats(&dest, text);
+ str = printtext_expand_formats(text);
print_line(&dest, str);
g_free(str);
}
@@ -311,6 +348,29 @@ void printtext_window(WINDOW_REC *window, int level, const char *text, ...)
va_end(va);
}
+void printtext_gui_args(const char *text, va_list va)
+{
+ TEXT_DEST_REC dest;
+ char *str;
+
+ g_return_if_fail(text != NULL);
+
+ memset(&dest, 0, sizeof(dest));
+
+ str = printtext_get_args(&dest, text, va);
+ format_send_to_gui(&dest, str);
+ g_free(str);
+}
+
+void printtext_gui(const char *text, ...)
+{
+ va_list va;
+
+ va_start(va, text);
+ printtext_gui_args(text, va);
+ va_end(va);
+}
+
static void msg_beep_check(SERVER_REC *server, int level)
{
if (level != 0 && (level & MSGLEVEL_NOHILIGHT) == 0 &&
diff --git a/src/fe-common/core/printtext.h b/src/fe-common/core/printtext.h
index 34db5a85..5133fa57 100644
--- a/src/fe-common/core/printtext.h
+++ b/src/fe-common/core/printtext.h
@@ -15,6 +15,13 @@ void printtext_window(WINDOW_REC *window, int level, const char *text, ...);
void printtext_multiline(void *server, const char *target, int level, const char *format, const char *text);
void printbeep(void);
+/* only GUI should call these - used for printing text to somewhere else
+ than windows */
+void printtext_gui(const char *text, ...);
+void printtext_gui_args(const char *text, va_list va);
+void printformat_module_gui(const char *module, int formatnum, ...);
+void printformat_module_gui_args(const char *module, int formatnum, va_list va);
+
void printtext_init(void);
void printtext_deinit(void);
@@ -30,12 +37,16 @@ void printtext_deinit(void);
printformat_module(MODULE_NAME, server, target, level, ##formatnum)
# define printformat_window(window, level, formatnum...) \
printformat_module_window(MODULE_NAME, window, level, ##formatnum)
+# define printformat_gui(formatnum...) \
+ printformat_module_gui(MODULE_NAME, ##formatnum)
#elif defined (_ISOC99_SOURCE)
/* C99 */
# define printformat(server, target, level, formatnum, ...) \
printformat_module(MODULE_NAME, server, target, level, formatnum, __VA_ARGS__)
# define printformat_window(window, level, formatnum, ...) \
printformat_module_window(MODULE_NAME, window, level, formatnum, __VA_ARGS__)
+# define printformat_gui(formatnum, ...) \
+ printformat_module_gui(MODULE_NAME, formatnum, __VA_ARGS__)
#else
/* inline/static */
#ifdef G_CAN_INLINE
@@ -65,6 +76,20 @@ void printformat_window(WINDOW_REC *window, int level, int formatnum, ...)
printformat_module_window_args(MODULE_NAME, window, level, formatnum, va);
va_end(va);
}
+
+#ifdef G_CAN_INLINE
+G_INLINE_FUNC
+#else
+static
+#endif
+void printformat_gui(int formatnum, ...)
+{
+ va_list va;
+
+ va_start(va, formatnum);
+ printformat_module_gui_args(MODULE_NAME, formatnum, va);
+ va_end(va);
+}
#endif
#endif