summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSascha Schumann <sas@php.net>2002-05-04 18:33:13 +0000
committerSascha Schumann <sas@php.net>2002-05-04 18:33:13 +0000
commit9743860d35c17da9b36c104c16cb06122d6cf6f6 (patch)
tree06d63c81ef2ada41067498b05d5174de4d21d9eb
parentebfff2df7e350557c72424311e94ca1984184a40 (diff)
downloadphp-git-9743860d35c17da9b36c104c16cb06122d6cf6f6.tar.gz
simplify handling of variables by maintaining two strings which
are simply appended instead of traversing the hash table on each URL/form. also fix an unconditional segfault in rshutdown due to efree'ing a static char *. remove remove_var, add reset_vars. move the function declarations into the right header file.
-rw-r--r--ext/session/session.c4
-rw-r--r--ext/standard/basic_functions.c2
-rw-r--r--ext/standard/url_scanner_ex.h9
-rw-r--r--ext/standard/url_scanner_ex.re100
-rw-r--r--main/output.c11
-rw-r--r--main/php_output.h3
6 files changed, 52 insertions, 77 deletions
diff --git a/ext/session/session.c b/ext/session/session.c
index aea119aac6..a028851c34 100644
--- a/ext/session/session.c
+++ b/ext/session/session.c
@@ -1379,7 +1379,9 @@ PHP_FUNCTION(session_unset)
static void php_rinit_session_globals(TSRMLS_D)
{
zend_hash_init(&PS(vars), 0, NULL, NULL, 0);
- php_url_scanner_remove_var(PS(session_name), strlen(PS(session_name)) TSRMLS_CC); /* save even if we haven't registered */
+#if I_KNOW_WHAT_THE_PURPOSE_OF_THIS_IS
+ php_url_scanner_reset_vars(TSRMLS_C); /* save even if we haven't registered */
+#endif
PS(id) = NULL;
PS(session_status) = php_session_none;
PS(mod_data) = NULL;
diff --git a/ext/standard/basic_functions.c b/ext/standard/basic_functions.c
index 54fc66b4fc..cbb9922da6 100644
--- a/ext/standard/basic_functions.c
+++ b/ext/standard/basic_functions.c
@@ -811,7 +811,7 @@ function_entry basic_functions[] = {
PHP_FE(aggregation_info, first_arg_force_ref)
PHP_FE(output_add_rewrite_var, NULL)
- PHP_FE(output_remove_rewrite_var, NULL)
+ PHP_FE(output_reset_rewrite_vars, NULL)
{NULL, NULL, NULL}
};
diff --git a/ext/standard/url_scanner_ex.h b/ext/standard/url_scanner_ex.h
index 3cc16c8531..dda749812c 100644
--- a/ext/standard/url_scanner_ex.h
+++ b/ext/standard/url_scanner_ex.h
@@ -25,11 +25,8 @@ PHP_MSHUTDOWN_FUNCTION(url_scanner_ex);
PHP_RINIT_FUNCTION(url_scanner_ex);
PHP_RSHUTDOWN_FUNCTION(url_scanner_ex);
-PHP_FUNCTION(output_add_rewrite_var);
-PHP_FUNCTION(output_remove_rewrite_var);
-
int php_url_scanner_add_var(char *name, int name_len, char *value, int value_len, int urlencode TSRMLS_DC);
-int php_url_scanner_remove_var(char *name, int name_len TSRMLS_DC);
+int php_url_scanner_reset_vars(TSRMLS_D);
int php_url_scanner_ex_activate(TSRMLS_D);
int php_url_scanner_ex_deactivate(TSRMLS_D);
@@ -46,8 +43,8 @@ typedef struct {
/* The result buffer */
smart_str result;
- /* The data which is appended to each relative URL */
- HashTable *rewrite_vars;
+ /* The data which is appended to each relative URL/FORM */
+ smart_str form_app, url_app;
int active;
diff --git a/ext/standard/url_scanner_ex.re b/ext/standard/url_scanner_ex.re
index 43898e46cd..d17ef1259f 100644
--- a/ext/standard/url_scanner_ex.re
+++ b/ext/standard/url_scanner_ex.re
@@ -96,15 +96,11 @@ alpha = [a-zA-Z];
#define YYLIMIT q
#define YYMARKER r
-static inline void append_modified_url(smart_str *url, smart_str *dest, HashTable *rewrite_vars, const char *separator)
+static inline void append_modified_url(smart_str *url, smart_str *dest, smart_str *url_app, const char *separator)
{
register const char *p, *q;
const char *bash = NULL;
const char *sep = "?";
- char *string_key;
- url_adapt_var_t *value;
- int num_key;
-
q = (p = url->c) + url->len;
@@ -128,16 +124,8 @@ done:
else
smart_str_append(dest, url);
- zend_hash_internal_pointer_reset(rewrite_vars);
- while (zend_hash_get_current_key(rewrite_vars, &string_key, &num_key, 0) != HASH_KEY_NON_EXISTANT) {
- zend_hash_get_current_data(rewrite_vars, &value);
- smart_str_appends(dest, sep);
- smart_str_append(dest, &(value->var));
- smart_str_appendc(dest, '=');
- smart_str_append(dest, &(value->val));
- zend_hash_move_forward(rewrite_vars);
- sep = separator; /* switch from ? to now! */
- }
+ smart_str_appends(dest, sep);
+ smart_str_append(dest, url_app);
if (bash)
smart_str_appendl(dest, bash, q - bash);
@@ -160,7 +148,7 @@ static inline void tag_arg(url_adapt_state_ex_t *ctx, char quotes, char type TSR
if (quotes)
smart_str_appendc(&ctx->result, type);
if (f) {
- append_modified_url(&ctx->val, &ctx->result, ctx->rewrite_vars, PG(arg_separator).output);
+ append_modified_url(&ctx->val, &ctx->result, &ctx->url_app, PG(arg_separator).output);
} else {
smart_str_append(&ctx->result, &ctx->val);
}
@@ -194,21 +182,10 @@ static inline void passthru(STD_PARA)
static inline void handle_form(STD_PARA)
{
- if (ctx->tag.len == 4 && strncasecmp(ctx->tag.c, "form", 4) == 0) {
- char *string_key;
- url_adapt_var_t *value;
- int num_key;
-
- zend_hash_internal_pointer_reset(ctx->rewrite_vars);
- while (zend_hash_get_current_key(ctx->rewrite_vars, &string_key, &num_key, 0) != HASH_KEY_NON_EXISTANT) {
- zend_hash_get_current_data(ctx->rewrite_vars, &value);
- smart_str_appends(&ctx->result, "<input type=\"hidden\" name=\"");
- smart_str_append(&ctx->result, &(value->var));
- smart_str_appends(&ctx->result, "\" value=\"");
- smart_str_append(&ctx->result, &(value->val));
- smart_str_appends(&ctx->result, "\" />");
- zend_hash_move_forward(ctx->rewrite_vars);
- }
+ if (ctx->form_app.len > 0
+ && ctx->tag.len == 4
+ && strncasecmp(ctx->tag.c, "form", 4) == 0) {
+ smart_str_append(&ctx->result, &ctx->form_app);
}
}
@@ -389,56 +366,60 @@ int php_url_scanner_ex_deactivate(TSRMLS_D)
static void php_url_scanner_output_handler(char *output, uint output_len, char **handled_output, uint *handled_output_len, int mode TSRMLS_DC)
{
- if (BG(url_adapt_state_ex).rewrite_vars && zend_hash_num_elements(BG(url_adapt_state_ex).rewrite_vars)) {
+ if (BG(url_adapt_state_ex).url_app.len != 0) {
*handled_output = url_adapt_ext(output, output_len, handled_output_len, (zend_bool) (mode&PHP_OUTPUT_HANDLER_END ? 1 : 0) TSRMLS_CC);
} else {
*handled_output = NULL;
}
}
-static void php_url_scanner_var_dtor(url_adapt_var_t *var)
-{
- smart_str_free(&(var->var));
- smart_str_free(&(var->val));
-}
-
int php_url_scanner_add_var(char *name, int name_len, char *value, int value_len, int urlencode TSRMLS_DC)
{
- url_adapt_var_t var;
char *encoded;
int encoded_len;
-
+ smart_str val;
+
if (! BG(url_adapt_state_ex).active) {
int chunk_size = 4096; /* XXX where should we get chunk_size from? */
php_url_scanner_ex_activate(TSRMLS_C);
php_start_ob_buffer(NULL, chunk_size, 1 TSRMLS_CC);
- php_ob_set_internal_handler(php_url_scanner_output_handler, chunk_size, "URL-Rewriter", 1 TSRMLS_CC);
+ php_ob_set_internal_handler(php_url_scanner_output_handler, chunk_size, estrdup("URL-Rewriter"), 1 TSRMLS_CC);
BG(url_adapt_state_ex).active = 1;
}
- if (! BG(url_adapt_state_ex).rewrite_vars) {
- BG(url_adapt_state_ex).rewrite_vars = emalloc(sizeof(HashTable));
- zend_hash_init(BG(url_adapt_state_ex).rewrite_vars, 0, NULL, (void (*)(void *)) php_url_scanner_var_dtor, 0);
- }
- smart_str_appendl(&(var.var), name, name_len);
+ if (BG(url_adapt_state_ex).url_app.len != 0) {
+ smart_str_appends(&BG(url_adapt_state_ex).url_app, PG(arg_separator).output);
+ }
if (urlencode) {
encoded = php_url_encode(value, value_len, &encoded_len);
- smart_str_setl(&(var.val), encoded, encoded_len);
+ smart_str_setl(&val, encoded, encoded_len);
} else {
- smart_str_appendl(&(var.val), value, value_len);
+ smart_str_setl(&val, value, value_len);
}
+
+ smart_str_appendl(&BG(url_adapt_state_ex).url_app, name, name_len);
+ smart_str_appendc(&BG(url_adapt_state_ex).url_app, '=');
+ smart_str_append(&BG(url_adapt_state_ex).url_app, &val);
+
+ smart_str_appends(&BG(url_adapt_state_ex).form_app, "<input type=\"hidden\" name=\"");
+ smart_str_appendl(&BG(url_adapt_state_ex).form_app, name, name_len);
+ smart_str_appends(&BG(url_adapt_state_ex).form_app, "\" value=\"");
+ smart_str_append(&BG(url_adapt_state_ex).form_app, &val);
+ smart_str_appends(&BG(url_adapt_state_ex).form_app, "\" />");
+
+ if (urlencode)
+ efree(encoded);
- return zend_hash_add(BG(url_adapt_state_ex).rewrite_vars, name, name_len, &var, sizeof(url_adapt_var_t), NULL);
+ return SUCCESS;
}
-int php_url_scanner_remove_var(char *name, int name_len TSRMLS_DC)
+int php_url_scanner_reset_vars(TSRMLS_D)
{
- if (BG(url_adapt_state_ex).rewrite_vars) {
- return zend_hash_del(BG(url_adapt_state_ex).rewrite_vars, name, name_len);
- }
+ BG(url_adapt_state_ex).form_app.len = 0;
+ BG(url_adapt_state_ex).url_app.len = 0;
return FAILURE;
}
@@ -447,6 +428,9 @@ PHP_MINIT_FUNCTION(url_scanner)
{
BG(url_adapt_state_ex).tags = NULL;
+ BG(url_adapt_state_ex).form_app.c = BG(url_adapt_state_ex).url_app.c = 0;
+ BG(url_adapt_state_ex).form_app.len = BG(url_adapt_state_ex).url_app.len = 0;
+
REGISTER_INI_ENTRIES();
return SUCCESS;
}
@@ -463,8 +447,10 @@ PHP_MSHUTDOWN_FUNCTION(url_scanner)
PHP_RINIT_FUNCTION(url_scanner)
{
BG(url_adapt_state_ex).active = 0;
- BG(url_adapt_state_ex).rewrite_vars = NULL;
+ smart_str_free(&BG(url_adapt_state_ex).form_app);
+ smart_str_free(&BG(url_adapt_state_ex).url_app);
+
return SUCCESS;
}
@@ -475,11 +461,5 @@ PHP_RSHUTDOWN_FUNCTION(url_scanner)
BG(url_adapt_state_ex).active = 0;
}
- if (BG(url_adapt_state_ex).rewrite_vars) {
- zend_hash_destroy(BG(url_adapt_state_ex).rewrite_vars);
- efree(BG(url_adapt_state_ex).rewrite_vars);
- BG(url_adapt_state_ex).rewrite_vars = NULL;
- }
-
return SUCCESS;
}
diff --git a/main/output.c b/main/output.c
index 2999227a1d..c8d414910a 100644
--- a/main/output.c
+++ b/main/output.c
@@ -795,16 +795,9 @@ PHPAPI int php_get_output_start_lineno(TSRMLS_D)
return OG(output_start_lineno);
}
-PHP_FUNCTION(output_remove_rewrite_var)
+PHP_FUNCTION(output_reset_rewrite_vars)
{
- char *name;
- int name_len;
-
- if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &name, &name_len) == FAILURE) {
- RETURN_FALSE;
- }
-
- if (php_url_scanner_remove_var(name, name_len TSRMLS_CC) == SUCCESS) {
+ if (php_url_scanner_reset_vars(TSRMLS_C) == SUCCESS) {
RETURN_TRUE;
} else {
RETURN_FALSE;
diff --git a/main/php_output.h b/main/php_output.h
index f1a8069ce1..48f9bde31d 100644
--- a/main/php_output.h
+++ b/main/php_output.h
@@ -94,5 +94,8 @@ ZEND_API extern php_output_globals output_globals;
#define PHP_OUTPUT_HANDLER_INTERNAL 0
#define PHP_OUTPUT_HANDLER_USER 1
+PHP_FUNCTION(output_add_rewrite_var);
+PHP_FUNCTION(output_reset_rewrite_vars);
+
#endif /* PHP_OUTPUT_H */