summaryrefslogtreecommitdiff
path: root/mysys
diff options
context:
space:
mode:
Diffstat (limited to 'mysys')
-rw-r--r--mysys/my_getopt.c70
1 files changed, 51 insertions, 19 deletions
diff --git a/mysys/my_getopt.c b/mysys/my_getopt.c
index a28d3dd4e3c..6eccd73bce1 100644
--- a/mysys/my_getopt.c
+++ b/mysys/my_getopt.c
@@ -35,6 +35,7 @@ static void init_variables(const struct my_option *options);
static const char *special_opt_prefix[]=
{"skip", "disable", "enable", "maximum", 0};
+char *disabled_my_option= (char*) "0";
/* Return error values from handle_options */
@@ -66,7 +67,7 @@ int handle_options(int *argc, char ***argv,
char *))
{
uint opt_found, argvpos= 0, length, spec_len, i;
- int err;
+ int err= 0;
my_bool end_of_options= 0, must_be_var, set_maximum_value, special_used;
char *progname= *(*argv), **pos, *optend, *prev_found;
const struct my_option *optp;
@@ -177,7 +178,7 @@ int handle_options(int *argc, char ***argv,
We were called with a special prefix, we can reuse opt_found
*/
special_used= 1;
- cur_arg += (spec_len + 1);
+ cur_arg+= (spec_len + 1);
if ((opt_found= findopt(cur_arg, length - (spec_len + 1),
&optp, &prev_found)))
{
@@ -190,7 +191,7 @@ int handle_options(int *argc, char ***argv,
return ERR_AMBIGUOUS_OPTION;
}
if (i < DISABLE_OPTION_COUNT)
- optend= (char*) "0";
+ optend= disabled_my_option;
else if (!compare_strings(special_opt_prefix[i],"enable",6))
optend= (char*) "1";
else if (!compare_strings(special_opt_prefix[i],"maximum",7))
@@ -236,15 +237,44 @@ int handle_options(int *argc, char ***argv,
}
if (must_be_var && !optp->value)
{
- fprintf(stderr, "%s: the argument '%s' is not an variable\n",
+ fprintf(stderr, "%s: argument '%s' is not a variable\n",
progname, *pos);
return ERR_MUST_BE_VARIABLE;
}
- if (optp->arg_type == NO_ARG && optend && !special_used)
+ if (optp->arg_type == NO_ARG)
{
- fprintf(stderr, "%s: option '--%s' cannot take an argument\n",
- progname, optp->name);
- return ERR_NO_ARGUMENT_ALLOWED;
+ if (optend && !special_used)
+ {
+ fprintf(stderr, "%s: option '--%s' cannot take an argument\n",
+ progname, optp->name);
+ return ERR_NO_ARGUMENT_ALLOWED;
+ }
+ if (optp->var_type == GET_BOOL)
+ {
+ /*
+ Set bool to 1 if no argument or if the user has used
+ --enable-'option-name'.
+ *optend was set to '0' if one used --disable-option
+ */
+ *((my_bool*) optp->value)= (my_bool) (!optend || *optend == '1');
+ (*argc)--;
+ continue;
+ }
+ argument= optend;
+ }
+ else if (optp->arg_type == OPT_ARG && optp->var_type == GET_BOOL)
+ {
+ if (optend == disabled_my_option)
+ *((my_bool*) optp->value)= (my_bool) 0;
+ else
+ {
+ if (!optend) /* No argument -> enable option */
+ *((my_bool*) optp->value)= (my_bool) 1;
+ else /* If argument differs from 0, enable option, else disable */
+ *((my_bool*) optp->value)= (my_bool) atoi(optend) != 0;
+ }
+ (*argc)--;
+ continue;
}
else if (optp->arg_type == REQUIRED_ARG && !optend)
{
@@ -312,6 +342,7 @@ int handle_options(int *argc, char ***argv,
{
gptr *result_pos= (set_maximum_value) ?
optp->u_max_value : optp->value;
+
if (!result_pos)
{
fprintf(stderr,
@@ -321,14 +352,13 @@ int handle_options(int *argc, char ***argv,
if (optp->var_type == GET_LONG)
*((long*) result_pos)= (long) getopt_ll(argument, optp, &err);
else if (optp->var_type == GET_LL)
- *((longlong*) result_pos)= getopt_ll(argument, optp, &err);
+ *((longlong*) result_pos)= getopt_ll(argument, optp, &err);
else if (optp->var_type == GET_STR)
*((char**) result_pos)= argument;
if (err)
return ERR_UNKNOWN_SUFFIX;
}
- else
- get_one_option(optp->id, optp, argument);
+ get_one_option(optp->id, optp, argument);
(*argc)--; /* option handled (short or long), decrease argument count */
}
@@ -489,17 +519,19 @@ void my_print_help(const struct my_option *options)
col+= 2 + strlen(optp->name);
if (optp->var_type == GET_STR)
{
- printf("=name ");
+ printf("%s=name%s ", optp->arg_type == OPT_ARG ? "[" : "",
+ optp->arg_type == OPT_ARG ? "]" : "");
col+= 6;
}
- else if (optp->var_type == GET_NO_ARG)
+ else if (optp->var_type == GET_NO_ARG || optp->var_type == GET_BOOL)
{
putchar(' ');
col++;
}
else
{
- printf("=# ");
+ printf("%s=#%s ", optp->arg_type == OPT_ARG ? "[" : "",
+ optp->arg_type == OPT_ARG ? "]" : "");
col+= 3;
}
if (col > name_space)
@@ -546,7 +578,7 @@ void my_print_variables(const struct my_option *options)
printf("--------------------------------- -------------\n");
for (optp= options; optp->id; optp++)
{
- if (optp->value)
+ if (optp->value && optp->var_type != GET_BOOL)
{
printf("%s", optp->name);
length= strlen(optp->name);
@@ -554,10 +586,10 @@ void my_print_variables(const struct my_option *options)
putchar(' ');
if (optp->var_type == GET_STR)
{
- if (!optp->def_value && !*((char**) optp->value))
- printf("(No default value)\n");
- else
+ if (*((char**) optp->value))
printf("%s\n", *((char**) optp->value));
+ else
+ printf("(No default value)\n");
}
else if (optp->var_type == GET_LONG)
{
@@ -566,7 +598,7 @@ void my_print_variables(const struct my_option *options)
else
printf("%lu\n", *((long*) optp->value));
}
- else
+ else
{
if (!optp->def_value && !*((longlong*) optp->value))
printf("(No default value)\n");