wez Fri Jul 22 00:33:58 2005 EDT
Modified files:
/php-src/ext/pdo pdo_stmt.c
Log:
this looks like a much better fix for refcounting/shutdown in lazy objects.
http://cvs.php.net/diff.php/php-src/ext/pdo/pdo_stmt.c?r1=1.114&r2=1.115&ty=u
Index: php-src/ext/pdo/pdo_stmt.c
diff -u php-src/ext/pdo/pdo_stmt.c:1.114 php-src/ext/pdo/pdo_stmt.c:1.115
--- php-src/ext/pdo/pdo_stmt.c:1.114 Thu Jul 21 22:09:19 2005
+++ php-src/ext/pdo/pdo_stmt.c Fri Jul 22 00:33:56 2005
@@ -18,7 +18,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: pdo_stmt.c,v 1.114 2005/07/22 02:09:19 wez Exp $ */
+/* $Id: pdo_stmt.c,v 1.115 2005/07/22 04:33:56 wez Exp $ */
/* The PDO Statement Handle Class */
@@ -222,7 +222,7 @@
Z_TYPE(stmt->lazy_object_ref) = IS_OBJECT;
Z_OBJ_HANDLE(stmt->lazy_object_ref) =
zend_objects_store_put(stmt,
(zend_objects_store_dtor_t)zend_objects_destroy_object,
(zend_objects_free_object_storage_t)pdo_row_free_storage, NULL TSRMLS_CC);
Z_OBJ_HT(stmt->lazy_object_ref) = &pdo_row_object_handlers;
- stmt->refcount++;
+ /* stmt->refcount++; */
}
Z_TYPE_P(return_value) = IS_OBJECT;
Z_OBJ_HANDLE_P(return_value) = Z_OBJ_HANDLE(stmt->lazy_object_ref);
@@ -2311,11 +2311,13 @@
void pdo_row_free_storage(pdo_stmt_t *stmt TSRMLS_DC)
{
+#if 0
ZVAL_NULL(&stmt->lazy_object_ref);
if (--stmt->refcount == 0) {
free_statement(stmt TSRMLS_CC);
}
+#endif
}
zend_object_value pdo_row_new(zend_class_entry *ce TSRMLS_DC)
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php