summaryrefslogtreecommitdiff
path: root/ext/xml/xml.c
diff options
context:
space:
mode:
authorRob Richards <rrichards@php.net>2006-08-15 22:47:11 +0000
committerRob Richards <rrichards@php.net>2006-08-15 22:47:11 +0000
commitadf10989b09c824d4a99eec936105154cfdfb0eb (patch)
treeb0da3928c97c0aae550cfe123176e895632306c9 /ext/xml/xml.c
parentbe316018fdc2785aa8cc3416f7ca117969f3c4c9 (diff)
downloadphp-git-adf10989b09c824d4a99eec936105154cfdfb0eb.tar.gz
fix bug #38454 (warning upon disabling handler via xml_set_element_handler)
fix bug #38427 (unicode causes xml_parser to misbehave) add test
Diffstat (limited to 'ext/xml/xml.c')
-rw-r--r--ext/xml/xml.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/ext/xml/xml.c b/ext/xml/xml.c
index 789ec0cf5b..9c8d842176 100644
--- a/ext/xml/xml.c
+++ b/ext/xml/xml.c
@@ -380,7 +380,12 @@ static void xml_set_handler(zval **handler, zval **data)
/* IS_ARRAY might indicate that we're using array($obj, 'method') syntax */
if (Z_TYPE_PP(data) != IS_ARRAY) {
+
convert_to_string_ex(data);
+ if (Z_STRLEN_PP(data) == 0) {
+ *handler = NULL;
+ return;
+ }
}
zval_add_ref(data);
@@ -857,6 +862,25 @@ void _xml_characterDataHandler(void *userData, const XML_Char *s, int len)
} else {
zval *tag;
+ zval **curtag, **mytype, **myval;
+ HashPosition hpos=NULL;
+
+ zend_hash_internal_pointer_end_ex(Z_ARRVAL_P(parser->data), &hpos);
+
+ if (hpos && (zend_hash_get_current_data_ex(Z_ARRVAL_P(parser->data), (void **) &curtag, &hpos) == SUCCESS)) {
+ if (zend_hash_find(Z_ARRVAL_PP(curtag),"type",sizeof("type"),(void **) &mytype) == SUCCESS) {
+ if (!strcmp(Z_STRVAL_PP(mytype), "cdata")) {
+ if (zend_hash_find(Z_ARRVAL_PP(curtag),"value",sizeof("value"),(void **) &myval) == SUCCESS) {
+ int newlen = Z_STRLEN_PP(myval) + decoded_len;
+ Z_STRVAL_PP(myval) = erealloc(Z_STRVAL_PP(myval),newlen+1);
+ strcpy(Z_STRVAL_PP(myval) + Z_STRLEN_PP(myval),decoded_value);
+ Z_STRLEN_PP(myval) += decoded_len;
+ efree(decoded_value);
+ return;
+ }
+ }
+ }
+ }
MAKE_STD_ZVAL(tag);