summaryrefslogtreecommitdiff
path: root/ext/standard/html.c
diff options
context:
space:
mode:
authorYasuo Ohgaki <yohgaki@php.net>2014-03-20 10:49:23 +0900
committerYasuo Ohgaki <yohgaki@php.net>2014-03-20 10:50:32 +0900
commite1fe76f28ae4d93306c53477968311924f83bb79 (patch)
treeb219159b1c8549a1d64922a0f5daebbfc4ee9f5f /ext/standard/html.c
parentd0e3173016ce74198d010b5f6f2c243dde18797d (diff)
downloadphp-git-e1fe76f28ae4d93306c53477968311924f83bb79.tar.gz
Add default_charset handling
Diffstat (limited to 'ext/standard/html.c')
-rw-r--r--ext/standard/html.c39
1 files changed, 33 insertions, 6 deletions
diff --git a/ext/standard/html.c b/ext/standard/html.c
index 075a4d2ff9..ad2f38f2d4 100644
--- a/ext/standard/html.c
+++ b/ext/standard/html.c
@@ -84,6 +84,19 @@
#define sjis_lead(c) ((c) != 0x80 && (c) != 0xA0 && (c) < 0xFD)
#define sjis_trail(c) ((c) >= 0x40 && (c) != 0x7F && (c) < 0xFD)
+/* {{{ get_charset
+ */
+static void get_charset(char **charset, int *charset_len TSRMLS_DC) {
+ if (PG(internal_encoding) && PG(internal_encoding)[0]) {
+ *charset_len = strlen(PG(internal_encoding));
+ *charset = estrndup(PG(internal_encoding), *charset_len);
+ } else if (SG(default_charset) && SG(default_charset)[0] ) {
+ *charset_len = strlen(SG(default_charset));
+ *charset = estrndup(SG(default_charset), *charset_len);
+ }
+}
+/* }}} */
+
/* {{{ get_next_char
*/
static inline unsigned int get_next_char(
@@ -1432,8 +1445,8 @@ encode_amp:
*/
static void php_html_entities(INTERNAL_FUNCTION_PARAMETERS, int all)
{
- char *str, *hint_charset = PHP_DEFAULT_CHARSET;
- int str_len, hint_charset_len = sizeof(PHP_DEFAULT_CHARSET)-1;
+ char *str, *hint_charset = "";
+ int str_len, hint_charset_len = 0;
size_t new_len;
long flags = ENT_COMPAT;
char *replaced;
@@ -1443,7 +1456,14 @@ static void php_html_entities(INTERNAL_FUNCTION_PARAMETERS, int all)
return;
}
- replaced = php_escape_html_entities_ex(str, str_len, &new_len, all, (int) flags, hint_charset, double_encode TSRMLS_CC);
+ if (hint_charset_len) {
+ replaced = php_escape_html_entities_ex(str, str_len, &new_len, all, (int) flags, hint_charset, double_encode TSRMLS_CC);
+ } else {
+ get_charset(&hint_charset, &hint_charset_len TSRMLS_CC);
+ replaced = php_escape_html_entities_ex(str, str_len, &new_len, all, (int) flags, hint_charset, double_encode TSRMLS_CC);
+ efree(hint_charset);
+ }
+
RETVAL_STRINGL(replaced, (int)new_len, 0);
}
/* }}} */
@@ -1504,8 +1524,8 @@ PHP_FUNCTION(htmlspecialchars_decode)
Convert all HTML entities to their applicable characters */
PHP_FUNCTION(html_entity_decode)
{
- char *str, *hint_charset = PHP_DEFAULT_CHARSET;
- int str_len, hint_charset_len = sizeof(PHP_DEFAULT_CHARSET)-1;
+ char *str, *hint_charset = "";
+ int str_len, hint_charset_len = 0;
size_t new_len = 0;
long quote_style = ENT_COMPAT;
char *replaced;
@@ -1515,7 +1535,14 @@ PHP_FUNCTION(html_entity_decode)
return;
}
- replaced = php_unescape_html_entities(str, str_len, &new_len, 1 /*all*/, quote_style, hint_charset TSRMLS_CC);
+ if (hint_charset_len) {
+ replaced = php_unescape_html_entities(str, str_len, &new_len, 1 /*all*/, quote_style, hint_charset TSRMLS_CC);
+ } else {
+ get_charset(&hint_charset, &hint_charset_len TSRMLS_CC);
+ replaced = php_unescape_html_entities(str, str_len, &new_len, 1 /*all*/, quote_style, hint_charset TSRMLS_CC);
+ efree(hint_charset);
+ }
+
if (replaced) {
RETURN_STRINGL(replaced, (int)new_len, 0);
}