]> granicus.if.org Git - php/commitdiff
- Changed zend_resolve_class_name() prototype
authorFelipe Pena <felipe@php.net>
Sat, 9 Jul 2011 17:27:59 +0000 (17:27 +0000)
committerFelipe Pena <felipe@php.net>
Sat, 9 Jul 2011 17:27:59 +0000 (17:27 +0000)
# No needed to pass fetch_type as pointer here

Zend/zend_compile.c
Zend/zend_compile.h
Zend/zend_language_parser.y

index 5a6680bf72dcb97745587b5f2cefd3196dd7834e..bfa64215473aa15c2f31fea9bce3c60ab7d1474a 100644 (file)
@@ -699,9 +699,7 @@ void zend_do_fetch_static_member(znode *result, znode *class_name TSRMLS_DC) /*
 
        if (class_name->op_type == IS_CONST &&
            ZEND_FETCH_CLASS_DEFAULT == zend_get_class_fetch_type(Z_STRVAL(class_name->u.constant), Z_STRLEN(class_name->u.constant))) {
-               ulong fetch_type = ZEND_FETCH_CLASS_GLOBAL;
-
-               zend_resolve_class_name(class_name, &fetch_type, 1 TSRMLS_CC);
+               zend_resolve_class_name(class_name, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC);
                class_node = *class_name;
        } else {
                zend_do_fetch_class(&class_node, class_name TSRMLS_CC);
@@ -1856,7 +1854,7 @@ void zend_do_receive_arg(zend_uchar op, znode *varname, const znode *offset, con
                if (class_type->u.constant.type != IS_NULL) {
                        cur_arg_info->type_hint = IS_OBJECT;
                        if (ZEND_FETCH_CLASS_DEFAULT == zend_get_class_fetch_type(Z_STRVAL(class_type->u.constant), Z_STRLEN(class_type->u.constant))) {
-                               zend_resolve_class_name(class_type, &opline->extended_value, 1 TSRMLS_CC);
+                               zend_resolve_class_name(class_type, opline->extended_value, 1 TSRMLS_CC);
                        }
                        class_type->u.constant.value.str.val = zend_new_interned_string(class_type->u.constant.value.str.val, class_type->u.constant.value.str.len + 1, 1 TSRMLS_CC);
                        cur_arg_info->class_name = class_type->u.constant.value.str.val;
@@ -2063,7 +2061,7 @@ void zend_resolve_non_class_name(znode *element_name, zend_bool check_namespace
 }
 /* }}} */
 
