Added SILC Thread Queue API
[crypto.git] / apps / irssi / src / fe-common / core / formats.c
index b4d2e7edade7ab69d3685166f994c7d994a3dae1..ccfad968be7cb82adad035786b8262f7c84d13c5 100644 (file)
 #include "formats.h"
 #include "themes.h"
 #include "translation.h"
+#ifdef HAVE_GLIB2
+#include "recode.h"
+#include "utf8.h"
+#endif
 
 static const char *format_backs = "04261537";
 static const char *format_fores = "kbgcrmyw";
 static const char *format_boldfores = "KBGCRMYW";
 
 static int signal_gui_print_text;
-static int hide_text_style, hide_server_tags, hide_mirc_colors;
+static int hide_text_style, hide_server_tags, hide_colors;
 
 static int timestamp_level;
 static int timestamp_timeout;
@@ -66,13 +70,13 @@ static void format_expand_code(const char **format, GString *out, int *flags)
        int set;
 
        if (flags == NULL) {
-                /* flags are being ignored - skip the code */
+               /* flags are being ignored - skip the code */
                while (**format != ']')
                        (*format)++;
-                return;
+               return;
        }
 
-        set = TRUE;
+       set = TRUE;
        (*format)++;
        while (**format != ']' && **format != '\0') {
                if (**format == '+')
@@ -94,7 +98,7 @@ static void format_expand_code(const char **format, GString *out, int *flags)
                                (*format)++;
                        }
                        g_string_append_c(out, ',');
-                        (*format)--;
+                       (*format)--;
                        break;
                case 's':
                case 'S':
@@ -104,12 +108,12 @@ static void format_expand_code(const char **format, GString *out, int *flags)
                        break;
                case 't':
                        *flags |= set ? PRINT_FLAG_SET_TIMESTAMP :
-                                PRINT_FLAG_UNSET_TIMESTAMP;
-                        break;
+                               PRINT_FLAG_UNSET_TIMESTAMP;
+                       break;
                case 'T':
                        *flags |= set ? PRINT_FLAG_SET_SERVERTAG :
-                                PRINT_FLAG_UNSET_SERVERTAG;
-                        break;
+                               PRINT_FLAG_UNSET_SERVERTAG;
+                       break;
                }
 
                (*format)++;
