summaryrefslogtreecommitdiff
path: root/src/fe-common/core/window-items.c
diff options
context:
space:
mode:
authorTimo Sirainen <cras@irssi.org>2000-12-02 06:08:31 +0000
committercras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564>2000-12-02 06:08:31 +0000
commit0cb6db26d98c76b7965b0b9ddf2ed2e2892257cb (patch)
tree027f83ada5df4842db50c0cd334e9fb7a66bf700 /src/fe-common/core/window-items.c
parent800ee1ea9a7278ae0fa57d7db710398ede74fe59 (diff)
downloadirssi-0cb6db26d98c76b7965b0b9ddf2ed2e2892257cb.zip
/WINDOW ITEM GOTO <name> - sets <name> window item active in current window
/WINDOW ITEM MOVE <number>|<name> - moves window item to another window /JOIN #already_joined_channel - same as /WINDOW ITEM MOVE <name> git-svn-id: http://svn.irssi.org/repos/irssi/trunk@916 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src/fe-common/core/window-items.c')
-rw-r--r--src/fe-common/core/window-items.c31
1 files changed, 27 insertions, 4 deletions
diff --git a/src/fe-common/core/window-items.c b/src/fe-common/core/window-items.c
index 086ee884..3931a175 100644
--- a/src/fe-common/core/window-items.c
+++ b/src/fe-common/core/window-items.c
@@ -43,8 +43,6 @@ void window_add_item(WINDOW_REC *window, WI_ITEM_REC *item, int automatic)
window->active_server = item->server;
}
- signal_emit("gui window item init", 1, item);
-
if (!automatic || settings_get_bool("window_auto_change")) {
if (automatic)
signal_emit("window changed automatic", 1, window);
@@ -99,9 +97,33 @@ void window_item_change_server(WI_ITEM_REC *item, void *server)
if (window->active == item) window_change_server(window, item->server);
}
+static void window_item_move(WINDOW_REC *window, WI_ITEM_REC *item)
+{
+ WINDOW_REC *oldwin;
+
+ /* remove from old window */
+ oldwin = window_item_window(item);
+ oldwin->items = g_slist_remove(oldwin->items, item);
+ window->items = g_slist_append(window->items, item);
+
+ MODULE_DATA_SET(item, window);
+
+ if (oldwin->active == item) {
+ window_item_set_active(oldwin, oldwin->items == NULL ? NULL :
+ oldwin->items->data);
+ }
+
+ signal_emit("window item moved", 2, window, item);
+}
+
void window_item_set_active(WINDOW_REC *window, WI_ITEM_REC *item)
{
- g_return_if_fail(window != NULL);
+ g_return_if_fail(window != NULL);
+
+ if (item != NULL && window_item_window(item) != window) {
+ /* move item to different window */
+ window_item_move(window, item);
+ }
if (window->active != item) {
window->active = item;
@@ -180,7 +202,8 @@ void window_item_next(WINDOW_REC *window)
window_item_set_active(window, next);
}
-static WI_ITEM_REC *window_item_find_window(WINDOW_REC *window, void *server, const char *name)
+WI_ITEM_REC *window_item_find_window(WINDOW_REC *window,
+ void *server, const char *name)
{
GSList *tmp;