X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=ui%2Fncurses%2Fnc-menu.h;h=4d9e1887702b70d94367ce8fe33e2347bf38831d;hp=4abec6fffe258cb8d1306a83e23127654e8d38d0;hb=11c43508e4360456298a6dcb0563614e9a118b41;hpb=d3e5eadbdcce508c48258b15664baa753ce6fc81 diff --git a/ui/ncurses/nc-menu.h b/ui/ncurses/nc-menu.h index 4abec6f..4d9e188 100644 --- a/ui/ncurses/nc-menu.h +++ b/ui/ncurses/nc-menu.h @@ -20,11 +20,20 @@ #define _PB_NC_MENU_H #include + #include /* This must be included before ncurses.h */ -#include +#if defined HAVE_NCURSESW_MENU_H +# include +#elif defined HAVE_NCURSES_MENU_H +# include +#elif defined HAVE_MENU_H +# include +#else +# error "Curses menu.h not found." +#endif #include "log/log.h" -#include "pb-protocol/pb-protocol.h" +#include "types/types.h" #include "nc-scr.h" struct pmenu; @@ -40,14 +49,18 @@ struct pmenu_item { ITEM *nci; struct pmenu *pmenu; void *data; - int (*on_edit)(struct pmenu_item *item); + void (*on_edit)(struct pmenu_item *item); int (*on_execute)(struct pmenu_item *item); }; -struct pmenu_item *pmenu_item_alloc(struct pmenu *menu); -struct pmenu_item *pmenu_item_setup(struct pmenu *menu, struct pmenu_item *i, - unsigned int index, const char *name); -int pmenu_item_replace(struct pmenu_item *i, const char *name); +int pmenu_item_update(struct pmenu_item *item, const char *name); +struct pmenu_item *pmenu_item_create(struct pmenu *menu, const char *name); +struct pmenu_item *pmenu_find_device(struct pmenu *menu, struct device *dev, + struct boot_option *opt); +void pmenu_item_insert(struct pmenu *menu, struct pmenu_item *item, + unsigned int index); +void pmenu_item_add(struct pmenu *menu, struct pmenu_item *item, + unsigned int insert_pt); void pmenu_item_delete(struct pmenu_item *item); static inline struct pmenu_item *pmenu_item_from_arg(void *arg) @@ -58,12 +71,15 @@ static inline struct pmenu_item *pmenu_item_from_arg(void *arg) return item; } -static inline struct pmenu_item *pmenu_item_init(struct pmenu *menu, - unsigned int index, const char *name) +static inline struct cui_opt_data *cod_from_item(struct pmenu_item *item) { - return pmenu_item_setup(menu, pmenu_item_alloc(menu), index, name); + return item->data; } +typedef int (*hot_key_fn)(struct pmenu *menu, struct pmenu_item *item, int c); + +int pmenu_main_hot_keys(struct pmenu *menu, struct pmenu_item *item, int c); + /** * struct pmenu - Data structure defining complete menu. * @insert_pt: Index in nc item array. @@ -76,15 +92,17 @@ struct pmenu { ITEM **items; unsigned int item_count; unsigned int insert_pt; - int (*hot_key)(struct pmenu *menu, struct pmenu_item *item, int c); + const char *help_title; + const struct help_text *help_text; + hot_key_fn *hot_keys; + unsigned int n_hot_keys; void (*on_exit)(struct pmenu *menu); - void (*on_open)(struct pmenu *menu); + void (*on_new)(struct pmenu *menu); }; struct pmenu *pmenu_init(void *ui_ctx, unsigned int item_count, void (*on_exit)(struct pmenu *)); int pmenu_setup(struct pmenu *menu); -void pmenu_delete(struct pmenu *menu); unsigned int pmenu_grow(struct pmenu *menu, unsigned int count); int pmenu_remove(struct pmenu *menu, struct pmenu_item *item); struct pmenu_item *pmenu_find_selected(struct pmenu *menu); @@ -107,26 +125,18 @@ static inline struct pmenu *pmenu_from_scr(struct nc_scr *scr) /* debug routines */ -#if defined(DEBUG) -enum {do_debug = 1}; -#else -enum {do_debug = 0}; -#endif - static inline void pmenu_dump_item(const ITEM *item) { - if (do_debug) - pb_log("%p %s\n", item, (item ? item->name.str : "(null)")); + pb_debug("%p %s\n", item, (item ? item->name.str : "(null)")); } static inline void pmenu_dump_items(ITEM *const *items, unsigned int count) { unsigned int i; - if (do_debug) - for (i = 0; i < count; i++) - pb_log("%u: %p %s\n", i, items[i], - (items[i] ? items[i]->name.str : "(null)")); + for (i = 0; i < count; i++) + pb_debug("%u: %p %s\n", i, items[i], + (items[i] ? items[i]->name.str : "(null)")); } #endif