fmk Fri Mar 19 13:46:23 2004 EDT Modified files: /php-src/ext/mssql php_mssql.c Log: Fix for #26589. Crash when selecting many columns of type Money http://cvs.php.net/diff.php/php-src/ext/mssql/php_mssql.c?r1=1.130&r2=1.131&ty=u Index: php-src/ext/mssql/php_mssql.c diff -u php-src/ext/mssql/php_mssql.c:1.130 php-src/ext/mssql/php_mssql.c:1.131 --- php-src/ext/mssql/php_mssql.c:1.130 Mon Mar 15 14:41:48 2004 +++ php-src/ext/mssql/php_mssql.c Fri Mar 19 13:45:07 2004 @@ -16,7 +16,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: php_mssql.c,v 1.130 2004/03/15 19:41:48 fmk Exp $ */ +/* $Id: php_mssql.c,v 1.131 2004/03/19 18:45:07 fmk Exp $ */ #ifdef COMPILE_DL_MSSQL #define HAVE_MSSQL 1 @@ -797,9 +797,12 @@ ZVAL_STRINGL(result, data, length, 1); break; } + case SQLMONEY4: case SQLFLT4: ZVAL_DOUBLE(result, (double) floatcol4(offset)); break; + case SQLMONEY: + case SQLMONEYN: case SQLFLT8: ZVAL_DOUBLE(result, (double) floatcol8(offset)); break; @@ -891,8 +894,19 @@ if ((column_type != SQLDATETIME && column_type != SQLDATETIM4) || MS_SQL_G(datetimeconvert)) { - if (column_type == SQLDATETIM4) res_length += 14; - if (column_type == SQLDATETIME) res_length += 10; + switch (column_type) { + case SQLDATETIM4 : + res_length += 14; + break; + case SQLDATETIME : + res_length += 10; + break; + case SQLMONEY : + case SQLMONEY4 : + case SQLMONEYN : + res_length += 5; + break; + } res_buf = (unsigned char *) emalloc(res_length+1); res_length = dbconvert(NULL,coltype(offset),dbdata(mssql_ptr->link,offset), res_length, SQLCHAR, res_buf, -1); @@ -947,6 +961,9 @@ case SQLFLT4: case SQLFLT8: case SQLFLTN: + case SQLMONEY4: + case SQLMONEY: + case SQLMONEYN: convert_to_double_ex(&bind->zval); Z_DVAL_P(bind->zval) = *((double *)(dbretdata(mssql_ptr->link,i))); break;
-- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php