[cfe-dev] [PATCH] header search

Chris Lattner clattner at apple.com
Tue May 4 22:08:24 PDT 2010


Seems ok to me, please apply, thanks!

-Chris

On May 4, 2010, at 4:29 AM, mike-m wrote:

> Find attached patch which fixes <cstddef> issue on some linux distros and adds
> yet more C++ search dirs for various linux distros. Details follow.
> 
> 1)
>  Updated C++ include header search paths for various Debian/Ubuntu and Fedora
>  linux distros. The main changes are static ordering of directories to check
>  for GNU c++ includes:
> 
>        - newer versions of libstdc++ are checked for first
>        - distros listing is reverse chronological order
>        - more clear that N-distros need the same dir check
> 
>  Tracking for the following new distros has been added; unless otherwise noted,
>  all adds have been validated to not break things by building clang selfhost:
> 
>        - Ubuntu 10.04 LTS 64-bit, 32-bit
>        - Ubuntu 9.10 32-bit
>        - Ubuntu 9.04 64-bit
>        - Ubuntu 8.10 64-bit
>        - Ubuntu 8.04 LTS 64-bit, 32-bit
> 
>        - Debian 6.0 64-bit, 32-bit
>        - Debian 5.0 64-bit, 32-bit
> 
>        - Fedora 9 64-bit (untested but paths checked with distro rpms)
>        - Fedora 8 64-bit (untested but paths checked with distro rpms)
> 
> 2)
>  Moved clang-builtin include dir position to immediately precede /usr/include,
>  matching gcc compiler. Fixes #include_next shenanigans that lead to failures
>  when clang++ is used to compile source with <cstddef>. libstdc++ versions
>  4.3.0, 4.3.1 and 4.3.2 are at issue, which ship bundled on Debian 5.04,
>  Ubuntu 8.10 and Fedora 10. Example error from Ubuntu 8.10:
> 
>> /usr/include/c++/4.3/cstddef:47:15: fatal error: 'stddef.h' file not found
>> #include_next <stddef.h>
>>              ^
>> 1 error generated.
> 
> 
> ================================================================================
> Comparison of <...> search dirs on ubuntu 8.10:
> [note: '*' marks repositioned include dir]
> 
> unpatched clang++:
>  /home/mike/work/llvm/ubuntu/out.debug/Debug/lib/clang/2.0/include
>  /usr/include/c++/4.3
>  /usr/include/c++/4.3/x86_64-linux-gnu
>  /usr/include/c++/4.3/backward
>  /usr/local/include
>  /usr/include
> 
> patched clang++:
>  /usr/include/c++/4.3
>  /usr/include/c++/4.3/x86_64-linux-gnu
>  /usr/include/c++/4.3/backward
>  /usr/local/include
> * /home/mike/work/llvm/ubuntu/out.debug/Debug/lib/clang/2.0/include
>  /usr/include
> 
> g++:
>  /usr/include/c++/4.3
>  /usr/include/c++/4.3/x86_64-linux-gnu
>  /usr/include/c++/4.3/backward
>  /usr/local/include
>  /usr/lib/gcc/x86_64-linux-gnu/4.3.2/include
>  /usr/lib/gcc/x86_64-linux-gnu/4.3.2/include-fixed
>  /usr/include
> 
> ================================================================================
> Comparison of <...> search dirs on darwin 10.3.0:
> [note: '*' marks repositioned include dir]
> 
> unpatched clang++:
>  /tank1/work/llvm/ubuntu/out.debug/Debug/lib/clang/2.0/include
>  /usr/include/c++/4.2.1
>  /usr/include/c++/4.2.1/i686-apple-darwin10/x86_64
>  /usr/include/c++/4.2.1/backward
>  /usr/include/c++/4.0.0
>  /usr/include/c++/4.0.0/i686-apple-darwin8
>  /usr/include/c++/4.0.0/backward
>  /usr/local/include
>  /usr/include
>  /System/Library/Frameworks (framework directory)
>  /Library/Frameworks (framework directory)
> 
> patched clang++:
>  /usr/include/c++/4.2.1
>  /usr/include/c++/4.2.1/i686-apple-darwin10/x86_64
>  /usr/include/c++/4.2.1/backward
>  /usr/include/c++/4.0.0
>  /usr/include/c++/4.0.0/i686-apple-darwin8
>  /usr/include/c++/4.0.0/backward
>  /usr/local/include
> * /tank1/work/llvm/ubuntu/out.debug/Debug/lib/clang/2.0/include
>  /usr/include
>  /System/Library/Frameworks (framework directory)
>  /Library/Frameworks (framework directory)
> 
> g++:
>  /usr/include/c++/4.2.1
>  /usr/include/c++/4.2.1/i686-apple-darwin10/x86_64
>  /usr/include/c++/4.2.1/backward
>  /usr/local/include
>  /usr/lib/gcc/i686-apple-darwin10/4.2.1/include
>  /usr/include
>  /System/Library/Frameworks (framework directory)
>  /Library/Frameworks (framework directory)
> 
> 
> --mike-m
> <hsearch0.patch>_______________________________________________
> cfe-dev mailing list
> cfe-dev at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev





More information about the cfe-dev mailing list