]> git.ipfire.org Git - thirdparty/strongswan.git/commitdiff
pki tool supports single letter short options
authorMartin Willi <martin@strongswan.org>
Tue, 15 Sep 2009 08:20:22 +0000 (10:20 +0200)
committerMartin Willi <martin@strongswan.org>
Tue, 15 Sep 2009 08:20:22 +0000 (10:20 +0200)
src/pki/command.c
src/pki/command.h
src/pki/commands/gen.c
src/pki/commands/issue.c
src/pki/commands/keyid.c
src/pki/commands/pub.c
src/pki/commands/self.c
src/pki/commands/verify.c

index 10559557a1e18e21496efdaf0d2dd1a3d6d91998..2cf136539b8b8ad17e806efc4329c12072825c67 100644 (file)
@@ -46,19 +46,26 @@ static int help_idx;
 struct option command_opts[MAX_COMMANDS > MAX_OPTIONS ?: MAX_OPTIONS];
 
 /**
- * Build long_opts for a specific command
+ * Global optstring used by all subcommands
+ */
+char command_optstring[(MAX_COMMANDS > MAX_OPTIONS ?: MAX_OPTIONS) * 3];
+
+/**
+ * Build command_opts/command_optstr for the active command
  */
 static void build_opts()
 {
-       int i;
+       int i, pos = 0;
 
        memset(command_opts, 0, sizeof(command_opts));
+       memset(command_optstring, 0, sizeof(command_optstring));
        if (active == help_idx)
        {
                for (i = 0; cmds[i].cmd; i++)
                {
                        command_opts[i].name = cmds[i].cmd;
                        command_opts[i].val = cmds[i].op;
+                       command_optstring[i] = cmds[i].op;
                }
        }
        else
@@ -68,6 +75,19 @@ static void build_opts()
                        command_opts[i].name = cmds[active].options[i].name;
                        command_opts[i].has_arg = cmds[active].options[i].arg;
                        command_opts[i].val = cmds[active].options[i].op;
+                       command_optstring[pos++] = cmds[active].options[i].op;
+                       switch (cmds[active].options[i].arg)
+                       {
+                               case optional_argument:
+                                       command_optstring[pos++] = ':';
+                                       /* FALL */
+                               case required_argument:
+                                       command_optstring[pos++] = ':';
+                                       /* FALL */
+                               case no_argument:
+                               default:
+                                       break;
+                       }
                }
        }
 }
@@ -86,6 +106,7 @@ void command_register(command_t command)
 int command_usage(char *error)
 {
        FILE *out = stdout;
+       char buf[64];
        int i;
 
        if (error)
@@ -99,7 +120,8 @@ int command_usage(char *error)
        {
                for (i = 0; cmds[i].cmd; i++)
                {
-                       fprintf(out, "  pki --%-6s %s\n", cmds[i].cmd, cmds[i].description);
+                       snprintf(buf, sizeof(buf), "--%s (-%c)", cmds[i].cmd, cmds[i].op);
+                       fprintf(out, "  pki %-14s %s\n", buf, cmds[i].description);
                }
        }
        else
@@ -118,8 +140,10 @@ int command_usage(char *error)
                }
                for (i = 0; cmds[active].options[i].name; i++)
                {
-                       fprintf(out, "        --%-8s %s\n",
-                                       cmds[active].options[i].name, cmds[active].options[i].desc);
+                       snprintf(buf, sizeof(buf), "--%s (-%c)",
+                                        cmds[active].options[i].name, cmds[active].options[i].op);
+                       fprintf(out, "        %-15s %s\n",
+                                       buf, cmds[active].options[i].desc);
                }
        }
        return error != NULL;
@@ -145,7 +169,7 @@ int command_dispatch(int argc, char *argv[])
        command_register((command_t){help, 'h', "help", "show usage information"});
 
        build_opts();
