X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=ui%2Fncurses%2Fnc-cui.h;h=abe4db98173446fd34ddaeb04cd21018fce45e78;hp=abe22a8ad3fc61569398ea51069836f69bb43b0e;hb=2bc0df4aa35a89c5af7e54f459e2bbde20ca6a7e;hpb=1b0b59295d0500764c5096753f7cd11bf3ab5df4 diff --git a/ui/ncurses/nc-cui.h b/ui/ncurses/nc-cui.h index abe22a8..abe4db9 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-boot-editor.h" +#include "nc-helpscreen.h" struct cui_opt_data { - const char *name; - struct pb_boot_data *bd; + char *name; + union { + struct pb_boot_data *bd; + struct pb_plugin_data *pd; + }; /* optional data */ const struct device *dev; @@ -49,33 +51,67 @@ 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_boot)(struct cui *cui, struct cui_opt_data *cod); + bool preboot_mode; }; struct cui *cui_init(void* platform_info, - int (*on_boot)(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_boot_editor_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 +131,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