Avoid changing stdin/stdout to binary mode on Windows unless that is
authorTom Lane <[email protected]>
Sun, 11 Sep 2005 00:36:35 +0000 (00:36 +0000)
committerTom Lane <[email protected]>
Sun, 11 Sep 2005 00:36:35 +0000 (00:36 +0000)
really the source or destination of the archive.  I think this will
resolve recent complaints that password prompting is broken in pg_restore
on Windows.  Note that password prompting and reading from stdin is an
unworkable combination on Windows ... but that was true anyway.

src/bin/pg_dump/pg_backup_archiver.c

index fa4c11b69d77717ab086ba3216f77ea1dcebfa12..746dbe13f8159f4bf9ea71aac85b9ecc2efb655d 100644 (file)
@@ -1601,11 +1601,12 @@ _allocAH(const char *FileSpec, const ArchiveFormat fmt,
 
        /*
         * On Windows, we need to use binary mode to read/write non-text archive
-        * formats.  Force stdin/stdout into binary mode in case that is what
+        * formats.  Force stdin/stdout into binary mode if that is what
         * we are using.
         */
 #ifdef WIN32
-       if (fmt != archNull)
+       if (fmt != archNull &&
+               (AH->fSpec == NULL || strcmp(AH->fSpec, "") == 0))
        {
                if (mode == archModeWrite)
                        setmode(fileno(stdout), O_BINARY);