1
0
mirror of https://github.com/irssi/irssi.git synced 2025-02-02 15:08:01 -05:00

Added gui_printtext() function for printing text in printtext() format

to screen in specified position.


git-svn-id: http://svn.irssi.org/repos/irssi/trunk@1182 dbcabf3a-b0e7-0310-adc4-f8d773084564
This commit is contained in:
Timo Sirainen 2001-02-03 19:29:38 +00:00 committed by cras
parent e9b48e8942
commit e2acaaa067
6 changed files with 139 additions and 24 deletions

View File

@ -55,7 +55,7 @@ int format_find_tag(const char *module, const char *tag)
return -1; 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 *backs = "04261537";
static const char *fores = "kbgcrmyw"; static const char *fores = "kbgcrmyw";
@ -228,7 +228,7 @@ static char *format_get_text_args(TEXT_DEST_REC *dest,
while (*text != '\0') { while (*text != '\0') {
if (code == '%') { if (code == '%') {
/* color 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, '%'); g_string_append_c(out, '%');
g_string_append_c(out, *text); 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) void format_newline(WINDOW_REC *window)
{ {
g_return_if_fail(window != NULL);
window->lines++; window->lines++;
if (window->lines != 1) { if (window->lines != 1) {
signal_emit_id(signal_gui_print_text, 6, window, 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; break;
case 27: case 27:
/* ansi color code */ /* 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, current_theme : dest->window->theme,
ptr, ptr,
hide_text_style ? NULL : &fgcolor, hide_text_style ? NULL : &fgcolor,

View File

@ -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_REVERSE (0x03 + FORMAT_STYLE_SPECIAL)
#define FORMAT_STYLE_INDENT (0x04 + FORMAT_STYLE_SPECIAL) #define FORMAT_STYLE_INDENT (0x04 + FORMAT_STYLE_SPECIAL)
#define FORMAT_STYLE_DEFAULTS (0x05 + 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_init(void);
void formats_deinit(void); void formats_deinit(void);

View File

@ -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, signal_emit_id(signal_print_format, 5, theme, module,
dest, GINT_TO_POINTER(formatnum), arglist); 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); if (*str != '\0') print_line(dest, str);
g_free(str); g_free(str);
} }
@ -92,7 +93,8 @@ void printformat_module_args(const char *module, void *server,
printformat_module_dest(module, &dest, formatnum, va); 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; va_list va;
@ -120,6 +122,38 @@ void printformat_module_window(const char *module, WINDOW_REC *window,
va_end(va); 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) static void print_line(TEXT_DEST_REC *dest, const char *text)
{ {
char *str, *tmp; char *str, *tmp;
@ -141,7 +175,8 @@ static void print_line(TEXT_DEST_REC *dest, const char *text)
} }
/* append string to `out', expand newlines. */ /* 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') { while (*str != '\0') {
if (*str != '\n') 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; GString *out;
char *ret; char *ret;
@ -187,7 +223,8 @@ static char *printtext_get_args(TEXT_DEST_REC *dest, const char *str, va_list va
break; break;
} }
case 'u': { 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); g_string_sprintfa(out, "%u", d);
break; break;
} }
@ -206,7 +243,7 @@ static char *printtext_get_args(TEXT_DEST_REC *dest, const char *str, va_list va
break; break;
} }
default: default:
if (!format_expand_styles(out, *str, dest)) { if (!format_expand_styles(out, *str)) {
g_string_append_c(out, '%'); g_string_append_c(out, '%');
g_string_append_c(out, *str); 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; return ret;
} }
static char *printtext_expand_formats(TEXT_DEST_REC *dest, const char *str) static char *printtext_expand_formats(const char *str)
{ {
GString *out; GString *out;
char *ret; char *ret;
@ -234,7 +271,7 @@ static char *printtext_expand_formats(TEXT_DEST_REC *dest, const char *str)
if (*++str == '\0') if (*++str == '\0')
break; break;
if (!format_expand_styles(out, *str, dest)) { if (!format_expand_styles(out, *str)) {
g_string_append_c(out, '%'); g_string_append_c(out, '%');
g_string_append_c(out, *str); 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; sending_print_starting = FALSE;
} }
str = printtext_expand_formats(&dest, text); str = printtext_expand_formats(text);
print_line(&dest, str); print_line(&dest, str);
g_free(str); g_free(str);
} }
@ -311,6 +348,29 @@ void printtext_window(WINDOW_REC *window, int level, const char *text, ...)
va_end(va); 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) static void msg_beep_check(SERVER_REC *server, int level)
{ {
if (level != 0 && (level & MSGLEVEL_NOHILIGHT) == 0 && if (level != 0 && (level & MSGLEVEL_NOHILIGHT) == 0 &&

View File

@ -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 printtext_multiline(void *server, const char *target, int level, const char *format, const char *text);
void printbeep(void); 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_init(void);
void printtext_deinit(void); void printtext_deinit(void);
@ -30,12 +37,16 @@ void printtext_deinit(void);
printformat_module(MODULE_NAME, server, target, level, ##formatnum) printformat_module(MODULE_NAME, server, target, level, ##formatnum)
# define printformat_window(window, level, formatnum...) \ # define printformat_window(window, level, formatnum...) \
printformat_module_window(MODULE_NAME, 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) #elif defined (_ISOC99_SOURCE)
/* C99 */ /* C99 */
# define printformat(server, target, level, formatnum, ...) \ # define printformat(server, target, level, formatnum, ...) \
printformat_module(MODULE_NAME, server, target, level, formatnum, __VA_ARGS__) printformat_module(MODULE_NAME, server, target, level, formatnum, __VA_ARGS__)
# define printformat_window(window, level, formatnum, ...) \ # define printformat_window(window, level, formatnum, ...) \
printformat_module_window(MODULE_NAME, window, level, formatnum, __VA_ARGS__) printformat_module_window(MODULE_NAME, window, level, formatnum, __VA_ARGS__)
# define printformat_gui(formatnum, ...) \
printformat_module_gui(MODULE_NAME, formatnum, __VA_ARGS__)
#else #else
/* inline/static */ /* inline/static */
#ifdef G_CAN_INLINE #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); printformat_module_window_args(MODULE_NAME, window, level, formatnum, va);
va_end(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
#endif #endif

View File

@ -39,6 +39,8 @@ static int scrollback_lines, scrollback_hours;
static int scrollback_save_formats; static int scrollback_save_formats;
static GString *format; static GString *format;
static int next_xpos, next_ypos;
#define mark_temp_eol(text) \ #define mark_temp_eol(text) \
memcpy((text)->buffer + (text)->pos, "\0\200", 2); memcpy((text)->buffer + (text)->pos, "\0\200", 2);
@ -222,6 +224,20 @@ void gui_window_line_remove(WINDOW_REC *window, LINE_REC *line)
gui_window_redraw(window); gui_window_redraw(window);
} }
void gui_printtext(int xpos, int ypos, const char *str, ...)
{
va_list va;
next_xpos = xpos;
next_ypos = ypos;
va_start(va, str);
printtext_gui_args(str, va);
va_end(va);
next_xpos = next_ypos = -1;
}
static void remove_old_lines(WINDOW_REC *window) static void remove_old_lines(WINDOW_REC *window)
{ {
GUI_WINDOW_REC *gui; GUI_WINDOW_REC *gui;
@ -345,28 +361,38 @@ static void line_add_colors(GUI_WINDOW_REC *gui, int fg, int bg, int flags)
gui->last_color = fg | (bg << 4); gui->last_color = fg | (bg << 4);
} }
static void gui_printtext(WINDOW_REC *window, void *fgcolor, void *bgcolor, static void sig_gui_print_text(WINDOW_REC *window, void *fgcolor,
void *pflags, char *str, void *level) void *bgcolor, void *pflags,
char *str, void *level)
{ {
GUI_WINDOW_REC *gui; GUI_WINDOW_REC *gui;
LINE_REC *line; LINE_REC *line;
int fg, bg, flags, new_lines, n, visible, ypos, subline; int fg, bg, flags, new_lines, n, visible, ypos, subline;
g_return_if_fail(window != NULL);
remove_old_lines(window);
gui = WINDOW_GUI(window);
visible = is_window_visible(window) && gui->bottom;
flags = GPOINTER_TO_INT(pflags); flags = GPOINTER_TO_INT(pflags);
fg = GPOINTER_TO_INT(fgcolor); fg = GPOINTER_TO_INT(fgcolor);
bg = GPOINTER_TO_INT(bgcolor); bg = GPOINTER_TO_INT(bgcolor);
get_colors(flags, &fg, &bg);
if (window == NULL && next_xpos != -1) {
wmove(stdscr, next_ypos, next_xpos);
set_color(stdscr, fg | (bg << 4));
addstr(str);
next_xpos += strlen(str);
return;
}
g_return_if_fail(window != NULL);
gui = WINDOW_GUI(window);
visible = is_window_visible(window) && gui->bottom;
if (gui->cur_text == NULL) if (gui->cur_text == NULL)
create_text_chunk(gui); create_text_chunk(gui);
/* newline can be only at the start of the line.. */ /* newline can be only at the start of the line.. */
if (flags & PRINTFLAG_NEWLINE) { if (flags & PRINTFLAG_NEWLINE) {
remove_old_lines(window);
if (!gui->eol_marked) { if (!gui->eol_marked) {
if (format->len > 0 || gui->temp_line != NULL) { if (format->len > 0 || gui->temp_line != NULL) {
/* mark format continuing to next line */ /* mark format continuing to next line */
@ -389,7 +415,6 @@ static void gui_printtext(WINDOW_REC *window, void *fgcolor, void *bgcolor,
if (line->level == 0) line->level = GPOINTER_TO_INT(level); if (line->level == 0) line->level = GPOINTER_TO_INT(level);
} }
get_colors(flags, &fg, &bg);
line_add_colors(gui, fg, bg, flags); line_add_colors(gui, fg, bg, flags);
linebuf_add(gui, str, strlen(str)); linebuf_add(gui, str, strlen(str));
mark_temp_eol(gui->cur_text); mark_temp_eol(gui->cur_text);
@ -554,13 +579,14 @@ static void read_settings(void)
void gui_printtext_init(void) void gui_printtext_init(void)
{ {
next_xpos = next_ypos = -1;
format = g_string_new(NULL); format = g_string_new(NULL);
settings_add_int("history", "scrollback_lines", 500); settings_add_int("history", "scrollback_lines", 500);
settings_add_int("history", "scrollback_hours", 24); settings_add_int("history", "scrollback_hours", 24);
settings_add_bool("history", "scrollback_save_formats", FALSE); settings_add_bool("history", "scrollback_save_formats", FALSE);
signal_add("gui print text", (SIGNAL_FUNC) gui_printtext); signal_add("gui print text", (SIGNAL_FUNC) sig_gui_print_text);
signal_add("print text finished", (SIGNAL_FUNC) sig_printtext_finished); signal_add("print text finished", (SIGNAL_FUNC) sig_printtext_finished);
signal_add("print format", (SIGNAL_FUNC) sig_print_format); signal_add("print format", (SIGNAL_FUNC) sig_print_format);
signal_add("setup changed", (SIGNAL_FUNC) read_settings); signal_add("setup changed", (SIGNAL_FUNC) read_settings);
@ -574,7 +600,7 @@ void gui_printtext_deinit(void)
{ {
g_string_free(format, TRUE); g_string_free(format, TRUE);
signal_remove("gui print text", (SIGNAL_FUNC) gui_printtext); signal_remove("gui print text", (SIGNAL_FUNC) sig_gui_print_text);
signal_remove("print text finished", (SIGNAL_FUNC) sig_printtext_finished); signal_remove("print text finished", (SIGNAL_FUNC) sig_printtext_finished);
signal_remove("print format", (SIGNAL_FUNC) sig_print_format); signal_remove("print format", (SIGNAL_FUNC) sig_print_format);
signal_remove("setup changed", (SIGNAL_FUNC) read_settings); signal_remove("setup changed", (SIGNAL_FUNC) read_settings);

View File

@ -33,4 +33,6 @@ void gui_window_line_append(GUI_WINDOW_REC *gui, const char *str, int len);
void gui_window_line_remove(WINDOW_REC *window, LINE_REC *line); void gui_window_line_remove(WINDOW_REC *window, LINE_REC *line);
void gui_window_line_text_free(GUI_WINDOW_REC *gui, LINE_REC *line); void gui_window_line_text_free(GUI_WINDOW_REC *gui, LINE_REC *line);
void gui_printtext(int xpos, int ypos, const char *str, ...);
#endif #endif