diff options
author | Dmitry Stogov <dmitry@php.net> | 2010-08-26 12:20:35 +0000 |
---|---|---|
committer | Dmitry Stogov <dmitry@php.net> | 2010-08-26 12:20:35 +0000 |
commit | ab6ce922e2a9fffb845d37df2ca811518a5663a1 (patch) | |
tree | 0e211866942302682520457b63e5f71c8db6515d /main/php_variables.c | |
parent | cbe9f57a17c8646418268fdd4bb64c5b6cd9bad8 (diff) | |
download | php-git-ab6ce922e2a9fffb845d37df2ca811518a5663a1.tar.gz |
Use stack instead of heap
Diffstat (limited to 'main/php_variables.c')
-rw-r--r-- | main/php_variables.c | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/main/php_variables.c b/main/php_variables.c index e45598f603..f1744b111e 100644 --- a/main/php_variables.c +++ b/main/php_variables.c @@ -67,6 +67,7 @@ PHPAPI void php_register_variable_ex(char *var_name, zval *val, zval *track_vars zval *gpc_element, **gpc_element_p; zend_bool is_array = 0; HashTable *symtable1 = NULL; + ALLOCA_FLAG(use_heap) assert(var_name != NULL); @@ -80,16 +81,18 @@ PHPAPI void php_register_variable_ex(char *var_name, zval *val, zval *track_vars return; } - /* - * Prepare variable name - */ - var_orig = estrdup(var_name); - var = var_orig; /* ignore leading spaces in the variable name */ - while (*var && *var==' ') { - var++; + while (*var_name && *var_name==' ') { + var_name++; } + + /* + * Prepare variable name + */ + var_len = strlen(var_name); + var = var_orig = do_alloca(var_len + 1, use_heap); + memcpy(var_orig, var_name, var_len + 1); /* ensure that we don't have spaces or dots in the variable name (not binary safe) */ for (p = var; *p; p++) { @@ -106,7 +109,7 @@ PHPAPI void php_register_variable_ex(char *var_name, zval *val, zval *track_vars if (var_len==0) { /* empty variable name, or variable name with a space in it */ zval_dtor(val); - efree(var_orig); + free_alloca(var_orig, use_heap); return; } @@ -115,7 +118,7 @@ PHPAPI void php_register_variable_ex(char *var_name, zval *val, zval *track_vars var_len == sizeof("GLOBALS")-1 && !memcmp(var, "GLOBALS", sizeof("GLOBALS")-1)) { zval_dtor(val); - efree(var_orig); + free_alloca(var_orig, use_heap); return; } @@ -144,7 +147,7 @@ PHPAPI void php_register_variable_ex(char *var_name, zval *val, zval *track_vars if (!PG(display_errors)) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "Input variable nesting level exceeded %ld. To increase the limit change max_input_nesting_level in php.ini.", PG(max_input_nesting_level)); } - efree(var_orig); + free_alloca(var_orig, use_heap); return; } @@ -236,7 +239,7 @@ plain_var: } } } - efree(var_orig); + free_alloca(var_orig, use_heap); } SAPI_API SAPI_POST_HANDLER_FUNC(php_std_post_handler) |