pg_upgrade: make get_major_server_version() err msg consistent
authorBruce Momjian <bruce@momjian.us>
Thu, 19 Mar 2020 19:20:55 +0000 (15:20 -0400)
committerBruce Momjian <bruce@momjian.us>
Thu, 19 Mar 2020 19:20:55 +0000 (15:20 -0400)
This patch fixes the error message in get_major_server_version() to be
"could not parse version file", and uses the full file path name, rather
than just the data directory path.

Also, commit 4109bb5de4 added the cause of the failure to the  "could
not open" error message, and improved quoting.  This patch backpatches
the "could not open" cause to PG 12, where it was first widely used, and
backpatches the quoting fix in that patch to all supported releases.

Reported-by: Tom Lane
Discussion: https://postgr.es/m/87pne2w98h.fsf@wibble.ilmari.org

Author: Dagfinn Ilmari MannsÃ¥ker

Backpatch-through: 9.5

src/bin/pg_upgrade/server.c

index be604d33514cf346debfd7d6f07444db55e30ac3..f669bb4e8a9e199741db7be5bdbf45078ae71314 100644 (file)
@@ -168,7 +168,7 @@ get_major_server_version(ClusterInfo *cluster)
 
    if (fscanf(version_fd, "%63s", cluster->major_version_str) == 0 ||
        sscanf(cluster->major_version_str, "%d.%d", &v1, &v2) < 1)
-       pg_fatal("could not parse PG_VERSION file from \"%s\"\n", cluster->pgdata);
+       pg_fatal("could not parse version file \"%s\"\n", ver_filename);
 
    fclose(version_fd);