X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=ui%2Fncurses%2Fnc-cui.h;h=d26883b1e47d08a3a07d86c39898096e72e208fd;hp=ddbf27f074ec53d3bc45c01559fb0b2ab3ecbe2e;hb=c4be9490a5d94b662370576157b6e0ed73f2fe77;hpb=37428306a270088bfcb1f94362a0fe5b7a5a888e diff --git a/ui/ncurses/nc-cui.h b/ui/ncurses/nc-cui.h index ddbf27f..d26883b 100644 --- a/ui/ncurses/nc-cui.h +++ b/ui/ncurses/nc-cui.h @@ -22,13 +22,15 @@ #include #include "ui/common/joystick.h" -#include "ui/common/timer.h" #include "nc-menu.h" -#include "nc-ked.h" +#include "nc-helpscreen.h" struct cui_opt_data { - const char *name; - struct pb_kexec_data *kd; + char *name; + union { + struct pb_boot_data *bd; + struct pb_plugin_data *pd; + }; /* optional data */ const struct device *dev; @@ -49,33 +51,66 @@ struct cui_opt_data { struct cui { enum pb_nc_sig c_sig; + bool has_input; + struct autoboot_option *autoboot_opt; sig_atomic_t abort; sig_atomic_t resize; - int dry_run; struct nc_scr *current; struct pmenu *main; - struct ui_timer timer; + struct pmenu *plugin_menu; + unsigned int n_plugins; struct waitset *waitset; + struct discover_client *client; + struct system_info *sysinfo; + struct statuslog *statuslog; + struct sysinfo_screen *sysinfo_screen; + struct config *config; + struct config_screen *config_screen; + struct add_url_screen *add_url_screen; + struct plugin_screen *plugin_screen; + struct boot_editor *boot_editor; + struct lang_screen *lang_screen; + struct help_screen *help_screen; + struct subset_screen *subset_screen; + struct statuslog_screen *statuslog_screen; struct pjs *pjs; void *platform_info; unsigned int default_item; - int (*on_kexec)(struct cui *cui, struct cui_opt_data *cod); + int (*on_boot)(struct cui *cui, struct cui_opt_data *cod); }; struct cui *cui_init(void* platform_info, - int (*on_kexec)(struct cui *, struct cui_opt_data *), - int (*js_map)(const struct js_event *e), int start_deamon, int dry_run); + int (*js_map)(const struct js_event *e), + int start_daemon, int timeout); struct nc_scr *cui_set_current(struct cui *cui, struct nc_scr *scr); -int cui_run(struct cui *cui, struct pmenu *main, unsigned int default_item); -int cui_ked_run(struct pmenu_item *item); +int cui_run(struct cui *cui); +void cui_item_edit(struct pmenu_item *item); +void cui_item_new(struct pmenu *menu); +void cui_show_sysinfo(struct cui *cui); +void cui_show_config(struct cui *cui); +void cui_show_lang(struct cui *cui); +void cui_show_statuslog(struct cui *cui); +void cui_show_help(struct cui *cui, const char *title, + const struct help_text *text); +void cui_show_subset(struct cui *cui, const char *title, + void *arg); +void cui_show_add_url(struct cui *cui); +void cui_show_plugin(struct pmenu_item *item); +void cui_show_plugin_menu(struct cui *cui); +int cui_send_config(struct cui *cui, struct config *config); +int cui_send_url(struct cui *cui, char *url); +int cui_send_plugin_install(struct cui *cui, char *file); +void cui_send_reinit(struct cui *cui); /* convenience routines */ void cui_abort(struct cui *cui); void cui_resize(struct cui *cui); void cui_on_exit(struct pmenu *menu); +void cui_abort_on_exit(struct pmenu *menu); void cui_on_open(struct pmenu *menu); -int cui_run_cmd(struct pmenu_item *item); +int cui_run_cmd(struct cui *cui, const char **cmd_argv); +int cui_run_cmd_from_item(struct pmenu_item *item); static inline struct cui *cui_from_arg(void *arg) { @@ -95,15 +130,4 @@ static inline struct cui *cui_from_item(struct pmenu_item *item) return cui_from_pmenu(item->pmenu); } -static inline struct cui *cui_from_timer(struct ui_timer *timer) -{ - struct cui *cui; - - cui = (struct cui *)((char *)timer - - (size_t)&((struct cui *)0)->timer); - assert(cui->c_sig == pb_cui_sig); - - return cui; -} - #endif