iliaa           Tue Oct  3 17:45:16 2006 UTC

  Modified files:              
    /php-src/ext/standard       string.c streamsfuncs.c array.c 
  Log:
  MFB: optimize zend_hash_init() with known hash table sizes.
  
  
http://cvs.php.net/viewvc.cgi/php-src/ext/standard/string.c?r1=1.598&r2=1.599&diff_format=u
Index: php-src/ext/standard/string.c
diff -u php-src/ext/standard/string.c:1.598 php-src/ext/standard/string.c:1.599
--- php-src/ext/standard/string.c:1.598 Tue Oct  3 13:44:14 2006
+++ php-src/ext/standard/string.c       Tue Oct  3 17:45:16 2006
@@ -18,7 +18,7 @@
    +----------------------------------------------------------------------+
  */
 
-/* $Id: string.c,v 1.598 2006/10/03 13:44:14 tony2001 Exp $ */
+/* $Id: string.c,v 1.599 2006/10/03 17:45:16 iliaa Exp $ */
 
 /* Synced with php 3.0 revision 1.193 1999-06-16 [ssb] */
 
@@ -3836,7 +3836,7 @@
        int maxlen = 0, len;
        zval   ctmp;
 
-       zend_hash_init(tmp_hash, 0, NULL, NULL, 0);
+       zend_hash_init(tmp_hash, zend_hash_num_elements(hash), NULL, NULL, 0);
        zend_hash_internal_pointer_reset_ex(hash, &hpos);
        while (zend_hash_get_current_data_ex(hash, (void **)&entry, &hpos) == 
SUCCESS) {
                switch (zend_hash_get_current_key_ex(hash, &string_key, 
&string_key_len, &num_key, 0, &hpos)) {
http://cvs.php.net/viewvc.cgi/php-src/ext/standard/streamsfuncs.c?r1=1.90&r2=1.91&diff_format=u
Index: php-src/ext/standard/streamsfuncs.c
diff -u php-src/ext/standard/streamsfuncs.c:1.90 
php-src/ext/standard/streamsfuncs.c:1.91
--- php-src/ext/standard/streamsfuncs.c:1.90    Fri Sep 29 13:22:43 2006
+++ php-src/ext/standard/streamsfuncs.c Tue Oct  3 17:45:16 2006
@@ -17,7 +17,7 @@
   +----------------------------------------------------------------------+
 */
 
-/* $Id: streamsfuncs.c,v 1.90 2006/09/29 13:22:43 bjori Exp $ */
+/* $Id: streamsfuncs.c,v 1.91 2006/10/03 17:45:16 iliaa Exp $ */
 
 #include "php.h"
 #include "php_globals.h"
@@ -660,7 +660,7 @@
                return 0;
        }
        ALLOC_HASHTABLE(new_hash);
-       zend_hash_init(new_hash, 0, NULL, ZVAL_PTR_DTOR, 0);
+       zend_hash_init(new_hash, 
zend_hash_num_elements(Z_ARRVAL_P(stream_array)), NULL, ZVAL_PTR_DTOR, 0);
        
        for (zend_hash_internal_pointer_reset(Z_ARRVAL_P(stream_array));
                 zend_hash_get_current_data(Z_ARRVAL_P(stream_array), (void **) 
&elem) == SUCCESS;
@@ -708,7 +708,7 @@
                return 0;
        }
        ALLOC_HASHTABLE(new_hash);
-       zend_hash_init(new_hash, 0, NULL, ZVAL_PTR_DTOR, 0);
+       zend_hash_init(new_hash, 
zend_hash_num_elements(Z_ARRVAL_P(stream_array)), NULL, ZVAL_PTR_DTOR, 0);
        
        for (zend_hash_internal_pointer_reset(Z_ARRVAL_P(stream_array));
                 zend_hash_get_current_data(Z_ARRVAL_P(stream_array), (void **) 
&elem) == SUCCESS;
http://cvs.php.net/viewvc.cgi/php-src/ext/standard/array.c?r1=1.387&r2=1.388&diff_format=u
Index: php-src/ext/standard/array.c
diff -u php-src/ext/standard/array.c:1.387 php-src/ext/standard/array.c:1.388
--- php-src/ext/standard/array.c:1.387  Tue Oct  3 16:36:57 2006
+++ php-src/ext/standard/array.c        Tue Oct  3 17:45:16 2006
@@ -21,7 +21,7 @@
    +----------------------------------------------------------------------+
 */
 
-/* $Id: array.c,v 1.387 2006/10/03 16:36:57 bjori Exp $ */
+/* $Id: array.c,v 1.388 2006/10/03 17:45:16 iliaa Exp $ */
 
 #include "php.h"
 #include "php_ini.h"
@@ -3073,7 +3073,7 @@
                zval *tmp;
 
                ALLOC_HASHTABLE(ht);
-               zend_hash_init(ht, 0, NULL, ZVAL_PTR_DTOR, 0);
+               zend_hash_init(ht, 
zend_hash_num_elements(return_value->value.ht), NULL, ZVAL_PTR_DTOR, 0);
                zend_hash_copy(ht, return_value->value.ht, (copy_ctor_func_t) 
zval_add_ref, (void *) &tmp, sizeof(zval *));
                return_value->value.ht = ht;            
        }
@@ -3449,7 +3449,7 @@
                zval *tmp;
 
                ALLOC_HASHTABLE(ht);
-               zend_hash_init(ht, 0, NULL, ZVAL_PTR_DTOR, 0);
+               zend_hash_init(ht, 
zend_hash_num_elements(return_value->value.ht), NULL, ZVAL_PTR_DTOR, 0);
                zend_hash_copy(ht, return_value->value.ht, (copy_ctor_func_t) 
zval_add_ref, (void *) &tmp, sizeof(zval *));
                return_value->value.ht = ht;            
        }

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to