summaryrefslogtreecommitdiff
path: root/src/fe-common/core/window-items.c
diff options
context:
space:
mode:
authorTimo Sirainen <cras@irssi.org>2000-12-02 19:08:21 +0000
committercras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564>2000-12-02 19:08:21 +0000
commitdf94b9a44ca6fe33d3ffc43f80f2ea9185dc3734 (patch)
tree7a952e97189b12230f63b4b78c53f28aa3744f99 /src/fe-common/core/window-items.c
parented550c01d1aeb8ee94db3b288cfd343f7d750734 (diff)
downloadirssi-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.c35
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) {