diff options
author | Rob Richards <rrichards@php.net> | 2006-08-15 22:47:11 +0000 |
---|---|---|
committer | Rob Richards <rrichards@php.net> | 2006-08-15 22:47:11 +0000 |
commit | adf10989b09c824d4a99eec936105154cfdfb0eb (patch) | |
tree | b0da3928c97c0aae550cfe123176e895632306c9 /ext/xml/xml.c | |
parent | be316018fdc2785aa8cc3416f7ca117969f3c4c9 (diff) | |
download | php-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.c | 24 |
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); |