[cfe-dev] Default Headers with CompilerInstance

Manuel Klimek klimek at google.com
Thu Nov 8 11:21:13 PST 2012


On Thu, Nov 8, 2012 at 10:42 AM, Mehdi AMINI <mehdi.amini at silkan.com> wrote:

> Hi,
>
>
>
> Le 08/11/2012 10:22, Manuel Klimek a écrit :
>
>  See here for what's needed to build a tool on top of clang:
>> http://llvm.org/viewvc/llvm-**project/cfe/trunk/lib/Tooling/**
>> Tooling.cpp?revision=166508&**view=markup<http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Tooling/Tooling.cpp?revision=166508&view=markup>
>> (the solution is to use the Driver, which handles finding of builtin and
>> system includes)
>>
>> Alternatively, you can just use the tooling library :) (see
>> http://clang.llvm.org/docs/**LibTooling.html<http://clang.llvm.org/docs/LibTooling.html>
>> )
>>
>
> None of these solutions relieves you from building your binary at the same
> place at Clang is installed, or duplicate the Clang headers along your tool
> installation so that they are in PATH_TO_BIN/../lib/...
> Or did I miss something at some point?


What you can do is slurp up the builtin headers as char*'s in your sources,
compile them into your binary, and use virtual files at runtime with
LibTooling (we're actually doing that for our internal mapreduce framework).

The problem with this approach, and the main reason Chandler has opposed
doing that for quite some time, is that when you see errors that reference
the builtin headers you'll not be able to open those files from your editor
(Chandler will jump in if I misrepresented his views :)

Cheers,
/Manuel


>
>
>      I tried to add the system headers manually using
>>     "HeaderSearchOptions.Add" but (1) this is not portable and (2)
>>     anyway I can't make that work either.
>>
>>     Could you please explain me more in details how Clang does to find
>>     the default system headers ?
>>     I attach the source file of my simple prototype.
>>
>
>
> From my (very shallow) experience, unless you get very deep with the
> initialization it end up by looking the headers from the place the binary
> is installed.
>
> Best,
>
> Mehdi
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-dev/attachments/20121108/db4923b1/attachment.html>


More information about the cfe-dev mailing list