<div dir="ltr">Hi Pierrick,<div><br></div><div>You also have the option of writing your own CompilationDatabase, and using it in place of the builtin options. You get the benefits of not having to modify any internal clang code, complete control over which files are chosen for compilation/analysis (assuming you're using a libtooling), and you can add whatever extra information you need to it as long as it conforms to the clang::tooling::CompilationDatabase API.</div><div><br></div><div>- Neil<br><br>(API at: <a href="http://clang.llvm.org/doxygen/classclang_1_1tooling_1_1CompilationDatabase.html">http://clang.llvm.org/doxygen/classclang_1_1tooling_1_1CompilationDatabase.html</a>)</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Mar 2, 2015 at 7:41 PM, Pierrick Bouvier <span dir="ltr"><<a href="mailto:bouvier.pierrick@yahoo.fr" target="_blank">bouvier.pierrick@yahoo.fr</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Thank you for your quick answer.<br>
<br>
I have a few precisions to say (inline).<span class=""><br>
<br>
On 03/02/2015 04:06 AM, Manuel Klimek wrote:<br>
> Hi Pierrick,<br>
><br>
> On Mon, Mar 2, 2015 at 1:58 AM Pierrick Bouvier<br></span><span class="">
> <<a href="mailto:bouvier.pierrick@yahoo.fr" target="_blank">bouvier.pierrick@yahoo.fr</a> <mailto:<a href="mailto:bouvier.pierrick@yahoo.fr" target="_blank">bouvier.pierrick@<u></u>yahoo.fr</a>>> wrote:<br>
><br>
>     Hello Clang community,<br>
><br>
>     I am currently working on a tool able to generate a compilation<br>
>     database by catching all exec done, something similar to<br></span>
>     <a href="https://github.com/rizsotto/__Bear" target="_blank">https://github.com/rizsotto/__<u></u>Bear</a><span class=""><br>
>     <<a href="https://github.com/rizsotto/Bear" target="_blank">https://github.com/rizsotto/<u></u>Bear</a>> but with the end goal of<br>
>     providing more than just this feature to user (I want to use<br>
>     libclang for providing autocompletion, refactoring, stats and<br>
>     other stuff related to user's codebase, independently of any<br>
>     editor or IDE).<br>
><br>
>     I really like the idea of compilation database, and I have a few<br>
>     questions that were not answered by the manual page:<br></span>
>     <a href="http://clang.llvm.org/docs/__JSONCompilationDatabase.html" target="_blank">http://clang.llvm.org/docs/__<u></u>JSONCompilationDatabase.html</a><span class=""><br>
>     <<a href="http://clang.llvm.org/docs/JSONCompilationDatabase.html" target="_blank">http://clang.llvm.org/docs/<u></u>JSONCompilationDatabase.html</a>><br>
><br>
>     Those are my questions: 1) Is that possible to provide a cwd<br>
>     relative to compilation database file itself? What I aim is<br>
>     possibility for user to move his source folder from place without<br>
>     having to use sed or regenerate the compilation database. For<br>
>     example, if compilation database is<br></span>
>     "/my/project/compilation___<u></u>database.json" and my source is in<span class=""><br>
>     "/my/project/src/main.cpp" I want to offer cwd as "src/" and<br>
>     source file as "main.cpp". Is this correct and more than all, is<br>
>     that supported by libclang?<br>
><br>
><br>
> I don't think that's currently supported, but patches are welcome :)<br>
<br></span>
When I will be working on this part of my project, I'll work around<br>
this.<span class=""><br>
<br>
><br>
>     2) Is that possible to extend compilation_database without<br>
>     breaking libclang? I would like to add a list of fields named<br>
>     "dependency" to precise which files the source depends on. This<br>
>     can be used for creating statistics or simply to know if file (or<br>
>     any dep) has changed without having to preprocess, thus enabling<br>
>     speedlight on big projects.<br>
>     For example:<br>
>         - cwd "src/"<br>
>         - file "main.cpp"<br>
>         - command ...<br>
>         - dependency "/usr/include/stdio.h"<br>
>         - dependency "/usr/include/stdlib.h"<br>
><br>
>     If those feature are not possible with current libclang, and if<br>
>     you agree, I can work on a patch to make this possible.<br>
><br>
><br>
> Two part answer: a) regarding local extensions to the command line<br>
> database: I'd suggest not to do them; the probability we hit<br>
> incompatibilities seem high enough, and it seems easy to just put<br>
> another json file next to the compilation database having all your<br>
> extra data<br>
<br></span>
I don't really see the risk here. Well, I don't want libclang to<br>
understand the extra information I put in the json file, just ignore<br>
what it does not know. By doing this, you allow people who want to use<br>
this format to put additional information in the same file. Using two<br>
different json seems complicated to me, the aim is to just get one file<br>
with the whole content. Well, I can still hack the file and put my<br>
extension under a comment, and parse it anyway. I'll see what I do when<br>
I come at libclang interaction. I suppose it will be possible to discuss<br>
around a patch. And I plan to use this format for other languages than<br>
C/C++, thus extensions could be welcome to provide additional<br>
information than command line.<span class=""><br>
<br>
> b) regrading dependencies: I'm not sure the compilation database is<br>
> the right venue for that; that's why we have build systems; if you<br>
> want dependencies, you'll immediately need information on how to build<br>
> those dependencies, and suddenly you have a new build system<br>
><br>
<br></span>
I get your point but I don't want to recreate another build system. I<br>
just express dependencies of one compilation unit. I do not even speak<br>
about linked executable or so, just the object files. I still think this<br>
information could be used by tools like ccache or my project, to know if<br>
file needs recompilation without preprocessing (which is faster than<br>
compilation, but not fast as stating XX files, could be a big difference<br>
for huge projects (like Linux)).<br>
<br>
> Cheers,<br>
> /Manuel<br>
><br>
<br>
Pierrick<span class=""><br>
<br>
><br>
>     Thank you, and thank you again for providing clang/llvm to people.<br>
>     Pierrick<br></span>
>     ______________________________<u></u>___________________<br>
>     cfe-dev mailing list<br>
>     <a href="mailto:cfe-dev@cs.uiuc.edu" target="_blank">cfe-dev@cs.uiuc.edu</a> <mailto:<a href="mailto:cfe-dev@cs.uiuc.edu" target="_blank">cfe-dev@cs.uiuc.edu</a>><br>
>     <a href="http://lists.cs.uiuc.edu/__mailman/listinfo/cfe-dev" target="_blank">http://lists.cs.uiuc.edu/__<u></u>mailman/listinfo/cfe-dev</a><br>
>     <<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev" target="_blank">http://lists.cs.uiuc.edu/<u></u>mailman/listinfo/cfe-dev</a>><div class="HOEnZb"><div class="h5"><br>
><br>
______________________________<u></u>_________________<br>
cfe-dev mailing list<br>
<a href="mailto:cfe-dev@cs.uiuc.edu" target="_blank">cfe-dev@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/cfe-dev" target="_blank">http://lists.cs.uiuc.edu/<u></u>mailman/listinfo/cfe-dev</a><br>
</div></div></blockquote></div><br></div>