-       op = getopt_long(argc, argv, "", command_opts, NULL);
+       op = getopt_long(argc, argv, command_optstring, command_opts, NULL);
        for (i = 0; cmds[i].cmd; i++)
        {
                if (cmds[i].op == op)
index b82d174b363363eea46f43b115cf46fbde31dcf5..874bdaa8038627a628c3644e86bcaf401850dcae 100644 (file)
@@ -74,6 +74,11 @@ struct command_t {
  */
 extern struct option command_opts[];
 
+/**
+ * Short option string of the active command.
+ */
+extern char command_optstring[];
+
 /**
  * Register a command.
  */
index 65b5f5ca69dbf6cd6812ca16aa99f1c93127a1e5..fcdb50a8853e914a5e0a6cd0a7b00d8b0c44a754 100644 (file)
@@ -28,7 +28,7 @@ static int gen(int argc, char *argv[])
 
        while (TRUE)
        {
-               switch (getopt_long(argc, argv, "", command_opts, NULL))
+               switch (getopt_long(argc, argv, command_optstring, command_opts, NULL))
                {
                        case 'h':
                                return command_usage(NULL);
index ba0ead4b6e58a5143e79fd4d0ac38f863d58865b..d62de39a445016c3e1aeed8db069c307f22572ab 100644 (file)
@@ -53,7 +53,7 @@ static int issue(int argc, char *argv[])
 
        while (TRUE)
        {
-               switch (getopt_long(argc, argv, "", command_opts, NULL))
+               switch (getopt_long(argc, argv, command_optstring, command_opts, NULL))
                {
                        case 'h':
                                goto usage;
@@ -275,7 +275,7 @@ static int issue(int argc, char *argv[])
 
        not_before = time(NULL);
        not_after = not_before + lifetime * 24 * 60 * 60;
-       
+
        cert = lib->creds->create(lib->creds, CRED_CERTIFICATE, CERT_X509,
                                        BUILD_SIGNING_KEY, private, BUILD_SIGNING_CERT, ca,
                                        BUILD_PUBLIC_KEY, public, BUILD_SUBJECT, id,
index b302a8fcb925250b5bf39d9ff8d5bc01be8f80e4..b856a06e310e33ef152becd9c55dfc942f437775 100644 (file)
@@ -34,7 +34,7 @@ static int keyid(int argc, char *argv[])
 
        while (TRUE)
        {
-               switch (getopt_long(argc, argv, "", command_opts, NULL))
+               switch (getopt_long(argc, argv, command_optstring, command_opts, NULL))
                {
                        case 'h':
                                return command_usage(NULL);
index 05430675def5aed1f08213b4840976317e296ad7..7294179ded7c3814a3c7331121f9a24825629947 100644 (file)
@@ -35,7 +35,7 @@ static int pub(int argc, char *argv[])
 
        while (TRUE)
        {
-               switch (getopt_long(argc, argv, "", command_opts, NULL))
+               switch (getopt_long(argc, argv, command_optstring, command_opts, NULL))
                {
                        case 'h':
                                return command_usage(NULL);
index 54ef2399b78caf06ccb6fb613b73062fb46e8767..97eb78382599e03d9786afc6a24851415035bd39 100644 (file)
@@ -48,7 +48,7 @@ static int self(int argc, char *argv[])
 
        while (TRUE)
        {
-               switch (getopt_long(argc, argv, "", command_opts, NULL))
+               switch (getopt_long(argc, argv, command_optstring, command_opts, NULL))
                {
                        case 'h':
                                goto usage;
index d070ce090b58a3d6dfe46cd854bd5488703c5dad..26a6dca5de0fad971348b293927ffce2e2522061 100644 (file)
@@ -29,7 +29,7 @@ static int verify(int argc, char *argv[])
 
        while (TRUE)
        {
-               switch (getopt_long(argc, argv, "", command_opts, NULL))
+               switch (getopt_long(argc, argv, command_optstring, command_opts, NULL))
                {
                        case 'h':
                                return command_usage(NULL);