aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/bin/psql/command.c12
-rw-r--r--src/bin/psql/common.c14
2 files changed, 24 insertions, 2 deletions
diff --git a/src/bin/psql/command.c b/src/bin/psql/command.c
index c0a7a5566eb..93953fc8e7d 100644
--- a/src/bin/psql/command.c
+++ b/src/bin/psql/command.c
@@ -3120,8 +3120,14 @@ do_connect(enum trivalue reuse_previous_specification,
pg_log_error("\\connect: %s", PQerrorMessage(n_conn));
if (o_conn)
{
+ /*
+ * Transition to having no connection. Keep this bit in sync
+ * with CheckConnection().
+ */
PQfinish(o_conn);
pset.db = NULL;
+ ResetCancelConn();
+ UnsyncVariables();
}
}
@@ -3135,7 +3141,8 @@ do_connect(enum trivalue reuse_previous_specification,
/*
* Replace the old connection with the new one, and update
- * connection-dependent variables.
+ * connection-dependent variables. Keep the resynchronization logic in
+ * sync with CheckConnection().
*/
PQsetNoticeProcessor(n_conn, NoticeProcessor, NULL);
pset.db = n_conn;
@@ -3226,7 +3233,8 @@ connection_warnings(bool in_startup)
sverbuf, sizeof(sverbuf)));
#ifdef WIN32
- checkWin32Codepage();
+ if (in_startup)
+ checkWin32Codepage();
#endif
printSSLInfo();
printGSSInfo();
diff --git a/src/bin/psql/common.c b/src/bin/psql/common.c
index 44a782478d1..4b2679360fc 100644
--- a/src/bin/psql/common.c
+++ b/src/bin/psql/common.c
@@ -402,13 +402,27 @@ CheckConnection(void)
if (!OK)
{
fprintf(stderr, _("Failed.\n"));
+
+ /*
+ * Transition to having no connection. Keep this bit in sync with
+ * do_connect().
+ */
PQfinish(pset.db);
pset.db = NULL;
ResetCancelConn();
UnsyncVariables();
}
else
+ {
fprintf(stderr, _("Succeeded.\n"));
+
+ /*
+ * Re-sync, just in case anything changed. Keep this in sync with
+ * do_connect().
+ */
+ SyncVariables();
+ connection_warnings(false); /* Must be after SyncVariables */
+ }
}
return OK;