* newlib/libc/include/getopt.h (struct option): name field should be

"const char *".
	* newlib/libc/stdlib/getopt.c (getopt_internal): Use fputs()/fputc()
	instead of fprintf() to save code space.  Fix signed/unsigned
	comparison.
This commit is contained in:
Corinna Vinschen 2013-11-13 09:09:45 +00:00
parent 8246caa942
commit 02365c2064
3 changed files with 31 additions and 15 deletions

View File

@ -1,3 +1,11 @@
2013-11-13 Freddie Chopin <freddie_chopin@op.pl>
* newlib/libc/include/getopt.h (struct option): name field should be
"const char *".
* newlib/libc/stdlib/getopt.c (getopt_internal): Use fputs()/fputc()
instead of fprintf() to save code space. Fix signed/unsigned
comparison.
2013-11-12 Sebastian Huber <sebastian.huber@embedded-brains.de>
* libc/libc/stdlib/getopt.c (getopt_internal): Fix NULL pointer access.

View File

@ -104,7 +104,7 @@ extern "C"
/* types defined by this include file */
struct option
{
char *name; /* the name of the long option */
const char *name; /* the name of the long option */
int has_arg; /* one of the above macros */
int *flag; /* determines if getopt_long() returns a
* value for a long option; if it is

View File

@ -177,7 +177,9 @@ write_globals (struct getopt_data *data)
optwhere = data->optwhere;
}
/* getopt_internal: the function that does all the dirty work */
/* getopt_internal: the function that does all the dirty work
NOTE: to reduce the code and RAM footprint this function uses
fputs()/fputc() to do output to stderr instead of fprintf(). */
static int
getopt_internal (int argc, char *const argv[], const char *shortopts,
const struct option *longopts, int *longind, int only,
@ -301,7 +303,7 @@ getopt_internal (int argc, char *const argv[], const char *shortopts,
match_chars) == 0)
{
/* do we have an exact match? */
if (match_chars == (int) (strlen (longopts[optindex].name)))
if (match_chars == strlen (longopts[optindex].name))
{
longopt_match = optindex;
break;
@ -315,12 +317,14 @@ getopt_internal (int argc, char *const argv[], const char *shortopts,
{
/* we have ambiguous options */
if (data->opterr)
fprintf (stderr, "%s: option `%s' is ambiguous "
"(could be `--%s' or `--%s')\n",
argv[0],
argv[data->optind],
longopts[longopt_match].name,
longopts[optindex].name);
fputs (argv[0], stderr);
fputs (": option `", stderr);
fputs (argv[data->optind], stderr);
fputs ("' is ambiguous (could be `--", stderr);
fputs (longopts[longopt_match].name, stderr);
fputs ("' or `--", stderr);
fputs (longopts[optindex].name, stderr);
fputs ("')\n", stderr);
return (data->optopt = '?');
}
}
@ -338,9 +342,10 @@ getopt_internal (int argc, char *const argv[], const char *shortopts,
{
/* couldn't find option in shortopts */
if (data->opterr)
fprintf (stderr,
"%s: invalid option -- `-%c'\n",
argv[0], argv[data->optind][data->optwhere]);
fputs (argv[0], stderr);
fputs (": invalid option -- `-", stderr);
fputc (argv[data->optind][data->optwhere], stderr);
fputs ("'\n", stderr);
data->optwhere++;
if (argv[data->optind][data->optwhere] == '\0')
{
@ -377,17 +382,20 @@ getopt_internal (int argc, char *const argv[], const char *shortopts,
{
if (data->opterr)
{
fprintf (stderr, "%s: argument required for option `", argv[0]);
fputs (argv[0], stderr);
fputs (": argument required for option `-", stderr);
if (longopt_match >= 0)
{
fprintf (stderr, "--%s'\n", longopts[longopt_match].name);
fputc ('-', stderr);
fputs (longopts[longopt_match].name, stderr);
data->optopt = initial_colon ? ':' : '\?';
}
else
{
fprintf (stderr, "-%c'\n", *cp);
fputc (*cp, stderr);
data->optopt = *cp;
}
fputs ("'\n", stderr);
}
data->optind++;
return initial_colon ? ':' : '\?';