diff options
author | Timo Sirainen <cras@irssi.org> | 2000-12-02 19:08:21 +0000 |
---|---|---|
committer | cras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564> | 2000-12-02 19:08:21 +0000 |
commit | df94b9a44ca6fe33d3ffc43f80f2ea9185dc3734 (patch) | |
tree | 7a952e97189b12230f63b4b78c53f28aa3744f99 /src/fe-common/core/window-items.c | |
parent | ed550c01d1aeb8ee94db3b288cfd343f7d750734 (diff) | |
download | irssi-df94b9a44ca6fe33d3ffc43f80f2ea9185dc3734.zip |
window_[add|remove]_item -> window_item_[add|remove]
added window_item_destroy(), window_item_remove() doesn't destroy the
item anymore
window_find_item()'s first parameter changed from WINDOW_REC to SERVER_REC
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@922 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src/fe-common/core/window-items.c')
-rw-r--r-- | src/fe-common/core/window-items.c | 35 |
1 files changed, 12 insertions, 23 deletions
diff --git a/src/fe-common/core/window-items.c b/src/fe-common/core/window-items.c index 3931a175..3e0a15db 100644 --- a/src/fe-common/core/window-items.c +++ b/src/fe-common/core/window-items.c @@ -31,7 +31,7 @@ #include "window-items.h" #include "printtext.h" -void window_add_item(WINDOW_REC *window, WI_ITEM_REC *item, int automatic) +void window_item_add(WINDOW_REC *window, WI_ITEM_REC *item, int automatic) { g_return_if_fail(window != NULL); g_return_if_fail(item != NULL); @@ -58,7 +58,7 @@ void window_add_item(WINDOW_REC *window, WI_ITEM_REC *item, int automatic) } } -void window_remove_item(WINDOW_REC *window, WI_ITEM_REC *item) +void window_item_remove(WINDOW_REC *window, WI_ITEM_REC *item) { g_return_if_fail(window != NULL); g_return_if_fail(item != NULL); @@ -77,6 +77,13 @@ void window_remove_item(WINDOW_REC *window, WI_ITEM_REC *item) signal_emit("window item remove", 2, window, item); } +void window_item_destroy(WINDOW_REC *window, WI_ITEM_REC *item) +{ + window_item_remove(window, item); + + signal_emit("window item destroy", 2, window, item); +} + WINDOW_REC *window_item_window(WI_ITEM_REC *item) { g_return_val_if_fail(item != NULL, NULL); @@ -97,32 +104,14 @@ 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); if (item != NULL && window_item_window(item) != window) { /* move item to different window */ - window_item_move(window, item); + window_item_remove(window_item_window(item), item); + window_item_add(window, item, FALSE); } if (window->active != item) { @@ -299,7 +288,7 @@ void window_item_create(WI_ITEM_REC *item, int automatic) window = window_create(item, automatic); } else { /* use existing window */ - window_add_item(window, item, automatic); + window_item_add(window, item, automatic); } if (clear_waiting) { |