This is the mail archive of the
gcc-bugs@gcc.gnu.org
mailing list for the GCC project.
[Bug preprocessor/29831] New: changed include order when symlinking prefix or moving binaries
- From: "michael dot haubenwallner at salomon dot at" <gcc-bugzilla at gcc dot gnu dot org>
- To: gcc-bugs at gcc dot gnu dot org
- Date: 14 Nov 2006 14:05:36 -0000
- Subject: [Bug preprocessor/29831] New: changed include order when symlinking prefix or moving binaries
- Reply-to: gcc-bugzilla at gcc dot gnu dot org
Have built gcc with "--prefix=/usr/local/gcc-4.1.1".
When "/usr/local/gcc-4.1.1" is moved and symlinked to "/stranger/gcc-4.1.1",
the include path order changes, so that fixed system headers are searched
before local headers.
In non-symlink case, where the searched include path is correct, I can see this
output (with focus on the include path):
$ /usr/local/gcc-4.1.1/bin/gcc -c -v xx.c
Using built-in specs.
Target: i686-pc-linux-gnu
Configured with: /ftp/pub/source/gcc/gcc-4.1.1.orig/configure
--prefix=/usr/local/gcc-4.1.1 --enable-languages=c
Thread model: posix
gcc version 4.1.1
/usr/local/gcc-4.1.1/libexec/gcc/i686-pc-linux-gnu/4.1.1/cc1 -quiet -v xx.c
-quiet -dumpbase xx.c -mtune=pentiumpro -auxbase xx -version -o /tmp/ccL8OzjB.s
ignoring nonexistent directory
"/usr/local/gcc-4.1.1/lib/gcc/i686-pc-linux-gnu/4.1.1/../../../../i686-pc-linux-gnu/include"
#include "..." search starts here:
#include <...> search starts here:
/usr/local/include
/usr/local/gcc-4.1.1/include
/usr/local/gcc-4.1.1/lib/gcc/i686-pc-linux-gnu/4.1.1/include
/usr/include
End of search list.
GNU C version 4.1.1 (i686-pc-linux-gnu)
compiled by GNU C version 4.1.1 (Gentoo 4.1.1).
GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
Compiler executable checksum: 36febb42c74478a1ecbe6b4467b0f6b8
as -V -Qy -o xx.o /tmp/ccL8OzjB.s
GNU assembler version 2.16.1 (i686-pc-linux-gnu) using BFD version 2.16.1
When I move and symlink /usr/local/gcc-4.1.1 to /stranger/gcc-4.1.1, the
include order changes:
$ mkdir /stranger
$ mv /usr/local/gcc-4.1.1 /stranger
$ ln -s /stranger/gcc-4.1.1 /usr/local
$ /usr/local/gcc-4.1.1/bin/gcc -c -v xx.c
Using built-in specs.
Target: i686-pc-linux-gnu
Configured with: /ftp/pub/source/gcc/gcc-4.1.1.orig/configure
--prefix=/usr/local/gcc-4.1.1 --enable-languages=c
Thread model: posix
gcc version 4.1.1
/stranger/gcc-4.1.1/bin/../libexec/gcc/i686-pc-linux-gnu/4.1.1/cc1 -quiet -v
-iprefix /stranger/gcc-4.1.1/bin/../lib/gcc/i686-pc-linux-gnu/4.1.1/ xx.c
-quiet -dumpbase xx.c -mtune=pentiumpro -auxbase xx -version -o /tmp/cc0hiBMc.s
ignoring nonexistent directory
"/stranger/gcc-4.1.1/bin/../lib/gcc/i686-pc-linux-gnu/4.1.1/../../../../i686-pc-linux-gnu/include"
ignoring duplicate directory
"/usr/local/gcc-4.1.1/lib/gcc/i686-pc-linux-gnu/4.1.1/include"
ignoring nonexistent directory
"/usr/local/gcc-4.1.1/lib/gcc/i686-pc-linux-gnu/4.1.1/../../../../i686-pc-linux-gnu/include"
#include "..." search starts here:
#include <...> search starts here:
/stranger/gcc-4.1.1/bin/../lib/gcc/i686-pc-linux-gnu/4.1.1/include
/usr/local/include
/usr/local/gcc-4.1.1/include
/usr/include
End of search list.
GNU C version 4.1.1 (i686-pc-linux-gnu)
compiled by GNU C version 4.1.1 (Gentoo 4.1.1).
GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
Compiler executable checksum: 36febb42c74478a1ecbe6b4467b0f6b8
as -V -Qy -o xx.o /tmp/cc0hiBMc.s
GNU assembler version 2.16.1 (i686-pc-linux-gnu) using BFD version 2.16.1
The basic difference is that "cc1" gets called as:
"/stranger/gcc-4.1.1/bin/../libexec/gcc/i686-pc-linux-gnu/4.1.1/cc1"
with this additional argument:
"-iprefix /stranger/gcc-4.1.1/bin/../lib/gcc/i686-pc-linux-gnu/4.1.1/"
Additionally, when _moving_ to /stranger/gcc-4.1.1,
"/stranger/gcc-4.1.1/include" does not get searched any more, while fixed
system headers continue being searched first:
$ rm /usr/local/gcc-4.1.1
$ /stranger/gcc-4.1.1/bin/gcc -c -v xx.c
Using built-in specs.
Target: i686-pc-linux-gnu
Configured with: /ftp/pub/source/gcc/gcc-4.1.1.orig/configure
--prefix=/usr/local/gcc-4.1.1 --enable-languages=c
Thread model: posix
gcc version 4.1.1
/stranger/gcc-4.1.1/bin/../libexec/gcc/i686-pc-linux-gnu/4.1.1/cc1 -quiet -v
-iprefix /stranger/gcc-4.1.1/bin/../lib/gcc/i686-pc-linux-gnu/4.1.1/ xx.c
-quiet -dumpbase xx.c -mtune=pentiumpro -auxbase xx -version -o /tmp/ccIr1Gz5.s
ignoring nonexistent directory
"/stranger/gcc-4.1.1/bin/../lib/gcc/i686-pc-linux-gnu/4.1.1/../../../../i686-pc-linux-gnu/include"
ignoring nonexistent directory "/usr/local/gcc-4.1.1/include"
ignoring nonexistent directory
"/usr/local/gcc-4.1.1/lib/gcc/i686-pc-linux-gnu/4.1.1/include"
ignoring nonexistent directory "/usr/local/gcc-4.1.1/i686-pc-linux-gnu/include"
#include "..." search starts here:
#include <...> search starts here:
/stranger/gcc-4.1.1/bin/../lib/gcc/i686-pc-linux-gnu/4.1.1/include
/usr/local/include
/usr/include
End of search list.
GNU C version 4.1.1 (i686-pc-linux-gnu)
compiled by GNU C version 4.1.1 (Gentoo 4.1.1).
GGC heuristics: --param ggc-min-expand=100 --param ggc-min-heapsize=131072
Compiler executable checksum: 36febb42c74478a1ecbe6b4467b0f6b8
as -V -Qy -o xx.o /tmp/ccIr1Gz5.s
GNU assembler version 2.16.1 (i686-pc-linux-gnu) using BFD version 2.16.1
This is not only on linux, but on most (all?) unices too.
--
Summary: changed include order when symlinking prefix or moving
binaries
Product: gcc
Version: 4.1.1
Status: UNCONFIRMED
Severity: normal
Priority: P3
Component: preprocessor
AssignedTo: unassigned at gcc dot gnu dot org
ReportedBy: michael dot haubenwallner at salomon dot at
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=29831