iliaa           Sun Jul 22 15:14:21 2007 UTC

  Modified files:              (Branch: PHP_5_2)
    /php-src/ext/pdo    pdo_stmt.c 
  Log:
  Fixed PDO_FETCH_KEY_PAIR implementation for fetchAll()
  
http://cvs.php.net/viewvc.cgi/php-src/ext/pdo/pdo_stmt.c?r1=1.118.2.38.2.19&r2=1.118.2.38.2.20&diff_format=u
Index: php-src/ext/pdo/pdo_stmt.c
diff -u php-src/ext/pdo/pdo_stmt.c:1.118.2.38.2.19 
php-src/ext/pdo/pdo_stmt.c:1.118.2.38.2.20
--- php-src/ext/pdo/pdo_stmt.c:1.118.2.38.2.19  Tue Jun 26 01:24:10 2007
+++ php-src/ext/pdo/pdo_stmt.c  Sun Jul 22 15:14:21 2007
@@ -18,7 +18,7 @@
   +----------------------------------------------------------------------+
 */
 
-/* $Id: pdo_stmt.c,v 1.118.2.38.2.19 2007/06/26 01:24:10 iliaa Exp $ */
+/* $Id: pdo_stmt.c,v 1.118.2.38.2.20 2007/07/22 15:14:21 iliaa Exp $ */
 
 /* The PDO Statement Handle Class */
 
@@ -911,8 +911,9 @@
                                        pdo_raise_impl_error(stmt->dbh, stmt, 
"HY000", "PDO::FETCH_KEY_PAIR fetch mode requires the result set to contain 
extactly 2 columns." TSRMLS_CC);
                                        return 0;
                                }
-
-                               array_init(return_value);
+                               if (!return_all) {
+                                       array_init(return_value);
+                               }
                                break;
 
                        case PDO_FETCH_COLUMN:
@@ -1018,7 +1019,7 @@
                                return 0;
                }
                
-               if (return_all) {
+               if (return_all && how != PDO_FETCH_KEY_PAIR) {
                        INIT_PZVAL(&grp_val);
                        fetch_value(stmt, &grp_val, i, NULL TSRMLS_CC);
                        convert_to_string(&grp_val);
@@ -1044,17 +1045,15 @@
                                                zval *tmp;
                                                MAKE_STD_ZVAL(tmp);
                                                fetch_value(stmt, tmp, ++i, 
NULL TSRMLS_CC);
-                                               
-                                               if (Z_TYPE_P(val) == IS_STRING) 
{
-                                                       
zend_symtable_update(Z_ARRVAL_P(return_value), Z_STRVAL_P(val), Z_STRLEN_P(val) 
+ 1, &tmp, sizeof(zval *), NULL);
-                                               } else if (Z_TYPE_P(val) == 
IS_LONG) {
-                                                       
zend_hash_index_update(Z_ARRVAL_P(return_value), Z_LVAL_P(val), tmp, 
sizeof(tmp), NULL);
+
+                                               if (Z_TYPE_P(val) == IS_LONG) {
+                                                       
zend_hash_index_update((return_all ? Z_ARRVAL_P(return_all) : 
Z_ARRVAL_P(return_value)), Z_LVAL_P(val), &tmp, sizeof(zval *), NULL);
                                                } else {
                                                        convert_to_string(val);
-                                                       
zend_symtable_update(Z_ARRVAL_P(return_value), Z_STRVAL_P(val), Z_STRLEN_P(val) 
+ 1, &tmp, sizeof(zval *), NULL);
+                                                       
zend_symtable_update((return_all ? Z_ARRVAL_P(return_all) : 
Z_ARRVAL_P(return_value)), Z_STRVAL_P(val), Z_STRLEN_P(val) + 1, &tmp, 
sizeof(zval *), NULL);
                                                }
-                                               zval_dtor(val);
-                                               FREE_ZVAL(val);
+                                               zval_ptr_dtor(&val);
+                                               return 1;
                                        }
                                        break;
 
@@ -1522,7 +1521,7 @@
        if (!error)     {
                PDO_STMT_CLEAR_ERR();
                MAKE_STD_ZVAL(data);
-               if (how & PDO_FETCH_GROUP) {
+               if (how & (PDO_FETCH_GROUP|PDO_FETCH_KEY_PAIR)) {
                        array_init(return_value);
                        return_all = return_value;
                } else {
@@ -1534,10 +1533,12 @@
                }
        }
        if (!error) {
-               if ((how & PDO_FETCH_GROUP)) {
+               if (how & PDO_FETCH_GROUP) {
                        do {
                                MAKE_STD_ZVAL(data);
                        } while (do_fetch(stmt, TRUE, data, how, 
PDO_FETCH_ORI_NEXT, 0, return_all TSRMLS_CC));
+               } else if (how & PDO_FETCH_KEY_PAIR) {
+                       while (do_fetch(stmt, TRUE, data, how, 
PDO_FETCH_ORI_NEXT, 0, return_all TSRMLS_CC));
                } else {
                        array_init(return_value);
                        do {

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to