Commit 1d0d4716 authored by Marc Alff's avatar Marc Alff

Implemented code review comments

parent 47c6b6a6
...@@ -511,35 +511,18 @@ int handle_options(int *argc, char ***argv, ...@@ -511,35 +511,18 @@ int handle_options(int *argc, char ***argv,
{ {
/* /*
We are currently parsing a single argv[] argument We are currently parsing a single argv[] argument
of the form "-XYZ", and parsing is done in multiple phases. of the form "-XYZ".
One or the argument found is not an option. One or the argument found (say Y) is not an option.
Hack the string "-XYZ" to make a "-YZ" substring in it,
and push that to the output as an unrecognized parameter.
*/ */
if (optend == cur_arg) DBUG_ASSERT(optend > *pos);
{ DBUG_ASSERT(optend >= cur_arg);
/* DBUG_ASSERT(optend <= *pos + strlen(*pos));
The first argument, "-X", is not an option DBUG_ASSERT(*optend);
In this case, the entire argument "-XYZ" is rejected optend--;
from this phase, and preserved as is for later parsing. optend[0]= '-'; /* replace 'X' or '-' by '-' */
*/ (*argv)[argvpos++]= optend;
(*argv)[argvpos++]= *pos;
}
else
{
/*
We are in the middle of an "-XYZ" string already,
"-X" has already been parsed, and "Y" (pointed by optend)
is not an option.
Hack the string "-XYZ" to make a "-YZ" substring in it,
and push that to the next parsing phase.
*/
DBUG_ASSERT(optend > *pos);
DBUG_ASSERT(optend > cur_arg);
DBUG_ASSERT(optend <= *pos + strlen(*pos));
DBUG_ASSERT(*optend);
optend--;
optend[0]= '-'; /* replace 'X' by '-' */
(*argv)[argvpos++]= optend;
}
/* /*
Do not continue to parse at the current "-XYZ" argument, Do not continue to parse at the current "-XYZ" argument,
skip to the next argv[] argument instead. skip to the next argv[] argument instead.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment