diff options
| author | Thies C. Arntzen <thies@php.net> | 2001-07-09 06:49:34 +0000 | 
|---|---|---|
| committer | Thies C. Arntzen <thies@php.net> | 2001-07-09 06:49:34 +0000 | 
| commit | 6708768c074d424278706216fa3f6b812680f10b (patch) | |
| tree | b8c34856a6cd9c81f8aaca6612b85257a3e02824 /ext/xml/xml.c | |
| parent | 1e3553bd428f18eefbc4571428317fc69721500e (diff) | |
| download | php-git-6708768c074d424278706216fa3f6b812680f10b.tar.gz | |
xml_utf8_encode: make sure the returned data is zero-terminated
Diffstat (limited to 'ext/xml/xml.c')
| -rw-r--r-- | ext/xml/xml.c | 7 | 
1 files changed, 3 insertions, 4 deletions
| diff --git a/ext/xml/xml.c b/ext/xml/xml.c index 3aaac36138..1534a4fb5b 100644 --- a/ext/xml/xml.c +++ b/ext/xml/xml.c @@ -492,7 +492,7 @@ xml_utf8_encode(const char *s, int len, int *newlen, const XML_Char *encoding)  	}  	/* This is the theoretical max (will never get beyond len * 2 as long  	 * as we are converting from single-byte characters, though) */ -	newbuf = emalloc(len * 4); +	newbuf = emalloc(len * 4 + 1);  	while (pos > 0) {  		c = encoder ? encoder((unsigned char)(*s)) : (unsigned short)(*s);  		if (c < 0x80) { @@ -513,9 +513,8 @@ xml_utf8_encode(const char *s, int len, int *newlen, const XML_Char *encoding)  		pos--;  		s++;      } -	if (*newlen < len * 4) { -		newbuf = erealloc(newbuf, *newlen); -	} +	newbuf[*newlen] = 0; +	newbuf = erealloc(newbuf, (*newlen)+1);  	return newbuf;  }  /* }}} */ | 
