]> git.ozlabs.org Git - petitboot/blobdiff - ui/ncurses/ps3-cui.c
Remove nc menu description
[petitboot] / ui / ncurses / ps3-cui.c
index f166c8830cf54a748080e4205e853344c5940df1..dd5b25503e635927090871b0409240559bc1c35d 100644 (file)
@@ -21,9 +21,7 @@
 /*
  * TODO
  * removable media event
- * resize after video mode change
  * ncurses mouse support
- * timeout
  */
 
 #if defined(HAVE_CONFIG_H)
@@ -36,6 +34,7 @@
 #include <signal.h>
 #include <stdlib.h>
 #include <string.h>
+#include <sys/time.h>
 
 #include "log/log.h"
 #include "talloc/talloc.h"
@@ -53,7 +52,8 @@ static void print_usage(void)
 {
        print_version();
        printf(
-"Usage: pb-cui [-h, --help] [-l, --log log-file] [-V, --version]\n");
+"Usage: pb-cui [-h, --help] [-l, --log log-file] [-r, --reset-defaults]\n"
+"              [-t, --timeout] [-V, --version]\n");
 }
 
 /**
@@ -69,6 +69,8 @@ enum opt_value {opt_undef = 0, opt_yes, opt_no};
 struct opts {
        enum opt_value show_help;
        const char *log_file;
+       enum opt_value reset_defaults;
+       enum opt_value use_timeout;
        enum opt_value show_version;
 };
 
@@ -79,12 +81,14 @@ struct opts {
 static int opts_parse(struct opts *opts, int argc, char *argv[])
 {
        static const struct option long_options[] = {
-               {"help",    no_argument,       NULL, 'h'},
-               {"log",     required_argument, NULL, 'l'},
-               {"version", no_argument,       NULL, 'V'},
-               { NULL,     0,                 NULL, 0},
+               {"help",           no_argument,       NULL, 'h'},
+               {"log",            required_argument, NULL, 'l'},
+               {"reset-defaults", no_argument,       NULL, 'r'},
+               {"timeout",        no_argument,       NULL, 't'},
+               {"version",        no_argument,       NULL, 'V'},
+               { NULL, 0, NULL, 0},
        };
-       static const char short_options[] = "hl:V";
+       static const char short_options[] = "hl:trV";
        static const struct opts default_values = {
                .log_file = "pb-cui.log",
        };
@@ -105,6 +109,12 @@ static int opts_parse(struct opts *opts, int argc, char *argv[])
                case 'l':
                        opts->log_file = optarg;
                        break;
+               case 't':
+                       opts->use_timeout = opt_yes;
+                       break;
+               case 'r':
+                       opts->reset_defaults = opt_yes;
+                       break;
                case 'V':
                        opts->show_version = opt_yes;
                        break;
@@ -114,7 +124,7 @@ static int opts_parse(struct opts *opts, int argc, char *argv[])
                }
        }
 
-       return 0;
+       return optind != argc;
 }
 
 /**
@@ -189,11 +199,12 @@ static int ps3_kexec_cb(struct cui *cui, struct cui_opt_data *cod)
 {
        struct ps3_cui *ps3 = ps3_from_cui(cui);
 
-       pb_log("%s: %s:%s\n", __func__, cod->dev->name, cod->opt->name);
+       pb_log("%s: %s\n", __func__, cod->name);
 
        assert(ps3->cui->current == &ps3->cui->main->scr);
 
-       if (cui->default_item != cod->opt_hash || ps3->dirty_values) {
+       if ((cod->opt_hash && cod->opt_hash != cui->default_item)
+               || ps3->dirty_values) {
                ps3->values.default_item = cod->opt_hash;
                ps3_flash_set_values(&ps3->values);
        }
@@ -282,6 +293,21 @@ static int ps3_hot_key(struct pmenu __attribute__((unused)) *menu,
        return c;
 }
 
+/**
+ * ps3_timer_update - Timer callback.
+ */
+
+static void ps3_timer_update(struct ui_timer *timer, unsigned int timeout)
+{
+       struct ps3_cui *ps3 = ps3_from_cui(cui_from_timer(timer));
+
+       //FIXME: make scr:timer.
+       // nc_scr_timer_update(&ps3.mm->scr, timeout);
+
+       nc_scr_status_printf(&ps3->mm->scr,
+               "Welcome to Petitboot (timeout %u sec)", timeout);
+}
+
 /**
  * ps3_mm_init - Setup the main menu instance.
  */
