Sigh...I suck.

Foobared yet another patch.

Attached again.

Daniel
--- php-4.1.2/ext/oci8/oci8.c.orig      Wed Mar 13 14:51:19 2002
+++ php-4.1.2/ext/oci8/oci8.c   Thu Mar 14 10:02:48 2002
@@ -4090,16 +4090,35 @@
        zval **arg;
        oci_statement *statement;
        oci_connection *connection;
-    text errbuf[512];
-    sb4 errcode = 0;
+       text errbuf[512];
+       sb4 errcode = 0;
        sword error = 0;
        dvoid *errh = NULL;
+       ub2 errorofs = 0;
+       text *sqltext = NULL;
 
        if (zend_get_parameters_ex(1, &arg) == SUCCESS) {
                statement = (oci_statement *) zend_fetch_resource(arg TSRMLS_CC, -1, 
NULL, NULL, 1, le_stmt);
                if (statement) {
                        errh = statement->pError;
                        error = statement->error;
+                       
+                       CALL_OCI_RETURN(statement->error, OCIAttrGet(
+                               (dvoid *)statement->pStmt,
+                               OCI_HTYPE_STMT,
+                               (text *) &sqltext,
+                               (ub4 *)0,
+                               OCI_ATTR_STATEMENT,
+                               statement->pError));
+       
+                       CALL_OCI_RETURN(statement->error, OCIAttrGet(
+                               (dvoid *)statement->pStmt,
+                               OCI_HTYPE_STMT,
+                               (ub2 *)&errorofs,
+                               (ub4 *)0,
+                               OCI_ATTR_PARSE_ERROR_OFFSET,
+                               statement->pError));
+
                } else {
                        connection = (oci_connection *) zend_fetch_resource(arg 
TSRMLS_CC, -1, NULL, NULL, 1, le_conn);
                        if (connection) {
@@ -4134,6 +4153,8 @@
                array_init(return_value);
                add_assoc_long(return_value, "code", errcode);
                add_assoc_string(return_value, "message", (char*) errbuf, 1);
+               add_assoc_long(return_value, "offset", errorofs);
+               add_assoc_string(return_value, "sqltext", sqltext ? (char *) sqltext : 
+"", 1);
        } else {
                RETURN_FALSE;
        }

-- 
PHP Development Mailing List <http://www.php.net/>
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to