@@ -120,12 +124,12 @@ int format_expand_styles(GString *out, const char **format, int *flags)
 {
        char *p, fmt;
 
-        fmt = **format;
+       fmt = **format;
        switch (fmt) {
        case '{':
        case '}':
        case '%':
-                /* escaped char */
+               /* escaped char */
                g_string_append_c(out, fmt);
                break;
        case 'U':
@@ -165,13 +169,17 @@ int format_expand_styles(GString *out, const char **format, int *flags)
                g_string_append_c(out, FORMAT_STYLE_DEFAULTS);
                break;
        case '>':
-                /* clear to end of line */
+               /* clear to end of line */
                g_string_append_c(out, 4);
                g_string_append_c(out, FORMAT_STYLE_CLRTOEOL);
                break;
+       case '#':
+               g_string_append_c(out, 4);
+               g_string_append_c(out, FORMAT_STYLE_MONOSPACE);
+               break;
        case '[':
                /* code */
-                format_expand_code(format, out, flags);
+               format_expand_code(format, out, flags);
                break;
        default:
                /* check if it's a background color */
@@ -215,18 +223,16 @@ void format_read_arglist(va_list va, FORMAT_REC *format,
 {
        int num, len, bufpos;
 
-        g_return_if_fail(format->params < arglist_size);
+       g_return_if_fail(format->params < arglist_size);
 
        bufpos = 0;
-        arglist[format->params] = NULL;
+       arglist[format->params] = NULL;
        for (num = 0; num < format->params; num++) {
                switch (format->paramtypes[num]) {
                case FORMAT_STRING:
                        arglist[num] = (char *) va_arg(va, char *);
-                       if (arglist[num] == NULL) {
-                               g_warning("format_read_arglist() : parameter %d is NULL", num);
+                       if (arglist[num] == NULL)
                                arglist[num] = "";
-                       }
                        break;
                case FORMAT_INT: {
                        int d = (int) va_arg(va, int);
@@ -253,7 +259,7 @@ void format_read_arglist(va_list va, FORMAT_REC *format,
                        arglist[num] = buffer+bufpos;
                        len = g_snprintf(buffer+bufpos, buffer_size-bufpos,
                                         "%ld", l);
-                        bufpos += len+1;
+                       bufpos += len+1;
                        break;
                }
                case FORMAT_FLOAT: {
@@ -273,19 +279,18 @@ void format_read_arglist(va_list va, FORMAT_REC *format,
                }
        }
 }
-
 void format_create_dest(TEXT_DEST_REC *dest,
                        void *server, const char *target,
                        int level, WINDOW_REC *window)
 {
-        format_create_dest_tag(dest, server, NULL, target, level, window);
+       format_create_dest_tag(dest, server, NULL, target, level, window);
 }
 
 void format_create_dest_tag(TEXT_DEST_REC *dest, void *server,
                            const char *server_tag, const char *target,
                            int level, WINDOW_REC *window)
 {
-        memset(dest, 0, sizeof(TEXT_DEST_REC));
+       memset(dest, 0, sizeof(TEXT_DEST_REC));
 
        dest->server = server;
        dest->server_tag = server != NULL ? SERVER(server)->tag : server_tag;
@@ -294,23 +299,46 @@ void format_create_dest_tag(TEXT_DEST_REC *dest, void *server,
        dest->window = window != NULL ? window :
                window_find_closest(server, target, level);
 }
+#ifdef HAVE_GLIB2
+static int advance (char const **str, gboolean utf8)
+{
+       if (utf8) {
+               gunichar c;
+
+               c = g_utf8_get_char(*str);
+               *str = g_utf8_next_char(*str);
 
+               return utf8_width(c);
+       } else {
+               *str += 1;
+
+               return 1;
+       }
+}
+#endif
 /* Return length of text part in string (ie. without % codes) */
 int format_get_length(const char *str)
 {
-        GString *tmp;
+       GString *tmp;
        int len;
+#ifdef HAVE_GLIB2
+       gboolean utf8;
+#endif
 
-        g_return_val_if_fail(str != NULL, 0);
+       g_return_val_if_fail(str != NULL, 0);
 
-        tmp = g_string_new(NULL);
+#ifdef HAVE_GLIB2
+       utf8 = is_utf8() && g_utf8_validate(str, -1, NULL);
+#endif
+
+       tmp = g_string_new(NULL);
        len = 0;
        while (*str != '\0') {
                if (*str == '%' && str[1] != '\0') {
                        str++;
                        if (*str != '%' &&
                            format_expand_styles(tmp, &str, NULL)) {
-                                str++;
+                               str++;
                                continue;
                        }
 
@@ -318,13 +346,16 @@ int format_get_length(const char *str)
                        if (*str != '%')
                                len++;
                }
-
-                len++;
+#ifdef HAVE_GLIB2
+               len += advance(&str, utf8);
+#else
+         len++;
                str++;
+#endif
        }
 
        g_string_free(tmp, TRUE);
-        return len;
+       return len;
 }
 
 /* Return how many characters in `str' must be skipped before `len'
@@ -334,34 +365,44 @@ int format_real_length(const char *str, int len)
 {
        GString *tmp;
        const char *start;
-
-        g_return_val_if_fail(str != NULL, 0);
-        g_return_val_if_fail(len >= 0, 0);
-
-        start = str;
-        tmp = g_string_new(NULL);
+#ifdef HAVE_GLIB2
+       gboolean utf8;
+#endif
+       g_return_val_if_fail(str != NULL, 0);
+       g_return_val_if_fail(len >= 0, 0);
+
+#ifdef HAVE_GLIB2
+       utf8 = is_utf8() && g_utf8_validate(str, -1, NULL);
+#endif
+
+       start = str;
+       tmp = g_string_new(NULL);
        while (*str != '\0' && len > 0) {
                if (*str == '%' && str[1] != '\0') {
                        str++;
                        if (*str != '%' &&
                            format_expand_styles(tmp, &str, NULL)) {
-                                str++;
+                               str++;
                                continue;
                        }
 
                        /* %% or unknown %code, written as-is */
                        if (*str != '%') {
                                if (--len == 0)
-                                        break;
+                                       break;
                        }
                }
 
-                len--;
+#ifdef HAVE_GLIB2
+               len -= advance(&str, utf8);
+#else
+         len--;
                str++;
+#endif
        }
 
        g_string_free(tmp, TRUE);
-        return (int) (str-start);
+       return (int) (str-start);
 }
 
 char *format_string_expand(const char *text, int *flags)
@@ -369,7 +410,7 @@ char *format_string_expand(const char *text, int *flags)
        GString *out;
        char code, *ret;
 
-        g_return_val_if_fail(text != NULL, NULL);
+       g_return_val_if_fail(text != NULL, NULL);
 
        out = g_string_new(NULL);
 
@@ -430,7 +471,7 @@ static char *format_get_text_args(TEXT_DEST_REC *dest,
                        if (ret != NULL) {
                                /* string shouldn't end with \003 or it could
                                   mess up the next one or two characters */
-                                int diff;
+                               int diff;
                                int len = strlen(ret);
                                while (len > 0 && ret[len-1] == 3) len--;
                                diff = strlen(ret)-len;
@@ -500,7 +541,7 @@ char *format_get_text_theme_charargs(THEME_REC *theme, const char *module,
        if (module_theme == NULL)
                return NULL;
 
-        text = module_theme->expanded_formats[formatnum];
+       text = module_theme->expanded_formats[formatnum];
        return format_get_text_args(dest, text, args);
 }
 
@@ -546,7 +587,32 @@ char *format_add_linestart(const char *text, const char *linestart)
 
        ret = str->str;
        g_string_free(str, FALSE);
-        return ret;
+       return ret;
+}
+
+char *format_add_lineend(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(text, linestart, NULL);
+
+       str = g_string_new(NULL);
+       while (*text != '\0') {
+               if (*text == '\n')
+                       g_string_append(str, linestart);
+               g_string_append_c(str, *text);
+               text++;
+       }
+       g_string_append(str, linestart);
+
+       ret = str->str;
+       g_string_free(str, FALSE);
+       return ret;
 }
 
 #define LINE_START_IRSSI_LEVEL \
@@ -562,16 +628,16 @@ char *format_get_level_tag(THEME_REC *theme, TEXT_DEST_REC *dest)
 {
        int format;
 
-        /* check for flags if we want to override defaults */
+       /* check for flags if we want to override defaults */
        if (dest->flags & PRINT_FLAG_UNSET_LINE_START)
                return NULL;
 
        if (dest->flags & PRINT_FLAG_SET_LINE_START)
                format = TXT_LINE_START;
-        else if (dest->flags & PRINT_FLAG_SET_LINE_START_IRSSI)
+       else if (dest->flags & PRINT_FLAG_SET_LINE_START_IRSSI)
                format = TXT_LINE_START_IRSSI;
        else {
-                /* use defaults */
+               /* use defaults */
                if (dest->level & LINE_START_IRSSI_LEVEL)
                        format = TXT_LINE_START_IRSSI;
                else if ((dest->level & NOT_LINE_START_LEVEL) == 0)
@@ -585,20 +651,20 @@ char *format_get_level_tag(THEME_REC *theme, TEXT_DEST_REC *dest)
 
 static char *get_timestamp(THEME_REC *theme, TEXT_DEST_REC *dest, time_t t)
 {
-        char *format, str[256];
+       char *format, str[256];
        struct tm *tm;
        int diff;
 
        if ((timestamp_level & dest->level) == 0)
                return NULL;
 
-        /* check for flags if we want to override defaults */
+       /* check for flags if we want to override defaults */
        if (dest->flags & PRINT_FLAG_UNSET_TIMESTAMP)
                return NULL;
 
        if ((dest->flags & PRINT_FLAG_SET_TIMESTAMP) == 0 &&
            (dest->level & (MSGLEVEL_NEVER|MSGLEVEL_LASTLOG)) != 0)
-                return NULL;
+               return NULL;
 
 
        if (timestamp_timeout > 0) {
@@ -612,7 +678,7 @@ static char *get_timestamp(THEME_REC *theme, TEXT_DEST_REC *dest, time_t t)
        format = format_get_text_theme(theme, MODULE_NAME, dest,
                                       TXT_TIMESTAMP);
        if (strftime(str, sizeof(str), format, tm) <= 0)
-                str[0] = '\0';
+               str[0] = '\0';
        g_free(format);
        return g_strdup(str);
 }
@@ -622,9 +688,9 @@ static char *get_server_tag(THEME_REC *theme, TEXT_DEST_REC *dest)
        int count = 0;
 
        if (dest->server_tag == NULL || hide_server_tags)
-                return NULL;
+               return NULL;
 
-        /* check for flags if we want to override defaults */
+       /* check for flags if we want to override defaults */
        if (dest->flags & PRINT_FLAG_UNSET_SERVERTAG)
                return NULL;
 
@@ -645,7 +711,7 @@ static char *get_server_tag(THEME_REC *theme, TEXT_DEST_REC *dest)
                }
 
                if (count < 2)
-                        return NULL;
+                       return NULL;
        }
 
        return format_get_text_theme(theme, MODULE_NAME, dest,
@@ -678,7 +744,7 @@ void format_newline(WINDOW_REC *window)
        signal_emit_id(signal_gui_print_text, 6, window,
                       GINT_TO_POINTER(-1), GINT_TO_POINTER(-1),
                       GINT_TO_POINTER(GUI_PRINT_FLAG_NEWLINE),
-                      "", GINT_TO_POINTER(-1));
+                      "", NULL);
 }
 
 /* parse ANSI color string */
@@ -729,8 +795,10 @@ static const char *get_ansi_color(THEME_REC *theme, const char *str,
                        flags |= GUI_PRINT_FLAG_REVERSE;
                        break;
                default:
-                       if (num >= 30 && num <= 37)
+                       if (num >= 30 && num <= 37) {
+                               if (fg == -1) fg = 0;
                                fg = (fg & 0xf8) | ansitab[num-30];
+                       }
                        if (num >= 40 && num <= 47) {
                                if (bg == -1) bg = 0;
                                bg = (bg & 0xf8) | ansitab[num-40];
@@ -767,7 +835,7 @@ static void get_mirc_color(const char **str, int *fg_ret, int *bg_ret)
                /* foreground color */
                if (**str != ',') {
                        fg = **str-'0';
-                        (*str)++;
+                       (*str)++;
                        if (i_isdigit(**str)) {
                                fg = fg*10 + (**str-'0');
                                (*str)++;
@@ -804,7 +872,7 @@ int strip_real_length(const char *str, int len,
 {
        const char *start = str;
 
-        if (last_color_pos != NULL)
+       if (last_color_pos != NULL)
                *last_color_pos = -1;
        if (last_color_len != NULL)
                *last_color_len = -1;
@@ -815,25 +883,25 @@ int strip_real_length(const char *str, int len,
 
                        if (last_color_pos != NULL)
                                *last_color_pos = (int) (str-start);
-                        str++;
+                       str++;
                        get_mirc_color(&str, NULL, NULL);
-                        if (last_color_len != NULL)
+                       if (last_color_len != NULL)
                                *last_color_len = (int) (str-mircstart);
 
                } else if (*str == 4 && str[1] != '\0') {
                        if (str[1] < FORMAT_STYLE_SPECIAL && str[2] != '\0') {
                                if (last_color_pos != NULL)
                                        *last_color_pos = (int) (str-start);
-                                if (last_color_len != NULL)
-                                        *last_color_len = 3;
+                               if (last_color_len != NULL)
+                                       *last_color_len = 3;
                                str++;
                        } else if (str[1] == FORMAT_STYLE_DEFAULTS) {
                                if (last_color_pos != NULL)
                                        *last_color_pos = (int) (str-start);
-                                if (last_color_len != NULL)
-                                        *last_color_len = 2;
+                               if (last_color_len != NULL)
+                                       *last_color_len = 2;
                        }
-                        str += 2;
+                       str += 2;
                } else {
                        if (!IS_COLOR_CODE(*str)) {
                                if (len-- == 0)
@@ -848,56 +916,61 @@ int strip_real_length(const char *str, int len,
 
 char *strip_codes(const char *input)
 {
-        const char *p;
-        char *str, *out;
-
-        out = str = g_strdup(input);
-        for (p = input; *p != '\0'; p++) {
-                if (*p == 3) {
-                        p++;  
-
-                        /* mirc color */
-                        get_mirc_color(&p, NULL, NULL);
-                        p--;
-                        continue;
-                }
-
-                if (*p == 4 && p[1] != '\0') {
-                        if (p[1] >= FORMAT_STYLE_SPECIAL) {
-                                p++;
-                                continue;
-                        }
-
-                        /* irssi color */
-                        if (p[2] != '\0') {
-                                p += 2;
-                                continue;
-                        }
+       const char *p;
+       char *str, *out;
+
+       out = str = g_strdup(input);
+       for (p = input; *p != '\0'; p++) {
+               if (*p == 3) {
+                       p++;
+
+                       /* mirc color */
+                       get_mirc_color(&p, NULL, NULL);
+                       p--;
+                       continue;
                }
 
-               if (*p == 27 && p[1] != '\0')
-                       p = get_ansi_color(current_theme, p, NULL, NULL, NULL);
+               if (*p == 4 && p[1] != '\0') {
+                       if (p[1] >= FORMAT_STYLE_SPECIAL) {
+                               p++;
+                               continue;
+                       }
 
-                if (!IS_COLOR_CODE(*p))
-                        *out++ = *p;   
-        }
+                       /* irssi color */
+                       if (p[2] != '\0') {
+                               p += 2;
+                               continue;
+                       }
+               }
+
+               if (*p == 27 && p[1] != '\0') {
+                       p++;
+                       p = get_ansi_color(current_theme, p, NULL, NULL, NULL);
+                       p--;
+               } else if (!IS_COLOR_CODE(*p))
+                       *out++ = *p;
+       }
 
-        *out = '\0';
-        return str; 
+       *out = '\0';
+       return str;
 }
 
 /* send a fully parsed text string for GUI to print */
 void format_send_to_gui(TEXT_DEST_REC *dest, const char *text)
 {
+       THEME_REC *theme;
        char *dup, *str, *ptr, type;
        int fgcolor, bgcolor;
        int flags;
 
+       theme = dest->window != NULL && dest->window->theme != NULL ?
+               dest->window->theme : current_theme;
+
        dup = str = g_strdup(text);
 
-       flags = 0; fgcolor = -1; bgcolor = -1;
+       flags = 0; fgcolor = theme->default_color; bgcolor = -1;
        while (*str != '\0') {
-                type = '\0';
+               type = '\0';
                for (ptr = str; *ptr != '\0'; ptr++) {
                        if (IS_COLOR_CODE(*ptr) || *ptr == '\n') {
                                type = *ptr;
@@ -911,19 +984,19 @@ void format_send_to_gui(TEXT_DEST_REC *dest, const char *text)
                if (type == 7) {
                        /* bell */
                        if (settings_get_bool("bell_beeps"))
-                                signal_emit("beep", 0);
+                               signal_emit("beep", 0);
                } else if (type == 4 && *ptr == FORMAT_STYLE_CLRTOEOL) {
-                        /* clear to end of line */
+                       /* clear to end of line */
                        flags |= GUI_PRINT_FLAG_CLRTOEOL;
                }
 
                if (*str != '\0' || (flags & GUI_PRINT_FLAG_CLRTOEOL)) {
-                        /* send the text to gui handler */
+                       /* send the text to gui handler */
                        signal_emit_id(signal_gui_print_text, 6, dest->window,
                                       GINT_TO_POINTER(fgcolor),
                                       GINT_TO_POINTER(bgcolor),
                                       GINT_TO_POINTER(flags), str,
-                                      dest->level);
+                                      dest);
                        flags &= ~(GUI_PRINT_FLAG_INDENT|GUI_PRINT_FLAG_CLRTOEOL);
                }
 
@@ -943,9 +1016,9 @@ void format_send_to_gui(TEXT_DEST_REC *dest, const char *text)
                case 3:
                        /* MIRC color */
                        get_mirc_color((const char **) &ptr,
-                                       hide_mirc_colors || hide_text_style ? NULL : &fgcolor,
-                                       hide_mirc_colors || hide_text_style ? NULL : &bgcolor);
-                       if (!hide_mirc_colors && !hide_text_style)
+                                       hide_colors ? NULL : &fgcolor,
+                                       hide_colors ? NULL : &bgcolor);
+                       if (!hide_colors)
                                flags |= GUI_PRINT_FLAG_MIRC_COLOR;
                        break;
                case 4:
@@ -964,6 +1037,9 @@ void format_send_to_gui(TEXT_DEST_REC *dest, const char *text)
                        case FORMAT_STYLE_REVERSE:
                                flags ^= GUI_PRINT_FLAG_REVERSE;
                                break;
+                       case FORMAT_STYLE_MONOSPACE:
+                               flags ^= GUI_PRINT_FLAG_MONOSPACE;
+                               break;
                        case FORMAT_STYLE_INDENT:
                                flags |= GUI_PRINT_FLAG_INDENT;
                                break;
@@ -972,18 +1048,20 @@ void format_send_to_gui(TEXT_DEST_REC *dest, const char *text)
                                while (*ptr != ',' && *ptr != '\0')
                                        ptr++;
                                if (*ptr != '\0') *ptr++ = '\0';
+                               ptr--;
                                signal_emit_id(signal_gui_print_text, 6,
                                               dest->window, NULL, NULL,
                                               GINT_TO_POINTER(GUI_PRINT_FLAG_INDENT_FUNC),
-                                              str, start, dest->level);
+                                              start, dest);
                                break;
                        }
                        case FORMAT_STYLE_DEFAULTS:
-                               fgcolor = bgcolor = -1;
-                               flags &= GUI_PRINT_FLAG_INDENT;
+                               fgcolor = theme->default_color;
+                               bgcolor = -1;
+                               flags &= GUI_PRINT_FLAG_INDENT|GUI_PRINT_FLAG_MONOSPACE;
                                break;
                        case FORMAT_STYLE_CLRTOEOL:
-                                break;
+                               break;
                        default:
                                if (*ptr != FORMAT_COLOR_NOCHANGE) {
                                        fgcolor = (unsigned char) *ptr-'0';
@@ -995,6 +1073,9 @@ void format_send_to_gui(TEXT_DEST_REC *dest, const char *text)
                                                flags |= GUI_PRINT_FLAG_BOLD;
                                        }
                                }
+                               if (ptr[1] == '\0')
+                                       break;
+
                                ptr++;
                                if (*ptr != FORMAT_COLOR_NOCHANGE) {
                                        bgcolor = *ptr-'0';
@@ -1002,8 +1083,8 @@ void format_send_to_gui(TEXT_DEST_REC *dest, const char *text)
                                                flags &= ~GUI_PRINT_FLAG_BLINK;
                                        else {
                                                /* blink */
-                                                bgcolor -= 8;
-                                                flags |= GUI_PRINT_FLAG_BLINK;
+                                               bgcolor -= 8;
+                                               flags |= GUI_PRINT_FLAG_BLINK;
                                        }
                                }
                        }
@@ -1016,8 +1097,9 @@ void format_send_to_gui(TEXT_DEST_REC *dest, const char *text)
                        break;
                case 15:
                        /* remove all styling */
-                       fgcolor = bgcolor = -1;
-                       flags &= GUI_PRINT_FLAG_INDENT;
+                       fgcolor = theme->default_color;
+                       bgcolor = -1;
+                       flags &= GUI_PRINT_FLAG_INDENT|GUI_PRINT_FLAG_MONOSPACE;
                        break;
                case 22:
                        /* reverse */
@@ -1032,12 +1114,10 @@ void format_send_to_gui(TEXT_DEST_REC *dest, const char *text)
                case 27:
                        /* ansi color code */
                        ptr = (char *)
-                               get_ansi_color(dest->window == NULL || dest->window->theme == NULL ?
-                                              current_theme : dest->window->theme,
-                                              ptr,
-                                              hide_text_style ? NULL : &fgcolor,
-                                              hide_text_style ? NULL : &bgcolor,
-                                              hide_text_style ? NULL : &flags);
+                               get_ansi_color(theme, ptr,
+                                              hide_colors ? NULL : &fgcolor,
+                                              hide_colors ? NULL : &bgcolor,
+                                              hide_colors ? NULL : &flags);
                        break;
                }
 
@@ -1050,15 +1130,13 @@ void format_send_to_gui(TEXT_DEST_REC *dest, const char *text)
 static void read_settings(void)
 {
        timestamp_level = settings_get_bool("timestamps") ? MSGLEVEL_ALL : 0;
-       if (timestamp_level > 0) {
-               timestamp_level =
-                       level2bits(settings_get_str("timestamp_level"));
-       }
-       timestamp_timeout = settings_get_int("timestamp_timeout");
+       if (timestamp_level > 0)
+               timestamp_level = settings_get_level("timestamp_level");
+       timestamp_timeout = settings_get_time("timestamp_timeout")/1000;
 
        hide_server_tags = settings_get_bool("hide_server_tags");
        hide_text_style = settings_get_bool("hide_text_style");
-       hide_mirc_colors = settings_get_bool("hide_mirc_colors");
+       hide_colors = hide_text_style || settings_get_bool("hide_colors");
 }
 
 void formats_init(void)