summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTimo Sirainen <cras@irssi.org>2000-10-28 20:14:19 +0000
committercras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564>2000-10-28 20:14:19 +0000
commit4dcbe05c0f67fe9e914ba323ce7e179885ebb1f7 (patch)
treef235d6f427cd0dd7e98dfbd36813a1098e127faa
parent8653c6ea36c29067a358ed59782b71ffd1401fc3 (diff)
downloadirssi-4dcbe05c0f67fe9e914ba323ce7e179885ebb1f7.zip
Cleaned up printtext.c, split part of it to formats.c
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@796 dbcabf3a-b0e7-0310-adc4-f8d773084564
-rw-r--r--src/fe-common/core/Makefile.am2
-rw-r--r--src/fe-common/core/fe-channels.c1
-rw-r--r--src/fe-common/core/fe-core-commands.c1
-rw-r--r--src/fe-common/core/fe-ignore.c1
-rw-r--r--src/fe-common/core/fe-log.c45
-rw-r--r--src/fe-common/core/fe-messages.c1
-rw-r--r--src/fe-common/core/fe-modules.c2
-rw-r--r--src/fe-common/core/fe-queries.c1
-rw-r--r--src/fe-common/core/fe-server.c1
-rw-r--r--src/fe-common/core/fe-settings.c1
-rw-r--r--src/fe-common/core/formats.c354
-rw-r--r--src/fe-common/core/formats.h62
-rw-r--r--src/fe-common/core/hilight-text.c1
-rw-r--r--src/fe-common/core/keyboard.c1
-rw-r--r--src/fe-common/core/module-formats.c2
-rw-r--r--src/fe-common/core/module-formats.h2
-rw-r--r--src/fe-common/core/printtext.c778
-rw-r--r--src/fe-common/core/printtext.h43
-rw-r--r--src/fe-common/core/themes.c1
-rw-r--r--src/fe-common/core/themes.h4
-rw-r--r--src/fe-common/core/window-commands.c1
-rw-r--r--src/fe-common/core/window-items.c1
-rw-r--r--src/fe-common/irc/dcc/fe-dcc.c1
-rw-r--r--src/fe-common/irc/dcc/module-formats.c2
-rw-r--r--src/fe-common/irc/dcc/module-formats.h2
-rw-r--r--src/fe-common/irc/fe-ctcp.c1
-rw-r--r--src/fe-common/irc/fe-events-numeric.c10
-rw-r--r--src/fe-common/irc/fe-events.c1
-rw-r--r--src/fe-common/irc/fe-irc-channels.c2
-rw-r--r--src/fe-common/irc/fe-irc-commands.c1
-rw-r--r--src/fe-common/irc/fe-irc-server.c1
-rw-r--r--src/fe-common/irc/fe-ircnet.c1
-rw-r--r--src/fe-common/irc/fe-netjoin.c2
-rw-r--r--src/fe-common/irc/fe-netsplit.c2
-rw-r--r--src/fe-common/irc/flood/fe-flood.c1
-rw-r--r--src/fe-common/irc/flood/module-formats.c2
-rw-r--r--src/fe-common/irc/flood/module-formats.h2
-rw-r--r--src/fe-common/irc/module-formats.c2
-rw-r--r--src/fe-common/irc/module-formats.h2
-rw-r--r--src/fe-common/irc/notifylist/fe-notifylist.c1
-rw-r--r--src/fe-common/irc/notifylist/module-formats.c2
-rw-r--r--src/fe-common/irc/notifylist/module-formats.h2
-rw-r--r--src/fe-text/gui-textwidget.c14
-rw-r--r--src/fe-text/mainwindows.c1
-rw-r--r--src/fe-text/module-formats.c2
-rw-r--r--src/fe-text/module-formats.h2
46 files changed, 733 insertions, 632 deletions
diff --git a/src/fe-common/core/Makefile.am b/src/fe-common/core/Makefile.am
index aa4432ac..cea60d81 100644
--- a/src/fe-common/core/Makefile.am
+++ b/src/fe-common/core/Makefile.am
@@ -22,6 +22,7 @@ libfe_common_core_a_SOURCES = \
fe-queries.c \
fe-server.c \
fe-settings.c \
+ formats.c \
hilight-text.c \
keyboard.c \
module-formats.c \
@@ -39,6 +40,7 @@ noinst_HEADERS = \
completion.h \
fe-common-core.h \
fe-queries.h \
+ formats.h \
hilight-text.h \
keyboard.h \
module-formats.h \
diff --git a/src/fe-common/core/fe-channels.c b/src/fe-common/core/fe-channels.c
index 19ad6c84..7f220752 100644
--- a/src/fe-common/core/fe-channels.c
+++ b/src/fe-common/core/fe-channels.c
@@ -32,6 +32,7 @@
#include "windows.h"
#include "window-items.h"
+#include "printtext.h"
static void signal_channel_created(CHANNEL_REC *channel, gpointer automatic)
{
diff --git a/src/fe-common/core/fe-core-commands.c b/src/fe-common/core/fe-core-commands.c
index ac6b846c..50617981 100644
--- a/src/fe-common/core/fe-core-commands.c
+++ b/src/fe-common/core/fe-core-commands.c
@@ -29,6 +29,7 @@
#include "irssi-version.h"
#include "windows.h"
+#include "printtext.h"
#define PASTE_CHECK_SPEED 200 /* 0.2 sec */
diff --git a/src/fe-common/core/fe-ignore.c b/src/fe-common/core/fe-ignore.c
index 051d7767..db2d4ad3 100644
--- a/src/fe-common/core/fe-ignore.c
+++ b/src/fe-common/core/fe-ignore.c
@@ -27,6 +27,7 @@
#include "servers.h"
#include "ignore.h"
+#include "printtext.h"
static void fe_unignore(IGNORE_REC *rec);
diff --git a/src/fe-common/core/fe-log.c b/src/fe-common/core/fe-log.c
index 35c570c1..1ded4f9b 100644
--- a/src/fe-common/core/fe-log.c
+++ b/src/fe-common/core/fe-log.c
@@ -31,7 +31,9 @@
#include "windows.h"
#include "window-items.h"
+#include "formats.h"
#include "themes.h"
+#include "printtext.h"
/* close autologs after 5 minutes of inactivity */
#define AUTOLOG_INACTIVITY_CLOSE (60*5)
@@ -419,13 +421,10 @@ static void sig_printtext_stripped(WINDOW_REC *window, void *server,
}
static void sig_print_format(THEME_REC *theme, const char *module,
- TEXT_DEST_REC *dest, gpointer formatnump,
+ TEXT_DEST_REC *dest, void *formatnum,
va_list va)
{
- MODULE_THEME_REC *module_theme;
- FORMAT_REC *formats;
- int formatnum;
- char *str, *str2, *stripped, *tmp;
+ char *str, *stripped, *linestart, *tmp;
if (log_theme == NULL) {
/* theme isn't loaded for some reason (/reload destroys it),
@@ -437,31 +436,20 @@ static void sig_print_format(THEME_REC *theme, const char *module,
if (theme == log_theme)
return;
- /* log uses a different theme .. very ugly kludge follows.. : */
- formatnum = GPOINTER_TO_INT(formatnump);
- module_theme = g_hash_table_lookup(log_theme->modules, module);
- formats = g_hash_table_lookup(default_formats, module);
+ str = format_get_text_theme_args(log_theme, module, dest,
+ GPOINTER_TO_INT(formatnum), va);
+ skip_next_printtext = TRUE;
- str = output_format_text_args(dest, &formats[formatnum],
- module_theme->expanded_formats[formatnum], va);
if (*str != '\0') {
- /* get_line_start_text() gets the line start with
- current theme. */
- THEME_REC *old_theme = current_theme;
- current_theme = log_theme;
- tmp = get_line_start_text(dest);
- current_theme = old_theme;
-
- /* line start + text */
- str2 = tmp == NULL ? str :
- g_strconcat(tmp, str, NULL);
- if (str2 != str) g_free(str);
- str = str2;
- g_free_not_null(tmp);
+ /* add the line start format */
+ linestart = format_get_line_start(log_theme, dest);
+ tmp = str;
+ str = format_add_linestart(tmp, linestart);
+ g_free_not_null(linestart);
+ g_free(tmp);
/* strip colors from text, log it. */
stripped = strip_codes(str);
- skip_next_printtext = TRUE;
log_line(dest->window, dest->server, dest->target,
dest->level, stripped);
g_free(stripped);
@@ -558,10 +546,10 @@ static void read_settings(void)
/* write to log files with different theme? */
log_theme_name = settings_get_str("log_theme");
- if (old_log_theme == NULL && *log_theme_name != '\0') {
+ if (*old_log_theme == '\0' && *log_theme_name != '\0') {
/* theme set */
signal_add("print format", (SIGNAL_FUNC) sig_print_format);
- } else if (old_log_theme != NULL && *log_theme_name == '\0') {
+ } else if (*old_log_theme != '\0' && *log_theme_name == '\0') {
/* theme unset */
signal_remove("print format", (SIGNAL_FUNC) sig_print_format);
}
@@ -581,6 +569,7 @@ void fe_log_init(void)
settings_add_str("log", "log_theme", "");
autolog_level = 0;
+ log_theme_name = "";
read_settings();
command_bind("log", NULL, (SIGNAL_FUNC) cmd_log);
@@ -605,7 +594,7 @@ void fe_log_init(void)
void fe_log_deinit(void)
{
g_source_remove(autoremove_tag);
- if (log_theme_name != NULL && *log_theme_name != '\0')
+ if (*log_theme_name != '\0')
signal_remove("print format", (SIGNAL_FUNC) sig_print_format);
command_unbind("log", (SIGNAL_FUNC) cmd_log);
diff --git a/src/fe-common/core/fe-messages.c b/src/fe-common/core/fe-messages.c
index 1a074f31..934f01b8 100644
--- a/src/fe-common/core/fe-messages.c
+++ b/src/fe-common/core/fe-messages.c
@@ -33,6 +33,7 @@
#include "nicklist.h"
#include "hilight-text.h"
#include "ignore.h"
+#include "printtext.h"
static char *get_nickmode(CHANNEL_REC *channel, const char *nick)
{
diff --git a/src/fe-common/core/fe-modules.c b/src/fe-common/core/fe-modules.c
index 1db51731..4dd97d56 100644
--- a/src/fe-common/core/fe-modules.c
+++ b/src/fe-common/core/fe-modules.c
@@ -25,6 +25,8 @@
#include "commands.h"
#include "levels.h"
+#include "printtext.h"
+
static void sig_module_error(void *number, const char *module, const char *data)
{
switch (GPOINTER_TO_INT(number)) {
diff --git a/src/fe-common/core/fe-queries.c b/src/fe-common/core/fe-queries.c
index f9f0840e..5875640c 100644
--- a/src/fe-common/core/fe-queries.c
+++ b/src/fe-common/core/fe-queries.c
@@ -30,6 +30,7 @@
#include "windows.h"
#include "window-items.h"
+#include "printtext.h"
static int queryclose_tag, query_auto_close, querycreate_level;
diff --git a/src/fe-common/core/fe-server.c b/src/fe-common/core/fe-server.c
index 53160037..72ac7b50 100644
--- a/src/fe-common/core/fe-server.c
+++ b/src/fe-common/core/fe-server.c
@@ -31,6 +31,7 @@
#include "servers-reconnect.h"
#include "module-formats.h"
+#include "printtext.h"
static void print_servers(void)
{
diff --git a/src/fe-common/core/fe-settings.c b/src/fe-common/core/fe-settings.c
index 4d8266dd..15968002 100644
--- a/src/fe-common/core/fe-settings.c
+++ b/src/fe-common/core/fe-settings.c
@@ -28,6 +28,7 @@
#include "settings.h"
#include "levels.h"
+#include "printtext.h"
static void set_print(SETTINGS_REC *rec)
{
diff --git a/src/fe-common/core/formats.c b/src/fe-common/core/formats.c
new file mode 100644
index 00000000..dd2fe8a4
--- /dev/null
+++ b/src/fe-common/core/formats.c
@@ -0,0 +1,354 @@
+/*
+ formats.c : irssi
+
+ Copyright (C) 1999-2000 Timo Sirainen
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+*/
+
+#include "module.h"
+#include "module-formats.h"
+#include "signals.h"
+#include "special-vars.h"
+
+#include "levels.h"
+
+#include "windows.h"
+#include "formats.h"
+#include "themes.h"
+
+int format_expand_styles(GString *out, char format, TEXT_DEST_REC *dest)
+{
+ static const char *backs = "04261537";
+ static const char *fores = "kbgcrmyw";
+ static const char *boldfores = "KBGCRMYW";
+ char *p;
+
+ switch (format) {
+ case 'U':
+ /* Underline on/off */
+ g_string_append_c(out, 4);
+ g_string_append_c(out, FORMAT_STYLE_UNDERLINE);
+ break;
+ case '9':
+ case '_':
+ /* bold on/off */
+ g_string_append_c(out, 4);
+ g_string_append_c(out, FORMAT_STYLE_BOLD);
+ break;
+ case '8':
+ /* reverse */
+ g_string_append_c(out, 4);
+ g_string_append_c(out, FORMAT_STYLE_REVERSE);
+ break;
+ case '%':
+ g_string_append_c(out, '%');
+ break;
+ case ':':
+ /* Newline */
+ g_string_append_c(out, '\n');
+ break;
+ case '|':
+ /* Indent here */
+ g_string_append_c(out, 4);
+ g_string_append_c(out, FORMAT_STYLE_INDENT);
+ break;
+ case 'F':
+ /* flashing - ignore */
+ break;
+ case 'N':
+ /* don't put clear-color tag at the end of the output - ignore */
+ break;
+ case 'n':
+ /* default color */
+ g_string_append_c(out, 4);
+ g_string_append_c(out, FORMAT_STYLE_DEFAULTS);
+ break;
+ default:
+ /* check if it's a background color */
+ p = strchr(backs, format);
+ if (p != NULL) {
+ g_string_append_c(out, 4);
+ g_string_append_c(out, FORMAT_COLOR_NOCHANGE);
+ g_string_append_c(out, (int) (p-backs)+'0');
+ break;
+ }
+
+ /* check if it's a foreground color */
+ if (format == 'p') format = 'm';
+ p = strchr(fores, format);
+ if (p != NULL) {
+ g_string_append_c(out, 4);
+ g_string_append_c(out, (int) (p-fores)+'0');
+ g_string_append_c(out, FORMAT_COLOR_NOCHANGE);
+ break;
+ }
+
+ /* check if it's a bold foreground color */
+ if (format == 'P') format = 'M';
+ p = strchr(boldfores, format);
+ if (p != NULL) {
+ g_string_append_c(out, 4);
+ g_string_append_c(out, 8+(int) (p-boldfores)+'0');
+ g_string_append_c(out, FORMAT_COLOR_NOCHANGE);
+ break;
+ }
+
+ return FALSE;
+ }
+
+ return TRUE;
+}
+
+static void read_arglist(va_list va, FORMAT_REC *format,
+ char **arglist, int arglist_size,
+ char *buffer, int buffer_size)
+{
+ int num, len, bufpos;
+
+ bufpos = 0;
+ arglist[format->params] = NULL;
+ for (num = 0; num < format->params && num < arglist_size; num++) {
+ switch (format->paramtypes[num]) {
+ case FORMAT_STRING:
+ arglist[num] = (char *) va_arg(va, char *);
+ if (arglist[num] == NULL) {
+ g_warning("read_arglist() : parameter %d is NULL", num);
+ arglist[num] = "";
+ }
+ break;
+ case FORMAT_INT: {
+ int d = (int) va_arg(va, int);
+
+ if (bufpos >= buffer_size) {
+ arglist[num] = "";
+ break;
+ }
+
+ arglist[num] = buffer+bufpos;
+ len = g_snprintf(buffer+bufpos, buffer_size-bufpos,
+ "%d", d);
+ bufpos += len+1;
+ break;
+ }
+ case FORMAT_LONG: {
+ long l = (long) va_arg(va, long);
+
+ if (bufpos >= buffer_size) {
+ arglist[num] = "";
+ break;
+ }
+
+ arglist[num] = buffer+bufpos;
+ len = g_snprintf(buffer+bufpos, buffer_size-bufpos,
+ "%ld", l);
+ bufpos += len+1;
+ break;
+ }
+ case FORMAT_FLOAT: {
+ double f = (double) va_arg(va, double);
+
+ if (bufpos >= buffer_size) {
+ arglist[num] = "";
+ break;
+ }
+
+ arglist[num] = buffer+bufpos;
+ len = g_snprintf(buffer+bufpos, buffer_size-bufpos,
+ "%0.2f", f);
+ bufpos += len+1;
+ break;
+ }
+ }
+ }
+}
+
+void format_create_dest(TEXT_DEST_REC *dest,
+ void *server, const char *target,
+ int level, WINDOW_REC *window)
+{
+ dest->server = server;
+ dest->target = target;
+ dest->level = level;
+ dest->window = window != NULL ? window :
+ window_find_closest(server, target, level);
+}
+
+static char *format_get_text_args(TEXT_DEST_REC *dest, FORMAT_REC *format,
+ const char *text, va_list va)
+{
+ GString *out;
+ char *arglist[10];
+ char buffer[200]; /* should be enough? (won't overflow even if it isn't) */
+
+ char code, *ret;
+ int need_free;
+
+ /* read all optional arguments to arglist[] list
+ so they can be used in any order.. */
+ read_arglist(va, format,
+ arglist, sizeof(arglist)/sizeof(void*),
+ buffer, sizeof(buffer));
+
+ out = g_string_new(NULL);
+
+ code = 0;
+ while (*text != '\0') {
+ if (code == '%') {
+ /* color code */
+ if (!format_expand_styles(out, *text, dest)) {
+ g_string_append_c(out, '%');
+ g_string_append_c(out, '%');
+ g_string_append_c(out, *text);
+ }
+ code = 0;
+ } else if (code == '$') {
+ /* argument */
+ char *ret;
+
+ ret = parse_special((char **) &text, active_win->active_server,
+ active_win->active, arglist, &need_free, NULL);
+
+ if (ret != NULL) {
+ /* string shouldn't end with \003 or it could
+ mess up the next one or two characters */
+ int diff;
+ int len = strlen(ret);
+ while (len > 0 && ret[len-1] == 3) len--;
+ diff = strlen(ret)-len;
+
+ g_string_append(out, ret);
+ if (diff > 0)
+ g_string_truncate(out, out->len-diff);
+ if (need_free) g_free(ret);
+ }
+ code = 0;
+ } else {
+ if (*text == '%' || *text == '$')
+ code = *text;
+ else
+ g_string_append_c(out, *text);
+ }
+
+ text++;
+ }
+
+ ret = out->str;
+ g_string_free(out, FALSE);
+ return ret;
+}
+
+char *format_get_text_theme(THEME_REC *theme, const char *module,
+ TEXT_DEST_REC *dest, int formatnum, ...)
+{
+ va_list va;
+ char *str;
+
+ if (theme == NULL) {
+ theme = dest->window->theme == NULL ? current_theme :
+ dest->window->theme;
+ }
+
+ va_start(va, formatnum);
+ str = format_get_text_theme_args(theme, module, dest, formatnum, va);
+ va_end(va);
+
+ return str;
+}
+
+char *format_get_text_theme_args(THEME_REC *theme, const char *module,
+ TEXT_DEST_REC *dest, int formatnum,
+ va_list va)
+{
+ MODULE_THEME_REC *module_theme;
+ FORMAT_REC *formats;
+ char *str;
+
+ module_theme = g_hash_table_lookup(theme->modules, module);
+ formats = g_hash_table_lookup(default_formats, module);
+
+ str = format_get_text_args(dest, &formats[formatnum],
+ module_theme->expanded_formats[formatnum], va);
+ return str;
+}
+
+char *format_get_text(const char *module, WINDOW_REC *window,
+ void *server, const char *target,
+ int formatnum, ...)
+{
+ TEXT_DEST_REC dest;
+ THEME_REC *theme;
+ va_list va;
+ char *str;
+
+ format_create_dest(&dest, server, target, 0, window);
+ theme = dest.window->theme == NULL ? current_theme :
+ dest.window->theme;
+
+ va_start(va, formatnum);
+ str = format_get_text_theme_args(theme, module, &dest, formatnum, va);
+ va_end(va);
+
+ return str;
+}
+
+/* add `linestart' to start of each line in `text'. `text' may contain
+ multiple lines separated with \n. */
+char *format_add_linestart(const char *text, const char *linestart)
+{
+ GString *str;
+ char *ret;
+
+ if (linestart == NULL)
+ return g_strdup(text);
+
+ if (strchr(text, '\n') == NULL)
+ return g_strconcat(linestart, text, NULL);
+
+ str = g_string_new(linestart);
+ while (*text != '\0') {
+ g_string_append_c(str, *text);
+ if (*text == '\n')
+ g_string_append(str, linestart);
+ text++;
+ }
+
+ ret = str->str;
+ g_string_free(str, FALSE);
+ return ret;
+}
+
+#define LINE_START_IRSSI_LEVEL \
+ (MSGLEVEL_CLIENTERROR | MSGLEVEL_CLIENTNOTICE)
+
+#define NOT_LINE_START_LEVEL \
+ (MSGLEVEL_NEVER | MSGLEVEL_LASTLOG | MSGLEVEL_CLIENTCRAP | \
+ MSGLEVEL_MSGS | MSGLEVEL_PUBLIC | MSGLEVEL_DCC | MSGLEVEL_DCCMSGS | \
+ MSGLEVEL_ACTIONS | MSGLEVEL_NOTICES | MSGLEVEL_SNOTES | MSGLEVEL_CTCPS)
+
+/* return the "-!- " text at the start of the line */
+char *format_get_line_start(THEME_REC *theme, TEXT_DEST_REC *dest)
+{
+ int format;
+
+ if (dest->level & LINE_START_IRSSI_LEVEL)
+ format = IRCTXT_LINE_START_IRSSI;
+ else if ((dest->level & NOT_LINE_START_LEVEL) == 0)
+ format = IRCTXT_LINE_START;
+ else
+ return NULL;
+
+ return format_get_text_theme(theme, MODULE_NAME, dest, format);
+}
diff --git a/src/fe-common/core/formats.h b/src/fe-common/core/formats.h
new file mode 100644
index 00000000..a448bc21
--- /dev/null
+++ b/src/fe-common/core/formats.h
@@ -0,0 +1,62 @@
+#ifndef __FORMATS_H
+#define __FORMATS_H
+
+#include "themes.h"
+#include "windows.h"
+
+enum {
+ FORMAT_STRING,
+ FORMAT_INT,
+ FORMAT_LONG,
+ FORMAT_FLOAT
+};
+
+struct _FORMAT_REC {
+ char *tag;
+ char *def;
+
+ int params;
+ int paramtypes[10];
+};
+
+typedef struct {
+ WINDOW_REC *window;
+ void *server;
+ const char *target;
+ int level;
+} TEXT_DEST_REC;
+
+char *format_get_text(const char *module, WINDOW_REC *window,
+ void *server, const char *target,
+ int formatnum, ...);
+
+char *format_get_text_theme(THEME_REC *theme, const char *module,
+ TEXT_DEST_REC *dest, int formatnum, ...);
+char *format_get_text_theme_args(THEME_REC *theme, const char *module,
+ TEXT_DEST_REC *dest, int formatnum,
+ va_list va);
+
+/* add `linestart' to start of each line in `text'. `text' may contain
+ multiple lines separated with \n. */
+char *format_add_linestart(const char *text, const char *linestart);
+
+/* return the "-!- " text at the start of the line */
+char *format_get_line_start(THEME_REC *theme, TEXT_DEST_REC *dest);
+
+
+/* "private" functions for printtext */
+void format_create_dest(TEXT_DEST_REC *dest,
+ void *server, const char *target,
+ int level, WINDOW_REC *window);
+
+#define FORMAT_COLOR_NOCHANGE ('0'-1)
+
+#define FORMAT_STYLE_SPECIAL 0x60
+#define FORMAT_STYLE_UNDERLINE (0x01 + FORMAT_STYLE_SPECIAL)
+#define FORMAT_STYLE_BOLD (0x02 + FORMAT_STYLE_SPECIAL)
+#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);
+
+#endif
diff --git a/src/fe-common/core/hilight-text.c b/src/fe-common/core/hilight-text.c
index 06029fe9..94b2952f 100644
--- a/src/fe-common/core/hilight-text.c
+++ b/src/fe-common/core/hilight-text.c
@@ -30,6 +30,7 @@
#include "servers.h"
#include "hilight-text.h"
+#include "printtext.h"
#define DEFAULT_HILIGHT_LEVEL \
(MSGLEVEL_PUBLIC | MSGLEVEL_MSGS | \
diff --git a/src/fe-common/core/keyboard.c b/src/fe-common/core/keyboard.c
index 80704db9..a21c11c1 100644
--- a/src/fe-common/core/keyboard.c
+++ b/src/fe-common/core/keyboard.c
@@ -29,6 +29,7 @@
#include "keyboard.h"
#include "windows.h"
+#include "printtext.h"
GSList *keyinfos;
static GHashTable *keys;
diff --git a/src/fe-common/core/module-formats.c b/src/fe-common/core/module-formats.c
index 91c7c1e7..43379fa8 100644
--- a/src/fe-common/core/module-formats.c
+++ b/src/fe-common/core/module-formats.c
@@ -19,7 +19,7 @@
*/
#include "module.h"
-#include "printtext.h"
+#include "formats.h"
FORMAT_REC fecommon_core_formats[] = {
{ MODULE_NAME, "Core", 0 },
diff --git a/src/fe-common/core/module-formats.h b/src/fe-common/core/module-formats.h
index 362b9074..57246414 100644
--- a/src/fe-common/core/module-formats.h
+++ b/src/fe-common/core/module-formats.h
@@ -1,4 +1,4 @@
-#include "printtext.h"
+#include "formats.h"
enum {
IRCTXT_MODULE_NAME,
diff --git a/src/fe-common/core/printtext.c b/src/fe-common/core/printtext.c
index dc352c13..d7ddb50a 100644
--- a/src/fe-common/core/printtext.c
+++ b/src/fe-common/core/printtext.c
@@ -23,7 +23,6 @@
#include "modules.h"
#include "signals.h"
#include "commands.h"
-#include "special-vars.h"
#include "settings.h"
#include "levels.h"
@@ -32,6 +31,7 @@
#include "translation.h"
#include "themes.h"
#include "windows.h"
+#include "printtext.h"
static int beep_msg_level, beep_when_away;
static int timestamps, msgs_timestamps, hide_text_style;
@@ -43,7 +43,7 @@ static int signal_print_text;
static int signal_print_text_finished;
static int signal_print_format;
-static void print_string(TEXT_DEST_REC *dest, const char *text);
+static void print_line(TEXT_DEST_REC *dest, const char *text);
void printbeep(void)
{
@@ -51,23 +51,47 @@ void printbeep(void)
GINT_TO_POINTER(PRINTFLAG_BEEP), "", MSGLEVEL_NEVER);
}
-static void skip_mirc_color(char **str)
+static void get_mirc_color(const char **str, int *fg_ret, int *bg_ret)
{
- if (!isdigit((int) **str))
- return;
-
- /* foreground */
- (*str)++;
- if (isdigit((int) **str)) (*str)++;
-
- if (**str != ',' || !isdigit((int) (*str)[1])) return;
+ int fg, bg;
+
+ fg = fg_ret == NULL ? -1 : *fg_ret;
+ bg = bg_ret == NULL ? -1 : *bg_ret;
+
+ if (!isdigit((int) **str) && **str != ',') {
+ fg = -1;
+ bg = -1;
+ } else {
+ /* foreground color */
+ if (**str != ',') {
+ fg = **str-'0';
+ (*str)++;
+ if (isdigit((int) **str)) {
+ fg = fg*10 + (**str-'0');
+ (*str)++;
+ }
+ }
+ if (**str == ',') {
+ /* background color */
+ (*str)++;
+ if (!isdigit((int) **str))
+ bg = -1;
+ else {
+ bg = **str-'0';
+ (*str)++;
+ if (isdigit((int) **str)) {
+ bg = bg*10 + (**str-'0');
+ (*str)++;
+ }
+ }
+ }
+ }
- /* background */
- (*str) += 2;
- if (isdigit((int) **str)) (*str)++;
+ if (fg_ret) *fg_ret = fg;
+ if (bg_ret) *bg_ret = bg;
}
-#define is_color_code(c) \
+#define IS_COLOR_CODE(c) \
((c) == 2 || (c) == 3 || (c) == 4 || (c) == 6 || (c) == 7 || \
(c) == 15 || (c) == 22 || (c) == 27 || (c) == 31)
@@ -81,25 +105,26 @@ char *strip_codes(const char *input)
if (*p == 3) {
p++;
- if (*p < 17 && *p > 0) {
- /* irssi color */
- if (p[1] < 17 && p[1] > 0) p++;
- continue;
- }
-
/* mirc color */
- skip_mirc_color((char **) &p);
+ get_mirc_color(&p, NULL, NULL);
p--;
continue;
}
- if (*p == 4 && p[1] != '\0' && p[2] != '\0') {
+ if (*p == 4 && p[1] != '\0') {
+ if (p[1] >= FORMAT_STYLE_SPECIAL) {
+ p++;
+ continue;
+ }
+
/* irssi color */
- p += 2;
- continue;
+ if (p[2] != '\0') {
+ p += 2;
+ continue;
+ }
}
- if (!is_color_code(*p))
+ if (!IS_COLOR_CODE(*p))
*out++ = *p;
}
@@ -108,20 +133,20 @@ char *strip_codes(const char *input)
}
/* parse ANSI color string */
-static char *convert_ansi(THEME_REC *theme, char *str,
- int *fgcolor, int *bgcolor, int *flags)
+static char *get_ansi_color(THEME_REC *theme, char *str,
+ int *fg_ret, int *bg_ret, int *flags_ret)
{
static char ansitab[8] = { 0, 4, 2, 6, 1, 5, 3, 7 };
char *start;
- int fg, bg, fl, num;
+ int fg, bg, flags, num;
if (*str != '[')
return str;
start = str++;
- fg = *fgcolor < 0 ? theme->default_color : *fgcolor;
- bg = *bgcolor < 0 ? -1 : *bgcolor;
- fl = *flags;
+ fg = fg_ret == NULL || *fg_ret < 0 ? theme->default_color : *fg_ret;
+ bg = bg_ret == NULL || *bg_ret < 0 ? -1 : *bg_ret;
+ flags = flags_ret == NULL ? 0 : *flags_ret;
num = 0;
for (;; str++) {
@@ -140,19 +165,19 @@ static char *convert_ansi(THEME_REC *theme, char *str,
/* reset colors back to default */
fg = theme->default_color;
bg = -1;
- fl &= ~(PRINTFLAG_BEEP|PRINTFLAG_INDENT);
+ flags &= ~(PRINTFLAG_BEEP|PRINTFLAG_INDENT);
break;
case 1:
/* hilight */
- fl |= PRINTFLAG_BOLD;
+ flags |= PRINTFLAG_BOLD;
break;
case 5:
/* blink */
- fl |= PRINTFLAG_BLINK;
+ flags |= PRINTFLAG_BLINK;
break;
case 7:
/* reverse */
- fl |= PRINTFLAG_REVERSE;
+ flags |= PRINTFLAG_REVERSE;
break;
default:
if (num >= 30 && num <= 37)
@@ -166,11 +191,10 @@ static char *convert_ansi(THEME_REC *theme, char *str,
num = 0;
if (*str == 'm') {
- if (!hide_text_style) {
- *fgcolor = fg;
- *bgcolor = bg;
- *flags = fl;
- }
+ if (fg_ret != NULL) *fg_ret = fg;
+ if (bg_ret != NULL) *bg_ret = bg;
+ if (flags_ret != NULL) *flags_ret = flags;
+
str++;
break;
}
@@ -179,301 +203,23 @@ static char *convert_ansi(THEME_REC *theme, char *str,
return str;
}
-static int expand_styles(GString *out, char format, TEXT_DEST_REC *dest)
-{
- static const char *backs = "04261537";
- static const char *fores = "kbgcrmyw";
- static const char *boldfores = "KBGCRMYW";
- char *p;
-
- switch (format) {
- case 'U':
- /* Underline on/off */
- g_string_append_c(out, 4);
- g_string_append_c(out, -1);
- g_string_append_c(out, 2);
- break;
- case '9':
- case '_':
- /* bold on/off */
- g_string_append_c(out, 4);
- g_string_append_c(out, -1);
- g_string_append_c(out, 1);
- break;
- case '8':
- /* reverse */
- g_string_append_c(out, 4);
- g_string_append_c(out, -1);
- g_string_append_c(out, 3);
- break;
- case '%':
- g_string_append_c(out, '%');
- break;
- case ':':
- /* Newline */
- print_string(dest, out->str);
- g_string_truncate(out, 0);
- break;
- case '|':
- /* Indent here */
- g_string_append_c(out, 4);
- g_string_append_c(out, -1);
- g_string_append_c(out, 4);
- break;
- case 'F':
- /* flashing - ignore */
- break;
- case 'N':
- /* don't put clear-color tag at the end of the output - ignore */
- break;
- case 'n':
- /* default color */
- g_string_append_c(out, 4);
- g_string_append_c(out, -1);
- g_string_append_c(out, -1);
- break;
- default:
- /* check if it's a background color */
- p = strchr(backs, format);
- if (p != NULL) {
- g_string_append_c(out, 4);
- g_string_append_c(out, -2);
- g_string_append_c(out, (int) (p-backs)+1);
- break;
- }
-
- /* check if it's a foreground color */
- if (format == 'p') format = 'm';
- p = strchr(fores, format);
- if (p != NULL) {
- g_string_append_c(out, 4);
- g_string_append_c(out, (int) (p-fores)+1);
- g_string_append_c(out, -2);
- break;
- }
-
- /* check if it's a bold foreground color */
- if (format == 'P') format = 'M';
- p = strchr(boldfores, format);
- if (p != NULL) {
- g_string_append_c(out, 4);
- g_string_append_c(out, 8+(int) (p-boldfores)+1);
- g_string_append_c(out, -2);
- break;
- }
-
- return FALSE;
- }
-
- return TRUE;
-}
-
-static void read_arglist(va_list va, FORMAT_REC *format,
- char **arglist, int arglist_size,
- char *buffer, int buffer_size)
-{
- int num, len, bufpos;
-
- bufpos = 0;
- arglist[format->params] = NULL;
- for (num = 0; num < format->params && num < arglist_size; num++) {
- switch (format->paramtypes[num]) {
- case FORMAT_STRING:
- arglist[num] = (char *) va_arg(va, char *);
- if (arglist[num] == NULL) {
- g_warning("read_arglist() : parameter %d is NULL", num);
- arglist[num] = "";
- }
- break;
- case FORMAT_INT: {
- int d = (int) va_arg(va, int);
-
- if (bufpos >= buffer_size) {
- arglist[num] = "";
- break;
- }
-
- arglist[num] = buffer+bufpos;
- len = g_snprintf(buffer+bufpos, buffer_size-bufpos,
- "%d", d);
- bufpos += len+1;
- break;
- }
- case FORMAT_LONG: {
- long l = (long) va_arg(va, long);
-
- if (bufpos >= buffer_size) {
- arglist[num] = "";
- break;
- }
-
- arglist[num] = buffer+bufpos;
- len = g_snprintf(buffer+bufpos, buffer_size-bufpos,
- "%ld", l);
- bufpos += len+1;
- break;
- }
- case FORMAT_FLOAT: {
- double f = (double) va_arg(va, double);
-
- if (bufpos >= buffer_size) {
- arglist[num] = "";
- break;
- }
-
- arglist[num] = buffer+bufpos;
- len = g_snprintf(buffer+bufpos, buffer_size-bufpos,
- "%0.2f", f);
- bufpos += len+1;
- break;
- }
- }
- }
-}
-
-static void create_dest_rec(TEXT_DEST_REC *dest,
- void *server, const char *target,
- int level, WINDOW_REC *window)
-{
- dest->server = server;
- dest->target = target;
- dest->level = level;
- dest->window = window != NULL ? window :
- window_find_closest(server, target, level);
-}
-
-char *output_format_text_args(TEXT_DEST_REC *dest, FORMAT_REC *format,
- const char *text, va_list va)
-{
- GString *out;
- char *arglist[10];
- char buffer[200]; /* should be enough? (won't overflow even if it isn't) */
-
- char code, *ret;
- int need_free;
-
- /* read all optional arguments to arglist[] list
- so they can be used in any order.. */
- read_arglist(va, format,
- arglist, sizeof(arglist)/sizeof(void*),
- buffer, sizeof(buffer));
-
- out = g_string_new(NULL);
-
- code = 0;
- while (*text != '\0') {
- if (code == '%') {
- /* color code */
- if (!expand_styles(out, *text, dest)) {
- g_string_append_c(out, '%');
- g_string_append_c(out, '%');
- g_string_append_c(out, *text);
- }
- code = 0;
- } else if (code == '$') {
- /* argument */
- char *ret;
-
- ret = parse_special((char **) &text, active_win->active_server,
- active_win->active, arglist, &need_free, NULL);
-
- if (ret != NULL) {
- /* string shouldn't end with \003 or it could
- mess up the next one or two characters */
- int diff;
- int len = strlen(ret);
- while (len > 0 && ret[len-1] == 3) len--;
- diff = strlen(ret)-len;
-
- g_string_append(out, ret);
- if (diff > 0)
- g_string_truncate(out, out->len-diff);
- if (need_free) g_free(ret);
- }
- code = 0;
- } else {
- if (*text == '%' || *text == '$')
- code = *text;
- else
- g_string_append_c(out, *text);
- }
-
- text++;
- }
-
- ret = out->str;
- g_string_free(out, FALSE);
- return ret;
-}
-
-char *output_format_get_text(const char *module, WINDOW_REC *window,
- void *server, const char *target,
- int formatnum, ...)
-{
- TEXT_DEST_REC dest;
- THEME_REC *theme;
- MODULE_THEME_REC *module_theme;
- FORMAT_REC *formats;
- va_list va;
- char *ret;
-
- create_dest_rec(&dest, server, target, 0, window);
- theme = dest.window->theme == NULL ? current_theme :
- dest.window->theme;
-
- module_theme = g_hash_table_lookup(theme->modules, module);
- formats = g_hash_table_lookup(default_formats, module);
-
- va_start(va, formatnum);
- ret = output_format_text_args(&dest, &formats[formatnum],
- module_theme->expanded_formats[formatnum], va);
- va_end(va);
-
- return ret;
-}
-
-static char *output_format_text(TEXT_DEST_REC *dest, int formatnum, ...)
-{
- THEME_REC *theme;
- MODULE_THEME_REC *module_theme;
- va_list va;
- char *ret;
-
- theme = dest->window->theme == NULL ? current_theme :
- dest->window->theme;
- module_theme = g_hash_table_lookup(theme->modules, MODULE_NAME);
-
- va_start(va, formatnum);
- ret = output_format_text_args(dest, &fecommon_core_formats[formatnum],
- module_theme->expanded_formats[formatnum], va);
- va_end(va);
-
- return ret;
-}
-
void printformat_module_args(const char *module, void *server,
const char *target, int level,
int formatnum, va_list va)
{
THEME_REC *theme;
- MODULE_THEME_REC *module_theme;
TEXT_DEST_REC dest;
- FORMAT_REC *formats;
char *str;
- create_dest_rec(&dest, server, target, level, NULL);
+ format_create_dest(&dest, server, target, level, NULL);
theme = dest.window->theme == NULL ? current_theme :
dest.window->theme;
signal_emit_id(signal_print_format, 5, theme, module,
&dest, GINT_TO_POINTER(formatnum), va);
- module_theme = g_hash_table_lookup(theme->modules, module);
- formats = g_hash_table_lookup(default_formats, module);
-
- str = output_format_text_args(&dest, &formats[formatnum],
- module_theme->expanded_formats[formatnum], va);
- if (*str != '\0') print_string(&dest, str);
+ str = format_get_text_theme_args(theme, module, &dest, formatnum, va);
+ if (*str != '\0') print_line(&dest, str);
g_free(str);
}
@@ -490,24 +236,18 @@ void printformat_module_window_args(const char *module, WINDOW_REC *window,
int level, int formatnum, va_list va)
{
THEME_REC *theme;
- MODULE_THEME_REC *module_theme;
TEXT_DEST_REC dest;
- FORMAT_REC *formats;
char *str;
- create_dest_rec(&dest, NULL, NULL, level, window);
+ format_create_dest(&dest, NULL, NULL, level, window);
theme = window->theme == NULL ? current_theme :
window->theme;
signal_emit_id(signal_print_format, 5, theme, module,
&dest, GINT_TO_POINTER(formatnum), va);
- module_theme = g_hash_table_lookup(theme->modules, module);
- formats = g_hash_table_lookup(default_formats, module);
-
- str = output_format_text_args(&dest, &formats[formatnum],
- module_theme->expanded_formats[formatnum], va);
- if (*str != '\0') print_string(&dest, str);
+ str = format_get_text_theme_args(theme, module, &dest, formatnum, va);
+ if (*str != '\0') print_line(&dest, str);
g_free(str);
}
@@ -521,37 +261,16 @@ void printformat_module_window(const char *module, WINDOW_REC *window,
va_end(va);
}
-#define LINE_START_IRSSI_LEVEL \
- (MSGLEVEL_CLIENTERROR | MSGLEVEL_CLIENTNOTICE)
-
-#define NOT_LINE_START_LEVEL \
- (MSGLEVEL_NEVER | MSGLEVEL_LASTLOG | MSGLEVEL_CLIENTCRAP | \
- MSGLEVEL_MSGS | MSGLEVEL_PUBLIC | MSGLEVEL_DCC | MSGLEVEL_DCCMSGS | \
- MSGLEVEL_ACTIONS | MSGLEVEL_NOTICES | MSGLEVEL_SNOTES | MSGLEVEL_CTCPS)
-
-/* return the "-!- " text at the start of the line */
-char *get_line_start_text(TEXT_DEST_REC *dest)
+static void print_line(TEXT_DEST_REC *dest, const char *text)
{
- if (dest->level & LINE_START_IRSSI_LEVEL)
- return output_format_text(dest, IRCTXT_LINE_START_IRSSI);
-
- if ((dest->level & NOT_LINE_START_LEVEL) == 0)
- return output_format_text(dest, IRCTXT_LINE_START);
-
- return NULL;
-}
-
-static void print_string(TEXT_DEST_REC *dest, const char *text)
-{
- gpointer levelp;
+ void *levelp;
char *str, *tmp;
g_return_if_fail(dest != NULL);
g_return_if_fail(text != NULL);
- tmp = get_line_start_text(dest);
- str = tmp == NULL ? (char *) text :
- g_strconcat(tmp, text, NULL);
+ tmp = format_get_line_start(current_theme, dest);
+ str = format_add_linestart(text, tmp);
g_free_not_null(tmp);
levelp = GINT_TO_POINTER(dest->level);
@@ -562,7 +281,7 @@ static void print_string(TEXT_DEST_REC *dest, const char *text)
g_free(tmp);
signal_emit_id(signal_print_text, 5, dest->window, dest->server, dest->target, levelp, str);
- if (str != text) g_free(str);
+ g_free(str);
}
/* append string to `out', expand newlines. */
@@ -572,7 +291,7 @@ static void printtext_append_str(TEXT_DEST_REC *dest, GString *out, const char *
if (*str != '\n')
g_string_append_c(out, *str);
else {
- print_string(dest, out->str);
+ print_line(dest, out->str);
g_string_truncate(out, 0);
}
str++;
@@ -631,7 +350,7 @@ static char *printtext_get_args(TEXT_DEST_REC *dest, const char *str, va_list va
break;
}
default:
- if (!expand_styles(out, *str, dest)) {
+ if (!format_expand_styles(out, *str, dest)) {
g_string_append_c(out, '%');
g_string_append_c(out, *str);
}
@@ -653,13 +372,13 @@ void printtext(void *server, const char *target, int level, const char *text, ..
g_return_if_fail(text != NULL);
- create_dest_rec(&dest, server, target, level, NULL);
+ format_create_dest(&dest, server, target, level, NULL);
va_start(va, text);
str = printtext_get_args(&dest, text, va);
va_end(va);
- print_string(&dest, str);
+ print_line(&dest, str);
g_free(str);
}
@@ -671,14 +390,14 @@ void printtext_window(WINDOW_REC *window, int level, const char *text, ...)
g_return_if_fail(text != NULL);
- create_dest_rec(&dest, NULL, NULL, level,
- window != NULL ? window : active_win);
+ format_create_dest(&dest, NULL, NULL, level,
+ window != NULL ? window : active_win);
va_start(va, text);
str = printtext_get_args(&dest, text, va);
va_end(va);
- print_string(&dest, str);
+ print_line(&dest, str);
g_free(str);
}
@@ -715,9 +434,10 @@ static char *get_timestamp(TEXT_DEST_REC *dest)
}
tm = localtime(&t);
- return output_format_text(dest, IRCTXT_TIMESTAMP,
- tm->tm_year+1900, tm->tm_mon+1, tm->tm_mday,
- tm->tm_hour, tm->tm_min, tm->tm_sec);
+ return format_get_text_theme(NULL, MODULE_NAME, dest, IRCTXT_TIMESTAMP,
+ tm->tm_year+1900,
+ tm->tm_mon+1, tm->tm_mday,
+ tm->tm_hour, tm->tm_min, tm->tm_sec);
}
static char *get_server_tag(TEXT_DEST_REC *dest)
@@ -730,7 +450,8 @@ static char *get_server_tag(TEXT_DEST_REC *dest)
(dest->window->active != NULL && dest->window->active->server == server))
return NULL;
- return output_format_text(dest, IRCTXT_SERVERTAG, server->tag);
+ return format_get_text_theme(NULL, MODULE_NAME, dest,
+ IRCTXT_SERVERTAG, server->tag);
}
static void msg_beep_check(SERVER_REC *server, int level)
@@ -742,197 +463,166 @@ static void msg_beep_check(SERVER_REC *server, int level)
}
}
+static char *fix_line_start(TEXT_DEST_REC *dest, const char *text)
+{
+ char *timestamp, *servertag;
+ char *linestart, *str;
+
+ timestamp = get_timestamp(dest);
+ servertag = get_server_tag(dest);
+
+ if (timestamp == NULL && servertag == NULL)
+ return g_strdup(text);
+
+ linestart = g_strconcat(timestamp != NULL ? timestamp : "",
+ servertag, NULL);
+ str = format_add_linestart(text, linestart);
+ g_free(linestart);
+
+ g_free_not_null(timestamp);
+ g_free_not_null(servertag);
+ return str;
+}
+
static void sig_print_text(WINDOW_REC *window, SERVER_REC *server,
const char *target, gpointer level,
const char *text)
{
- TEXT_DEST_REC dest;
- char *dup, *ptr, type, *str, *timestamp, *servertag;
- int fgcolor, bgcolor;
- int flags;
-
- g_return_if_fail(text != NULL);
- g_return_if_fail(window != NULL);
-
- create_dest_rec(&dest, server, target, GPOINTER_TO_INT(level), window);
- msg_beep_check(server, dest.level);
-
- flags = 0; fgcolor = -1; bgcolor = -1; type = '\0';
- window->last_line = time(NULL);
- newline(window);
-
- timestamp = get_timestamp(&dest);
- servertag = get_server_tag(&dest);
- str = g_strconcat(timestamp != NULL ? timestamp : "",
- servertag != NULL ? servertag : "",
- text, NULL);
- g_free_not_null(timestamp);
- g_free_not_null(servertag);
-
- dup = str;
- while (*str != '\0')
- {
- for (ptr = str; *ptr != '\0'; ptr++)
- {
- if (is_color_code(*ptr))
- {
- type = *ptr;
- *ptr++ = '\0';
- break;
- }
-
- *ptr = (char) translation_in[(gint) (guchar) *ptr];
- }
+ TEXT_DEST_REC dest;
+ char *dup, *ptr, type, *str;
+ int fgcolor, bgcolor;
+ int flags;
- if (type == 7)
- {
- /* bell */
- if (settings_get_bool("bell_beeps"))
- flags |= PRINTFLAG_BEEP;
- }
- if (*str != '\0' || flags & PRINTFLAG_BEEP)
- {
- signal_emit_id(signal_gui_print_text, 6, window,
- GINT_TO_POINTER(fgcolor), GINT_TO_POINTER(bgcolor),
- GINT_TO_POINTER(flags), str, level);
- flags &= ~(PRINTFLAG_BEEP|PRINTFLAG_INDENT);
- }
- if (*ptr == '\0') break;
-
- switch (type)
- {
- case 2:
- /* bold */
- if (!hide_text_style)
- flags ^= PRINTFLAG_BOLD;
- break;
- case 6:
- /* blink */
- if (!hide_text_style)
- flags ^= PRINTFLAG_BLINK;
- break;
- case 15:
- /* remove all styling */
- flags &= PRINTFLAG_BEEP;
- fgcolor = bgcolor = -1;
- break;
- case 22:
- /* reverse */
- if (!hide_text_style)
- flags ^= PRINTFLAG_REVERSE;
- break;
- case 31:
- /* underline */
- if (!hide_text_style)
- flags ^= PRINTFLAG_UNDERLINE;
- case 27:
- /* ansi color code */
- ptr = convert_ansi(window->theme == NULL ? current_theme :
- window->theme, ptr, &fgcolor, &bgcolor, &flags);
- break;
- case 4:
- /* user specific colors */
- flags &= ~PRINTFLAG_MIRC_COLOR;
- if ((signed char) *ptr == -1)
- {
- ptr++;
- if ((signed char) *ptr == -1)
- {
- fgcolor = bgcolor = -1;
- flags &= PRINTFLAG_INDENT;
- }
- else if (*ptr == 1)
- flags ^= PRINTFLAG_BOLD;
- else if (*ptr == 2)
- flags ^= PRINTFLAG_UNDERLINE;
- else if (*ptr == 3)
- flags ^= PRINTFLAG_REVERSE;
- else if (*ptr == 4)
- flags |= PRINTFLAG_INDENT;
- }
- else
- {
- if ((signed char) *ptr != -2)
- {
- fgcolor = (guchar) *ptr-1;
- if (fgcolor <= 7)
- flags &= ~PRINTFLAG_BOLD;
- else
- {
- /* bold */
- if (fgcolor != 8) fgcolor -= 8;
- flags |= PRINTFLAG_BOLD;
+ g_return_if_fail(text != NULL);
+ g_return_if_fail(window != NULL);
+
+ format_create_dest(&dest, server, target,
+ GPOINTER_TO_INT(level), window);
+ msg_beep_check(server, dest.level);
+
+ window->last_line = time(NULL);
+ newline(window);
+
+ dup = str = fix_line_start(&dest, text);
+ flags = 0; fgcolor = -1; bgcolor = -1; type = '\0';
+ while (*str != '\0') {
+ for (ptr = str; *ptr != '\0'; ptr++) {
+ if (IS_COLOR_CODE(*ptr)) {
+ type = *ptr;
+ *ptr++ = '\0';
+ break;
}
- }
- ptr++;
- if ((signed char) *ptr != -2)
- bgcolor = (signed char) *ptr == -1 ? -1 : *ptr-1;
- }
- ptr++;
- break;
- case 3:
- if (*ptr < 17)
- {
- /* mostly just for irssi's internal use.. */
- fgcolor = (*ptr++)-1;
- if (*ptr == 0 || *ptr >= 17)
- bgcolor = -1;
- else
- bgcolor = (*ptr++)-1;
- if (fgcolor & 8)
- flags |= PRINTFLAG_BOLD;
- else
- flags &= ~PRINTFLAG_BOLD;
- break;
- }
- /* MIRC color */
- if (hide_text_style)
- {
- /* don't show them. */
- skip_mirc_color(&ptr);
- break;
- }
+ *ptr = (char) translation_in[(int) (unsigned char) *ptr];
+ }
- flags |= PRINTFLAG_MIRC_COLOR;
- if (!isdigit((gint) *ptr) && *ptr != ',')
- {
- fgcolor = -1;
- bgcolor = -1;
+ if (type == 7) {
+ /* bell */
+ if (settings_get_bool("bell_beeps"))
+ flags |= PRINTFLAG_BEEP;
}
- else
+ if (*str != '\0' || flags & PRINTFLAG_BEEP) {
+ /* send the text to gui handler */
+ signal_emit_id(signal_gui_print_text, 6, window,
+ GINT_TO_POINTER(fgcolor),
+ GINT_TO_POINTER(bgcolor),
+ GINT_TO_POINTER(flags), str, level);
+ flags &= ~(PRINTFLAG_BEEP|PRINTFLAG_INDENT);
+ }
+
+ if (*ptr == '\0')
+ break;
+
+ switch (type)
{
- /* foreground color */
- if (*ptr != ',')
- {
- fgcolor = *ptr++-'0';
- if (isdigit((gint) *ptr))
- fgcolor = fgcolor*10 + (*ptr++-'0');
- }
- if (*ptr == ',')
- {
- /* back color */
- bgcolor = 0;
- if (!isdigit((gint) *++ptr))
- bgcolor = -1;
- else
- {
- bgcolor = *ptr++-'0';
- if (isdigit((gint) *ptr))
- bgcolor = bgcolor*10 + (*ptr++-'0');
+ case 2:
+ /* bold */
+ if (!hide_text_style)
+ flags ^= PRINTFLAG_BOLD;
+ break;
+ case 6:
+ /* blink */
+ if (!hide_text_style)
+ flags ^= PRINTFLAG_BLINK;
+ break;
+ case 15:
+ /* remove all styling */
+ flags &= PRINTFLAG_BEEP;
+ fgcolor = bgcolor = -1;
+ break;
+ case 22:
+ /* reverse */
+ if (!hide_text_style)
+ flags ^= PRINTFLAG_REVERSE;
+ break;
+ case 31:
+ /* underline */
+ if (!hide_text_style)
+ flags ^= PRINTFLAG_UNDERLINE;
+ case 27:
+ /* ansi color code */
+ ptr = get_ansi_color(window->theme == NULL ?
+ current_theme : window->theme,
+ ptr,
+ hide_text_style ? NULL : &fgcolor,
+ hide_text_style ? NULL : &bgcolor,
+ hide_text_style ? NULL : &flags);
+ break;
+ case 4:
+ /* user specific colors */
+ flags &= ~PRINTFLAG_MIRC_COLOR;
+ switch (*ptr) {
+ case FORMAT_STYLE_UNDERLINE:
+ flags ^= PRINTFLAG_UNDERLINE;
+ break;
+ case FORMAT_STYLE_BOLD:
+ flags ^= PRINTFLAG_BOLD;
+ break;
+ case FORMAT_STYLE_REVERSE:
+ flags ^= PRINTFLAG_REVERSE;
+ break;
+ case FORMAT_STYLE_INDENT:
+ flags |= PRINTFLAG_INDENT;
+ break;
+ case FORMAT_STYLE_DEFAULTS:
+ fgcolor = bgcolor = -1;
+ flags &= PRINTFLAG_INDENT;
+ break;
+ default:
+ if (*ptr != FORMAT_COLOR_NOCHANGE) {
+ fgcolor = (unsigned char) *ptr-'0';
+ if (fgcolor <= 7)
+ flags &= ~PRINTFLAG_BOLD;
+ else {
+ /* bold */
+ if (fgcolor != 8) fgcolor -= 8;
+ flags |= PRINTFLAG_BOLD;
+ }
+ }
+ ptr++;
+ if (*ptr != FORMAT_COLOR_NOCHANGE)
+ bgcolor = *ptr-'0';
}
- }
+ ptr++;
+ break;
+ case 3:
+ /* MIRC color */
+ get_mirc_color((const char **) &ptr,
+ hide_text_style ? NULL : &fgcolor,
+ hide_text_style ? NULL : &bgcolor);
+ if (!hide_text_style)
+ flags |= PRINTFLAG_MIRC_COLOR;
+ break;
}
- break;
- }
- str = ptr;
- }
- g_free(dup);
- signal_emit_id(signal_print_text_finished, 1, window);
+ str = ptr;
+ }
+ g_free(dup);
+ signal_emit_id(signal_print_text_finished, 1, window);
}
-void printtext_multiline(void *server, const char *target, int level, const char *format, const char *text)
+void printtext_multiline(void *server, const char *target, int level,
+ const char *format, const char *text)
{
char **lines, **tmp;
diff --git a/src/fe-common/core/printtext.h b/src/fe-common/core/printtext.h
index e75a105a..9ec79023 100644
--- a/src/fe-common/core/printtext.h
+++ b/src/fe-common/core/printtext.h
@@ -3,21 +3,6 @@
#include "windows.h"
-enum {
- FORMAT_STRING,
- FORMAT_INT,
- FORMAT_LONG,
- FORMAT_FLOAT
-};
-
-typedef struct {
- char *tag;
- char *def;
-
- int params;
- int paramtypes[10];
-} FORMAT_REC;
-
#define PRINTFLAG_BOLD 0x01
#define PRINTFLAG_REVERSE 0x02
#define PRINTFLAG_UNDERLINE 0x04
@@ -26,10 +11,6 @@ typedef struct {
#define PRINTFLAG_MIRC_COLOR 0x20
#define PRINTFLAG_INDENT 0x40
-char *output_format_get_text(const char *module, WINDOW_REC *window,
- void *server, const char *target,
- int formatnum, ...);
-
void printformat_module(const char *module, void *server, const char *target, int level, int formatnum, ...);
void printformat_module_window(const char *module, WINDOW_REC *window, int level, int formatnum, ...);
@@ -67,9 +48,10 @@ void printtext_deinit(void);
printformat_module_window(MODULE_NAME, window, level, formatnum, __VA_ARGS__)
#else
/* inline/static */
-static
#ifdef G_CAN_INLINE
-inline
+G_INLINE_FUNC
+#else
+static
#endif
void printformat(void *server, const char *target, int level, int formatnum, ...)
{
@@ -80,9 +62,10 @@ void printformat(void *server, const char *target, int level, int formatnum, ...
va_end(va);
}
-static
#ifdef G_CAN_INLINE
-inline
+G_INLINE_FUNC
+#else
+static
#endif
void printformat_window(WINDOW_REC *window, int level, int formatnum, ...)
{
@@ -94,18 +77,4 @@ void printformat_window(WINDOW_REC *window, int level, int formatnum, ...)
}
#endif
-/* semi-private functions.. */
-typedef struct {
- WINDOW_REC *window;
- void *server;
- const char *target;
- int level;
-} TEXT_DEST_REC;
-
-char *output_format_text_args(TEXT_DEST_REC *dest, FORMAT_REC *format,
- const char *text, va_list va);
-
-/* return the "-!- " text at the start of the line */
-char *get_line_start_text(TEXT_DEST_REC *dest);
-
#endif
diff --git a/src/fe-common/core/themes.c b/src/fe-common/core/themes.c
index c9026e46..24685c17 100644
--- a/src/fe-common/core/themes.c
+++ b/src/fe-common/core/themes.c
@@ -29,6 +29,7 @@
#include "settings.h"
#include "themes.h"
+#include "printtext.h"
GSList *themes;
THEME_REC *current_theme;
diff --git a/src/fe-common/core/themes.h b/src/fe-common/core/themes.h
index c5e48355..cfca4c0d 100644
--- a/src/fe-common/core/themes.h
+++ b/src/fe-common/core/themes.h
@@ -1,8 +1,6 @@
#ifndef __THEMES_H
#define __THEMES_H
-#include "printtext.h"
-
typedef struct {
char *name;
@@ -26,6 +24,8 @@ typedef struct {
void *gui_data;
} THEME_REC;
+typedef struct _FORMAT_REC FORMAT_REC;
+
extern GSList *themes;
extern THEME_REC *current_theme;
extern GHashTable *default_formats;
diff --git a/src/fe-common/core/window-commands.c b/src/fe-common/core/window-commands.c
index 60fa1c9b..b9ef8450 100644
--- a/src/fe-common/core/window-commands.c
+++ b/src/fe-common/core/window-commands.c
@@ -31,6 +31,7 @@
#include "windows.h"
#include "window-items.h"
#include "window-save.h"
+#include "printtext.h"
static void cmd_window(const char *data, void *server, WI_ITEM_REC *item)
{
diff --git a/src/fe-common/core/window-items.c b/src/fe-common/core/window-items.c
index 443ca586..52065d86 100644
--- a/src/fe-common/core/window-items.c
+++ b/src/fe-common/core/window-items.c
@@ -29,6 +29,7 @@
#include "windows.h"
#include "window-items.h"
+#include "printtext.h"
void window_add_item(WINDOW_REC *window, WI_ITEM_REC *item, int automatic)
{
diff --git a/src/fe-common/irc/dcc/fe-dcc.c b/src/fe-common/irc/dcc/fe-dcc.c
index 08869107..bcd6ae34 100644
--- a/src/fe-common/irc/dcc/fe-dcc.c
+++ b/src/fe-common/irc/dcc/fe-dcc.c
@@ -35,6 +35,7 @@
#include "windows.h"
#include "module-formats.h"
+#include "printtext.h"
static void dcc_connected(DCC_REC *dcc)
{
diff --git a/src/fe-common/irc/dcc/module-formats.c b/src/fe-common/irc/dcc/module-formats.c
index 4fe22dbd..3994e9d3 100644
--- a/src/fe-common/irc/dcc/module-formats.c
+++ b/src/fe-common/irc/dcc/module-formats.c
@@ -19,7 +19,7 @@
*/
#include "module.h"
-#include "printtext.h"
+#include "formats.h"
FORMAT_REC fecommon_irc_dcc_formats[] = {
{ MODULE_NAME, "IRC", 0 },
diff --git a/src/fe-common/irc/dcc/module-formats.h b/src/fe-common/irc/dcc/module-formats.h
index ac07846d..f1a89e62 100644
--- a/src/fe-common/irc/dcc/module-formats.h
+++ b/src/fe-common/irc/dcc/module-formats.h
@@ -1,4 +1,4 @@
-#include "printtext.h"
+#include "formats.h"
enum {
IRCTXT_MODULE_NAME,
diff --git a/src/fe-common/irc/fe-ctcp.c b/src/fe-common/irc/fe-ctcp.c
index 1c2ed843..02703883 100644
--- a/src/fe-common/irc/fe-ctcp.c
+++ b/src/fe-common/irc/fe-ctcp.c
@@ -32,6 +32,7 @@
#include "windows.h"
#include "window-items.h"
+#include "printtext.h"
static void ctcp_print(const char *pre, const char *data, IRC_SERVER_REC *server, const char *nick, const char *addr, const char *target)
{
diff --git a/src/fe-common/irc/fe-events-numeric.c b/src/fe-common/irc/fe-events-numeric.c
index 0bc6d245..fb506d68 100644
--- a/src/fe-common/irc/fe-events-numeric.c
+++ b/src/fe-common/irc/fe-events-numeric.c
@@ -30,6 +30,8 @@
#include "irc-channels.h"
#include "nicklist.h"
+#include "printtext.h"
+
static char *last_away_nick = NULL;
static char *last_away_msg = NULL;
@@ -96,10 +98,10 @@ static void display_sorted_nicks(CHANNEL_REC *channel, GSList *nicklist, gint it
memset(linebuf, ' ', max);
nickmode[0] = rec->op ? '@' : rec->voice ? '+' : ' ';
memcpy(linebuf, rec->nick, strlen(rec->nick));
- ret = output_format_get_text(MODULE_NAME, NULL,
- channel->server, channel->name,
- IRCTXT_NAMES_NICK, nickmode, linebuf);
- g_string_append(str, ret);
+ ret = format_get_text(MODULE_NAME, NULL,
+ channel->server, channel->name,
+ IRCTXT_NAMES_NICK, nickmode, linebuf);
+ g_string_append(str, ret);
g_free(ret);
cols++;
}
diff --git a/src/fe-common/irc/fe-events.c b/src/fe-common/irc/fe-events.c
index acce8c20..4e1c70f7 100644
--- a/src/fe-common/irc/fe-events.c
+++ b/src/fe-common/irc/fe-events.c
@@ -36,6 +36,7 @@
#include "irc-channels.h"
#include "irc-nicklist.h"
#include "windows.h"
+#include "printtext.h"
#include "completion.h"
diff --git a/src/fe-common/irc/fe-irc-channels.c b/src/fe-common/irc/fe-irc-channels.c
index 8a7de92d..ef9a79b8 100644
--- a/src/fe-common/irc/fe-irc-channels.c
+++ b/src/fe-common/irc/fe-irc-channels.c
@@ -28,6 +28,8 @@
#include "irc.h"
#include "channel-rejoin.h"
+#include "printtext.h"
+
static void sig_channel_rejoin(IRC_SERVER_REC *server, REJOIN_REC *rec)
{
g_return_if_fail(rec != NULL);
diff --git a/src/fe-common/irc/fe-irc-commands.c b/src/fe-common/irc/fe-irc-commands.c
index aae3bbc1..43bf0e94 100644
--- a/src/fe-common/irc/fe-irc-commands.c
+++ b/src/fe-common/irc/fe-irc-commands.c
@@ -36,6 +36,7 @@
#include "fe-queries.h"
#include "windows.h"
#include "window-items.h"
+#include "printtext.h"
/* SYNTAX: ME <message> */
static void cmd_me(gchar *data, IRC_SERVER_REC *server, WI_ITEM_REC *item)
diff --git a/src/fe-common/irc/fe-irc-server.c b/src/fe-common/irc/fe-irc-server.c
index ace02feb..635391c4 100644
--- a/src/fe-common/irc/fe-irc-server.c
+++ b/src/fe-common/irc/fe-irc-server.c
@@ -32,6 +32,7 @@
#include "irc-servers-setup.h"
#include "windows.h"
+#include "printtext.h"
static void sig_server_add_create(IRC_SERVER_SETUP_REC **rec,
GHashTable *optlist)
diff --git a/src/fe-common/irc/fe-ircnet.c b/src/fe-common/irc/fe-ircnet.c
index 090c8a61..99dd7a69 100644
--- a/src/fe-common/irc/fe-ircnet.c
+++ b/src/fe-common/irc/fe-ircnet.c
@@ -28,6 +28,7 @@
#include "irc-servers.h"
#include "irc-chatnets.h"
+#include "printtext.h"
static void cmd_ircnet_list(void)
{
diff --git a/src/fe-common/irc/fe-netjoin.c b/src/fe-common/irc/fe-netjoin.c
index 9ce718db..40b43dcb 100644
--- a/src/fe-common/irc/fe-netjoin.c
+++ b/src/fe-common/irc/fe-netjoin.c
@@ -31,6 +31,8 @@
#include "ignore.h"
#include "netsplit.h"
+#include "printtext.h"
+
#define NETJOIN_WAIT_TIME 2 /* how many seconds to wait for the netsplitted JOIN messages to stop */
#define NETJOIN_MAX_WAIT 30 /* how many seconds to wait for nick to join to the rest of the channels she was before the netsplit */
diff --git a/src/fe-common/irc/fe-netsplit.c b/src/fe-common/irc/fe-netsplit.c
index a756ea7a..4b3a19a6 100644
--- a/src/fe-common/irc/fe-netsplit.c
+++ b/src/fe-common/irc/fe-netsplit.c
@@ -30,6 +30,8 @@
#include "ignore.h"
#include "netsplit.h"
+#include "printtext.h"
+
#define SPLIT_WAIT_TIME 2 /* how many seconds to wait for the QUIT split messages to stop */
static int split_tag;
diff --git a/src/fe-common/irc/flood/fe-flood.c b/src/fe-common/irc/flood/fe-flood.c
index ce96699f..7f5a0ee5 100644
--- a/src/fe-common/irc/flood/fe-flood.c
+++ b/src/fe-common/irc/flood/fe-flood.c
@@ -27,6 +27,7 @@
#include "irc/flood/autoignore.h"
#include "themes.h"
+#include "printtext.h"
static void event_autoignore_new(IRC_SERVER_REC *server, AUTOIGNORE_REC *ignore)
{
diff --git a/src/fe-common/irc/flood/module-formats.c b/src/fe-common/irc/flood/module-formats.c
index 2cca360f..29b76ace 100644
--- a/src/fe-common/irc/flood/module-formats.c
+++ b/src/fe-common/irc/flood/module-formats.c
@@ -19,7 +19,7 @@
*/
#include "module.h"
-#include "printtext.h"
+#include "formats.h"
FORMAT_REC fecommon_irc_flood_formats[] =
{
diff --git a/src/fe-common/irc/flood/module-formats.h b/src/fe-common/irc/flood/module-formats.h
index 7386dd2a..73e313ba 100644
--- a/src/fe-common/irc/flood/module-formats.h
+++ b/src/fe-common/irc/flood/module-formats.h
@@ -1,4 +1,4 @@
-#include "printtext.h"
+#include "formats.h"
enum {
IRCTXT_MODULE_NAME,
diff --git a/src/fe-common/irc/module-formats.c b/src/fe-common/irc/module-formats.c
index 01197397..4229faff 100644
--- a/src/fe-common/irc/module-formats.c
+++ b/src/fe-common/irc/module-formats.c
@@ -19,7 +19,7 @@
*/
#include "module.h"
-#include "printtext.h"
+#include "formats.h"
FORMAT_REC fecommon_irc_formats[] = {
{ MODULE_NAME, "IRC", 0 },
diff --git a/src/fe-common/irc/module-formats.h b/src/fe-common/irc/module-formats.h
index 4bf14185..c1ad6d9d 100644
--- a/src/fe-common/irc/module-formats.h
+++ b/src/fe-common/irc/module-formats.h
@@ -1,4 +1,4 @@
-#include "printtext.h"
+#include "formats.h"
enum {
IRCTXT_MODULE_NAME,
diff --git a/src/fe-common/irc/notifylist/fe-notifylist.c b/src/fe-common/irc/notifylist/fe-notifylist.c
index cd9adf9c..a408fb15 100644
--- a/src/fe-common/irc/notifylist/fe-notifylist.c
+++ b/src/fe-common/irc/notifylist/fe-notifylist.c
@@ -33,6 +33,7 @@
#include "irc/notifylist/notifylist.h"
#include "themes.h"
+#include "printtext.h"
/* add the nick of a hostmask to list if it isn't there already */
static GSList *mask_add_once(GSList *list, const char *mask)
diff --git a/src/fe-common/irc/notifylist/module-formats.c b/src/fe-common/irc/notifylist/module-formats.c
index 345dfe24..0b29406e 100644
--- a/src/fe-common/irc/notifylist/module-formats.c
+++ b/src/fe-common/irc/notifylist/module-formats.c
@@ -19,7 +19,7 @@
*/
#include "module.h"
-#include "printtext.h"
+#include "formats.h"
FORMAT_REC fecommon_irc_notifylist_formats[] =
{
diff --git a/src/fe-common/irc/notifylist/module-formats.h b/src/fe-common/irc/notifylist/module-formats.h
index e37045f1..e934def3 100644
--- a/src/fe-common/irc/notifylist/module-formats.h
+++ b/src/fe-common/irc/notifylist/module-formats.h
@@ -1,4 +1,4 @@
-#include "printtext.h"
+#include "formats.h"
enum {
IRCTXT_MODULE_NAME,
diff --git a/src/fe-text/gui-textwidget.c b/src/fe-text/gui-textwidget.c
index 9b16e691..04055bb4 100644
--- a/src/fe-text/gui-textwidget.c
+++ b/src/fe-text/gui-textwidget.c
@@ -28,6 +28,7 @@
#include "irc-servers.h"
#include "windows.h"
+#include "printtext.h"
#include "screen.h"
#include "gui-windows.h"
@@ -56,8 +57,8 @@ static gchar *gui_window_line2text(LINE_REC *line)
{
/* set color */
color = *ptr;
- g_string_sprintfa(str, "\003%c%c", (color & 0x07)+1, ((color & 0xf0) >> 4)+1);
- if (color & 0x08) g_string_sprintfa(str, "\002");
+ g_string_sprintfa(str, "\004%c%c", (color & 0x0f)+'0',
+ ((color & 0xf0) >> 4)+'0');
}
else switch ((guchar) *ptr)
{
@@ -73,16 +74,19 @@ static gchar *gui_window_line2text(LINE_REC *line)
g_string_append_c(str, 31);
break;
case LINE_CMD_COLOR0:
- g_string_sprintfa(str, "\003%c%c", 1, ((color & 0xf0) >> 4)+1);
+ g_string_sprintfa(str, "\004%c%c",
+ '0', ((color & 0xf0) >> 4)+'0');
break;
case LINE_CMD_COLOR8:
- g_string_sprintfa(str, "\003%c%c", 9, ((color & 0xf0) >> 4)+1);
+ g_string_sprintfa(str, "\004%c%c",
+ '8', ((color & 0xf0) >> 4)+'0');
color &= 0xfff0;
color |= 8|ATTR_COLOR8;
break;
case LINE_CMD_BLINK:
color |= 0x80;
- g_string_sprintfa(str, "\003%c%c", (color & 0x0f)+1, ((color & 0xf0) >> 4)+1);
+ g_string_sprintfa(str, "\004%c%c", (color & 0x0f)+'0',
+ ((color & 0xf0) >> 4)+'0');
break;
case LINE_CMD_INDENT:
break;
diff --git a/src/fe-text/mainwindows.c b/src/fe-text/mainwindows.c
index 2ba547dc..48bbf0b9 100644
--- a/src/fe-text/mainwindows.c
+++ b/src/fe-text/mainwindows.c
@@ -24,6 +24,7 @@
#include "commands.h"
#include "levels.h"
#include "misc.h"
+#include "printtext.h"
#include "screen.h"
#include "statusbar.h"
diff --git a/src/fe-text/module-formats.c b/src/fe-text/module-formats.c
index 4114ca50..935e6eee 100644
--- a/src/fe-text/module-formats.c
+++ b/src/fe-text/module-formats.c
@@ -19,7 +19,7 @@
*/
#include "module.h"
-#include "printtext.h"
+#include "formats.h"
FORMAT_REC gui_text_formats[] =
{
diff --git a/src/fe-text/module-formats.h b/src/fe-text/module-formats.h
index 2af040eb..06d02727 100644
--- a/src/fe-text/module-formats.h
+++ b/src/fe-text/module-formats.h
@@ -1,4 +1,4 @@
-#include "printtext.h"
+#include "formats.h"
enum {
IRCTXT_MODULE_NAME,