summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@php.net>2008-07-22 07:29:31 +0000
committerDmitry Stogov <dmitry@php.net>2008-07-22 07:29:31 +0000
commit4d8bdd9d1b8a0287ec34f4baca527dbd32103722 (patch)
treec710308561ee28a7bd7c1df1216583bf677becad
parent05d2ae4c9eb5504c573e2b840fcf7353ff0a9d19 (diff)
downloadphp-git-4d8bdd9d1b8a0287ec34f4baca527dbd32103722.tar.gz
Closure object cannot have properties
-rwxr-xr-xZend/tests/closure_022.phpt12
-rw-r--r--Zend/zend_closures.c41
2 files changed, 53 insertions, 0 deletions
diff --git a/Zend/tests/closure_022.phpt b/Zend/tests/closure_022.phpt
new file mode 100755
index 0000000000..25fbe931d8
--- /dev/null
+++ b/Zend/tests/closure_022.phpt
@@ -0,0 +1,12 @@
+--TEST--
+Closure 022: Closure properties
+--FILE--
+<?php
+$a = 0;
+$foo = function() use ($a) {
+};
+$foo->a = 1;
+?>
+--EXPECTF--
+Fatal error: Closure object cannot have properties in %sclosure_022.php on line 5
+
diff --git a/Zend/zend_closures.c b/Zend/zend_closures.c
index 30187a8fc7..c49dd0eeaa 100644
--- a/Zend/zend_closures.c
+++ b/Zend/zend_closures.c
@@ -29,6 +29,9 @@
#define ZEND_INVOKE_FUNC_NAME "__invoke"
#define ZEND_CLOSURE_PRINT_NAME "Closure object"
+#define ZEND_CLOSURE_PROPERTY_ERROR() \
+ zend_error(E_ERROR, "Closure object cannot have properties")
+
typedef struct _zend_closure {
zend_object std;
zend_function func;
@@ -137,6 +140,39 @@ static zend_function *zend_closure_get_method(zval **object_ptr, char *method_na
}
/* }}} */
+static zval *zend_closure_read_property(zval *object, zval *member, int type TSRMLS_DC) /* {{{ */
+{
+ ZEND_CLOSURE_PROPERTY_ERROR();
+ return NULL;
+}
+/* }}} */
+
+static void zend_closure_write_property(zval *object, zval *member, zval *value TSRMLS_DC) /* {{{ */
+{
+ ZEND_CLOSURE_PROPERTY_ERROR();
+}
+/* }}} */
+
+static zval **zend_closure_get_property_ptr_ptr(zval *object, zval *member TSRMLS_DC) /* {{{ */
+{
+ ZEND_CLOSURE_PROPERTY_ERROR();
+ return NULL;
+}
+/* }}} */
+
+static int zend_closure_has_property(zval *object, zval *member, int has_set_exists TSRMLS_DC) /* {{{ */
+{
+ ZEND_CLOSURE_PROPERTY_ERROR();
+ return 0;
+}
+/* }}} */
+
+static void zend_closure_unset_property(zval *object, zval *member TSRMLS_DC) /* {{{ */
+{
+ ZEND_CLOSURE_PROPERTY_ERROR();
+}
+/* }}} */
+
static void zend_closure_free_storage(void *object TSRMLS_DC) /* {{{ */
{
zend_closure *closure = (zend_closure *)object;
@@ -195,6 +231,11 @@ void zend_register_closure_ce(TSRMLS_D) /* {{{ */
memcpy(&closure_handlers, zend_get_std_object_handlers(), sizeof(zend_object_handlers));
closure_handlers.get_constructor = zend_closure_get_constructor;
closure_handlers.get_method = zend_closure_get_method;
+ closure_handlers.write_property = zend_closure_write_property;
+ closure_handlers.read_property = zend_closure_read_property;
+ closure_handlers.get_property_ptr_ptr = zend_closure_get_property_ptr_ptr;
+ closure_handlers.has_property = zend_closure_has_property;
+ closure_handlers.unset_property = zend_closure_unset_property;
closure_handlers.compare_objects = zend_closure_compare_objects;
closure_handlers.cast_object = zend_closure_cast_object_tostring;
closure_handlers.clone_obj = NULL;