mirror of
https://github.com/php/php-src.git
synced 2024-09-21 09:57:23 +00:00
Use get_serialization_string_from_zval() in all encoding functions
This commit is contained in:
parent
56fea5995d
commit
ca66a11c36
@ -916,19 +916,14 @@ static xmlNodePtr to_xml_string(encodeTypePtr type, zval *data, int style, xmlNo
|
||||
static xmlNodePtr to_xml_base64(encodeTypePtr type, zval *data, int style, xmlNodePtr parent)
|
||||
{
|
||||
xmlNodePtr ret, text;
|
||||
zend_string *str;
|
||||
|
||||
ret = xmlNewNode(NULL, BAD_CAST("BOGUS"));
|
||||
xmlAddChild(parent, ret);
|
||||
FIND_ZVAL_NULL(data, ret, style);
|
||||
|
||||
if (Z_TYPE_P(data) == IS_STRING) {
|
||||
str = php_base64_encode((unsigned char*)Z_STRVAL_P(data), Z_STRLEN_P(data));
|
||||
} else {
|
||||
zend_string *tmp = zval_get_string_func(data);
|
||||
str = php_base64_encode((unsigned char*) ZSTR_VAL(tmp), ZSTR_LEN(tmp));
|
||||
zend_string_release_ex(tmp, 0);
|
||||
}
|
||||
zend_string *serialization = get_serialization_string_from_zval(data);
|
||||
zend_string *str = php_base64_encode((unsigned char *) ZSTR_VAL(serialization), ZSTR_LEN(serialization));
|
||||
zend_string_release(serialization);
|
||||
|
||||
text = xmlNewTextLen(BAD_CAST(ZSTR_VAL(str)), ZSTR_LEN(str));
|
||||
xmlAddChild(ret, text);
|
||||
@ -953,7 +948,7 @@ static xmlNodePtr to_xml_hexbin(encodeTypePtr type, zval *data, int style, xmlNo
|
||||
FIND_ZVAL_NULL(data, ret, style);
|
||||
|
||||
if (Z_TYPE_P(data) != IS_STRING) {
|
||||
ZVAL_STR(&tmp, zval_get_string_func(data));
|
||||
ZVAL_STR(&tmp, get_serialization_string_from_zval(data));
|
||||
data = &tmp;
|
||||
}
|
||||
str = (unsigned char *) safe_emalloc(Z_STRLEN_P(data) * 2, sizeof(char), 1);
|
||||
@ -3006,7 +3001,7 @@ static xmlNodePtr to_xml_list(encodeTypePtr enc, zval *data, int style, xmlNodeP
|
||||
smart_str list = {0};
|
||||
|
||||
if (Z_TYPE_P(data) != IS_STRING) {
|
||||
ZVAL_STR(&tmp, zval_get_string_func(data));
|
||||
ZVAL_STR(&tmp, get_serialization_string_from_zval(data));
|
||||
data = &tmp;
|
||||
}
|
||||
str = estrndup(Z_STRVAL_P(data), Z_STRLEN_P(data));
|
||||
@ -3115,13 +3110,10 @@ static xmlNodePtr to_xml_any(encodeTypePtr type, zval *data, int style, xmlNodeP
|
||||
} ZEND_HASH_FOREACH_END();
|
||||
return ret;
|
||||
}
|
||||
if (Z_TYPE_P(data) == IS_STRING) {
|
||||
ret = xmlNewTextLen(BAD_CAST(Z_STRVAL_P(data)), Z_STRLEN_P(data));
|
||||
} else {
|
||||
zend_string *tmp = zval_get_string_func(data);
|
||||
ret = xmlNewTextLen(BAD_CAST(ZSTR_VAL(tmp)), ZSTR_LEN(tmp));
|
||||
zend_string_release_ex(tmp, 0);
|
||||
}
|
||||
|
||||
zend_string *serialization = get_serialization_string_from_zval(data);
|
||||
ret = xmlNewTextLen(BAD_CAST(ZSTR_VAL(serialization)), ZSTR_LEN(serialization));
|
||||
zend_string_release_ex(serialization, false);
|
||||
|
||||
ret->name = xmlStringTextNoenc;
|
||||
ret->parent = parent;
|
||||
|
Loading…
Reference in New Issue
Block a user