summaryrefslogtreecommitdiff
path: root/src/fe-common
diff options
context:
space:
mode:
authorTimo Sirainen <cras@irssi.org>2001-08-08 16:08:47 +0000
committercras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564>2001-08-08 16:08:47 +0000
commit4737d162900e8c90df461c421ca71136d519e3f1 (patch)
treeb4dfe4c9490810e56f3b56c209ac603093ad0674 /src/fe-common
parentd248a87497a39841e9f020dc6b67cc72fbbaa6ce (diff)
downloadirssi-4737d162900e8c90df461c421ca71136d519e3f1.zip
Fixed leaking window binds. They were added but rarely removed.
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@1721 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src/fe-common')
-rw-r--r--src/fe-common/core/fe-windows.c7
-rw-r--r--src/fe-common/core/fe-windows.h1
-rw-r--r--src/fe-common/core/window-items.c16
3 files changed, 18 insertions, 6 deletions
diff --git a/src/fe-common/core/fe-windows.c b/src/fe-common/core/fe-windows.c
index 01aae056..5c323c68 100644
--- a/src/fe-common/core/fe-windows.c
+++ b/src/fe-common/core/fe-windows.c
@@ -396,6 +396,7 @@ GSList *windows_get_sorted(void)
return sorted;
}
+/* Add a new bind to window - if duplicate is found it's returned */
WINDOW_BIND_REC *window_bind_add(WINDOW_REC *window, const char *servertag,
const char *name)
{
@@ -403,7 +404,11 @@ WINDOW_BIND_REC *window_bind_add(WINDOW_REC *window, const char *servertag,
g_return_val_if_fail(window != NULL, NULL);
g_return_val_if_fail(servertag != NULL, NULL);
- g_return_val_if_fail(name != NULL, NULL);
+ g_return_val_if_fail(name != NULL, NULL);
+
+ rec = window_bind_find(window, servertag, name);
+ if (rec != NULL)
+ return rec;
rec = g_new0(WINDOW_BIND_REC, 1);
rec->name = g_strdup(name);
diff --git a/src/fe-common/core/fe-windows.h b/src/fe-common/core/fe-windows.h
index 796285a8..d1c6fbc7 100644
--- a/src/fe-common/core/fe-windows.h
+++ b/src/fe-common/core/fe-windows.h
@@ -81,6 +81,7 @@ int windows_refnum_last(void);
int window_refnum_cmp(WINDOW_REC *w1, WINDOW_REC *w2);
GSList *windows_get_sorted(void);
+/* Add a new bind to window - if duplicate is found it's returned */
WINDOW_BIND_REC *window_bind_add(WINDOW_REC *window, const char *servertag,
const char *name);
void window_bind_destroy(WINDOW_REC *window, WINDOW_BIND_REC *rec);
diff --git a/src/fe-common/core/window-items.c b/src/fe-common/core/window-items.c
index 43e6413d..649241fb 100644
--- a/src/fe-common/core/window-items.c
+++ b/src/fe-common/core/window-items.c
@@ -241,6 +241,7 @@ static int window_bind_has_sticky(WINDOW_REC *window)
void window_item_create(WI_ITEM_REC *item, int automatic)
{
WINDOW_REC *window;
+ WINDOW_BIND_REC *bind;
GSList *tmp, *sorted;
int clear_waiting, reuse_unused_windows;
@@ -255,11 +256,16 @@ void window_item_create(WI_ITEM_REC *item, int automatic)
WINDOW_REC *rec = tmp->data;
/* is item bound to this window? */
- if (item->server != NULL &&
- window_bind_find(rec, item->server->tag, item->name)) {
- window = rec;
- clear_waiting = FALSE;
- break;
+ if (item->server != NULL) {
+ bind = window_bind_find(rec, item->server->tag,
+ item->name);
+ if (bind != NULL) {
+ if (!bind->sticky)
+ window_bind_destroy(rec, bind);
+ window = rec;
+ clear_waiting = FALSE;
+ break;
+ }
}
/* use this window IF: