summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2019-01-18 15:06:26 -0500
committerTom Lane <tgl@sss.pgh.pa.us>2019-01-18 15:06:26 -0500
commit167ba6b1569d5a96d0452fbe708e866222d5b8a8 (patch)
tree0905f92c091f6ea22263a384f61f97baba4471ed
parent9450b91cdf140e7becb5e9bb477da0c1f6cdbdb1 (diff)
downloadpostgresql-167ba6b1569d5a96d0452fbe708e866222d5b8a8.tar.gz
Use our own getopt() on OpenBSD.
Recent OpenBSD (at least 5.9 and up) has a version of getopt(3) that will not cope with the "-:" spec we use to accept double-dash options in postgres.c and postmaster.c. Admittedly, that's a hack because POSIX only requires getopt() to allow alphanumeric option characters. I have no desire to find another way, however, so let's just do what we were already doing on Solaris: force use of our own src/port/getopt.c implementation. In passing, improve some of the comments around said implementation. Per buildfarm and local testing. Back-patch to all supported branches. Discussion: https://postgr.es/m/30197.1547835700@sss.pgh.pa.us
-rwxr-xr-xconfigure6
-rw-r--r--configure.in6
-rw-r--r--src/include/pg_getopt.h10
-rw-r--r--src/port/getopt.c11
4 files changed, 21 insertions, 12 deletions
diff --git a/configure b/configure
index 98a1a746a1..6e9ae2689b 100755
--- a/configure
+++ b/configure
@@ -13374,9 +13374,9 @@ esac
fi
-# Solaris' getopt() doesn't do what we want for long options, so always use
-# our version on that platform.
-if test "$PORTNAME" = "solaris"; then
+# On OpenBSD and Solaris, getopt() doesn't do what we want for long options
+# (i.e., allow '-' as a flag character), so use our version on those platforms.
+if test "$PORTNAME" = "openbsd" -o "$PORTNAME" = "solaris"; then
case " $LIBOBJS " in
*" getopt.$ac_objext "* ) ;;
*) LIBOBJS="$LIBOBJS getopt.$ac_objext"
diff --git a/configure.in b/configure.in
index bfb03f892d..86fbdff8d4 100644
--- a/configure.in
+++ b/configure.in
@@ -1652,9 +1652,9 @@ else
AC_LIBOBJ(getopt_long)
fi
-# Solaris' getopt() doesn't do what we want for long options, so always use
-# our version on that platform.
-if test "$PORTNAME" = "solaris"; then
+# On OpenBSD and Solaris, getopt() doesn't do what we want for long options
+# (i.e., allow '-' as a flag character), so use our version on those platforms.
+if test "$PORTNAME" = "openbsd" -o "$PORTNAME" = "solaris"; then
AC_LIBOBJ(getopt)
fi
diff --git a/src/include/pg_getopt.h b/src/include/pg_getopt.h
index 82532d5b95..9f137d6c70 100644
--- a/src/include/pg_getopt.h
+++ b/src/include/pg_getopt.h
@@ -1,4 +1,13 @@
/*
+ * Postgres files that use getopt(3) always include this file.
+ * We must cope with three different scenarios:
+ * 1. We're using the platform's getopt(), and we should just import the
+ * appropriate declarations.
+ * 2. The platform lacks getopt(), and we must declare everything.
+ * 3. The platform has getopt(), but we're not using it because we don't
+ * like its behavior. The declarations we make here must be compatible
+ * with both the platform's getopt() and our src/port/getopt.c.
+ *
* Portions Copyright (c) 1987, 1993, 1994
* The Regents of the University of California. All rights reserved.
*
@@ -39,6 +48,7 @@ extern int optopt;
extern int optreset;
#endif
+/* Provide getopt() declaration if the platform doesn't have it */
#ifndef HAVE_GETOPT
extern int getopt(int nargc, char *const * nargv, const char *ostr);
#endif
diff --git a/src/port/getopt.c b/src/port/getopt.c
index f1ad93d7d6..56bfa94ed2 100644
--- a/src/port/getopt.c
+++ b/src/port/getopt.c
@@ -1,7 +1,5 @@
/* src/port/getopt.c */
-/* This is used by psql under Win32 */
-
/*
* Copyright (c) 1987, 1993, 1994
* The Regents of the University of California. All rights reserved.
@@ -40,10 +38,11 @@ static char sccsid[] = "@(#)getopt.c 8.3 (Berkeley) 4/27/95";
/*
- * On some versions of Solaris, opterr and friends are defined in core libc
- * rather than in a separate getopt module. Define these variables only
- * if configure found they aren't there by default. (We assume that testing
- * opterr is sufficient for all of these.)
+ * On OpenBSD and some versions of Solaris, opterr and friends are defined in
+ * core libc rather than in a separate getopt module. Define these variables
+ * only if configure found they aren't there by default; otherwise, this
+ * module and its callers will just use libc's variables. (We assume that
+ * testing opterr is sufficient for all of these.)
*/
#ifndef HAVE_INT_OPTERR