X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=openbox%2Fmenu.h;h=32944b79a763d4fc54613e10bffbfaf3de1ba81d;hb=827e7baf20c3d0bb8251f5d024d304d0f9bebbe6;hp=bbc9fe81d024761969e488d21c70e7937cc11e3b;hpb=0e28a07e3d6677aa6af9ad97fbc55f8101f3fdf2;p=chaz%2Fopenbox diff --git a/openbox/menu.h b/openbox/menu.h index bbc9fe81..32944b79 100644 --- a/openbox/menu.h +++ b/openbox/menu.h @@ -6,6 +6,8 @@ #include +extern GHashTable *menu_map; + typedef struct Menu { char *label; char *name; @@ -16,7 +18,6 @@ typedef struct Menu { /* ? */ gboolean shown; gboolean invalid; - gpointer render_data; /* where the engine can store anything it likes */ struct Menu *parent; @@ -26,17 +27,20 @@ typedef struct Menu { void (*update)( /* some bummu */); void (*mouseover)( /* some bummu */); void (*selected)( /* some bummu */); -} Menu; -typedef struct MenuRenderData { + + /* render stuff */ + Client *client; Window frame; Window title; Appearance *a_title; int title_min_w, title_h; Window items; Appearance *a_items; + int bullet_w; int item_h; -} MenuRenderData; + int width; +} Menu; typedef enum MenuEntryRenderType { MenuEntryRenderType_None = 0, @@ -54,18 +58,20 @@ typedef struct { Action *action; MenuEntryRenderType render_type; + gboolean hilite; gboolean enabled; gboolean boolean_value; - gpointer render_data; /* where the engine can store anything it likes */ Menu *submenu; -} MenuEntry; -typedef struct MenuEntryRenderData { + /* render stuff */ Window item; Appearance *a_item; + Appearance *a_disabled; + Appearance *a_hilite; + int y; int min_w; -} MenuEntryRenderData; +} MenuEntry; void menu_startup(); void menu_shutdown(); @@ -74,6 +80,7 @@ Menu *menu_new(char *label, char *name, Menu *parent); void menu_free(char *name); void menu_show(char *name, int x, int y, Client *client); +void menu_hide(Menu *self); MenuEntry *menu_entry_new_full(char *label, Action *action, MenuEntryRenderType render_type, @@ -87,4 +94,11 @@ void menu_entry_free(MenuEntry *entry); void menu_entry_set_submenu(MenuEntry *entry, Menu *submenu); void menu_add_entry(Menu *menu, MenuEntry *entry); + +MenuEntry *menu_find_entry(Menu *menu, Window win); + +void menu_entry_render(MenuEntry *self); + +void menu_entry_fire(MenuEntry *self); + #endif