]> granicus.if.org Git - php/commitdiff
MFB: fix #36743 (In a class extending XMLReader array properties are not writable)
authorAntony Dovgal <tony2001@php.net>
Fri, 17 Mar 2006 10:17:36 +0000 (10:17 +0000)
committerAntony Dovgal <tony2001@php.net>
Fri, 17 Mar 2006 10:17:36 +0000 (10:17 +0000)
ext/xmlreader/php_xmlreader.c
ext/xmlreader/tests/bug36743.phpt [new file with mode: 0644]

index fe8d789d4f699428dd81493b242a2524b69edab1..20de2c9d9fe59f29801073cf0528d688f2da8bf7 100644 (file)
@@ -109,6 +109,40 @@ static int xmlreader_property_reader(xmlreader_object *obj, xmlreader_prop_handl
 }
 /* }}} */
 
+/* {{{ xmlreader_get_property_ptr_ptr */
+zval **xmlreader_get_property_ptr_ptr(zval *object, zval *member TSRMLS_DC)
+{
+       xmlreader_object *obj;
+       zval tmp_member;
+       zval **retval = NULL;
+       xmlreader_prop_handler *hnd;
+       zend_object_handlers *std_hnd;
+       int ret = FAILURE;
+
+       if (member->type != IS_STRING) {
+               tmp_member = *member;
+               zval_copy_ctor(&tmp_member);
+               convert_to_string(&tmp_member);
+               member = &tmp_member;
+       }
+
+       obj = (xmlreader_object *)zend_objects_get_address(object TSRMLS_CC);
+
+       if (obj->prop_handler != NULL) {
+               ret = zend_hash_find(obj->prop_handler, Z_STRVAL_P(member), Z_STRLEN_P(member)+1, (void **) &hnd);
+       }
+       if (ret == FAILURE) {
+               std_hnd = zend_get_std_object_handlers();
+               retval = std_hnd->get_property_ptr_ptr(object, member TSRMLS_CC);
+       }
+
+       if (member == &tmp_member) {
+               zval_dtor(member);
+       }
+       return retval;
+}
+/* }}} */
+
 /* {{{ xmlreader_read_property */
 zval *xmlreader_read_property(zval *object, zval *member, int type TSRMLS_DC)
 {
@@ -1121,7 +1155,7 @@ PHP_MINIT_FUNCTION(xmlreader)
        memcpy(&xmlreader_object_handlers, zend_get_std_object_handlers(), sizeof(zend_object_handlers));
        xmlreader_object_handlers.read_property = xmlreader_read_property;
        xmlreader_object_handlers.write_property = xmlreader_write_property;
-       xmlreader_object_handlers.get_property_ptr_ptr = NULL;
+       xmlreader_object_handlers.get_property_ptr_ptr = xmlreader_get_property_ptr_ptr;
 
        INIT_CLASS_ENTRY(ce, "XMLReader", xmlreader_functions);
        ce.create_object = xmlreader_objects_new;
diff --git a/ext/xmlreader/tests/bug36743.phpt b/ext/xmlreader/tests/bug36743.phpt
new file mode 100644 (file)
index 0000000..45747d4
--- /dev/null
@@ -0,0 +1,25 @@
+--TEST--
+Bug #36743 (In a class extending XMLReader array properties are not writable)
+--FILE--
+<?php
+
+class Test extends XMLReader
+{
+    private $testArr = array();
+    public function __construct()
+    {
+        $this->testArr[] = 1;
+        var_dump($this->testArr);
+    }
+}
+
+$t = new test;
+
+echo "Done\n";
+?>
+--EXPECT--     
+array(1) {
+  [0]=>
+  int(1)
+}
+Done