Give more details about error.
diff --git a/src/ziptool.c b/src/ziptool.c
index 9b2c8b2..27d325a 100644
--- a/src/ziptool.c
+++ b/src/ziptool.c
@@ -40,13 +40,6 @@
 #ifdef HAVE_UNISTD_H
 #include <unistd.h>
 #endif
-#ifdef HAVE_STDBOOL_H
-#include <stdbool.h>
-#else
-typedef char bool;
-#define true    1
-#define false   0
-#endif
 #ifdef _WIN32
 /* WIN32 needs <fcntl.h> for _O_BINARY */
 #include <fcntl.h>
@@ -917,16 +910,21 @@
 
 
 static void
-usage(const char *progname, bool ok)
+usage(const char *progname, const char *reason)
 {
     unsigned int i;
     FILE *out;
-    if (ok)
+    if (reason == NULL)
 	out = stdout;
     else
 	out = stderr;
-    fprintf(out, "usage: %s [-cegHhmnrst] archive command1 [args] [command2 [args] ...]\n\n"
-	    "Supported options are:\n"
+    fprintf(out, "usage: %s [-cegHhmnrst] archive command1 [args] [command2 [args] ...]\n", progname);
+    if (reason != NULL) {
+	fprintf(out, "%s\n", reason);
+	exit(1);
+    }
+
+    fprintf(out, "\nSupported options are:\n"
 	    "\t-c\tcheck consistency\n"
 	    "\t-e\terror if archive already exists (only useful with -n)\n"
 	    "\t-g\tguess file name encoding (for stat)\n"
@@ -936,7 +934,7 @@
 	    "\t-n\tcreate archive if it doesn't exist (default)\n"
 	    "\t-r\tprint raw file name encoding without translation (for stat)\n"
 	    "\t-s\tfollow file name convention strictly (for stat)\n"
-	    "\t-t\tdisregard current archive contents, if any\n", progname);
+	    "\t-t\tdisregard current archive contents, if any\n");
     fprintf(out, "\nSupported commands and arguments are:\n");
     for (i=0; i<sizeof(dispatch_table)/sizeof(dispatch_table_t); i++) {
 	fprintf(out, "\t%s %s\n\t    %s\n\n", dispatch_table[i].cmdline_name, dispatch_table[i].arg_names, dispatch_table[i].description);
@@ -948,7 +946,7 @@
 	    "\tl\tZIP_FL_LOCAL\n"
 	    "\tu\tZIP_FL_UNCHANGED\n");
     fprintf(out, "\nThe index is zero-based.\n");
-    exit(1);
+    exit(0);
 }
 
 int
@@ -965,7 +963,7 @@
     prg = argv[0];
 
     if (argc < 2)
-	usage(prg, false);
+	usage(prg, "too few arguments");
 
     while ((c=getopt(argc, argv, "cegHhmnrst")) != -1) {
 	switch (c) {
@@ -982,7 +980,7 @@
             source_type = SOURCE_TYPE_HOLE;
             break;
 	case 'h':
-	    usage(prg, true);
+	    usage(prg, NULL);
 	    break;
 	case 'm':
             source_type = SOURCE_TYPE_IN_MEMORY;
@@ -1001,7 +999,11 @@
 	    break;
 
 	default:
-	    usage(prg, false);
+	{
+	    char reason[128];
+	    snprintf(reason, sizeof(reason), "invalid option -%c", optopt);
+	    usage(prg, reason);
+	}
 	}
     }