X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fmenu.c;h=5c8dcc9de75586afa2ba08a543cd802930485898;hb=5f42ecfacbbf0bcfe43137c51a20b60d8ea368e3;hp=bd6cf065c2230a5d976423f3cbbfde5adc04dda9;hpb=3443454f33f88e10f187b78594ecfb5c09e1448d;p=chaz%2Fopenbox diff --git a/openbox/menu.c b/openbox/menu.c index bd6cf065..5c8dcc9d 100644 --- a/openbox/menu.c +++ b/openbox/menu.c @@ -1,32 +1,85 @@ #include #include "menu.h" +#include -Menu *menu_new(char *label, Menu *parent) +GHashTable *menu_hash = NULL; + +void menu_destroy_hash_key(const gpointer data) +{ + g_free(data); +} + +void menu_free_entries(const Menu *menu) +{ + GList *it; + + for (it = menu->entries; it; it = it->next) + menu_entry_free((MenuEntry *)it->data); + + g_list_free(menu->entries); +} + +void menu_destroy_hash_value(const gpointer data) +{ + const Menu *del_menu = (Menu *)data; + + g_free(del_menu->label); + g_free(del_menu->name); + + menu_free_entries(del_menu); +} + +void menu_entry_free(const MenuEntry *entry) +{ + g_free(entry->label); + g_free(entry->render_data); +} + +void menu_startup() +{ + menu_hash = g_hash_table_new_full(g_str_hash, g_str_equal, + menu_destroy_hash_key, + menu_destroy_hash_value); +} + +void menu_shutdown() { - Menu *new_menu = g_new(Menu, 1); - new_menu->label = g_strdup(lable); + g_hash_table_destroy(menu_hash); +} + +Menu *menu_new(const char *label, const char *name, Menu *parent) +{ + Menu *new_menu = g_new0(Menu, 1); + new_menu->label = g_strdup(label); + new_menu->name = g_strdup(name); new_menu->parent = parent; new_menu->entries = NULL; - new_menu->tail = NULL; new_menu->shown = FALSE; new_menu->invalid = FALSE; /* default controllers? */ + g_hash_table_insert(menu_hash, g_strdup(name), new_menu); return new_menu; } -MenuEntry *menu_entry_new_full(char *label, Action *action, - MenuEntryRenderType render_type, +void menu_free(const char *name) +{ + g_hash_table_remove(menu_hash, name); +} + +MenuEntry *menu_entry_new_full(const char *label, Action *action, + const MenuEntryRenderType render_type, gpointer render_data, gpointer submenu) { MenuEntry *menu_entry = g_new(MenuEntry, 1); menu_entry->label = g_strdup(label); + menu_entry->render_type = render_type; menu_entry->action.func = action->func; - menu_entry->action.data = action->data; //watch out. copying Client * ptr + menu_entry->action.data = action->data; /*watch out. copying Client * ptr*/ - menu_entry->render_data = render_data; //watch out. + menu_entry->render_data = render_data; /*watch out.*/ menu_entry->submenu = submenu; return menu_entry;