patches/gcc/4.2.2/200-index_macro.patch
author Zoltan Devai <zdevai@gmail.com>
Wed Oct 28 12:03:38 2009 +0100 (2009-10-28)
changeset 1602 1ba79f2126df
parent 431 8bde4c6ea47a
permissions -rw-r--r--
libc/uClibc: fix building on system with recent glibc

While trying to build a toolchain with ct-ng 1.5.0,
arm-unknown-linux-uclibcgnueabi target,
I get the following error:

[INFO ] Installing C library headers
[EXTRA] Copying sources to build dir
[EXTRA] Applying configuration
[EXTRA] Building headers
[EXTRA] Installing headers
[ERROR] extra/scripts/unifdef.c:209: error: conflicting types for 'getline'
[ERROR] make[2]: *** [extra/scripts/unifdef] Error 1
[ERROR] Build failed in step 'Installing C library headers'

The following patch solves the problem.
(It's a backport of this uClibc commit:
http://git.uclibc.org/uClibc/commit/?id=49e81cada73616864b9b31df0aeb6961c30f5a6e
)

[--SNIP from another mail--]
AFAIK this is a problem since glibc 2.10.
yann@313
     1
diff -durN gcc-4.2.1.orig/libstdc++-v3/include/ext/rope gcc-4.2.1/libstdc++-v3/include/ext/rope
yann@313
     2
--- gcc-4.2.1.orig/libstdc++-v3/include/ext/rope	2006-10-17 13:56:21.000000000 +0200
yann@313
     3
+++ gcc-4.2.1/libstdc++-v3/include/ext/rope	2007-08-03 20:34:23.000000000 +0200
yann@313
     4
@@ -58,6 +58,9 @@
yann@313
     5
 #include <bits/allocator.h>
yann@313
     6
 #include <ext/hash_fun.h>
yann@313
     7
 
yann@313
     8
+/* cope w/ index defined as macro, SuSv3 proposal */
yann@313
     9
+#undef index
yann@313
    10
+
yann@313
    11
 # ifdef __GC
yann@313
    12
 #   define __GC_CONST const
yann@313
    13
 # else
yann@313
    14
diff -durN gcc-4.2.1.orig/libstdc++-v3/include/ext/ropeimpl.h gcc-4.2.1/libstdc++-v3/include/ext/ropeimpl.h
yann@313
    15
--- gcc-4.2.1.orig/libstdc++-v3/include/ext/ropeimpl.h	2006-10-17 13:56:21.000000000 +0200
yann@313
    16
+++ gcc-4.2.1/libstdc++-v3/include/ext/ropeimpl.h	2007-08-03 20:34:23.000000000 +0200
yann@313
    17
@@ -54,6 +54,9 @@
yann@313
    18
 #include <ext/memory> // For uninitialized_copy_n
yann@313
    19
 #include <ext/numeric> // For power
yann@313
    20
 
yann@313
    21
+/* cope w/ index defined as macro, SuSv3 proposal */
yann@313
    22
+#undef index
yann@313
    23
+
yann@313
    24
 _GLIBCXX_BEGIN_NAMESPACE(__gnu_cxx)
yann@313
    25
 
yann@313
    26
   using std::size_t;