diff options
| author | Hye-Shik Chang <hyeshik@gmail.com> | 2003-12-29 01:36:01 +0000 | 
|---|---|---|
| committer | Hye-Shik Chang <hyeshik@gmail.com> | 2003-12-29 01:36:01 +0000 | 
| commit | 7db07e697286c8bedb7d8c320203ddbc7a98bad2 (patch) | |
| tree | ee6402f92fd62ec87498c767b4eb626639cd76d9 /Python/codecs.c | |
| parent | f1ca7f561c6e02509e17414825305ebcbd6f72b0 (diff) | |
| download | cpython-git-7db07e697286c8bedb7d8c320203ddbc7a98bad2.tar.gz | |
Fix gcc 3.3 warnings related to Py_UNICODE_WIDE.
Diffstat (limited to 'Python/codecs.c')
| -rw-r--r-- | Python/codecs.c | 22 | 
1 files changed, 20 insertions, 2 deletions
| diff --git a/Python/codecs.c b/Python/codecs.c index 3675f3cc80..a208898e8c 100644 --- a/Python/codecs.c +++ b/Python/codecs.c @@ -563,12 +563,17 @@ PyObject *PyCodec_XMLCharRefReplaceErrors(PyObject *exc)  		ressize += 2+3+1;  	    else if (*p<10000)  		ressize += 2+4+1; +#ifndef Py_UNICODE_WIDE +	    else +		ressize += 2+5+1; +#else  	    else if (*p<100000)  		ressize += 2+5+1;  	    else if (*p<1000000)  		ressize += 2+6+1;  	    else  		ressize += 2+7+1; +#endif  	}  	/* allocate replacement */  	res = PyUnicode_FromUnicode(NULL, ressize); @@ -600,6 +605,12 @@ PyObject *PyCodec_XMLCharRefReplaceErrors(PyObject *exc)  		digits = 4;  		base = 1000;  	    } +#ifndef Py_UNICODE_WIDE +	    else { +		digits = 5; +		base = 10000; +	    } +#else  	    else if (*p<100000) {  		digits = 5;  		base = 10000; @@ -612,6 +623,7 @@ PyObject *PyCodec_XMLCharRefReplaceErrors(PyObject *exc)  		digits = 7;  		base = 1000000;  	    } +#endif  	    while (digits-->0) {  		*outp++ = '0' + c/base;  		c %= base; @@ -655,9 +667,12 @@ PyObject *PyCodec_BackslashReplaceErrors(PyObject *exc)  	    return NULL;  	startp = PyUnicode_AS_UNICODE(object);  	for (p = startp+start, ressize = 0; p < startp+end; ++p) { +#ifdef Py_UNICODE_WIDE  	    if (*p >= 0x00010000)  		ressize += 1+1+8; -	    else if (*p >= 0x100) { +	    else +#endif +	    if (*p >= 0x100) {  		ressize += 1+1+4;  	    }  	    else @@ -670,6 +685,7 @@ PyObject *PyCodec_BackslashReplaceErrors(PyObject *exc)  	    p < startp+end; ++p) {  	    Py_UNICODE c = *p;  	    *outp++ = '\\'; +#ifdef Py_UNICODE_WIDE  	    if (c >= 0x00010000) {  		*outp++ = 'U';  		*outp++ = hexdigits[(c>>28)&0xf]; @@ -679,7 +695,9 @@ PyObject *PyCodec_BackslashReplaceErrors(PyObject *exc)  		*outp++ = hexdigits[(c>>12)&0xf];  		*outp++ = hexdigits[(c>>8)&0xf];  	    } -	    else if (c >= 0x100) { +	    else +#endif +	    if (c >= 0x100) {  		*outp++ = 'u';  		*outp++ = hexdigits[(c>>12)&0xf];  		*outp++ = hexdigits[(c>>8)&0xf]; | 
