]> granicus.if.org Git - php/commitdiff
Fix parse_method_params
authorNikita Popov <nikic@php.net>
Tue, 6 May 2014 19:56:01 +0000 (21:56 +0200)
committerNikita Popov <nikic@php.net>
Tue, 6 May 2014 19:56:01 +0000 (21:56 +0200)
Zend/zend_API.c

index 8fc21f1769fbdcfdbeed6bacefdd4991e9d13704..f944de9df3a59687375145c74223865467b79154 100644 (file)
@@ -1012,7 +1012,12 @@ ZEND_API int zend_parse_method_parameters(int num_args TSRMLS_DC, zval *this_ptr
        zval **object;
        zend_class_entry *ce;
 
-       if (!this_ptr || Z_TYPE_P(this_ptr) != IS_OBJECT) {
+       /* Just checking this_ptr is not enough, because fcall_common_helper does not set
+        * Z_OBJ(EG(This)) to NULL when calling an internal function with common.scope == NULL.
+        * In that case EG(This) would still be the $this from the calling code and we'd take the
+        * wrong branch here. */
+       zend_bool is_method = EG(current_execute_data)->function_state.function->common.scope != NULL;
+       if (!is_method || !this_ptr || Z_TYPE_P(this_ptr) != IS_OBJECT) {
                RETURN_IF_ZERO_ARGS(num_args, p, 0);
 
                va_start(va, type_spec);