From: Jeremy Kerr Date: Tue, 3 Jul 2018 06:34:46 +0000 (+1000) Subject: ui/ncurses: Implement non-boot-cancelling keys X-Git-Tag: v1.9.0~62 X-Git-Url: http://git.ozlabs.org/?p=petitboot;a=commitdiff_plain;h=47c55b245aab729a9c23bfb830329022c7b25d83 ui/ncurses: Implement non-boot-cancelling keys Allow some keys to not cancel the default-boot process. For the moment, this is just the screen refresh (ctrl+L). Signed-off-by: Jeremy Kerr Signed-off-by: Samuel Mendoza-Jonas --- diff --git a/ui/ncurses/nc-cui.c b/ui/ncurses/nc-cui.c index 8a3f97d..87540ca 100644 --- a/ui/ncurses/nc-cui.c +++ b/ui/ncurses/nc-cui.c @@ -527,6 +527,14 @@ struct nc_scr *cui_set_current(struct cui *cui, struct nc_scr *scr) return old; } +static bool key_cancels_boot(int key) +{ + if (key == 0xc) + return false; + + return true; +} + static bool process_global_keys(struct cui *cui, int key) { switch (key) { @@ -582,7 +590,7 @@ static int cui_process_key(void *arg) } } - if (!cui->has_input) { + if (!cui->has_input && key_cancels_boot(c)) { cui->has_input = true; if (cui->client) { pb_log("UI input received (key = %d), aborting "