diff options
| author | Nikita Popov <nikic@php.net> | 2014-08-27 00:25:48 +0200 | 
|---|---|---|
| committer | Nikita Popov <nikic@php.net> | 2014-08-27 00:26:21 +0200 | 
| commit | 95fac3cee397d03f29465c892ca80b46d3ee6dd4 (patch) | |
| tree | dcaa16c83b7dda690355b15d6055d119d26e34d1 | |
| parent | 614bc31635502ec33b44ede618bf49742fbd13a6 (diff) | |
| download | php-git-95fac3cee397d03f29465c892ca80b46d3ee6dd4.tar.gz | |
Fix session handlers in zts
Also use ZEND_HASH_FOREACH API.
| -rw-r--r-- | ext/session/session.c | 26 | 
1 files changed, 8 insertions, 18 deletions
| diff --git a/ext/session/session.c b/ext/session/session.c index c765a660df..92fa7fa470 100644 --- a/ext/session/session.c +++ b/ext/session/session.c @@ -1777,10 +1777,7 @@ static PHP_FUNCTION(session_set_save_handler)  	if (argc > 0 && argc <= 2) {  		zval *obj = NULL;  		zend_string *func_name; -		HashPosition pos; -		zend_function *default_mptr, *current_mptr; -		zend_ulong func_index; -		php_shutdown_function_entry shutdown_function_entry; +		zend_function *current_mptr;  		zend_bool register_shutdown = 1;  		if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "O|b", &obj, php_session_iface_entry, ®ister_shutdown) == FAILURE) { @@ -1788,11 +1785,8 @@ static PHP_FUNCTION(session_set_save_handler)  		}  		/* Find implemented methods - SessionHandlerInterface */ -		zend_hash_internal_pointer_reset_ex(&php_session_iface_entry->function_table, &pos);  		i = 0; -		while ((default_mptr = zend_hash_get_current_data_ptr_ex(&php_session_iface_entry->function_table, &pos))) { -			zend_hash_get_current_key_ex(&php_session_iface_entry->function_table, &func_name, &func_index, 0, &pos); - +		ZEND_HASH_FOREACH_STR_KEY(&php_session_iface_entry->function_table, func_name) {  			if ((current_mptr = zend_hash_find_ptr(&Z_OBJCE_P(obj)->function_table, func_name))) {  				if (!Z_ISUNDEF(PS(mod_user_names).names[i])) {  					zval_ptr_dtor(&PS(mod_user_names).names[i]); @@ -1801,21 +1795,17 @@ static PHP_FUNCTION(session_set_save_handler)  				array_init_size(&PS(mod_user_names).names[i], 2);  				Z_ADDREF_P(obj);  				add_next_index_zval(&PS(mod_user_names).names[i], obj); -				add_next_index_str(&PS(mod_user_names).names[i], func_name); +				add_next_index_str(&PS(mod_user_names).names[i], zend_string_copy(func_name));  			} else {  				php_error_docref(NULL TSRMLS_CC, E_ERROR, "Session handler's function table is corrupt");  				RETURN_FALSE;  			} -			zend_hash_move_forward_ex(&php_session_iface_entry->function_table, &pos);  			++i; -		} +		} ZEND_HASH_FOREACH_END();  		/* Find implemented methods - SessionIdInterface (optional) */ -		zend_hash_internal_pointer_reset_ex(&php_session_id_iface_entry->function_table, &pos); -		while ((default_mptr = zend_hash_get_current_data_ptr_ex(&php_session_id_iface_entry->function_table, &pos))) { -			zend_hash_get_current_key_ex(&php_session_id_iface_entry->function_table, &func_name, &func_index, 0, &pos); - +		ZEND_HASH_FOREACH_STR_KEY(&php_session_id_iface_entry->function_table, func_name) {  			if ((current_mptr = zend_hash_find_ptr(&Z_OBJCE_P(obj)->function_table, func_name))) {  				if (!Z_ISUNDEF(PS(mod_user_names).names[i])) {  					zval_ptr_dtor(&PS(mod_user_names).names[i]); @@ -1824,15 +1814,15 @@ static PHP_FUNCTION(session_set_save_handler)  				array_init_size(&PS(mod_user_names).names[i], 2);  				Z_ADDREF_P(obj);  				add_next_index_zval(&PS(mod_user_names).names[i], obj); -				add_next_index_str(&PS(mod_user_names).names[i], func_name); +				add_next_index_str(&PS(mod_user_names).names[i], zend_string_copy(func_name));  			} -			zend_hash_move_forward_ex(&php_session_id_iface_entry->function_table, &pos);  			++i; -		} +		} ZEND_HASH_FOREACH_END();  		if (register_shutdown) {  			/* create shutdown function */ +			php_shutdown_function_entry shutdown_function_entry;  			shutdown_function_entry.arg_count = 1;  			shutdown_function_entry.arguments = (zval *) safe_emalloc(sizeof(zval), 1, 0); | 