@@ -291,8 +317,7 @@ static struct pmenu *ps3_mm_init(struct ps3_cui *ps3_cui)
        int result;
        struct pmenu *m;
        struct pmenu_item *i;
-       static const char *const bgo[] =
-               {"/usr/sbin/ps3-boot-game-os-NOT", NULL};
+       static const char *const bgo[] = {"/usr/sbin/ps3-boot-game-os", NULL};
 
        m = pmenu_init(ps3_cui->cui, 3, cui_on_exit);
 
@@ -302,22 +327,26 @@ static struct pmenu *ps3_mm_init(struct ps3_cui *ps3_cui)
        }
 
        m->hot_key = ps3_hot_key;
+       m->on_open = cui_on_open;
+
+#if defined(DEBUG)
+       m->scr.frame.title = talloc_strdup(m,
+               "Petitboot PS3 (ver " PACKAGE_VERSION ")");
+#else
        m->scr.frame.title = talloc_strdup(m, "Petitboot PS3");
+#endif
        m->scr.frame.help = talloc_strdup(m,
-               "ESC=exit, Enter=accept, E,e=edit");
+               "ESC=exit, Enter=accept, e=edit, o=open");
        m->scr.frame.status = talloc_strdup(m, "Welcome to Petitboot");
 
-       i = pmenu_item_init(m, 0, "Boot GameOS",
-               "Reboot the PS3 into the GameOS");
+       i = pmenu_item_init(m, 0, "Boot GameOS");
        i->on_execute = cui_run_cmd;
        i->data = (void *)bgo;
 
-       i = pmenu_item_init(m, 1, "Set Video Mode",
-               "Display a video mode selection menu");
+       i = pmenu_item_init(m, 1, "Set Video Mode");
        i->on_execute = ps3_mm_to_svm_cb;
 
-       i = pmenu_item_init(m, 2, "Exit to Shell",
-               "Exit petitboot and return to a shell prompt");
+       i = pmenu_item_init(m, 2, "Exit to Shell");
        i->on_execute = pmenu_exit_cb;
 
        result = pmenu_setup(m);
@@ -360,53 +389,51 @@ static struct pmenu *ps3_svm_init(struct ps3_cui *ps3_cui)
        m->scr.frame.title = talloc_strdup(m, "Select PS3 Video Mode");
        m->scr.frame.help = talloc_strdup(m, "ESC=exit, Enter=accept");
 
-       i = pmenu_item_init(m, 0, "auto detect",
-               "Auto detect the best HDMI video mode");
+       i = pmenu_item_init(m, 0, "auto detect");
        i->on_execute = ps3_svm_cb;
        i->data = (void *)0;
 
-       i = pmenu_item_init(m, 1, "480i    (576 x 384)", NULL);
+       i = pmenu_item_init(m, 1, "480i    (576 x 384)");
        i->on_execute = ps3_svm_cb;
        i->data = (void *)1;
 
-       i = pmenu_item_init(m, 2, "480p    (576 x 384)", NULL);
+       i = pmenu_item_init(m, 2, "480p    (576 x 384)");
        i->on_execute = ps3_svm_cb;
        i->data = (void *)2;
 
-       i = pmenu_item_init(m, 3, "576i    (576 x 460)", NULL);
+       i = pmenu_item_init(m, 3, "576i    (576 x 460)");
        i->on_execute = ps3_svm_cb;
        i->data = (void *)6;
 
