]> git.ozlabs.org Git - petitboot/blobdiff - ui/ncurses/nc-cui.h
ui/ncurses: Add support for 'add-url' action
[petitboot] / ui / ncurses / nc-cui.h
index 79c41a4ec90b4d243150838ca0689771790c5327..694ebd1fbaceaa9a291dc7e6834620a2ccb55560 100644 (file)
 
 #include <signal.h>
 
-#include "ui/common/timer.h"
+#include "ui/common/joystick.h"
 #include "nc-menu.h"
-#include "nc-ked.h"
+#include "nc-helpscreen.h"
 
 struct cui_opt_data {
+       const char *name;
+       struct pb_boot_data *bd;
+
+       /* optional data */
        const struct device *dev;
        const struct boot_option *opt;
        uint32_t opt_hash;
-       struct pb_kexec_data *kd;
 };
 
 /**
@@ -45,27 +48,50 @@ struct cui_opt_data {
 
 struct cui {
        enum pb_nc_sig c_sig;
+       bool has_input;
        sig_atomic_t abort;
        sig_atomic_t resize;
        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 add_url_screen *add_url_screen;
+       struct boot_editor *boot_editor;
+       struct lang_screen *lang_screen;
+       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);
 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_help(struct cui *cui, const char *title,
+               const struct help_text *text);
+void cui_show_add_url(struct cui *cui);
+int cui_send_config(struct cui *cui, struct config *config);
+int cui_send_url(struct cui *cui, char *url);
+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_on_open(struct pmenu *menu);
 int cui_run_cmd(struct pmenu_item *item);
 
 static inline struct cui *cui_from_arg(void *arg)
@@ -86,15 +112,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