From 77dd63ac835d32b0343098a4d7b61588da9ed6f1 Mon Sep 17 00:00:00 2001 From: Emanuele Giaquinta Date: Wed, 16 Apr 2008 20:32:36 +0000 Subject: Make last_{fg,bg,flags} members of TEXT_BUFFER_REC. git-svn-id: http://svn.irssi.org/repos/irssi/trunk@4804 dbcabf3a-b0e7-0310-adc4-f8d773084564 --- src/fe-text/textbuffer.c | 26 ++++++++++++-------------- src/fe-text/textbuffer.h | 3 +++ 2 files changed, 15 insertions(+), 14 deletions(-) (limited to 'src') diff --git a/src/fe-text/textbuffer.c b/src/fe-text/textbuffer.c index 5be6c60a..fc016ff9 100644 --- a/src/fe-text/textbuffer.c +++ b/src/fe-text/textbuffer.c @@ -40,6 +40,8 @@ TEXT_BUFFER_REC *textbuffer_create(void) buffer = g_mem_chunk_alloc0(buffer_chunk); buffer->last_eol = TRUE; + buffer->last_fg = LINE_COLOR_DEFAULT; + buffer->last_bg = LINE_COLOR_DEFAULT | LINE_COLOR_BG; return buffer; } @@ -266,8 +268,6 @@ int textbuffer_line_exists_after(LINE_REC *line, LINE_REC *search) return FALSE; } -static int last_fg, last_bg, last_flags; - void textbuffer_line_add_colors(TEXT_BUFFER_REC *buffer, LINE_REC **line, int fg, int bg, int flags) { @@ -283,22 +283,22 @@ void textbuffer_line_add_colors(TEXT_BUFFER_REC *buffer, LINE_REC **line, bg |= LINE_COLOR_BLINK; pos = 0; - if (fg != last_fg) { - last_fg = fg; + if (fg != buffer->last_fg) { + buffer->last_fg = fg; data[pos++] = 0; data[pos++] = fg == 0 ? LINE_CMD_COLOR0 : fg; } - if (bg != last_bg) { - last_bg = bg; + if (bg != buffer->last_bg) { + buffer->last_bg = bg; data[pos++] = 0; data[pos++] = bg; } - if ((flags & GUI_PRINT_FLAG_UNDERLINE) != (last_flags & GUI_PRINT_FLAG_UNDERLINE)) { + if ((flags & GUI_PRINT_FLAG_UNDERLINE) != (buffer->last_flags & GUI_PRINT_FLAG_UNDERLINE)) { data[pos++] = 0; data[pos++] = LINE_CMD_UNDERLINE; } - if ((flags & GUI_PRINT_FLAG_REVERSE) != (last_flags & GUI_PRINT_FLAG_REVERSE)) { + if ((flags & GUI_PRINT_FLAG_REVERSE) != (buffer->last_flags & GUI_PRINT_FLAG_REVERSE)) { data[pos++] = 0; data[pos++] = LINE_CMD_REVERSE; } @@ -310,7 +310,7 @@ void textbuffer_line_add_colors(TEXT_BUFFER_REC *buffer, LINE_REC **line, if (pos > 0) *line = textbuffer_insert(buffer, *line, data, pos, NULL); - last_flags = flags; + buffer->last_flags = flags; } LINE_REC *textbuffer_append(TEXT_BUFFER_REC *buffer, @@ -344,9 +344,9 @@ LINE_REC *textbuffer_insert(TEXT_BUFFER_REC *buffer, LINE_REC *insert_after, data[len-2] == 0 && data[len-1] == LINE_CMD_EOL; if (buffer->last_eol) { - last_fg = LINE_COLOR_DEFAULT; - last_bg = LINE_COLOR_DEFAULT | LINE_COLOR_BG; - last_flags = 0; + buffer->last_fg = LINE_COLOR_DEFAULT; + buffer->last_bg = LINE_COLOR_DEFAULT | LINE_COLOR_BG; + buffer->last_flags = 0; } return line; @@ -590,8 +590,6 @@ GList *textbuffer_find_text(TEXT_BUFFER_REC *buffer, LINE_REC *startline, void textbuffer_init(void) { - last_fg = LINE_COLOR_DEFAULT; - last_bg = LINE_COLOR_DEFAULT | LINE_COLOR_BG; buffer_chunk = g_mem_chunk_new("text buffer chunk", sizeof(TEXT_BUFFER_REC), sizeof(TEXT_BUFFER_REC)*32, G_ALLOC_AND_FREE); diff --git a/src/fe-text/textbuffer.h b/src/fe-text/textbuffer.h index cb1ef591..da0e5f1c 100644 --- a/src/fe-text/textbuffer.h +++ b/src/fe-text/textbuffer.h @@ -65,6 +65,9 @@ typedef struct { TEXT_CHUNK_REC *cur_text; unsigned int last_eol:1; + int last_fg; + int last_bg; + int last_flags; } TEXT_BUFFER_REC; /* Create new buffer */ -- cgit v1.2.3