X-Git-Url: https://git.draconx.ca/gitweb/rrace.git/blobdiff_plain/2160e352fae550a6a25bc37c68c251214cb7119f..ec2e7b448d7d0d404c0b3102c5b25ac9464d9fc5:/src/motif.c diff --git a/src/motif.c b/src/motif.c index f98b307..12959f7 100644 --- a/src/motif.c +++ b/src/motif.c @@ -33,13 +33,13 @@ static const char *progname = PROGNAME; static const struct option lopts[] = { LOPTS_INITIALIZER, {0} }; static char * const default_resources[] = { + "*title: RRace", "*game.height: 371", // 365 + 2*shadowThickness "*game.width: 498", "*game.XmFrame.shadowThickness: 3", "*game.XmFrame.shadowType: shadow_in", "*goalArea.leftOffset: 1", - "*gameCanvas.background: #202020", "*gameNew.accelerator: CtrlN", "*gameNew.acceleratorText: Ctrl+N", @@ -67,6 +67,7 @@ static void print_usage(FILE *f) static void print_help(void) { + struct lopt_help help = {0}; const struct option *opt; print_usage(stdout); @@ -74,8 +75,6 @@ static void print_help(void) putchar('\n'); puts("Options:"); for (opt = lopts; opt->name; opt++) { - struct lopt_help help; - if (!lopt_get_help(opt, &help)) continue; help_print_option(opt, help.arg, help.desc, 20); @@ -103,9 +102,9 @@ static Widget early_setup(XtAppContext *app, int argc, char **argv) } } - shell = XtOpenApplication(app, PROGNAME, NULL, 0, + shell = XtOpenApplication(app, PACKAGE_TARNAME, NULL, 0, &argc, argv, (String *)default_resources, - sessionShellWidgetClass, NULL, 0); + sessionShellWidgetClass, NULL, 0); opterr = optind = 1; while ((opt = getopt_long_only(argc, argv, "", lopts, NULL)) != -1) { @@ -135,9 +134,18 @@ static void proc_exit(Widget w, XEvent *e, String *argv, Cardinal *argc) static void proc_new_game(Widget w, XEvent *e, String *argv, Cardinal *argc) { + Widget shell; + + for (shell = w; !XtIsWMShell(shell);) + shell = XtParent(shell); + game_reset(&state.board); - x11_redraw_goal(&state); - x11_redraw_game(&state); + + x11_redraw_goal(&state, -1); + x11_redraw_game(&state, -1); + x11_redraw_icon(&state, shell); + + game_begin(&state.board); } static const XtActionsRec menu_actions[] = { @@ -149,6 +157,7 @@ static XtAppContext app_initialize(int argc, char **argv) { XtAppContext app; Widget shell; + int i; if (argc > 0) progname = argv[0]; @@ -156,10 +165,19 @@ static XtAppContext app_initialize(int argc, char **argv) shell = early_setup(&app, argc, argv); XtAppAddActions(app, (void *)menu_actions, XtNumber(menu_actions)); ui_initialize(&state, shell); - x11_initialize(&state, XtScreen(shell)); + x11_initialize(&state, shell); + + /* Begin with the game in winning state */ game_reset(&state.board); + for (i = 0; i < 3; i++) + state.board.game[i] = state.board.goal[i] << GOAL_SHIFT; + game_finish(&state.board); + + state.use_ewmh_icons = ewmh_probe_wm_icon(shell); XtRealizeWidget(shell); + x11_redraw_icon(&state, shell); + return app; }