X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=blobdiff_plain;f=ui%2Fncurses%2Fnc-scr.h;h=e3ed20a8502d8de3cad30f0fe6d1a3e475a62fb8;hp=bda2c3241df0e6cb026f32a10f25cc7ef5f14138;hb=651940467773d2e679f9210e02f4654fb05cd449;hpb=6d51866f409e90274ff8cfb06b92a6c828692698;ds=sidebyside diff --git a/ui/ncurses/nc-scr.h b/ui/ncurses/nc-scr.h index bda2c32..e3ed20a 100644 --- a/ui/ncurses/nc-scr.h +++ b/ui/ncurses/nc-scr.h @@ -20,29 +20,34 @@ #define _PB_NC_SCR_H #include /* This must be included before ncurses.h */ -#include - -#ifdef DEBUG -#define DBG(fmt, args...) pb_log("DBG: " fmt, ## args) -#define DBGS(fmt, args...) \ - pb_log("DBG:%s:%d: " fmt, __func__, __LINE__, ## args) +#if defined HAVE_NCURSESW_CURSES_H +# include +#elif defined HAVE_NCURSESW_H +# include +#elif defined HAVE_NCURSES_CURSES_H +# include +#elif defined HAVE_NCURSES_H +# include +#elif defined HAVE_CURSES_H +# include #else -#define DBG(fmt, args...) -#define DBGS(fmt, args...) +# error "Curses header file not found." #endif +#define DBG(fmt, args...) pb_debug("DBG: " fmt, ## args) +#define DBGS(fmt, args...) \ + pb_debug("DBG:%s:%d: " fmt, __func__, __LINE__, ## args) + enum pb_nc_sig { - pb_cui_sig = 111, - pb_pmenu_sig = 222, - pb_item_sig = 333, - pb_ked_sig = 444, - pb_removed_sig = -555, + pb_cui_sig = 111, + pb_pmenu_sig = 222, + pb_item_sig = 333, + pb_boot_editor_sig = 444, + pb_sysinfo_screen_sig = 555, + pb_removed_sig = -666, }; -void nc_start(void); -void nc_atexit(void); - static inline void nc_flush_keys(void) { while (getch() != ERR) @@ -52,6 +57,7 @@ static inline void nc_flush_keys(void) enum nc_scr_pos { nc_scr_pos_title = 0, nc_scr_pos_title_sep = 1, + nc_scr_pos_lrtitle_space = 2, nc_scr_pos_sub = 2, nc_scr_pos_help_sep = 3, @@ -59,10 +65,12 @@ enum nc_scr_pos { nc_scr_pos_status = 1, nc_scr_frame_lines = 5, + nc_scr_frame_cols = 1, }; struct nc_frame { - char *title; + char *ltitle; + char *rtitle; char *help; char *status; }; @@ -75,13 +83,13 @@ struct nc_scr { void *ui_ctx; int (*post)(struct nc_scr *scr); int (*unpost)(struct nc_scr *scr); - void (*process_key)(struct nc_scr *scr); + void (*process_key)(struct nc_scr *scr, int key); void (*resize)(struct nc_scr *scr); }; int nc_scr_init(struct nc_scr *scr, enum pb_nc_sig sig, int begin_x, void *ui_ctx, - void (*process_key)(struct nc_scr *), + void (*process_key)(struct nc_scr *, int), int (*post)(struct nc_scr *), int (*unpost)(struct nc_scr *), void (*resize)(struct nc_scr *)); @@ -89,4 +97,7 @@ void nc_scr_status_free(struct nc_scr *scr); void nc_scr_status_printf(struct nc_scr *scr, const char *format, ...); void nc_scr_frame_draw(struct nc_scr *scr); +int nc_scr_post(struct nc_scr *src); +int nc_scr_unpost(struct nc_scr *src); + #endif