X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fmenu.h;h=c91be82b67f3e3cdd76dd8d714d59876f8b6f9a9;hb=c34915ae8d49f61426912ef332e8097be516bdd3;hp=c6b36719f5de2eae160036ab231d902f30e1761f;hpb=58cfbb7f8419e084af6b6b8b00c88ed270c29e88;p=chaz%2Fopenbox diff --git a/openbox/menu.h b/openbox/menu.h index c6b36719..c91be82b 100644 --- a/openbox/menu.h +++ b/openbox/menu.h @@ -2,141 +2,112 @@ #define __menu_h #include "action.h" -#include "render/render.h" +#include "window.h" #include "geom.h" +#include "render/render.h" +#include "parser/parse.h" #include -extern GHashTable *menu_map; +struct _ObClient; +struct _ObMenuFrame; +struct _ObMenuEntryFrame; -struct Menu; -struct MenuEntry; +typedef struct _ObMenu ObMenu; +typedef struct _ObMenuEntry ObMenuEntry; +typedef struct _ObNormalMenuEntry ObNormalMenuEntry; +typedef struct _ObSubmenuMenuEntry ObSubmenuMenuEntry; +typedef struct _ObSeparatorMenuEntry ObSeparatorMenuEntry; -typedef void(*menu_controller_show)(struct Menu *self, int x, int y, Client *); -typedef void(*menu_controller_update)(struct Menu *self); -typedef void(*menu_controller_mouseover)(struct MenuEntry *self, - gboolean enter); +typedef void (*ObMenuUpdateFunc)(struct _ObMenuFrame *frame, gpointer data); +typedef void (*ObMenuExecuteFunc)(struct _ObMenuEntryFrame *frame, + gpointer data); +typedef void (*ObMenuDestroyFunc)(struct _ObMenu *menu, gpointer data); -typedef struct Menu { - ObWindow obwin; +extern GList *menu_visible; - char *label; - char *name; - - GList *entries; +struct _ObMenu +{ + /* Name of the menu. Used in the showmenu action. */ + gchar *name; + /* Displayed title */ + gchar *title; - gboolean shown; - gboolean invalid; - - struct Menu *parent; - - struct Menu *open_submenu; - - /* place a menu on screen */ - menu_controller_show show; - void (*hide)( /* some bummu */); - - /* render a menu */ - menu_controller_update update; - menu_controller_mouseover mouseover; - void (*selected)( /* some bummu */); - - - /* 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; - Point location; - Size size; - - /* plugin stuff */ - char *plugin; - void *plugin_data; -} Menu; - -typedef enum MenuEntryRenderType { - MenuEntryRenderType_None = 0, - MenuEntryRenderType_Submenu = 1 << 0, - MenuEntryRenderType_Boolean = 1 << 1, - MenuEntryRenderType_Separator = 1 << 2, - - MenuEntryRenderType_Other = 1 << 7 -} MenuEntryRenderType; - -typedef struct { - char *label; - Menu *parent; - - Action *action; - - MenuEntryRenderType render_type; - gboolean hilite; - gboolean enabled; - gboolean boolean_value; + /* ObMenuEntry list */ + GList *entries; - Menu *submenu; + /* plugin data */ + gpointer data; - /* render stuff */ - Window item; - Appearance *a_item; - Appearance *a_disabled; - Appearance *a_hilite; - int y; - int min_w; -} MenuEntry; + ObMenuUpdateFunc update_func; + ObMenuExecuteFunc execute_func; + ObMenuDestroyFunc destroy_func; +}; -void menu_startup(); -void menu_shutdown(); +typedef enum +{ + OB_MENU_ENTRY_TYPE_NORMAL, + OB_MENU_ENTRY_TYPE_SUBMENU, + OB_MENU_ENTRY_TYPE_SEPARATOR +} ObMenuEntryType; -#define menu_new(l, n, p) \ - menu_new_full(l, n, p, NULL, NULL) +struct _ObNormalMenuEntry { + gchar *label; -Menu *menu_new_full(char *label, char *name, Menu *parent, - menu_controller_show show, menu_controller_update update); -void menu_free(char *name); + /* state */ + gboolean enabled; -void menu_show(char *name, int x, int y, Client *client); -void menu_show_full(Menu *menu, int x, int y, Client *client); + /* List of ObActions */ + GSList *actions; +}; -void menu_hide(Menu *self); +struct _ObSubmenuMenuEntry { + gchar *name; + ObMenu *submenu; +}; -void menu_clear(Menu *self); +struct _ObSeparatorMenuEntry { + gchar foo; /* placeholder */ +}; -MenuEntry *menu_entry_new_full(char *label, Action *action, - MenuEntryRenderType render_type, - gpointer submenu); +struct _ObMenuEntry +{ + ObMenuEntryType type; + ObMenu *menu; -#define menu_entry_new(label, action) \ -menu_entry_new_full(label, action, MenuEntryRenderType_None, NULL) + gint id; -#define menu_entry_new_separator(label) \ -menu_entry_new_full(label, NULL, MenuEntryRenderType_Separator, NULL) + union u { + ObNormalMenuEntry normal; + ObSubmenuMenuEntry submenu; + ObSeparatorMenuEntry separator; + } data; +}; -#define menu_entry_new_submenu(label, submenu) \ -menu_entry_new_full(label, NULL, MenuEntryRenderType_Submenu, submenu) +void menu_startup(); +void menu_shutdown(); -#define menu_entry_new_boolean(label, action) \ -menu_entry_new_full(label, action, MenuEntryRenderType_Boolean, NULL) +void menu_parse(); -void menu_entry_free(MenuEntry *entry); +gboolean menu_new(gchar *name, gchar *title, gpointer data); +void menu_free(gchar *name); -void menu_entry_set_submenu(MenuEntry *entry, Menu *submenu); +gboolean menu_open_plugin(ObParseInst *i, gchar *name, gchar *plugin); -void menu_add_entry(Menu *menu, MenuEntry *entry); +void menu_set_update_func(gchar *name, ObMenuUpdateFunc func); +void menu_set_execute_func(gchar *name, ObMenuExecuteFunc func); +void menu_set_destroy_func(gchar *name, ObMenuDestroyFunc func); -MenuEntry *menu_find_entry(Menu *menu, Window win); +void menu_show(gchar *name, gint x, gint y, struct _ObClient *client); -void menu_entry_render(MenuEntry *self); +/* functions for building menus */ +void menu_clear_entries(gchar *name); +void menu_add_normal(gchar *name, gint id, gchar *label, GSList *actions); +void menu_add_submenu(gchar *name, gint id, gchar *submenu); +void menu_add_separator(gchar *name, gint id); -void menu_entry_fire(MenuEntry *self); +ObMenuEntry* menu_find_entry_id(ObMenu *self, gint id); -void menu_render(Menu *self); +void menu_find_submenus(ObMenu *self); -void menu_control_mouseover(MenuEntry *entry, gboolean enter); #endif