summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZeev Suraski <zeev@php.net>2001-08-08 17:16:20 +0000
committerZeev Suraski <zeev@php.net>2001-08-08 17:16:20 +0000
commit5eb9495b1b651550b89a6874264f6a268f096024 (patch)
tree5520737eddb2d7bc37ad87fbf4f2e43cf6d776e2
parent7f4453f4c118830bcf14b553f13318cb250c1c3e (diff)
downloadphp-git-5eb9495b1b651550b89a6874264f6a268f096024.tar.gz
- Implement $_FORM
- Update phpinfo() - Update NEWS
-rw-r--r--NEWS7
-rw-r--r--ext/standard/info.c13
-rw-r--r--main/main.c38
3 files changed, 48 insertions, 10 deletions
diff --git a/NEWS b/NEWS
index 692a5cc9ee..ef3ea04c77 100644
--- a/NEWS
+++ b/NEWS
@@ -1,6 +1,13 @@
PHP 4.0 NEWS
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
?? ??? 200?, Version 4.0.7-dev
+- Introduced a new $_FORM variable, which includes any GET, POST or COOKIE
+ variables. Like the other new variables, this variable is also available
+ regardless of the context. (Andi & Zeev)
+- Introduced $_GET, $_POST, $_COOKIE, $_SERVER and $_ENV variables, which
+ deprecate the old $HTTP_*_VARS arrays. In addition to be much shorter to
+ type - these variables are also available regardless of the scope, and
+ there's no need to import them using the 'global' statement. (Andi & Zeev)
- Added vprintf() and vsprintf() functions that allow passing all arguments
after format as an array. (Andrei)
- Added support for GD2 image type for ImageCreateFromString() (Jani)
diff --git a/ext/standard/info.c b/ext/standard/info.c
index 01a70db73d..b1040264d3 100644
--- a/ext/standard/info.c
+++ b/ext/standard/info.c
@@ -301,12 +301,13 @@ PHPAPI void php_print_info(int flag TSRMLS_DC)
if (zend_hash_find(&EG(symbol_table), "PHP_AUTH_PW", sizeof("PHP_AUTH_PW"), (void **) &data) != FAILURE) {
php_info_print_table_row(2, "PHP_AUTH_PW", (*data)->value.str.val);
}
- php_print_gpcse_array("HTTP_GET_VARS", sizeof("HTTP_GET_VARS")-1 TSRMLS_CC);
- php_print_gpcse_array("HTTP_POST_VARS", sizeof("HTTP_POST_VARS")-1 TSRMLS_CC);
- php_print_gpcse_array("HTTP_POST_FILES", sizeof("HTTP_POST_FILES")-1 TSRMLS_CC);
- php_print_gpcse_array("HTTP_COOKIE_VARS", sizeof("HTTP_COOKIE_VARS")-1 TSRMLS_CC);
- php_print_gpcse_array("HTTP_SERVER_VARS", sizeof("HTTP_SERVER_VARS")-1 TSRMLS_CC);
- php_print_gpcse_array("HTTP_ENV_VARS", sizeof("HTTP_ENV_VARS")-1 TSRMLS_CC);
+ php_print_gpcse_array("_FORM", sizeof("_FORM")-1 TSRMLS_CC);
+ php_print_gpcse_array("_GET", sizeof("_GET")-1 TSRMLS_CC);
+ php_print_gpcse_array("_POST", sizeof("_POST")-1 TSRMLS_CC);
+ php_print_gpcse_array("_FILES", sizeof("_FILES")-1 TSRMLS_CC);
+ php_print_gpcse_array("_COOKIE", sizeof("_COOKIE")-1 TSRMLS_CC);
+ php_print_gpcse_array("_SERVER", sizeof("_SERVER")-1 TSRMLS_CC);
+ php_print_gpcse_array("_ENV", sizeof("_ENV")-1 TSRMLS_CC);
php_info_print_table_end();
}
diff --git a/main/main.c b/main/main.c
index 0a512f83e4..bd835ecb94 100644
--- a/main/main.c
+++ b/main/main.c
@@ -894,6 +894,7 @@ int php_module_startup(sapi_module_struct *sf)
for (i=0; i<6; i++) {
zend_register_auto_global(short_track_vars_names[i], short_track_vars_names_length[i]-1 TSRMLS_CC);
}
+ zend_register_auto_global("_FORM", sizeof("_FORM")-1 TSRMLS_CC);
zend_set_utility_values(&zuv);
php_startup_sapi_content_types();
@@ -1036,6 +1037,7 @@ static int php_hash_environment(TSRMLS_D)
zval *dummy_track_vars_array;
zend_bool initialized_dummy_track_vars_array=0;
int i;
+ char *variables_order;
char *track_vars_names[] = {
"HTTP_POST_VARS",
"HTTP_GET_VARS",
@@ -1060,10 +1062,10 @@ static int php_hash_environment(TSRMLS_D)
}
if (PG(variables_order)) {
- p = PG(variables_order);
+ variables_order = PG(variables_order);
have_variables_order=1;
} else {
- p = PG(gpc_order);
+ variables_order = PG(gpc_order);
have_variables_order=0;
ALLOC_ZVAL(PG(http_globals)[TRACK_VARS_ENV]);
array_init(PG(http_globals)[TRACK_VARS_ENV]);
@@ -1071,8 +1073,8 @@ static int php_hash_environment(TSRMLS_D)
php_import_environment_variables(PG(http_globals)[TRACK_VARS_ENV] TSRMLS_CC);
}
- while(p && *p) {
- switch(*p++) {
+ for (p=variables_order; p && *p; p++) {
+ switch(*p) {
case 'p':
case 'P':
if (!_gpc_flags[0] && !SG(headers_sent) && SG(request_info).request_method && !strcasecmp(SG(request_info).request_method, "POST")) {
@@ -1132,6 +1134,34 @@ static int php_hash_environment(TSRMLS_D)
PG(http_globals)[i]->refcount++;
zend_hash_update(&EG(symbol_table), short_track_vars_names[i], short_track_vars_names_length[i], &PG(http_globals)[i], sizeof(zval *), NULL);
}
+
+ {
+ zval *form_variables;
+
+ ALLOC_ZVAL(form_variables);
+ array_init(form_variables);
+ INIT_PZVAL(form_variables);
+
+ for (p=variables_order; p && *p; p++) {
+ switch (*p) {
+ case 'g':
+ case 'G':
+ zend_hash_merge(Z_ARRVAL_P(form_variables), Z_ARRVAL_P(PG(http_globals)[TRACK_VARS_GET]), (void (*)(void *pData)) zval_add_ref, NULL, sizeof(zval *), 0);
+ break;
+ case 'p':
+ case 'P':
+ zend_hash_merge(Z_ARRVAL_P(form_variables), Z_ARRVAL_P(PG(http_globals)[TRACK_VARS_POST]), (void (*)(void *pData)) zval_add_ref, NULL, sizeof(zval *), 0);
+ break;
+ case 'c':
+ case 'C':
+ zend_hash_merge(Z_ARRVAL_P(form_variables), Z_ARRVAL_P(PG(http_globals)[TRACK_VARS_COOKIE]), (void (*)(void *pData)) zval_add_ref, NULL, sizeof(zval *), 0);
+ break;
+ }
+ }
+
+ zend_hash_update(&EG(symbol_table), "_FORM", sizeof("_FORM"), &form_variables, sizeof(zval *), NULL);
+ }
+
return SUCCESS;
}
/* }}} */