ui/ncurses: Use a separate type for help text
[petitboot] / ui / ncurses / nc-cui.h
index 3bdbcfca2eaf8e4423aa6ec218d3f336d1f19398..e9e4d38b320ce8063b8c881687a9ae69b38b74bb 100644 (file)
@@ -22,9 +22,8 @@
 #include <signal.h>
 
 #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;
@@ -49,25 +48,38 @@ struct cui_opt_data {
 
 struct cui {
        enum pb_nc_sig c_sig;
+       bool has_input;
        sig_atomic_t abort;
        sig_atomic_t resize;
-       int dry_run;
        struct nc_scr *current;
        struct pmenu *main;
-       struct ui_timer timer;
        struct waitset *waitset;
+       struct discover_client *client;
+       struct system_info *sysinfo;
+       struct sysinfo_screen *sysinfo_screen;
+       struct config *config;
+       struct config_screen *config_screen;
+       struct boot_editor *boot_editor;
+       struct help_screen *help_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_deamon);
 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);
+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_help(struct cui *cui, const char *title,
+               const struct help_text *text);
+int cui_send_config(struct cui *cui, struct config *config);
+void cui_send_reinit(struct cui *cui);
 
 /* convenience routines */
 
@@ -95,15 +107,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