summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIlia Alshanetsky <iliaa@php.net>2003-06-14 15:08:27 +0000
committerIlia Alshanetsky <iliaa@php.net>2003-06-14 15:08:27 +0000
commit93a5238465f77616b76132eea112dfab9d8a6bd7 (patch)
treee6b0eb2ba5346975325d8545b793ba3ac3327b0f
parentf07f3267e24bc4b6af7af9c8d3f549d372790bcc (diff)
downloadphp-git-93a5238465f77616b76132eea112dfab9d8a6bd7.tar.gz
Fixed bug #24007 (Problem with register_globals & arrays)
-rw-r--r--main/main.c15
-rw-r--r--main/php_variables.c23
2 files changed, 16 insertions, 22 deletions
diff --git a/main/main.c b/main/main.c
index 68cbffa353..1be845c08e 100644
--- a/main/main.c
+++ b/main/main.c
@@ -1583,6 +1583,21 @@ static zend_bool php_auto_globals_create_request(TSRMLS_D)
}
}
+ if (PG(register_globals)) {
+ HashPosition pos;
+ zval **data;
+ char *string_key;
+ uint string_key_len;
+
+ zend_hash_internal_pointer_reset_ex(Z_ARRVAL_P(form_variables), &pos);
+ while (zend_hash_get_current_data_ex(Z_ARRVAL_P(form_variables), (void **)&data, &pos) == SUCCESS) {
+ zend_hash_get_current_key_ex(Z_ARRVAL_P(form_variables), &string_key, &string_key_len, NULL, 0, &pos);
+
+ ZEND_SET_SYMBOL_WITH_LENGTH(&EG(symbol_table), string_key, string_key_len, *data, (*data)->refcount+1, 0);
+ zend_hash_move_forward_ex(Z_ARRVAL_P(form_variables), &pos);
+ }
+ }
+
zend_hash_update(&EG(symbol_table), "_REQUEST", sizeof("_REQUEST"), &form_variables, sizeof(zval *), NULL);
}
#endif
diff --git a/main/php_variables.c b/main/php_variables.c
index 0c3283fa79..05516747d4 100644
--- a/main/php_variables.c
+++ b/main/php_variables.c
@@ -67,23 +67,15 @@ PHPAPI void php_register_variable_ex(char *var, zval *val, pval *track_vars_arra
char *ip; /* index pointer */
char *index;
int var_len, index_len;
- zval *gpc_element, **gpc_element_p, **top_gpc_p=NULL;
+ zval *gpc_element, **gpc_element_p;
zend_bool is_array;
HashTable *symtable1=NULL;
- HashTable *symtable2=NULL;
assert(var != NULL);
if (track_vars_array) {
symtable1 = Z_ARRVAL_P(track_vars_array);
}
- if (PG(register_globals)) {
- if (symtable1) {
- symtable2 = EG(active_symbol_table);
- } else {
- symtable1 = EG(active_symbol_table);
- }
- }
if (!symtable1) {
/* Nothing to do */
zval_dtor(val);
@@ -168,9 +160,6 @@ PHPAPI void php_register_variable_ex(char *var, zval *val, pval *track_vars_arra
efree(escaped_index);
}
}
- if (!top_gpc_p) {
- top_gpc_p = gpc_element_p;
- }
symtable1 = Z_ARRVAL_PP(gpc_element_p);
/* ip pointed to the '[' character, now obtain the key */
index = index_s;
@@ -193,19 +182,9 @@ plain_var:
} else {
zend_hash_update(symtable1, index, index_len+1, &gpc_element, sizeof(zval *), (void **) &gpc_element_p);
}
- if (!top_gpc_p) {
- top_gpc_p = gpc_element_p;
- }
break;
}
}
-
- if (top_gpc_p) {
- if (symtable2) {
- zend_hash_update(symtable2, var, var_len+1, top_gpc_p, sizeof(zval *), NULL);
- (*top_gpc_p)->refcount++;
- }
- }
}