From: Tom Lane Date: Sat, 11 Mar 2000 03:09:28 +0000 (+0000) Subject: Update libpq documentation for PQconndefaults() change. Add section X-Git-Tag: REL7_0~462 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=370186e807cd99d1a65e5f98d32233e893cbe515;p=postgresql Update libpq documentation for PQconndefaults() change. Add section about thread-safeness of the library. --- diff --git a/doc/src/sgml/libpq.sgml b/doc/src/sgml/libpq.sgml index 506d98002c..853e8ae969 100644 --- a/doc/src/sgml/libpq.sgml +++ b/doc/src/sgml/libpq.sgml @@ -182,9 +182,6 @@ PGconn *PQconnectdb(const char *conninfo) The return value is a pointer to an abstract struct representing the connection to the backend. - - This function is not thread-safe. - @@ -204,9 +201,6 @@ PGconn *PQsetdbLogin(const char *pghost, This is the predecessor of PQconnectdb with a fixed number of parameters but the same functionality. - - This function is not thread-safe. - @@ -380,9 +374,6 @@ PostgresPollingStatusType *PQconnectPoll(PQconn *conn) These functions leave the socket in a non-blocking state as if PQsetnonblocking had been called. - - These functions are not thread-safe. - @@ -396,18 +387,17 @@ struct PQconninfoOption char *keyword; /* The keyword of the option */ char *envvar; /* Fallback environment variable name */ char *compiled; /* Fallback compiled in default value */ - char *val; /* Option's value */ + char *val; /* Option's current value, or NULL */ char *label; /* Label for field in connect dialog */ char *dispchar; /* Character to display for this field in a connect dialog. Values are: "" Display entered value as is "*" Password field - hide value - "D" Debug options - don't - create a field by default */ + "D" Debug option - don't show by default */ int dispsize; /* Field size in characters for dialog */ } - Returns the address of the connection options structure. This may + Returns a connection options array. This may be used to determine all possible PQconnectdb options and their current default values. The return value points to an array of PQconninfoOption structs, which ends with an entry having a NULL @@ -416,7 +406,14 @@ struct PQconninfoOption Callers must treat the connection options data as read-only. - This function is not thread-safe. + After processing the options array, free it by passing it to + PQconninfoFree(). If this is not done, a small amount of memory + is leaked for each call to PQconndefaults(). + + + In PostgreSQL versions before 7.0, PQconndefaults() returned a pointer + to a static array, rather than a dynamically allocated array. That + wasn't thread-safe, so the behavior has been changed. @@ -675,9 +672,6 @@ void PQsetenvAbort(PGsetenvHandle handle) The procedure may be aborted at any time by calling PQsetenvAbort(handle). - - These functions are not thread-safe. - @@ -1019,7 +1013,7 @@ char * PQcmdTuples(const PGresult *res); Oid PQoidValue(const PGresult *res); - The type Oid and the constant Invalid + The type Oid and the constant InvalidOid will be defined if you include the libpq header file. They will both be some integer type. @@ -1034,7 +1028,7 @@ Oid PQoidValue(const PGresult *res); char * PQoidStatus(const PGresult *res); -The function is deprecated in favor of PQoidValue +This function is deprecated in favor of PQoidValue and is not thread-safe. @@ -1773,13 +1767,14 @@ PQsetNoticeProcessor(PGconn *conn, -By default, libpq prints notice messages -from the backend as well as a few error messages that it generates by itself -on stderr. +By default, libpq prints notice +messages from the backend on stderr, +as well as a few error messages that it generates by itself. This behavior can be overridden by supplying a callback function that does something else with the messages. The callback function is passed the text of the error message (which includes a trailing newline), plus -a void pointer that is the same one passed to PQsetNoticeProcessor. +a void pointer that is the same one passed to +PQsetNoticeProcessor. (This pointer can be used to access application-specific state if needed.) The default notice processor is simply @@ -1789,13 +1784,23 @@ defaultNoticeProcessor(void * arg, const char * message) fprintf(stderr, "%s", message); } -To use a special notice processor, call PQsetNoticeProcessor just after +To use a special notice processor, call +PQsetNoticeProcessor just after creation of a new PGconn object. -The return value is the pointer to the previous notice processor. If you supply a callback -function pointer of NULL, no action is taken, but the current pointer is returned. +The return value is the pointer to the previous notice processor. +If you supply a callback function pointer of NULL, no action is taken, +but the current pointer is returned. + + + +Once you have set a notice processor, you should expect that that function +could be called as long as either the PGconn object or PGresult objects +made from it exist. At creation of a PGresult, the PGconn's current +notice processor pointer is copied into the PGresult for possible use by +routines like PQgetvalue. @@ -1886,6 +1891,13 @@ sets the default style of date/time representation. sets the default time zone. + + +PGCLIENTENCODING +sets the default client encoding (if MULTIBYTE support was selected +when configuring Postgres). + + @@ -1910,6 +1922,33 @@ for information on correct values for these environment variables. + +Threading Behavior + + +libpq is thread-safe as of +PostgreSQL 7.0, so long as no two threads +attempt to manipulate the same PGconn object at the same time. In particular, +you can't issue concurrent queries from different threads through the same +connection object. (If you need to run concurrent queries, start up multiple +connections.) + + + +PGresult objects are read-only after creation, and so can be passed around +freely between threads. + + + +The deprecated functions PQoidStatus and +fe_setauthsvc are not thread-safe and should not be +used in multi-thread programs. PQoidStatus can be +replaced by PQoidValue. There is no good reason to +call fe_setauthsvc at all. + + + + Sample Programs