[cfe-dev] [cfe-commits] Design proposal: Add custom compilation database formats as plugins

Arnaud de Grandmaison arnaud.allarddegrandmaison at parrot.com
Thu Jul 19 02:54:51 PDT 2012


Or maybe:
 - add a private field 'hook' in CompilationDatabase (a function pointer
to the user callback),
 - initialize it by default to NULL
 - add a setter to CompilationDatabase for this hook field
 - and use the hook if non null in findCompilationDatabaseFromDirectory

The burden of linking in the other required libraries is left to the
user of the hook --- which seems good to me : we can not generally
decide for the user which libraries should be linked in.

This can probably be extended by changing the hook to a vector (of
hooks). This would allow registering several user backends to a specific
CompilationDatabase instance, and have it try to use them in turn, until
one succeed.

Cheers,
--
Arnaud de Grandmaison

On 07/19/2012 11:32 AM, Daniel Jasper wrote:
> While I also like the plugin concept much better, I am still unsure
> about the fundamental problem of getting other libraries linked in.
> The problem is that the linker will simply throw away any object file
> that has no references to it. After some discussions on IRC, I see two
> options:
>
> 1. Conditionally compile in a custom registration method, i.e.:
> in CompilationDatabase.cpp:
>   void someInit() {
>     #ifdef USE_CUSTOM_COMPILATION_DATABASES
>     RegisterCompilationDatabases();
>     #endif
>   }
> And then implement RegisterCompilationDatabases() together with the
> custom compilation database.
> Pros: Very easy to understand and to use right.
> Cons: It would be hard to link together multiple such implementations.
>
> 2. Conditionally compile in custom anchors, i.e;.:
> in CompilationDatabase.cpp:
>   #ifdef COMPILATION_DATABASE_ANCHORS
>   COMPILATION_DATABASE_ANCHORS;
>   #endif
> And then e..g. "-DCOMPILATION_DATABASE_ANCHORS='extern volatile int
> MyAnchorSource; static int MyAnchorDest = MyAnchorSource;'"
> Pros: Multiple custom compilation databases can be added. Nice clean
> separation (conditional code can be somewhere on the bottom of
> "CompilationDatabase.cpp".
> Cons: Seems a bit tangled and easy to get the -D part wrong.
>
> I will try to get #2 to work (possibly simplifying it a bit with more
> macros :-/). Does anyone see a better solution?
>
>
> On Thu, Jul 19, 2012 at 10:42 AM, Manuel Klimek <klimek at google.com
> <mailto:klimek at google.com>> wrote:
>
>     On Thu, Jul 19, 2012 at 12:34 AM, Sean Silva <silvas at purdue.edu
>     <mailto:silvas at purdue.edu>> wrote:
>     >> 3) It is *incredibly* easy to write a minimal JSON writer that
>     only supports the features we need.
>     >
>     > Ah, ok, I seem to have overestimated how difficult/annoying this
>     would
>     > be to write.
>
>     Writing JSON is simple: it's a well-defined format with very little
>     chance that it ever changes. No need to have a "writer", just print it
>     out:
>
>     stream << "[\n";
>     for (tu : tus) {
>       stream << "  {\n      " << "\"directory\": " <<
>     shellEscape(tu.directory())
>       ...
>     }
>     stream << "]\n";
>
>     The hard part is the shell escaping. CMake already had that built in.
>
>     >> We can easily place a copy of the code into LLVM or re-license
>     it however it helps.
>     >
>     > This might be good, to help keep things consistent. Are you thinking
>     > something with a role like ninja's ninja_syntax.py?
>     >
>     > --Sean Silva
>     >
>     > On Wed, Jul 18, 2012 at 3:15 PM, Chandler Carruth
>     <chandlerc at google.com <mailto:chandlerc at google.com>> wrote:
>     >> On Wed, Jul 18, 2012 at 3:11 PM, Sean Silva <silvas at purdue.edu
>     <mailto:silvas at purdue.edu>> wrote:
>     >>>
>     >>> > For ninja in particular, I have long thought that the
>     correct approach
>     >>> > is to write something which can convert 'ninja -t commands'
>     into the JSON
>     >>> > format, or to build a tool for writing the JSON database
>     directly into
>     >>> > ninja.
>     >>>
>     >>> This was my line of thought as well.
>     >>>
>     >>> Since the C++ stdlib unfortunately doesn't have JSON support,
>     what do
>     >>> you think about a simpler, more plaintext-y compilation database
>     >>> (PlaintextCompilationDatabase?); it seems like that might be a win
>     >>> since it is simpler to output. For example, the format would
>     just be
>     >>>
>     >>> /path/to/dir/
>     >>> clang++ foo.cpp
>     >>> foo.cpp
>     >>> <empty line>
>     >>>
>     >>> Just a mirror of the JSON one, but with a format easier to
>     output (god
>     >>> forbid there's a newline in one of the command lines or
>     filenames). On
>     >>> the other hand, throwing together a simple "good-enough" JSON
>     writer
>     >>> isn't *too* difficult; nonetheless, for tools written in
>     C/C++, this
>     >>> could lower the bar to entry. Do you know what CMake currently
>     does?
>     >>> Does it have its own mini JSON writer?
>     >>
>     >>
>     >> We didn't go with the plaintext route for three important reasons:
>     >>
>     >> 1) Filenames do have whitespace in them. The format should be
>     robust against
>     >> that.
>     >> 2) Many other tools and languages should have a minimal barrier
>     to read
>     >> them. An existing format eases this.
>     >> 3) It is *incredibly* easy to write a minimal JSON writer that
>     only supports
>     >> the features we need.
>     >>
>     >> Manuel contributed the CMake support for the JSON database, and
>     it includes
>     >> just such a trivial JSON writer. =] We can easily place a copy
>     of the code
>     >> into LLVM or re-license it however it helps.
>     >>
>     >> That said, the latest version of CMake already has support for
>     JSON + Ninja
>     >> -- we didn't contribute it, so I don't know what strategy they
>     followed, but
>     >> you should look at that and talk to the ninja and CMake
>     developers before
>     >> going too far here.
>     > _______________________________________________
>     > cfe-commits mailing list
>     > cfe-commits at cs.uiuc.edu <mailto:cfe-commits at cs.uiuc.edu>
>     > http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
>     _______________________________________________
>     cfe-commits mailing list
>     cfe-commits at cs.uiuc.edu <mailto:cfe-commits at cs.uiuc.edu>
>     http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
>
>


-- 
Arnaud de Grandmaison
Senior CPU engineer
Business Unit Digital Tuner

Parrot S.A.
174, quai de Jemmapes
75010 Paris - France
Phone: +33 1 48 03 84 59

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-dev/attachments/20120719/844eaa4a/attachment.html>


More information about the cfe-dev mailing list