]> granicus.if.org Git - php/commitdiff
- Fix for bug #17882. We complain if the same method is declared twice.
authorAndi Gutmans <andi@php.net>
Sat, 29 Jun 2002 08:38:24 +0000 (08:38 +0000)
committerAndi Gutmans <andi@php.net>
Sat, 29 Jun 2002 08:38:24 +0000 (08:38 +0000)
Zend/zend_compile.c

index cebaecf4e717195368bdb091fee5d313d0e6712b..8f0e1d25b00920dd73ae3d670e220fd42b12db26 100644 (file)
@@ -924,7 +924,9 @@ void zend_do_begin_function_declaration(znode *function_token, znode *function_n
        op_array.scope = CG(active_class_entry);
 
        if (is_method) {
-               zend_hash_update(&CG(active_class_entry)->function_table, name, name_len+1, &op_array, sizeof(zend_op_array), (void **) &CG(active_op_array));
+               if (zend_hash_add(&CG(active_class_entry)->function_table, name, name_len+1, &op_array, sizeof(zend_op_array), (void **) &CG(active_op_array)) == FAILURE) {
+                       zend_error(E_COMPILE_ERROR, "Multiply defined method '%s'", name);
+               }
                if ((CG(active_class_entry)->name_length == (uint) name_len) && (!memcmp(CG(active_class_entry)->name, name, name_len))) {
                        CG(active_class_entry)->constructor = (zend_function *) CG(active_op_array);
                } else if ((function_name->u.constant.value.str.len == sizeof(ZEND_CONSTRUCTOR_FUNC_NAME)-1) && (!memcmp(function_name->u.constant.value.str.val, ZEND_CONSTRUCTOR_FUNC_NAME, sizeof(ZEND_CONSTRUCTOR_FUNC_NAME)))) {