Hi all,<div><br></div><div>to make the tooling library more widely applicable, we'd like to make the CompilationDatabase architecture extensible, i.e. provide the option of implementing custom adapters to other kinds of compilation databases (other than the currently available JSONCompilationDatabase).</div>
<div><br></div><div>In r160061, I provided a hack that enables this, but we definitely want something nicer.</div><div><br></div><div>In the attached patch, I am using LLVM's plugin registry to enable registering new compilation databases. To provide a new CompilationDatabase, you'd need to subclass CompilationDatabasePlugin and CompilationDatabase and register the former with CompilationDatabasePluginRegistry::Add (as shown for JSONCompilationDatabase). This is not a finished patch for review, I'd just like to get feedback on the approach. What do you think?</div>
<div><br>Also, several points that need to be addressed:</div><div>- Error handling: In CompilationDatabase::loadFromDirectory, I currently simply try each plugin until I find a compilation database. Any ideas, what I should do with the error messages, especially if I do not find any compilation database. Should I concatenate them, potentially with the plugin-name as a prefix?</div>
<div>- Should I move the JSONCompilationDatabase to a separate set of files as it is now loosely coupled?</div><div><br></div><div>Cheers,<br>Daniel</div>