Remove optreset from src/port/ implementations of getopt and getopt_long.
We don't actually need optreset, because we can easily fix the code to ensure that it's cleanly restartable after having completed a scan over the argv array; which is the only case we need to restart in. Getting rid of it avoids a class of interactions with the system libraries and allows reversion of my change of yesterday in postmaster.c and postgres.c. Back-patch to 8.4. Before that the getopt code was a bit different anyway.
This commit is contained in:
parent
2dffe1f8bb
commit
0a0eec670d
@ -305,8 +305,7 @@ extern char *optarg;
|
|||||||
extern int optind,
|
extern int optind,
|
||||||
opterr;
|
opterr;
|
||||||
|
|
||||||
/* If not HAVE_GETOPT, we are using src/port/getopt.c, which has optreset */
|
#ifdef HAVE_INT_OPTRESET
|
||||||
#if defined(HAVE_INT_OPTRESET) || !defined(HAVE_GETOPT)
|
|
||||||
extern int optreset; /* might not be declared by system headers */
|
extern int optreset; /* might not be declared by system headers */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -723,7 +722,7 @@ PostmasterMain(int argc, char *argv[])
|
|||||||
* getopt(3) library so that it will work correctly in subprocesses.
|
* getopt(3) library so that it will work correctly in subprocesses.
|
||||||
*/
|
*/
|
||||||
optind = 1;
|
optind = 1;
|
||||||
#if defined(HAVE_INT_OPTRESET) || !defined(HAVE_GETOPT)
|
#ifdef HAVE_INT_OPTRESET
|
||||||
optreset = 1; /* some systems need this too */
|
optreset = 1; /* some systems need this too */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -18,7 +18,6 @@ extern int opterr;
|
|||||||
extern int optind;
|
extern int optind;
|
||||||
extern int optopt;
|
extern int optopt;
|
||||||
extern char *optarg;
|
extern char *optarg;
|
||||||
extern int optreset;
|
|
||||||
|
|
||||||
#ifndef HAVE_STRUCT_OPTION
|
#ifndef HAVE_STRUCT_OPTION
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ static char sccsid[] = "@(#)getopt.c 8.3 (Berkeley) 4/27/95";
|
|||||||
* On some versions of Solaris, opterr and friends are defined in core libc
|
* On some versions of Solaris, opterr and friends are defined in core libc
|
||||||
* rather than in a separate getopt module. Define these variables only
|
* rather than in a separate getopt module. Define these variables only
|
||||||
* if configure found they aren't there by default. (We assume that testing
|
* if configure found they aren't there by default. (We assume that testing
|
||||||
* opterr is sufficient for all of these except optreset.)
|
* opterr is sufficient for all of these.)
|
||||||
*/
|
*/
|
||||||
#ifndef HAVE_INT_OPTERR
|
#ifndef HAVE_INT_OPTERR
|
||||||
|
|
||||||
@ -57,12 +57,6 @@ extern int optopt;
|
|||||||
extern char *optarg;
|
extern char *optarg;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef HAVE_INT_OPTRESET
|
|
||||||
int optreset; /* reset getopt */
|
|
||||||
#else
|
|
||||||
extern int optreset;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define BADCH (int)'?'
|
#define BADCH (int)'?'
|
||||||
#define BADARG (int)':'
|
#define BADARG (int)':'
|
||||||
#define EMSG ""
|
#define EMSG ""
|
||||||
@ -70,6 +64,12 @@ extern int optreset;
|
|||||||
/*
|
/*
|
||||||
* getopt
|
* getopt
|
||||||
* Parse argc/argv argument vector.
|
* Parse argc/argv argument vector.
|
||||||
|
*
|
||||||
|
* This implementation does not use optreset. Instead, we guarantee that
|
||||||
|
* it can be restarted on a new argv array after a previous call returned -1,
|
||||||
|
* if the caller resets optind to 1 before the first call of the new series.
|
||||||
|
* (Internally, this means we must be sure to reset "place" to EMSG before
|
||||||
|
* returning -1.)
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
getopt(nargc, nargv, ostr)
|
getopt(nargc, nargv, ostr)
|
||||||
@ -80,9 +80,8 @@ const char *ostr;
|
|||||||
static char *place = EMSG; /* option letter processing */
|
static char *place = EMSG; /* option letter processing */
|
||||||
char *oli; /* option letter list index */
|
char *oli; /* option letter list index */
|
||||||
|
|
||||||
if (optreset || !*place)
|
if (!*place)
|
||||||
{ /* update scanning pointer */
|
{ /* update scanning pointer */
|
||||||
optreset = 0;
|
|
||||||
if (optind >= nargc || *(place = nargv[optind]) != '-')
|
if (optind >= nargc || *(place = nargv[optind]) != '-')
|
||||||
{
|
{
|
||||||
place = EMSG;
|
place = EMSG;
|
||||||
@ -102,7 +101,10 @@ const char *ostr;
|
|||||||
* if the user didn't specify '-' as an option, assume it means -1.
|
* if the user didn't specify '-' as an option, assume it means -1.
|
||||||
*/
|
*/
|
||||||
if (optopt == (int) '-')
|
if (optopt == (int) '-')
|
||||||
|
{
|
||||||
|
place = EMSG;
|
||||||
return -1;
|
return -1;
|
||||||
|
}
|
||||||
if (!*place)
|
if (!*place)
|
||||||
++optind;
|
++optind;
|
||||||
if (opterr && *ostr != ':')
|
if (opterr && *ostr != ':')
|
||||||
|
@ -38,17 +38,21 @@
|
|||||||
|
|
||||||
#include "getopt_long.h"
|
#include "getopt_long.h"
|
||||||
|
|
||||||
#ifndef HAVE_INT_OPTRESET
|
|
||||||
int optreset;
|
|
||||||
|
|
||||||
/* else the "extern" was provided by getopt_long.h */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define BADCH '?'
|
#define BADCH '?'
|
||||||
#define BADARG ':'
|
#define BADARG ':'
|
||||||
#define EMSG ""
|
#define EMSG ""
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* getopt_long
|
||||||
|
* Parse argc/argv argument vector, with long options.
|
||||||
|
*
|
||||||
|
* This implementation does not use optreset. Instead, we guarantee that
|
||||||
|
* it can be restarted on a new argv array after a previous call returned -1,
|
||||||
|
* if the caller resets optind to 1 before the first call of the new series.
|
||||||
|
* (Internally, this means we must be sure to reset "place" to EMSG before
|
||||||
|
* returning -1.)
|
||||||
|
*/
|
||||||
int
|
int
|
||||||
getopt_long(int argc, char *const argv[],
|
getopt_long(int argc, char *const argv[],
|
||||||
const char *optstring,
|
const char *optstring,
|
||||||
@ -57,10 +61,8 @@ getopt_long(int argc, char *const argv[],
|
|||||||
static char *place = EMSG; /* option letter processing */
|
static char *place = EMSG; /* option letter processing */
|
||||||
char *oli; /* option letter list index */
|
char *oli; /* option letter list index */
|
||||||
|
|
||||||
if (optreset || !*place)
|
if (!*place)
|
||||||
{ /* update scanning pointer */
|
{ /* update scanning pointer */
|
||||||
optreset = 0;
|
|
||||||
|
|
||||||
if (optind >= argc)
|
if (optind >= argc)
|
||||||
{
|
{
|
||||||
place = EMSG;
|
place = EMSG;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user