summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnatol Belski <ab@php.net>2016-11-07 20:18:29 +0100
committerAnatol Belski <ab@php.net>2016-11-07 20:18:29 +0100
commit3558e70e58f0980cb86e5343947f4876017ef3e3 (patch)
tree7dc586c6b95176ff1010b601e7e3f0b3b960fa52
parent20587805f90023ac90e0c6891e9dd5833c5fc089 (diff)
downloadphp-git-3558e70e58f0980cb86e5343947f4876017ef3e3.tar.gz
Fixed bug #73448 odbc_errormsg returns trash, always 513 bytes
-rw-r--r--ext/odbc/php_odbc.c23
1 files changed, 8 insertions, 15 deletions
diff --git a/ext/odbc/php_odbc.c b/ext/odbc/php_odbc.c
index f432dcd551..eb722f7f17 100644
--- a/ext/odbc/php_odbc.c
+++ b/ext/odbc/php_odbc.c
@@ -2442,6 +2442,7 @@ int odbc_sqlconnect(odbc_connection **conn, char *db, char *uid, char *pwd, int
RETCODE rc;
*conn = (odbc_connection *)pemalloc(sizeof(odbc_connection), persistent);
+ memset(*conn, 0, sizeof(odbc_connection));
(*conn)->persistent = persistent;
SQLAllocEnv(&((*conn)->henv));
SQLAllocConnect((*conn)->henv, &((*conn)->hdbc));
@@ -3047,38 +3048,30 @@ static void php_odbc_lasterror(INTERNAL_FUNCTION_PARAMETERS, int mode)
{
odbc_connection *conn;
zval *pv_handle;
- zend_string *ptr;
- int len;
+ char *ret;
if (zend_parse_parameters(ZEND_NUM_ARGS(), "|r", &pv_handle) == FAILURE) {
return;
}
- if (mode == 0) { /* last state */
- len = 6;
- } else { /* last error message */
- len = SQL_MAX_MESSAGE_LENGTH;
- }
-
if (ZEND_NUM_ARGS() == 1) {
if (!(conn = (odbc_connection *)zend_fetch_resource2(Z_RES_P(pv_handle), "ODBC-Link", le_conn, le_pconn))) {
RETURN_FALSE;
}
- ptr = zend_string_alloc(len + 1, 0);
if (mode == 0) {
- strlcpy(ZSTR_VAL(ptr), conn->laststate, len+1);
+ ret = conn->laststate;
} else {
- strlcpy(ZSTR_VAL(ptr), conn->lasterrormsg, len+1);
+ ret = conn->lasterrormsg;
}
} else {
- ptr = zend_string_alloc(len, 0);
if (mode == 0) {
- strlcpy(ZSTR_VAL(ptr), ODBCG(laststate), len+1);
+ ret = ODBCG(laststate);
} else {
- strlcpy(ZSTR_VAL(ptr), ODBCG(lasterrormsg), len+1);
+ ret = ODBCG(lasterrormsg);
}
}
- RETVAL_STR(ptr);
+
+ RETURN_STRING(ret);
}
/* }}} */