X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fmenu.h;h=b0f39b7b53b9b4258bc615e355e10cb6d15bd12e;hb=c3b02749d72e0077aff85f29d7a28e5ba329b071;hp=bbc9fe81d024761969e488d21c70e7937cc11e3b;hpb=0e28a07e3d6677aa6af9ad97fbc55f8101f3fdf2;p=chaz%2Fopenbox diff --git a/openbox/menu.h b/openbox/menu.h index bbc9fe81..b0f39b7b 100644 --- a/openbox/menu.h +++ b/openbox/menu.h @@ -2,89 +2,120 @@ #define __menu_h #include "action.h" +#include "window.h" +#include "geom.h" #include "render/render.h" +#include "parser/parse.h" #include -typedef struct Menu { - char *label; - char *name; - +struct _ObClient; +struct _ObMenuFrame; +struct _ObMenuEntryFrame; + +typedef struct _ObMenu ObMenu; +typedef struct _ObMenuEntry ObMenuEntry; +typedef struct _ObNormalMenuEntry ObNormalMenuEntry; +typedef struct _ObSubmenuMenuEntry ObSubmenuMenuEntry; +typedef struct _ObSeparatorMenuEntry ObSeparatorMenuEntry; + +typedef void (*ObMenuUpdateFunc)(struct _ObMenuFrame *frame, gpointer data); +typedef void (*ObMenuExecuteFunc)(struct _ObMenuEntry *entry, gpointer data); +typedef void (*ObMenuDestroyFunc)(struct _ObMenu *menu, gpointer data); + +struct _ObMenu +{ + /* Name of the menu. Used in the showmenu action. */ + gchar *name; + /* Displayed title */ + gchar *title; + + /* Command to execute to rebuild the menu */ + gchar *execute; + + /* ObMenuEntry list */ GList *entries; - /* GList *tail; */ - - /* ? */ - gboolean shown; - gboolean invalid; - gpointer render_data; /* where the engine can store anything it likes */ - - struct Menu *parent; - - /* waste o' pointers */ - void (*show)( /* some bummu */); - void (*hide)( /* some bummu */); - void (*update)( /* some bummu */); - void (*mouseover)( /* some bummu */); - void (*selected)( /* some bummu */); -} Menu; - -typedef struct MenuRenderData { - Window frame; - Window title; - Appearance *a_title; - int title_min_w, title_h; - Window items; - Appearance *a_items; - int item_h; -} MenuRenderData; - -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; + + /* plugin data */ + gpointer data; + + ObMenuUpdateFunc update_func; + ObMenuExecuteFunc execute_func; + ObMenuDestroyFunc destroy_func; +}; + +typedef enum +{ + OB_MENU_ENTRY_TYPE_NORMAL, + OB_MENU_ENTRY_TYPE_SUBMENU, + OB_MENU_ENTRY_TYPE_SEPARATOR +} ObMenuEntryType; + +struct _ObNormalMenuEntry { + gchar *label; + + /* state */ gboolean enabled; - gboolean boolean_value; - gpointer render_data; /* where the engine can store anything it likes */ - Menu *submenu; -} MenuEntry; + /* List of ObActions */ + GSList *actions; + + /* Icon shit */ + gint icon_width; + gint icon_height; + RrPixel32 *icon_data; +}; + +struct _ObSubmenuMenuEntry { + gchar *name; + ObMenu *submenu; +}; + +struct _ObSeparatorMenuEntry { + gchar foo; /* placeholder */ +}; -typedef struct MenuEntryRenderData { - Window item; - Appearance *a_item; - int min_w; -} MenuEntryRenderData; +struct _ObMenuEntry +{ + ObMenuEntryType type; + ObMenu *menu; + + gint id; + + union u { + ObNormalMenuEntry normal; + ObSubmenuMenuEntry submenu; + ObSeparatorMenuEntry separator; + } data; +}; void menu_startup(); void menu_shutdown(); -Menu *menu_new(char *label, char *name, Menu *parent); -void menu_free(char *name); +ObMenu* menu_new(gchar *name, gchar *title, gpointer data); +void menu_free(ObMenu *menu); + +/* Repopulate a pipe-menu by running its command */ +void menu_pipe_execute(ObMenu *self); + +void menu_show(gchar *name, gint x, gint y, struct _ObClient *client); -void menu_show(char *name, int x, int y, Client *client); +void menu_set_update_func(ObMenu *menu, ObMenuUpdateFunc func); +void menu_set_execute_func(ObMenu *menu, ObMenuExecuteFunc func); +void menu_set_destroy_func(ObMenu *menu, ObMenuDestroyFunc func); -MenuEntry *menu_entry_new_full(char *label, Action *action, - MenuEntryRenderType render_type, - gpointer submenu); +/* functions for building menus */ +ObMenuEntry* menu_add_normal(ObMenu *menu, gint id, gchar *label, + GSList *actions); +ObMenuEntry* menu_add_submenu(ObMenu *menu, gint id, gchar *submenu); +ObMenuEntry* menu_add_separator(ObMenu *menu, gint id); -#define menu_entry_new(label, action) \ - menu_entry_new_full(label, action, MenuEntryRenderType_None, NULL) +void menu_clear_entries(ObMenu *menu); +void menu_entry_remove(ObMenuEntry *self); -void menu_entry_free(MenuEntry *entry); +ObMenuEntry* menu_find_entry_id(ObMenu *self, gint id); -void menu_entry_set_submenu(MenuEntry *entry, Menu *submenu); +/* fills in the submenus, for use when a menu is being shown */ +void menu_find_submenus(ObMenu *self); -void menu_add_entry(Menu *menu, MenuEntry *entry); #endif