#define PGSQL_ESCAPE_STRING 1
#define PGSQL_ESCAPE_BYTEA 2
+#if HAVE_PQSETNONBLOCKING
+#define PQ_SETNONBLOCKING(pg_link, flag) PQsetnonblocking(pg_link, flag)
+#else
+#define PQ_SETNONBLOCKING(pg_link, flag) 0
+#endif
+
#define CHECK_DEFAULT_LINK(x) if (x == -1) { php_error(E_WARNING, "%s() no PostgreSQL link opened yet", get_active_function_name(TSRMLS_C)); }
/* {{{ pgsql_functions[]
return 0;
link = (PGconn *) rsrc->ptr;
+
+ if (PQ_SETNONBLOCKING(link, 0)) {
+ php_error(E_NOTICE,"PostgreSQL cannot set connection to blocking mode");
+ return -1;
+ }
- PQsetnonblocking(link, 0);
while ((res = PQgetResult(link))) {
PQclear(res);
}
PGG(ignore_notices) = 1;
- PQexec(link,"BEGIN;ROLLBACK;");
+ res = PQexec(link,"BEGIN;ROLLBACK;");
+ PQclear(res);
PGG(ignore_notices) = 0;
return 0;
ZEND_FETCH_RESOURCE2(pgsql, PGconn *, pgsql_link, id, "PostgreSQL link", le_link, le_plink);
convert_to_string_ex(query);
- PQsetnonblocking(pgsql, 0);
+ if (PQ_SETNONBLOCKING(pgsql, 0)) {
+ php_error(E_NOTICE,"%s() cannot set connection to blocking mode",
+ get_active_function_name(TSRMLS_C));
+ RETURN_FALSE;
+ }
while ((pgsql_result = PQgetResult(pgsql))) {
PQclear(pgsql_result);
leftover = 1;
ZEND_FETCH_RESOURCE(pg_result, pgsql_result_handle *, result, -1, "PostgreSQL result", le_result);
pgsql_result = pg_result->result;
-#if HAVE_PQOIDVALUE
+#ifdef HAVE_PQOIDVALUE
Z_LVAL_P(return_value) = (int) PQoidValue(pgsql_result);
if (Z_LVAL_P(return_value) == InvalidOid) {
RETURN_FALSE;
}
/* }}} */
-#if HAVE_PQCLIENTENCODING
+#ifdef HAVE_PQCLIENTENCODING
/* {{{ proto int pg_set_client_encoding([resource connection,] string encoding)
Set client encoding */
PHP_FUNCTION(pg_set_client_encoding)
}
/* }}} */
-#if HAVE_PQESCAPE
+#ifdef HAVE_PQESCAPE
/* {{{ proto string pg_escape_string(string data)
Escape string for text/char type */
PHP_FUNCTION(pg_escape_string)
zval *result;
PGresult *pgsql_result;
pgsql_result_handle *pg_result;
+ char *err = NULL;
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "r",
&result) == FAILURE) {
if (!pgsql_result) {
RETURN_FALSE;
}
- RETURN_STRING(PQresultErrorMessage(pgsql_result),1);
+ err = (char *)PQresultErrorMessage(pgsql_result);
+ RETURN_STRING(err,1);
}
/* }}} */
ZEND_FETCH_RESOURCE2(pgsql, PGconn *, &pgsql_link, id, "PostgreSQL link", le_link, le_plink);
- if (PQsetnonblocking(pgsql, 1)) {
+ if (PQ_SETNONBLOCKING(pgsql, 1)) {
php_error(E_NOTICE,"%s() cannot set connection to nonblocking mode",
get_active_function_name(TSRMLS_C));
RETURN_FALSE;
get_active_function_name(TSRMLS_C));
break;
}
- if (PQsetnonblocking(pgsql, 0)) {
+ if (PQ_SETNONBLOCKING(pgsql, 0)) {
php_error(E_NOTICE,"%s() cannot set connection to blocking mode",
get_active_function_name(TSRMLS_C));
}
ZEND_FETCH_RESOURCE2(pgsql, PGconn *, &pgsql_link, id, "PostgreSQL link", le_link, le_plink);
- if (PQsetnonblocking(pgsql, 1)) {
+ if (PQ_SETNONBLOCKING(pgsql, 1)) {
php_error(E_NOTICE,"%s() cannot set connection to nonblocking mode",
get_active_function_name(TSRMLS_C));
RETURN_FALSE;
if (!PQsendQuery(pgsql, query)) {
RETURN_FALSE;
}
- if (PQsetnonblocking(pgsql, 0)) {
+ if (PQ_SETNONBLOCKING(pgsql, 0)) {
php_error(E_NOTICE,"%s() cannot set connection to blocking mode",
get_active_function_name(TSRMLS_C));
}