summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlan Coopersmith <alan.coopersmith@oracle.com>2013-09-06 15:56:02 -0700
committerAlan Coopersmith <alan.coopersmith@oracle.com>2013-09-06 15:56:02 -0700
commit2d288dfa7fd5f9f88939f2842202e1b7eb7aca87 (patch)
tree64d8f4adfcff1d3303d7be086a5dc7f67e52f820
parentbf4620e2d78d2a4766948f136f2372a596ac275d (diff)
Allow printing -help & -grammar messages without a valid DISPLAY
If a user just wants to see syntax hints, don't require XOpenDisplay() to succeed when we're not going to use it. Signed-off-by: Alan Coopersmith <alan.coopersmith@oracle.com>
-rw-r--r--xmodmap.c39
1 files changed, 26 insertions, 13 deletions
diff --git a/xmodmap.c b/xmodmap.c
index 0f89629..2a10976 100644
--- a/xmodmap.c
+++ b/xmodmap.c
@@ -114,6 +114,7 @@ static const char help_message[] =
" -pk print keymap table\n"
" -pke print keymap table as expressions\n"
" -pp print pointer map\n"
+" -help print this usage message\n"
" -grammar print out short help on allowable input\n"
" - read standard input\n"
"\n";
@@ -121,11 +122,11 @@ static const char help_message[] =
static void
_X_NORETURN
-usage(void)
+usage(int exitcode)
{
fprintf (stderr, "usage: %s [-options ...] [filename]\n", ProgramName);
fprintf (stderr, "%s\n", help_message);
- Exit (1);
+ Exit (exitcode);
}
static const char grammar_message[] =
@@ -180,9 +181,21 @@ main(int argc, char *argv[])
*/
for (i = 1; i < argc; i++) {
- if (strncmp (argv[i], "-d", 2) == 0) {
- if (++i >= argc) usage ();
- displayname = argv[i];
+ const char *arg = argv[i];
+
+ if (arg[0] == '-') {
+ switch (arg[1]) {
+ case 'd': /* -display host:dpy */
+ if (++i >= argc) usage (1);
+ displayname = argv[i];
+ break;
+ case 'g': /* -grammar */
+ grammar_usage ();
+ /*NOTREACHED*/
+ case 'h': /* -help */
+ case '?':
+ usage(0);
+ }
}
}
@@ -221,7 +234,7 @@ main(int argc, char *argv[])
continue;
case 'e': /* -e expression */
didAnything = True;
- if (++i >= argc) usage ();
+ if (++i >= argc) usage (1);
process_line (argv[i]);
continue;
case 'p': /* -p... */
@@ -239,14 +252,14 @@ main(int argc, char *argv[])
printKeyTableExprs = True;
break;
default:
- usage ();
+ usage (1);
}
break;
case 'p': /* -pp */
printPointerMap = True;
break;
default:
- usage ();
+ usage (1);
/* NOTREACHED */
}
didAnything = True;
@@ -289,7 +302,7 @@ main(int argc, char *argv[])
case 'c': {
char *cmd;
didAnything = True;
- if (++i >= argc) usage ();
+ if (++i >= argc) usage (1);
if (asprintf (&cmd, "remove %s = %s",
((arg[1] == 's') ? "shift" :
((arg[1] == 'l') ? "lock" :
@@ -299,7 +312,7 @@ main(int argc, char *argv[])
continue;
}
default:
- usage ();
+ usage (1);
/*NOTREACHED*/
}
} else if (arg[0] == '+') { /* old xmodmap args */
@@ -311,7 +324,7 @@ main(int argc, char *argv[])
case '5': {
char *cmd;
didAnything = True;
- if (++i >= argc) usage ();
+ if (++i >= argc) usage (1);
if (asprintf (&cmd, "add mod%c = %s", arg[1], argv[i]) == -1)
FatalError("Could not allocate memory for add cmd");
process_line (cmd);
@@ -327,7 +340,7 @@ main(int argc, char *argv[])
case 'c': {
char *cmd;
didAnything = True;
- if (++i >= argc) usage ();
+ if (++i >= argc) usage (1);
if (asprintf (&cmd, "add %s = %s",
((arg[1] == 's') ? "shift" :
((arg[1] == 'l') ? "lock" :
@@ -337,7 +350,7 @@ main(int argc, char *argv[])
continue;
}
default:
- usage ();
+ usage (1);
}
} else {
didAnything = True;