-       i = pmenu_item_init(m, 4, "576p    (576 x 460)", NULL);
+       i = pmenu_item_init(m, 4, "576p    (576 x 460)");
        i->on_execute = ps3_svm_cb;
        i->data = (void *)7;
 
-       i = pmenu_item_init(m, 5, "720p   (1124 x 644)", NULL);
+       i = pmenu_item_init(m, 5, "720p   (1124 x 644)");
        i->on_execute = ps3_svm_cb;
        i->data = (void *)3;
 
-       i = pmenu_item_init(m, 6, "1080i  (1688 x 964)", NULL);
+       i = pmenu_item_init(m, 6, "1080i  (1688 x 964)");
        i->on_execute = ps3_svm_cb;
        i->data = (void *)4;
 
-       i = pmenu_item_init(m, 7, "1080p  (1688 x 964)", NULL);
+       i = pmenu_item_init(m, 7, "1080p  (1688 x 964)");
        i->on_execute = ps3_svm_cb;
        i->data = (void *)5;
 
-       i = pmenu_item_init(m, 8, "wxga   (1280 x 768)", NULL);
+       i = pmenu_item_init(m, 8, "wxga   (1280 x 768)");
        i->on_execute = ps3_svm_cb;
        i->data = (void *)11;
 
-       i = pmenu_item_init(m, 9, "sxga   (1280 x 1024)", NULL);
+       i = pmenu_item_init(m, 9, "sxga   (1280 x 1024)");
        i->on_execute = ps3_svm_cb;
        i->data = (void *)12;
 
-       i = pmenu_item_init(m, 10, "wuxga  (1920 x 1200)", NULL);
+       i = pmenu_item_init(m, 10, "wuxga  (1920 x 1200)");
        i->on_execute = ps3_svm_cb;
        i->data = (void *)13;
 
-       i = pmenu_item_init(m, 11, "Return",
-               "Return to the main menu");
+       i = pmenu_item_init(m, 11, "Return");
        i->on_execute = ps3_svm_to_mm_cb;
 
        result = pmenu_setup(m);
@@ -434,6 +461,10 @@ static void sig_handler(int signum)
        DBGS("%d\n", signum);
 
        switch (signum) {
+       case SIGALRM:
+               if (ps3.cui)
+                       ui_timer_sigalrm(&ps3.cui->timer);
+               break;
        case SIGWINCH:
                if (ps3.cui)
                        cui_resize(ps3.cui);
@@ -491,8 +522,9 @@ int main(int argc, char *argv[])
        pb_log("--- pb-cui ---\n");
 
        sa.sa_handler = sig_handler;
-       result = sigaction(SIGINT, &sa, NULL);
+       result = sigaction(SIGALRM, &sa, NULL);
        result += sigaction(SIGHUP, &sa, NULL);
+       result += sigaction(SIGINT, &sa, NULL);
        result += sigaction(SIGTERM, &sa, NULL);
        result += sigaction(SIGWINCH, &sa, NULL);
 
@@ -501,7 +533,10 @@ int main(int argc, char *argv[])
                return EXIT_FAILURE;
        }
 
-       ps3.dirty_values = ps3_flash_get_values(&ps3.values);
+       ps3.values = ps3_flash_defaults;
+
+       if (opts.reset_defaults != opt_yes)
+               ps3.dirty_values = ps3_flash_get_values(&ps3.values);
 
        result = ps3_get_video_mode(&mode);
 
@@ -523,6 +558,14 @@ int main(int argc, char *argv[])
        ps3.mm = ps3_mm_init(&ps3);
        ps3.svm = ps3_svm_init(&ps3);
 
+       if (opts.use_timeout != opt_yes
+               || ps3.values.timeout == ps3_timeout_forever)
+               ui_timer_disable(&ps3.cui->timer);
+       else {
+               ps3.cui->timer.update_display = ps3_timer_update;
+               ui_timer_init(&ps3.cui->timer, ps3.values.timeout);
+       }
+
        cui_result = cui_run(ps3.cui, ps3.mm, ps3.values.default_item);
 
        pmenu_delete(ps3.mm);