summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoe Watkins <krakjoe@php.net>2019-04-06 01:30:03 +0200
committerJoe Watkins <krakjoe@php.net>2019-04-06 01:31:32 +0200
commit1b85e72032ecf912f6fc50d0704662dfa2cb0292 (patch)
treef20e3caf76f8bd365c0f5128cf0fd0dbe72877c5
parent7f4a6b147825eb1d64598075362ba2b8e330216a (diff)
parent0c6a68fa362be996d9a027ef4847c52a6bfa7873 (diff)
downloadphp-git-1b85e72032ecf912f6fc50d0704662dfa2cb0292.tar.gz
Merge branch 'PHP-7.3' into PHP-7.4
* PHP-7.3: Follow up #77849 PDOStatement objects in undefined state after clone
-rw-r--r--ext/pdo/pdo_stmt.c18
-rw-r--r--ext/pdo/tests/bug_77849_2.phpt18
2 files changed, 19 insertions, 17 deletions
diff --git a/ext/pdo/pdo_stmt.c b/ext/pdo/pdo_stmt.c
index c3e79f5b68..6e0f22cd6e 100644
--- a/ext/pdo/pdo_stmt.c
+++ b/ext/pdo/pdo_stmt.c
@@ -2246,22 +2246,6 @@ static int dbstmt_compare(zval *object1, zval *object2)
return -1;
}
-static zend_object *dbstmt_clone_obj(zval *zobject)
-{
- pdo_stmt_t *stmt;
- pdo_stmt_t *old_stmt;
-
- stmt = zend_object_alloc(sizeof(pdo_stmt_t), Z_OBJCE_P(zobject));
- zend_object_std_init(&stmt->std, Z_OBJCE_P(zobject));
- object_properties_init(&stmt->std, Z_OBJCE_P(zobject));
-
- old_stmt = Z_PDO_STMT_P(zobject);
-
- zend_objects_clone_members(&stmt->std, &old_stmt->std);
-
- return &stmt->std;
-}
-
zend_object_handlers pdo_dbstmt_object_handlers;
zend_object_handlers pdo_row_object_handlers;
@@ -2667,7 +2651,7 @@ void pdo_stmt_init(void)
pdo_dbstmt_object_handlers.unset_property = dbstmt_prop_delete;
pdo_dbstmt_object_handlers.get_method = dbstmt_method_get;
pdo_dbstmt_object_handlers.compare_objects = dbstmt_compare;
- pdo_dbstmt_object_handlers.clone_obj = dbstmt_clone_obj;
+ pdo_dbstmt_object_handlers.clone_obj = NULL;
INIT_CLASS_ENTRY(ce, "PDORow", pdo_row_functions);
pdo_row_ce = zend_register_internal_class(&ce);
diff --git a/ext/pdo/tests/bug_77849_2.phpt b/ext/pdo/tests/bug_77849_2.phpt
new file mode 100644
index 0000000000..53a0735e97
--- /dev/null
+++ b/ext/pdo/tests/bug_77849_2.phpt
@@ -0,0 +1,18 @@
+--TEST--
+PDO Common: Bug #77849 (inconsistent state of cloned statament object)
+--SKIPIF--
+<?php
+if (!extension_loaded('pdo')) die('skip');
+?>
+--FILE--
+<?php
+$stmt = new PDOStatement();
+
+clone $stmt;
+?>
+--EXPECTF--
+Fatal error: Uncaught Error: Trying to clone an uncloneable object of class PDOStatement in %s:4
+Stack trace:
+#0 {main}
+ thrown in %s on line 4
+