mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-05 12:31:50 +01:00
Allow marking options as ignored.
* jnlib/argparse.h (ARGPARSE_OPT_IGNORE): New. (ARGPARSE_TYPE_MASK): New, for internal use. (ARGPARSE_ignore): New. * jnlib/argparse.c (optfile_parse, arg_parse): Replace remaining constants by macros. (optfile_parse): Implement ARGPARSE_OPT_IGNORE. (arg_parse): Exclide ignore options from --dump-options. -- In addition to the ignore-invalid-option (commit 41d56433) it is often useful to mark options in a configuration which as NOP. For example options which have no more function at all but can be expected to be found in existing conf files. Such an option (or command) may now be given as ARGPARSE_ignore (300, "obsolete-option") The 300 is merely used as a non-valid single option name much like group names or the 500+n values used for long options. Signed-off-by: Werner Koch <wk@gnupg.org> (cherry picked from commit 54c54e2824aab5716a187bbbf6dff8860d6a6056) Resolved conflicts: common/argparse.c: Fixed.
This commit is contained in:
parent
191e32026f
commit
8fc9de8d6b
@ -1,6 +1,7 @@
|
|||||||
/* [argparse.c wk 17.06.97] Argument Parser for option handling
|
/* [argparse.c wk 17.06.97] Argument Parser for option handling
|
||||||
* Copyright (C) 1998, 1999, 2000, 2001, 2006
|
* Copyright (C) 1998, 1999, 2000, 2001, 2006
|
||||||
* 2007, 2008, 2012 Free Software Foundation, Inc.
|
* 2007, 2008, 2012 Free Software Foundation, Inc.
|
||||||
|
* Copyright (C) 1997, 2013 Werner Koch
|
||||||
*
|
*
|
||||||
* This file is part of JNLIB, which is a subsystem of GnuPG.
|
* This file is part of JNLIB, which is a subsystem of GnuPG.
|
||||||
*
|
*
|
||||||
@ -104,7 +105,8 @@
|
|||||||
* 4 = takes ulong argument
|
* 4 = takes ulong argument
|
||||||
* Bit 3 : argument is optional (r_type will the be set to 0)
|
* Bit 3 : argument is optional (r_type will the be set to 0)
|
||||||
* Bit 4 : allow 0x etc. prefixed values.
|
* Bit 4 : allow 0x etc. prefixed values.
|
||||||
* Bit 7 : this is a command and not an option
|
* Bit 6 : Ignore this option
|
||||||
|
* Bit 7 : This is a command and not an option
|
||||||
* You stop the option processing by setting opts to NULL, the function will
|
* You stop the option processing by setting opts to NULL, the function will
|
||||||
* then return 0.
|
* then return 0.
|
||||||
* @Return Value
|
* @Return Value
|
||||||
@ -128,6 +130,7 @@
|
|||||||
* { 'o', "output", 2 },
|
* { 'o', "output", 2 },
|
||||||
* { 'c', "cross-ref", 2|8 },
|
* { 'c', "cross-ref", 2|8 },
|
||||||
* { 'm', "my-option", 1|8 },
|
* { 'm', "my-option", 1|8 },
|
||||||
|
* { 300, "ignored-long-option, ARGPARSE_OP_IGNORE},
|
||||||
* { 500, "have-no-short-option-for-this-long-option", 0 },
|
* { 500, "have-no-short-option-for-this-long-option", 0 },
|
||||||
* {0} };
|
* {0} };
|
||||||
* ARGPARSE_ARGS pargs = { &argc, &argv, 0 }
|
* ARGPARSE_ARGS pargs = { &argc, &argv, 0 }
|
||||||
@ -482,7 +485,12 @@ optfile_parse (FILE *fp, const char *filename, unsigned *lineno,
|
|||||||
}
|
}
|
||||||
idx = i;
|
idx = i;
|
||||||
arg->r_opt = opts[idx].short_opt;
|
arg->r_opt = opts[idx].short_opt;
|
||||||
if (!opts[idx].short_opt )
|
if ((opts[idx].flags & ARGPARSE_OPT_IGNORE))
|
||||||
|
{
|
||||||
|
state = i = 0;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
else if (!opts[idx].short_opt )
|
||||||
{
|
{
|
||||||
if (!strcmp (keyword, "ignore-invalid-option"))
|
if (!strcmp (keyword, "ignore-invalid-option"))
|
||||||
{
|
{
|
||||||
@ -500,9 +508,9 @@ optfile_parse (FILE *fp, const char *filename, unsigned *lineno,
|
|||||||
? ARGPARSE_INVALID_COMMAND
|
? ARGPARSE_INVALID_COMMAND
|
||||||
: ARGPARSE_INVALID_OPTION);
|
: ARGPARSE_INVALID_OPTION);
|
||||||
}
|
}
|
||||||
else if (!(opts[idx].flags & 7))
|
else if (!(opts[idx].flags & ARGPARSE_TYPE_MASK))
|
||||||
arg->r_type = 0; /* Does not take an arg. */
|
arg->r_type = 0; /* Does not take an arg. */
|
||||||
else if ((opts[idx].flags & 8) )
|
else if ((opts[idx].flags & ARGPARSE_OPT_OPTIONAL) )
|
||||||
arg->r_type = 0; /* Arg is optional. */
|
arg->r_type = 0; /* Arg is optional. */
|
||||||
else
|
else
|
||||||
arg->r_opt = ARGPARSE_MISSING_ARG;
|
arg->r_opt = ARGPARSE_MISSING_ARG;
|
||||||
@ -514,9 +522,9 @@ optfile_parse (FILE *fp, const char *filename, unsigned *lineno,
|
|||||||
/* No argument found. */
|
/* No argument found. */
|
||||||
if (in_alias)
|
if (in_alias)
|
||||||
arg->r_opt = ARGPARSE_MISSING_ARG;
|
arg->r_opt = ARGPARSE_MISSING_ARG;
|
||||||
else if (!(opts[idx].flags & 7))
|
else if (!(opts[idx].flags & ARGPARSE_TYPE_MASK))
|
||||||
arg->r_type = 0; /* Does not take an arg. */
|
arg->r_type = 0; /* Does not take an arg. */
|
||||||
else if ((opts[idx].flags & 8))
|
else if ((opts[idx].flags & ARGPARSE_OPT_OPTIONAL))
|
||||||
arg->r_type = 0; /* No optional argument. */
|
arg->r_type = 0; /* No optional argument. */
|
||||||
else
|
else
|
||||||
arg->r_opt = ARGPARSE_MISSING_ARG;
|
arg->r_opt = ARGPARSE_MISSING_ARG;
|
||||||
@ -552,7 +560,7 @@ optfile_parse (FILE *fp, const char *filename, unsigned *lineno,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (!(opts[idx].flags & 7))
|
else if (!(opts[idx].flags & ARGPARSE_TYPE_MASK))
|
||||||
arg->r_opt = ARGPARSE_UNEXPECTED_ARG;
|
arg->r_opt = ARGPARSE_UNEXPECTED_ARG;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -614,7 +622,11 @@ optfile_parse (FILE *fp, const char *filename, unsigned *lineno,
|
|||||||
break;
|
break;
|
||||||
idx = i;
|
idx = i;
|
||||||
arg->r_opt = opts[idx].short_opt;
|
arg->r_opt = opts[idx].short_opt;
|
||||||
if (!opts[idx].short_opt)
|
if ((opts[idx].flags & ARGPARSE_OPT_IGNORE))
|
||||||
|
{
|
||||||
|
state = 1; /* Process like a comment. */
|
||||||
|
}
|
||||||
|
else if (!opts[idx].short_opt)
|
||||||
{
|
{
|
||||||
if (!strcmp (keyword, "alias"))
|
if (!strcmp (keyword, "alias"))
|
||||||
{
|
{
|
||||||
@ -849,7 +861,7 @@ arg_parse( ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts)
|
|||||||
{
|
{
|
||||||
for (i=0; opts[i].short_opt; i++ )
|
for (i=0; opts[i].short_opt; i++ )
|
||||||
{
|
{
|
||||||
if ( opts[i].long_opt )
|
if (opts[i].long_opt && !(opts[i].flags & ARGPARSE_OPT_IGNORE))
|
||||||
writestrings (0, "--", opts[i].long_opt, "\n", NULL);
|
writestrings (0, "--", opts[i].long_opt, "\n", NULL);
|
||||||
}
|
}
|
||||||
writestrings (0, "--dump-options\n--help\n--version\n--warranty\n",
|
writestrings (0, "--dump-options\n--help\n--version\n--warranty\n",
|
||||||
@ -868,7 +880,7 @@ arg_parse( ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts)
|
|||||||
arg->r_opt = opts[i].short_opt;
|
arg->r_opt = opts[i].short_opt;
|
||||||
if ( i < 0 )
|
if ( i < 0 )
|
||||||
;
|
;
|
||||||
else if ( (opts[i].flags & 0x07) )
|
else if ( (opts[i].flags & ARGPARSE_TYPE_MASK) )
|
||||||
{
|
{
|
||||||
if ( argpos )
|
if ( argpos )
|
||||||
{
|
{
|
||||||
@ -952,7 +964,7 @@ arg_parse( ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts)
|
|||||||
arg->internal.inarg++; /* Point to the next arg. */
|
arg->internal.inarg++; /* Point to the next arg. */
|
||||||
arg->r.ret_str = s;
|
arg->r.ret_str = s;
|
||||||
}
|
}
|
||||||
else if ( (opts[i].flags & 7) )
|
else if ( (opts[i].flags & ARGPARSE_TYPE_MASK) )
|
||||||
{
|
{
|
||||||
if ( s[1] && !dash_kludge )
|
if ( s[1] && !dash_kludge )
|
||||||
{
|
{
|
||||||
@ -1024,9 +1036,9 @@ arg_parse( ARGPARSE_ARGS *arg, ARGPARSE_OPTS *opts)
|
|||||||
static int
|
static int
|
||||||
set_opt_arg(ARGPARSE_ARGS *arg, unsigned flags, char *s)
|
set_opt_arg(ARGPARSE_ARGS *arg, unsigned flags, char *s)
|
||||||
{
|
{
|
||||||
int base = (flags & 16)? 0 : 10;
|
int base = (flags & ARGPARSE_OPT_PREFIX)? 0 : 10;
|
||||||
|
|
||||||
switch ( (arg->r_type = (flags & 7)) )
|
switch ( (arg->r_type = (flags & ARGPARSE_TYPE_MASK)) )
|
||||||
{
|
{
|
||||||
case ARGPARSE_TYPE_INT:
|
case ARGPARSE_TYPE_INT:
|
||||||
arg->r.ret_int = (int)strtol(s,NULL,base);
|
arg->r.ret_int = (int)strtol(s,NULL,base);
|
||||||
|
@ -94,7 +94,10 @@ typedef struct
|
|||||||
#define ARGPARSE_TYPE_ULONG 4 /* Takes an unsigned long argument. */
|
#define ARGPARSE_TYPE_ULONG 4 /* Takes an unsigned long argument. */
|
||||||
#define ARGPARSE_OPT_OPTIONAL (1<<3) /* Argument is optional. */
|
#define ARGPARSE_OPT_OPTIONAL (1<<3) /* Argument is optional. */
|
||||||
#define ARGPARSE_OPT_PREFIX (1<<4) /* Allow 0x etc. prefixed values. */
|
#define ARGPARSE_OPT_PREFIX (1<<4) /* Allow 0x etc. prefixed values. */
|
||||||
#define ARGPARSE_OPT_COMMAND (1<<8) /* The argument is a command. */
|
#define ARGPARSE_OPT_IGNORE (1<<6) /* Ignore command or option. */
|
||||||
|
#define ARGPARSE_OPT_COMMAND (1<<7) /* The argument is a command. */
|
||||||
|
|
||||||
|
#define ARGPARSE_TYPE_MASK 7 /* Mask for the type values (internal). */
|
||||||
|
|
||||||
/* A set of macros to make option definitions easier to read. */
|
/* A set of macros to make option definitions easier to read. */
|
||||||
#define ARGPARSE_x(s,l,t,f,d) \
|
#define ARGPARSE_x(s,l,t,f,d) \
|
||||||
@ -161,6 +164,8 @@ typedef struct
|
|||||||
#define ARGPARSE_c(s,l,d) \
|
#define ARGPARSE_c(s,l,d) \
|
||||||
{ (s), (l), (ARGPARSE_TYPE_NONE | ARGPARSE_OPT_COMMAND), (d) }
|
{ (s), (l), (ARGPARSE_TYPE_NONE | ARGPARSE_OPT_COMMAND), (d) }
|
||||||
|
|
||||||
|
#define ARGPARSE_ignore(s,l) \
|
||||||
|
{ (s), (l), (ARGPARSE_OPT_IGNORE), "@" }
|
||||||
|
|
||||||
#define ARGPARSE_group(s,d) \
|
#define ARGPARSE_group(s,d) \
|
||||||
{ (s), NULL, 0, (d) }
|
{ (s), NULL, 0, (d) }
|
||||||
|
Loading…
x
Reference in New Issue
Block a user