iliaa Sun Mar 6 14:36:52 2005 EDT
Modified files:
/php-src/ext/standard html.c
Log:
Make html_entity_decode() 15-20% faster by avoiding pointless string
duplication.
http://cvs.php.net/diff.php/php-src/ext/standard/html.c?r1=1.101&r2=1.102&ty=u
Index: php-src/ext/standard/html.c
diff -u php-src/ext/standard/html.c:1.101 php-src/ext/standard/html.c:1.102
--- php-src/ext/standard/html.c:1.101 Tue Jan 11 15:58:46 2005
+++ php-src/ext/standard/html.c Sun Mar 6 14:36:51 2005
@@ -18,7 +18,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: html.c,v 1.101 2005/01/11 20:58:46 moriyoshi Exp $ */
+/* $Id: html.c,v 1.102 2005/03/06 19:36:51 iliaa Exp $ */
/*
* HTML entity resources:
@@ -940,9 +940,11 @@
return 0;
}
- replaced = php_str_to_str(ret, retlen, entity,
entity_length, replacement, replacement_len, &retlen);
- efree(ret);
- ret = replaced;
+ if (php_memnstr(ret, entity, entity_length,
ret+retlen)) {
+ replaced = php_str_to_str(ret, retlen,
entity, entity_length, replacement, replacement_len, &retlen);
+ efree(ret);
+ ret = replaced;
+ }
}
}
}
@@ -954,10 +956,12 @@
replacement[0] = (unsigned char)basic_entities[j].charcode;
replacement[1] = '\0';
-
- replaced = php_str_to_str(ret, retlen,
basic_entities[j].entity, basic_entities[j].entitylen, replacement, 1, &retlen);
- efree(ret);
- ret = replaced;
+
+ if (php_memnstr(ret, basic_entities[j].entity,
basic_entities[j].entitylen, ret+retlen)) {
+ replaced = php_str_to_str(ret, retlen,
basic_entities[j].entity, basic_entities[j].entitylen, replacement, 1, &retlen);
+ efree(ret);
+ ret = replaced;
+ }
}
/* replace numeric entities & "&" */
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php