Commit 4fec86f1 authored by Tatsuo Ishii's avatar Tatsuo Ishii

Fix nasty bug in setting client_encoding

parent eb089e7f
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-connect.c,v 1.119 2000/02/15 20:49:28 tgl Exp $ * $Header: /cvsroot/pgsql/src/interfaces/libpq/fe-connect.c,v 1.120 2000/02/19 05:04:54 ishii Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -1461,8 +1461,6 @@ PQsetenvPoll(PGconn *conn) ...@@ -1461,8 +1461,6 @@ PQsetenvPoll(PGconn *conn)
case SETENV_STATE_ENCODINGS_WAIT: case SETENV_STATE_ENCODINGS_WAIT:
{ {
const char *encoding = 0;
if (PQisBusy(handle->conn)) if (PQisBusy(handle->conn))
return PGRES_POLLING_READING; return PGRES_POLLING_READING;
...@@ -1470,6 +1468,8 @@ PQsetenvPoll(PGconn *conn) ...@@ -1470,6 +1468,8 @@ PQsetenvPoll(PGconn *conn)
if (handle->res) if (handle->res)
{ {
char *encoding;
if (PQresultStatus(handle->res) != PGRES_TUPLES_OK) if (PQresultStatus(handle->res) != PGRES_TUPLES_OK)
{ {
PQclear(handle->res); PQclear(handle->res);
...@@ -1478,13 +1478,10 @@ PQsetenvPoll(PGconn *conn) ...@@ -1478,13 +1478,10 @@ PQsetenvPoll(PGconn *conn)
encoding = PQgetvalue(handle->res, 0, 0); encoding = PQgetvalue(handle->res, 0, 0);
if (!encoding) /* this should not happen */ if (!encoding) /* this should not happen */
encoding = SQL_ASCII; conn->client_encoding = SQL_ASCII;
else
if (encoding)
{
/* set client encoding to pg_conn struct */ /* set client encoding to pg_conn struct */
conn->client_encoding = atoi(encoding); conn->client_encoding = pg_char_to_encoding(encoding);
}
PQclear(handle->res); PQclear(handle->res);
/* We have to keep going in order to clear up the query */ /* We have to keep going in order to clear up the query */
goto keep_going; goto keep_going;
...@@ -2395,6 +2392,9 @@ PQsetClientEncoding(PGconn *conn, const char *encoding) ...@@ -2395,6 +2392,9 @@ PQsetClientEncoding(PGconn *conn, const char *encoding)
if (!conn || conn->status != CONNECTION_OK) if (!conn || conn->status != CONNECTION_OK)
return -1; return -1;
if (!encoding)
return -1;
/* check query buffer overflow */ /* check query buffer overflow */
if (sizeof(qbuf) < (sizeof(query) + strlen(encoding))) if (sizeof(qbuf) < (sizeof(query) + strlen(encoding)))
return -1; return -1;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment