diff options
-rw-r--r-- | src/fe-common/core/fe-windows.c | 2 | ||||
-rw-r--r-- | src/fe-common/core/fe-windows.h | 1 | ||||
-rw-r--r-- | src/fe-common/core/window-commands.c | 2 | ||||
-rw-r--r-- | src/fe-text/mainwindows.c | 40 | ||||
-rw-r--r-- | src/fe-text/module-formats.c | 1 | ||||
-rw-r--r-- | src/fe-text/module-formats.h | 3 |
6 files changed, 47 insertions, 2 deletions
diff --git a/src/fe-common/core/fe-windows.c b/src/fe-common/core/fe-windows.c index a79f99b3..01aae056 100644 --- a/src/fe-common/core/fe-windows.c +++ b/src/fe-common/core/fe-windows.c @@ -376,7 +376,7 @@ int windows_refnum_last(void) return max; } -static int window_refnum_cmp(WINDOW_REC *w1, WINDOW_REC *w2) +int window_refnum_cmp(WINDOW_REC *w1, WINDOW_REC *w2) { return w1->refnum < w2->refnum ? -1 : 1; } diff --git a/src/fe-common/core/fe-windows.h b/src/fe-common/core/fe-windows.h index 7de6fc5a..796285a8 100644 --- a/src/fe-common/core/fe-windows.h +++ b/src/fe-common/core/fe-windows.h @@ -78,6 +78,7 @@ int window_refnum_prev(int refnum, int wrap); int window_refnum_next(int refnum, int wrap); int windows_refnum_last(void); +int window_refnum_cmp(WINDOW_REC *w1, WINDOW_REC *w2); GSList *windows_get_sorted(void); WINDOW_BIND_REC *window_bind_add(WINDOW_REC *window, const char *servertag, diff --git a/src/fe-common/core/window-commands.c b/src/fe-common/core/window-commands.c index 9cf917fb..960e9cfa 100644 --- a/src/fe-common/core/window-commands.c +++ b/src/fe-common/core/window-commands.c @@ -136,6 +136,8 @@ static void cmd_window_info(WINDOW_REC *win) if (win->items != NULL) window_print_items(win); + signal_emit("window print info", 1, win); + printformat_window(win, MSGLEVEL_CLIENTCRAP, TXT_WINDOW_INFO_FOOTER); } diff --git a/src/fe-text/mainwindows.c b/src/fe-text/mainwindows.c index 63820894..6fa37fac 100644 --- a/src/fe-text/mainwindows.c +++ b/src/fe-text/mainwindows.c @@ -848,6 +848,44 @@ static void cmd_window_stick(const char *data) } } +static void windows_print_sticky(MAIN_WINDOW_REC *win) +{ + GSList *tmp, *sorted; + GString *str; + + /* sort the sticky windows */ + sorted = NULL; + for (tmp = win->sticky_windows; tmp != NULL; tmp = tmp->next) { + WINDOW_REC *rec = tmp->data; + + sorted = g_slist_insert_sorted(sorted, rec, (GCompareFunc) + window_refnum_cmp); + } + + /* convert to string */ + str = g_string_new(NULL); + while (sorted != NULL) { + WINDOW_REC *rec = sorted->data; + + g_string_sprintfa(str, "#%d, ", rec->refnum); + sorted = g_slist_remove(sorted, rec); + } + g_string_truncate(str, str->len-2); + + printformat_window(win->active, MSGLEVEL_CLIENTCRAP, + TXT_WINDOW_INFO_STICKY, str->str); + g_string_free(str, TRUE); +} + +static void sig_window_print_info(WINDOW_REC *win) +{ + MAIN_WINDOW_REC *mainwin; + + mainwin = WINDOW_GUI(win)->parent; + if (mainwin->sticky_windows != NULL) + windows_print_sticky(mainwin); +} + void mainwindows_init(void) { old_screen_width = screen_width; @@ -871,6 +909,7 @@ void mainwindows_init(void) command_bind("window left", NULL, (SIGNAL_FUNC) cmd_window_left); command_bind("window right", NULL, (SIGNAL_FUNC) cmd_window_right); command_bind("window stick", NULL, (SIGNAL_FUNC) cmd_window_stick); + signal_add("window print info", (SIGNAL_FUNC) sig_window_print_info); } void mainwindows_deinit(void) @@ -889,4 +928,5 @@ void mainwindows_deinit(void) command_unbind("window left", (SIGNAL_FUNC) cmd_window_left); command_unbind("window right", (SIGNAL_FUNC) cmd_window_right); command_unbind("window stick", (SIGNAL_FUNC) cmd_window_stick); + signal_remove("window print info", (SIGNAL_FUNC) sig_window_print_info); } diff --git a/src/fe-text/module-formats.c b/src/fe-text/module-formats.c index be3c0eab..248bd03e 100644 --- a/src/fe-text/module-formats.c +++ b/src/fe-text/module-formats.c @@ -37,6 +37,7 @@ FORMAT_REC gui_text_formats[] = { "window_not_sticky", "Window is not sticky", 0 }, { "window_set_sticky", "Window set sticky", 0 }, { "window_unset_sticky", "Window is not sticky anymore", 0 }, + { "window_info_sticky", "Sticky : $0", 1, { 0 } }, { NULL, NULL, 0 } }; diff --git a/src/fe-text/module-formats.h b/src/fe-text/module-formats.h index fe33c8e2..055b2b04 100644 --- a/src/fe-text/module-formats.h +++ b/src/fe-text/module-formats.h @@ -14,7 +14,8 @@ enum { TXT_CANT_SHOW_STICKY_WINDOWS, TXT_WINDOW_NOT_STICKY, TXT_WINDOW_SET_STICKY, - TXT_WINDOW_UNSET_STICKY + TXT_WINDOW_UNSET_STICKY, + TXT_WINDOW_INFO_STICKY }; extern FORMAT_REC gui_text_formats[]; |