summaryrefslogtreecommitdiff
path: root/openbox/menu.c
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2003-09-14 21:04:30 +0000
committerDana Jansens <danakj@orodu.net>2003-09-14 21:04:30 +0000
commitabd2f914dff6a38b78532e8b269440e6008f8933 (patch)
tree2321a510215d911bebc046fb29aa75979205602f /openbox/menu.c
parent25e1e32f5440f16caae4609185ddcd5d81d8f6eb (diff)
fix a mem leak, and make suer the menus arent visible when they are modified
Diffstat (limited to 'openbox/menu.c')
-rw-r--r--openbox/menu.c29
1 files changed, 27 insertions, 2 deletions
diff --git a/openbox/menu.c b/openbox/menu.c
index cd4b5cb1..231777f2 100644
--- a/openbox/menu.c
+++ b/openbox/menu.c
@@ -161,6 +161,8 @@ void menu_pipe_execute(ObMenu *self)
} else {
g_warning("Invalid output from pipe-menu: %s", self->execute);
}
+
+ g_free(output);
}
static ObMenu* menu_from_name(gchar *name)
@@ -260,7 +262,17 @@ ObMenu* menu_new(gchar *name, gchar *title, gpointer data)
static void menu_destroy_hash_value(ObMenu *self)
{
- /* XXX make sure its not visible */
+ /* make sure its not visible */
+ {
+ GList *it;
+ ObMenuFrame *f;
+
+ for (it = menu_frame_visible; it; it = g_list_next(it)) {
+ f = it->data;
+ if (f->menu == self)
+ menu_frame_hide_all();
+ }
+ }
if (self->destroy_func)
self->destroy_func(self, self->data);
@@ -269,6 +281,8 @@ static void menu_destroy_hash_value(ObMenu *self)
g_free(self->name);
g_free(self->title);
g_free(self->execute);
+
+ g_free(self);
}
void menu_free(ObMenu *menu)
@@ -341,7 +355,18 @@ void menu_entry_free(ObMenuEntry *self)
void menu_clear_entries(ObMenu *self)
{
- /* XXX assert that the menu isn't visible */
+#ifdef DEBUG
+ /* assert that the menu isn't visible */
+ {
+ GList *it;
+ ObMenuFrame *f;
+
+ for (it = menu_frame_visible; it; it = g_list_next(it)) {
+ f = it->data;
+ g_assert(f->menu != self);
+ }
+ }
+#endif
while (self->entries) {
menu_entry_free(self->entries->data);