The tooling APIs have a lot of extension points for customization:
e.g. Executor, FrontendActionFactory, FrontendAction, ASTConsumer.
This customization is often not needed, and makes the APIs unergonomic.
This change introduces some shortcuts to bypass them, while attempting
not to add more concepts/complexity to the APIs.
main() entrypoint
Today tools are expected to create an executor (which can fail), then
use it to execute their action (which can report errors).
Errors are reported with llvm::Error, which is not what main() needs
(exit codes) but must be handled.
This patch adds executeFromCommandLineArgs(), which wraps this in a
single function which returns an exit code.
(It also tweaks ToolExecutor's execute() API to avoid replicating several
overloads here).
Skipping over FrontendAction to ASTConsumer
Tools that override ASTConsumer must provide two factory indirections:
FrontendActionFactory -> FrontendAction -> ASTConsumer.
These are sometimes meaningful, but often not.
newFrontendActionFactory<ActionT>() already lets you skip the first.
Now newFrontendActionFactory<ConsumerT>() lets you skip the second, too.
Implementing simple actions as lambdas
A large fraction of tools simply want to consume the final AST and do
something with it. Even ASTConsumer is too heavyweight an abstraction.
This patch adds consumeASTs(), which is a FrontendActionFactory that
calls a function once for each parsed AST:
Exec->execute(consumeASTs([&](ASTContext &Ctx) { ... process AST ... }));
Bonus: through lambda captures, state can be easily shared across TUs.
(This otherwise tends to require plumbing, or use of global variables)