]> granicus.if.org Git - postgresql/commitdiff
Fix failure of --jobs with vacuumdb on Windows
authorMichael Paquier <michael@paquier.xyz>
Tue, 27 Aug 2019 00:11:48 +0000 (09:11 +0900)
committerMichael Paquier <michael@paquier.xyz>
Tue, 27 Aug 2019 00:11:48 +0000 (09:11 +0900)
FD_SETSIZE needs to be declared before winsock2.h, or it is possible to
run into buffer overflow issues when using --jobs.  This is similar to
pgbench's solution done in a23c641.

This has been introduced by 71d84ef, and older versions have been using
the default value of FD_SETSIZE, defined at 64.  While on it, add a
missing newline to the previously-added error message.

Per buildfarm member jacana, but this impacts all Windows animals
running the TAP tests.  I have reproduced the failure locally to check
the patch.

Author: Michael Paquier
Reviewed-by: Andrew Dunstan
Discussion: https://postgr.es/m/20190826054000.GE7005@paquier.xyz
Backpatch-through: 9.5

src/bin/scripts/vacuumdb.c

index fa4fb72483640d6949222362d5944e120092df24..81d40659a097d2aca06095d9e55ba48110d0eea9 100644 (file)
  *-------------------------------------------------------------------------
  */
 
+#ifdef WIN32
+#define FD_SETSIZE 1024                        /* must set before winsock2.h is included */
+#endif
+
 #include "postgres_fe.h"
 
 #ifdef HAVE_SYS_SELECT_H
@@ -446,7 +450,7 @@ vacuum_one_database(const char *dbname, vacuumingOptions *vacopts,
                        if (PQsocket(conn) >= FD_SETSIZE)
                        {
                                fprintf(stderr,
-                                               _("%s: too many jobs for this platform -- try %d"),
+                                               _("%s: too many jobs for this platform -- try %d\n"),
                                                progname, i);
                                exit(1);
                        }