📄 glibc-2.3.2-allow-gcc-3.5-gconv.patch
字号:
Fixesgconv_open.c: In function `__gconv_open':gconv_open.c:186: error: invalid lvalue in assignmentwhen building glibc-2.3.2 with gcc-3.5.wget 'http://sources.redhat.com/cgi-bin/cvsweb.cgi/libc/iconv/gconv_simple.c.diff?r1=1.59&r2=1.63&cvsroot=glibc' * (internal_ucs4_loop): Fix typo in last change. * (internal_ucs4le_loop): Remove cast used as lvalue. * Fix last commit. * iconv/gconv_simple.c (ucs4le_internal_loop): Remove cast used as lvalue. (internal_ucs4le_loop_single): Likewise. (ucs4_internal_loop): Likewise. (BODY): Likewise. (internal_ucs4_loop_single): Likewise.wget 'http://sources.redhat.com/cgi-bin/cvsweb.cgi/libc/iconv/gconv_open.c.diff?r1=1.32&r2=1.33&cvsroot=glibc' * iconv/gconv_simple.c (ucs4le_internal_loop): Remove cast used as lvalue. (internal_ucs4le_loop_single): Likewise. (ucs4_internal_loop): Likewise. (BODY): Likewise. (internal_ucs4_loop_single): Likewise.===================================================================RCS file: /cvs/glibc/libc/iconv/gconv_open.c,vretrieving revision 1.32retrieving revision 1.33diff -u -r1.32 -r1.33--- libc/iconv/gconv_open.c 2001/11/29 04:51:58 1.32+++ libc/iconv/gconv_open.c 2004/02/07 15:56:32 1.33@@ -1,5 +1,5 @@ /* Find matching transformation algorithms and initialize steps.- Copyright (C) 1997, 1998, 1999, 2000, 2001 Free Software Foundation, Inc.+ Copyright (C) 1997, 1998, 1999, 2000, 2001, 2004 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997. @@ -182,8 +182,13 @@ || __builtin_expect (__gconv_translit_find (runp), 0) == 0) lastp = runp; else- /* This means we haven't found the module. Remove it. */- (lastp == NULL ? trans : lastp->next) = runp->next;+ {+ /* This means we haven't found the module. Remove it. */+ if (lastp == NULL)+ trans = runp->next;+ else+ lastp->next = runp->next;+ } } /* Allocate room for handle. */===================================================================RCS file: /cvs/glibc/libc/iconv/gconv_simple.c,vretrieving revision 1.59retrieving revision 1.63diff -u -r1.59 -r1.63--- libc/iconv/gconv_simple.c 2003/06/11 21:36:37 1.59+++ libc/iconv/gconv_simple.c 2004/03/09 10:00:31 1.63@@ -1,5 +1,5 @@ /* Simple transformations functions.- Copyright (C) 1997-2002, 2003 Free Software Foundation, Inc.+ Copyright (C) 1997-2003, 2004 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997. @@ -87,12 +87,13 @@ #if __BYTE_ORDER == __LITTLE_ENDIAN /* Sigh, we have to do some real work. */ size_t cnt;+ uint32_t *outptr32 = (uint32_t *) outptr; for (cnt = 0; cnt < n_convert; ++cnt, inptr += 4)- *((uint32_t *) outptr)++ = bswap_32 (*(const uint32_t *) inptr);+ *outptr32++ = bswap_32 (*(const uint32_t *) inptr); *inptrp = inptr;- *outptrp = outptr;+ *outptrp = (unsigned char *) outptr32; #elif __BYTE_ORDER == __BIG_ENDIAN /* Simply copy the data. */ *inptrp = inptr + n_convert * 4;@@ -192,13 +193,16 @@ (*outptrp)[2] = state->__value.__wchb[1]; (*outptrp)[3] = state->__value.__wchb[0]; - *outptrp += 4; #elif __BYTE_ORDER == __BIG_ENDIAN /* XXX unaligned */- *(*((uint32_t **) outptrp)++) = state->__value.__wch;+ (*outptrp)[0] = state->__value.__wchb[0];+ (*outptrp)[1] = state->__value.__wchb[1];+ (*outptrp)[2] = state->__value.__wchb[2];+ (*outptrp)[3] = state->__value.__wchb[3]; #else # error "This endianess is not supported." #endif+ *outptrp += 4; /* Clear the state buffer. */ state->__count &= ~7;@@ -268,7 +272,8 @@ return __GCONV_ILLEGAL_INPUT; } - *((uint32_t *) outptr)++ = inval;+ *((uint32_t *) outptr) = inval;+ outptr += sizeof (uint32_t); } *inptrp = inptr;@@ -447,9 +452,11 @@ #if __BYTE_ORDER == __BIG_ENDIAN /* Sigh, we have to do some real work. */ size_t cnt;+ uint32_t *outptr32 = (uint32_t *) outptr; for (cnt = 0; cnt < n_convert; ++cnt, inptr += 4)- *((uint32_t *) outptr)++ = bswap_32 (*(const uint32_t *) inptr);+ *outptr32++ = bswap_32 (*(const uint32_t *) inptr);+ outptr = (unsigned char *) outptr32; *inptrp = inptr; *outptrp = outptr;@@ -555,12 +562,17 @@ (*outptrp)[2] = state->__value.__wchb[1]; (*outptrp)[3] = state->__value.__wchb[0]; - *outptrp += 4; #else /* XXX unaligned */- *(*((uint32_t **) outptrp)++) = state->__value.__wch;+ (*outptrp)[0] = state->__value.__wchb[0];+ (*outptrp)[1] = state->__value.__wchb[1];+ (*outptrp)[2] = state->__value.__wchb[2];+ (*outptrp)[3] = state->__value.__wchb[3];+ #endif + *outptrp += 4;+ /* Clear the state buffer. */ state->__count &= ~7; @@ -626,7 +638,8 @@ return __GCONV_ILLEGAL_INPUT; } - *((uint32_t *) outptr)++ = inval;+ *((uint32_t *) outptr) = inval;+ outptr += sizeof (uint32_t); } *inptrp = inptr;@@ -808,7 +821,8 @@ } \ else \ /* It's an one byte sequence. */ \- *((uint32_t *) outptr)++ = *inptr++; \+ *((uint32_t *) outptr) = *inptr++; \+ outptr += sizeof (uint32_t); \ } #define LOOP_NEED_FLAGS #include <iconv/loop.c>@@ -838,7 +852,8 @@ } \ else \ /* It's an one byte sequence. */ \- *outptr++ = *((const uint32_t *) inptr)++; \+ *outptr++ = *((const uint32_t *) inptr); \+ inptr += sizeof (uint32_t); \ } #define LOOP_NEED_FLAGS #include <iconv/loop.c>@@ -1032,7 +1047,8 @@ } \ \ /* Now adjust the pointers and store the result. */ \- *((uint32_t *) outptr)++ = ch; \+ *((uint32_t *) outptr) = ch; \+ outptr += sizeof (uint32_t); \ } #define LOOP_NEED_FLAGS @@ -1153,7 +1169,8 @@ STANDARD_FROM_LOOP_ERR_HANDLER (2); \ } \ \- *((uint32_t *) outptr)++ = u1; \+ *((uint32_t *) outptr) = u1; \+ outptr += sizeof (uint32_t); \ inptr += 2; \ } #define LOOP_NEED_FLAGS@@ -1201,7 +1218,8 @@ } \ else \ { \- *((uint16_t *) outptr)++ = val; \+ *((uint16_t *) outptr) = val; \+ outptr += sizeof (uint16_t); \ inptr += 4; \ } \ }@@ -1242,7 +1260,8 @@ continue; \ } \ \- *((uint32_t *) outptr)++ = u1; \+ *((uint32_t *) outptr) = u1; \+ outptr += sizeof (uint32_t); \ inptr += 2; \ } #define LOOP_NEED_FLAGS@@ -1291,7 +1310,8 @@ } \ else \ { \- *((uint16_t *) outptr)++ = bswap_16 (val); \+ *((uint16_t *) outptr) = bswap_16 (val); \+ outptr += sizeof (uint16_t); \ inptr += 4; \ } \ }
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -