X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fmenu.h;h=2ecbb5cdef846ab2c0b62210c51a303026fdbaf6;hb=c90da6da781932c2d178bfb7e39ec1d5003543b7;hp=d441ec8452cb586e41e575635b641c6f2831402d;hpb=31cdb959639755a195f6bbf733b64971b6f5513c;p=chaz%2Fopenbox diff --git a/openbox/menu.h b/openbox/menu.h index d441ec84..2ecbb5cd 100644 --- a/openbox/menu.h +++ b/openbox/menu.h @@ -10,13 +10,18 @@ struct _ObClient; -typedef struct _ObMenu ObMenu; +typedef struct _ObMenu ObMenu; typedef struct _ObMenuEntry ObMenuEntry; typedef void(*menu_controller_show)(ObMenu *self, int x, int y, struct _ObClient *); typedef void(*menu_controller_update)(ObMenu *self); typedef void(*menu_controller_mouseover)(ObMenuEntry *self, gboolean enter); +typedef void(*menu_controller_selected)(ObMenuEntry *entry, + unsigned int button, + unsigned int x, unsigned int y); +typedef void(*menu_controller_hide)(ObMenu *self); + extern GHashTable *menu_hash; extern GList *menu_visible; @@ -25,26 +30,43 @@ struct _ObMenu { ObWindow obwin; + /* The title displayed above the menu. + NULL for no titlebar */ gchar *label; + + /* Name of the menu. + Used in the action showmenu */ gchar *name; - + + /* ObMenuEntry list */ GList *entries; + /* If the menu is currently displayed */ gboolean shown; + + /* If the rendering of the menu has changed and needs to be rerendered. */ gboolean invalid; + /* Kind of lame.Each menu can only be a submenu, and each menu can only + have one submenu open */ ObMenu *parent; - ObMenu *open_submenu; - + GList *over; + + /* behaviour callbacks + TODO: Document and split code that HAS to be in the overridden callback */ /* place a menu on screen */ menu_controller_show show; - void (*hide)( /* some bummu */); - + /* Hide the menu */ + menu_controller_hide hide; /* render a menu */ menu_controller_update update; + /* Event for a mouse enter/exit on an entry + TODO: May have to split from simple render updating? + */ menu_controller_mouseover mouseover; - void (*selected)( /* some bummu */); + /* Entry is clicked/hit enter on */ + menu_controller_selected selected; /* render stuff */ @@ -61,8 +83,9 @@ struct _ObMenu Size size; guint xin_area; /* index of the xinerama head/area */ - /* plugin stuff */ + /* Name of plugin for menu */ char *plugin; + /* plugin's data */ void *plugin_data; }; @@ -80,7 +103,7 @@ struct _ObMenuEntry char *label; ObMenu *parent; - Action *action; + ObAction *action; ObMenuEntryRenderType render_type; gboolean hilite; @@ -91,9 +114,12 @@ struct _ObMenuEntry /* render stuff */ Window item; + Window submenu_pic; + RrAppearance *a_item; RrAppearance *a_disabled; RrAppearance *a_hilite; + RrAppearance *a_submenu; gint y; gint min_w; } MenuEntry; @@ -108,11 +134,18 @@ typedef struct PluginMenuCreateData{ void menu_startup(); void menu_shutdown(); +void menu_noop(); + #define menu_new(l, n, p) \ - menu_new_full(l, n, p, NULL, NULL) + menu_new_full(l, n, p, menu_show_full, menu_render, menu_entry_fire, \ + menu_hide, menu_control_mouseover) ObMenu *menu_new_full(char *label, char *name, ObMenu *parent, - menu_controller_show show, menu_controller_update update); + menu_controller_show show, menu_controller_update update, + menu_controller_selected selected, + menu_controller_hide hide, + menu_controller_mouseover mouseover); + void menu_free(char *name); void menu_show(char *name, int x, int y, struct _ObClient *client); @@ -122,7 +155,7 @@ void menu_hide(ObMenu *self); void menu_clear(ObMenu *self); -ObMenuEntry *menu_entry_new_full(char *label, Action *action, +ObMenuEntry *menu_entry_new_full(char *label, ObAction *action, ObMenuEntryRenderType render_type, gpointer submenu); @@ -150,7 +183,8 @@ ObMenuEntry *menu_find_entry_by_pos(ObMenu *menu, int x, int y); void menu_entry_render(ObMenuEntry *self); -void menu_entry_fire(ObMenuEntry *self); +void menu_entry_fire(ObMenuEntry *entry, + unsigned int button, unsigned int x, unsigned int y); void menu_render(ObMenu *self); void menu_render_full(ObMenu *self); @@ -158,5 +192,5 @@ void menu_render_full(ObMenu *self); /*so plugins can call it? */ void parse_menu_full(xmlDocPtr doc, xmlNodePtr node, void *data, gboolean new); void menu_control_mouseover(ObMenuEntry *entry, gboolean enter); -ObMenuEntry *menu_control_keyboard_nav(ObMenuEntry *over, ObKey key); +void menu_control_keyboard_nav(unsigned int key); #endif