diff options
Diffstat (limited to 'parse-options.h')
| -rw-r--r-- | parse-options.h | 30 | 
1 files changed, 14 insertions, 16 deletions
| diff --git a/parse-options.h b/parse-options.h index a845a9d952..275fb44081 100644 --- a/parse-options.h +++ b/parse-options.h @@ -8,7 +8,6 @@  enum parse_opt_type {  	/* special types */  	OPTION_END, -	OPTION_ARGUMENT,  	OPTION_GROUP,  	OPTION_NUMBER,  	OPTION_ALIAS, @@ -34,6 +33,7 @@ enum parse_opt_flags {  	PARSE_OPT_KEEP_UNKNOWN = 1 << 3,  	PARSE_OPT_NO_INTERNAL_HELP = 1 << 4,  	PARSE_OPT_ONE_SHOT = 1 << 5, +	PARSE_OPT_SHELL_EVAL = 1 << 6,  };  enum parse_opt_option_flags { @@ -45,7 +45,6 @@ enum parse_opt_option_flags {  	PARSE_OPT_NODASH = 1 << 5,  	PARSE_OPT_LITERAL_ARGHELP = 1 << 6,  	PARSE_OPT_FROM_ALIAS = 1 << 7, -	PARSE_OPT_SHELL_EVAL = 1 << 8,  	PARSE_OPT_NOCOMPLETE = 1 << 9,  	PARSE_OPT_COMP_ARG = 1 << 10,  	PARSE_OPT_CMDMODE = 1 << 11, @@ -135,7 +134,7 @@ struct option {  	const char *argh;  	const char *help; -	int flags; +	enum parse_opt_option_flags flags;  	parse_opt_cb *callback;  	intptr_t defval;  	parse_opt_ll_cb *ll_callback; @@ -155,8 +154,6 @@ struct option {  #define OPT_INTEGER_F(s, l, v, h, f)     { OPTION_INTEGER, (s), (l), (v), N_("n"), (h), (f) }  #define OPT_END()                   { OPTION_END } -#define OPT_ARGUMENT(l, v, h)       { OPTION_ARGUMENT, 0, (l), (v), NULL, \ -				      (h), PARSE_OPT_NOARG, NULL, 1 }  #define OPT_GROUP(h)                { OPTION_GROUP, 0, NULL, NULL, NULL, (h) }  #define OPT_BIT(s, l, v, h, b)      OPT_BIT_F(s, l, v, h, b, 0)  #define OPT_BITOP(s, l, v, h, set, clear) { OPTION_BITOP, (s), (l), (v), NULL, (h), \ @@ -169,8 +166,10 @@ struct option {  #define OPT_BOOL(s, l, v, h)        OPT_BOOL_F(s, l, v, h, 0)  #define OPT_HIDDEN_BOOL(s, l, v, h) { OPTION_SET_INT, (s), (l), (v), NULL, \  				      (h), PARSE_OPT_NOARG | PARSE_OPT_HIDDEN, NULL, 1} -#define OPT_CMDMODE(s, l, v, h, i)  { OPTION_SET_INT, (s), (l), (v), NULL, \ -				      (h), PARSE_OPT_CMDMODE|PARSE_OPT_NOARG|PARSE_OPT_NONEG, NULL, (i) } +#define OPT_CMDMODE_F(s, l, v, h, i, f)  { OPTION_SET_INT, (s), (l), (v), NULL, \ +				      (h), PARSE_OPT_CMDMODE|PARSE_OPT_NOARG|PARSE_OPT_NONEG | (f), NULL, (i) } +#define OPT_CMDMODE(s, l, v, h, i)  OPT_CMDMODE_F(s, l, v, h, i, 0) +  #define OPT_INTEGER(s, l, v, h)     OPT_INTEGER_F(s, l, v, h, 0)  #define OPT_MAGNITUDE(s, l, v, h)   { OPTION_MAGNITUDE, (s), (l), (v), \  				      N_("n"), (h), PARSE_OPT_NONEG } @@ -216,7 +215,8 @@ struct option {   */  int parse_options(int argc, const char **argv, const char *prefix,  		  const struct option *options, -		  const char * const usagestr[], int flags); +		  const char * const usagestr[], +		  enum parse_opt_flags flags);  NORETURN void usage_with_options(const char * const *usagestr,  				 const struct option *options); @@ -225,9 +225,6 @@ NORETURN void usage_msg_opt(const char *msg,  			    const char * const *usagestr,  			    const struct option *options); -int optbug(const struct option *opt, const char *reason); -const char *optname(const struct option *opt, int flags); -  /*   * Use these assertions for callbacks that expect to be called with NONEG and   * NOARG respectively, and do not otherwise handle the "unset" and "arg" @@ -265,7 +262,7 @@ struct parse_opt_ctx_t {  	const char **out;  	int argc, cpidx, total;  	const char *opt; -	int flags; +	enum parse_opt_flags flags;  	const char *prefix;  	const char **alias_groups; /* must be in groups of 3 elements! */  	struct option *updated_options; @@ -273,11 +270,12 @@ struct parse_opt_ctx_t {  void parse_options_start(struct parse_opt_ctx_t *ctx,  			 int argc, const char **argv, const char *prefix, -			 const struct option *options, int flags); +			 const struct option *options, +			 enum parse_opt_flags flags); -int parse_options_step(struct parse_opt_ctx_t *ctx, -		       const struct option *options, -		       const char * const usagestr[]); +enum parse_opt_result parse_options_step(struct parse_opt_ctx_t *ctx, +					 const struct option *options, +					 const char * const usagestr[]);  int parse_options_end(struct parse_opt_ctx_t *ctx); | 
