From 8d2a4e04aeaded2606ca191af6d61692f320c694 Mon Sep 17 00:00:00 2001 From: Zeev Suraski Date: Mon, 9 Jun 2003 13:51:53 +0000 Subject: [PATCH] Fix bogus implicit declarations of properties (squash bug #23671) --- Zend/zend_compile.c | 44 +++++++++++++++++++++++++++++-------- Zend/zend_compile.h | 1 + Zend/zend_language_parser.y | 2 +- 3 files changed, 37 insertions(+), 10 deletions(-) diff --git a/Zend/zend_compile.c b/Zend/zend_compile.c index 31e433c835..8844ba2ed2 100644 --- a/Zend/zend_compile.c +++ b/Zend/zend_compile.c @@ -2516,12 +2516,6 @@ void zend_do_fetch_property(znode *result, znode *object, znode *property TSRMLS break; } *result = opline_ptr->result; - if (CG(active_class_entry) - && property->op_type == IS_CONST - && !zend_hash_exists(&CG(active_class_entry)->properties_info, property->u.constant.value.str.val, property->u.constant.value.str.len+1)) { - property->u.constant.value.str.val = estrndup(property->u.constant.value.str.val, property->u.constant.value.str.len); - zend_do_declare_property(property, NULL, ZEND_ACC_PUBLIC|ZEND_ACC_IMPLICIT_PUBLIC TSRMLS_CC); - } return; } } @@ -2539,6 +2533,36 @@ void zend_do_fetch_property(znode *result, znode *object, znode *property TSRMLS } + +void zend_do_declare_implicit_property(TSRMLS_D) +{ + zend_op *opline_ptr; + zend_llist_element *le; + zend_llist *fetch_list_ptr; + + + zend_stack_top(&CG(bp_stack), (void **) &fetch_list_ptr); + + if (fetch_list_ptr->count != 1) { + return; + } + + le = fetch_list_ptr->head; + opline_ptr = (zend_op *) le->data; + + if (opline_ptr->op1.op_type == IS_UNUSED + && CG(active_class_entry) + && opline_ptr->op2.op_type == IS_CONST + && !zend_hash_exists(&CG(active_class_entry)->properties_info, opline_ptr->op2.u.constant.value.str.val, opline_ptr->op2.u.constant.value.str.len+1)) { + znode property; + + property = opline_ptr->op2; + property.u.constant.value.str.val = estrndup(opline_ptr->op2.u.constant.value.str.val, opline_ptr->op2.u.constant.value.str.len); + zend_do_declare_property(&property, NULL, ZEND_ACC_PUBLIC|ZEND_ACC_IMPLICIT_PUBLIC TSRMLS_CC); + } +} + + void zend_do_push_object(znode *object TSRMLS_DC) { zend_stack_push(&CG(object_stack), object, sizeof(znode)); @@ -2547,10 +2571,12 @@ void zend_do_push_object(znode *object TSRMLS_DC) void zend_do_pop_object(znode *object TSRMLS_DC) { - znode *tmp; + if (object) { + znode *tmp; - zend_stack_top(&CG(object_stack), (void **) &tmp); - *object = *tmp; + zend_stack_top(&CG(object_stack), (void **) &tmp); + *object = *tmp; + } zend_stack_del_top(&CG(object_stack)); } diff --git a/Zend/zend_compile.h b/Zend/zend_compile.h index dbc71e9b77..09d5d2e88e 100644 --- a/Zend/zend_compile.h +++ b/Zend/zend_compile.h @@ -369,6 +369,7 @@ void zend_do_default_before_statement(znode *case_list, znode *default_token TSR void zend_do_begin_class_declaration(znode *class_token, znode *class_name, znode *parent_class_name TSRMLS_DC); void zend_do_end_class_declaration(znode *class_token, znode *parent_token TSRMLS_DC); void zend_do_declare_property(znode *var_name, znode *value, zend_uint access_type TSRMLS_DC); +void zend_do_declare_implicit_property(TSRMLS_D); void zend_do_declare_class_constant(znode *var_name, znode *value TSRMLS_DC); void zend_do_fetch_property(znode *result, znode *object, znode *property TSRMLS_DC); diff --git a/Zend/zend_language_parser.y b/Zend/zend_language_parser.y index 3b644eb6fe..01111ac0ca 100644 --- a/Zend/zend_language_parser.y +++ b/Zend/zend_language_parser.y @@ -746,7 +746,7 @@ method_or_not: function_call_parameter_list ')' { zend_do_end_function_call(&$1, &$$, &$3, 1, 1 TSRMLS_CC); zend_do_extended_fcall_end(TSRMLS_C); zend_do_push_object(&$$ TSRMLS_CC); $$.u.EA.type = ZEND_PARSED_METHOD_CALL; } - | /* empty */ { $$.u.EA.type = ZEND_PARSED_MEMBER; } + | /* empty */ { zend_do_declare_implicit_property(TSRMLS_C); $$.u.EA.type = ZEND_PARSED_MEMBER; } ; variable_without_objects: -- 2.50.1