-void zend_resolve_class_name(znode *class_name, ulong *fetch_type, int check_ns_name TSRMLS_DC) /* {{{ */
+void zend_resolve_class_name(znode *class_name, ulong fetch_type, int check_ns_name TSRMLS_DC) /* {{{ */
 {
        char *compound;
        char *lcname;
@@ -2171,7 +2169,7 @@ void zend_do_fetch_class(znode *result, znode *class_name TSRMLS_DC) /* {{{ */
                                zval_dtor(&class_name->u.constant);
                                break;
                        default:
-                               zend_resolve_class_name(class_name, &opline->extended_value, 0 TSRMLS_CC);
+                               zend_resolve_class_name(class_name, opline->extended_value, 0 TSRMLS_CC);
                                opline->op2_type = IS_CONST;
                                opline->op2.constant =
                                        zend_add_class_name_literal(CG(active_op_array), &class_name->u.constant TSRMLS_CC);
@@ -2329,7 +2327,6 @@ int zend_do_begin_class_member_function_call(znode *class_name, znode *method_na
        znode class_node;
        unsigned char *ptr = NULL;
        zend_op *opline;
-       ulong fetch_type = 0;
 
        if (method_name->op_type == IS_CONST) {
                char *lcname = zend_str_tolower_dup(Z_STRVAL(method_name->u.constant), Z_STRLEN(method_name->u.constant));
@@ -2343,8 +2340,7 @@ int zend_do_begin_class_member_function_call(znode *class_name, znode *method_na
 
        if (class_name->op_type == IS_CONST &&
            ZEND_FETCH_CLASS_DEFAULT == zend_get_class_fetch_type(Z_STRVAL(class_name->u.constant), Z_STRLEN(class_name->u.constant))) {
-               fetch_type = ZEND_FETCH_CLASS_GLOBAL;
-               zend_resolve_class_name(class_name, &fetch_type, 1 TSRMLS_CC);
+               zend_resolve_class_name(class_name, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC);
                class_node = *class_name;
                opline = get_next_op(CG(active_op_array) TSRMLS_CC);
        } else {
@@ -2687,9 +2683,7 @@ void zend_do_begin_catch(znode *try_token, znode *class_name, znode *catch_var,
 
        if (class_name->op_type == IS_CONST &&
            ZEND_FETCH_CLASS_DEFAULT == zend_get_class_fetch_type(Z_STRVAL(class_name->u.constant), Z_STRLEN(class_name->u.constant))) {
-               ulong fetch_type = ZEND_FETCH_CLASS_GLOBAL;
-
-               zend_resolve_class_name(class_name, &fetch_type, 1 TSRMLS_CC);
+               zend_resolve_class_name(class_name, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC);
                catch_class = *class_name;
        } else {
                zend_error(E_COMPILE_ERROR, "Bad class name in the catch statement");
@@ -4042,8 +4036,7 @@ void zend_prepare_reference(znode *result, znode *class_name, znode *method_name
        /* REM: There should not be a need for copying, 
           zend_do_begin_class_declaration is also just using that string */
        if (class_name) {
-               ulong fetch_type = ZEND_FETCH_CLASS_GLOBAL;
-               zend_resolve_class_name(class_name, &fetch_type, 1 TSRMLS_CC);
+               zend_resolve_class_name(class_name, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC);
                method_ref->class_name = Z_STRVAL(class_name->u.constant);
                method_ref->cname_len  = Z_STRLEN(class_name->u.constant);
        } else {
@@ -4735,7 +4728,7 @@ void zend_do_implements_interface(znode *interface_name TSRMLS_DC) /* {{{ */
        opline = get_next_op(CG(active_op_array) TSRMLS_CC);
        opline->opcode = ZEND_ADD_INTERFACE;
        SET_NODE(opline->op1, &CG(implementing_class));
-       zend_resolve_class_name(interface_name, &opline->extended_value, 0 TSRMLS_CC);
+       zend_resolve_class_name(interface_name, opline->extended_value, 0 TSRMLS_CC);
        opline->extended_value = (opline->extended_value & ~ZEND_FETCH_CLASS_MASK) | ZEND_FETCH_CLASS_INTERFACE;
        opline->op2_type = IS_CONST;
        opline->op2.constant = zend_add_class_name_literal(CG(active_op_array), &interface_name->u.constant TSRMLS_CC);
@@ -4760,7 +4753,7 @@ void zend_do_implements_trait(znode *trait_name TSRMLS_DC) /* {{{ */
        opline = get_next_op(CG(active_op_array) TSRMLS_CC);
        opline->opcode = ZEND_ADD_TRAIT;
        SET_NODE(opline->op1, &CG(implementing_class));
-       zend_resolve_class_name(trait_name, &opline->extended_value, 0 TSRMLS_CC);
+       zend_resolve_class_name(trait_name, opline->extended_value, 0 TSRMLS_CC);
        opline->extended_value = ZEND_FETCH_CLASS_TRAIT;
        opline->op2_type = IS_CONST;
        opline->op2.constant = zend_add_class_name_literal(CG(active_op_array), &trait_name->u.constant TSRMLS_CC);
@@ -5109,7 +5102,7 @@ void zend_do_fetch_constant(znode *result, znode *constant_container, znode *con
                                if (ZEND_FETCH_CLASS_STATIC == type) {
                                        zend_error(E_ERROR, "\"static::\" is not allowed in compile-time constants");
                                } else if (ZEND_FETCH_CLASS_DEFAULT == type) {
-                                       zend_resolve_class_name(constant_container, &fetch_type, 1 TSRMLS_CC);
+                                       zend_resolve_class_name(constant_container, fetch_type, 1 TSRMLS_CC);
                                }
                                zend_do_build_full_name(NULL, constant_container, constant_name, 1 TSRMLS_CC);
                                *result = *constant_container;
@@ -5118,7 +5111,7 @@ void zend_do_fetch_constant(znode *result, znode *constant_container, znode *con
                        case ZEND_RT:
                                if (constant_container->op_type == IS_CONST &&
                                ZEND_FETCH_CLASS_DEFAULT == zend_get_class_fetch_type(Z_STRVAL(constant_container->u.constant), Z_STRLEN(constant_container->u.constant))) {
-                                       zend_resolve_class_name(constant_container, &fetch_type, 1 TSRMLS_CC);
+                                       zend_resolve_class_name(constant_container, fetch_type, 1 TSRMLS_CC);
                                } else {
                                        zend_do_fetch_class(&tmp, constant_container TSRMLS_CC);
                                        constant_container = &tmp;
index 332b8cb6f7afbf325bfddab7496919880cafa546..8cb04755238c8de17b14894fe38e1e52006e79d9 100644 (file)
@@ -414,7 +414,7 @@ ZEND_API int zend_get_compiled_lineno(TSRMLS_D);
 ZEND_API size_t zend_get_scanned_file_offset(TSRMLS_D);
 
 void zend_resolve_non_class_name(znode *element_name, zend_bool check_namespace TSRMLS_DC);
-void zend_resolve_class_name(znode *class_name, ulong *fetch_type, int check_ns_name TSRMLS_DC);
+void zend_resolve_class_name(znode *class_name, ulong fetch_type, int check_ns_name TSRMLS_DC);
 ZEND_API char* zend_get_compiled_variable_name(const zend_op_array *op_array, zend_uint var, int* name_len);
 
 #ifdef ZTS
index 4dd5bdb977ea59b65d1a42cc3281c93c82219b2d..089209154afca1fa896f22f1e702e6f15fb88fd1 100644 (file)
@@ -612,8 +612,8 @@ trait_precedence:
 ;
 
 trait_reference_list:
-               fully_qualified_class_name                                                                      { ulong fetch_type = ZEND_FETCH_CLASS_GLOBAL; zend_resolve_class_name(&$1, &fetch_type, 1 TSRMLS_CC); zend_init_list(&$$.u.op.ptr, Z_STRVAL($1.u.constant) TSRMLS_CC); }
-       |       trait_reference_list ',' fully_qualified_class_name                     { ulong fetch_type = ZEND_FETCH_CLASS_GLOBAL; zend_resolve_class_name(&$3, &fetch_type, 1 TSRMLS_CC); zend_add_to_list(&$1.u.op.ptr, Z_STRVAL($3.u.constant) TSRMLS_CC); $$ = $1; }
+               fully_qualified_class_name                                                                      { zend_resolve_class_name(&$1, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC); zend_init_list(&$$.u.op.ptr, Z_STRVAL($1.u.constant) TSRMLS_CC); }
+       |       trait_reference_list ',' fully_qualified_class_name                     { zend_resolve_class_name(&$3, ZEND_FETCH_CLASS_GLOBAL, 1 TSRMLS_CC); zend_add_to_list(&$1.u.op.ptr, Z_STRVAL($3.u.constant) TSRMLS_CC); $$ = $1; }
 ;
 
 trait_method_reference: