| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
- // Exceptions. See /LICENSE for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- #ifndef CARBON_TOOLCHAIN_DRIVER_DRIVER_SUBCOMMAND_H_
- #define CARBON_TOOLCHAIN_DRIVER_DRIVER_SUBCOMMAND_H_
- #include "common/command_line.h"
- #include "common/ostream.h"
- #include "llvm/Support/VirtualFileSystem.h"
- #include "toolchain/base/install_paths.h"
- #include "toolchain/driver/driver_env.h"
- namespace Carbon {
- // The result of a driver run.
- struct DriverResult {
- // Overall success result.
- bool success;
- // Per-file success results. May be empty if files aren't individually
- // processed.
- llvm::SmallVector<std::pair<std::string, bool>> per_file_success = {};
- };
- // A subcommand for the driver.
- class DriverSubcommand {
- public:
- explicit DriverSubcommand(CommandLine::CommandInfo info) : info_(info) {}
- // Adds the subcommand to the main command, assigning `selected_command` when
- // the subcommand is in use.
- auto AddTo(CommandLine::CommandBuilder& b,
- DriverSubcommand** selected_subcommand) -> void {
- b.AddSubcommand(
- info_, [this, selected_subcommand](CommandLine::CommandBuilder& sub_b) {
- BuildOptionsAndSetAction(sub_b, selected_subcommand);
- });
- }
- // Adds command line options.
- virtual auto BuildOptions(CommandLine::CommandBuilder& b) -> void = 0;
- // Adds command line options and registers the `Run` method to be called.
- //
- // For more complex subcommands that need to control the action this method
- // can be overridden and bypass the simple API above.
- //
- // TODO: This isn't the most elegant way to manage this. There is probably a
- // better factoring / organization of the driver subcommand infrastructure
- // that bakes in the needed flexibility here, but that was deferred for a
- // future refactoring.
- virtual auto BuildOptionsAndSetAction(CommandLine::CommandBuilder& b,
- DriverSubcommand** selected_subcommand)
- -> void {
- BuildOptions(b);
- b.Do([this, selected_subcommand] { *selected_subcommand = this; });
- }
- // Runs the command.
- virtual auto Run(DriverEnv& driver_env) -> DriverResult = 0;
- protected:
- // Tests if fuzzing and if so diagnose and returns true.
- //
- // This should be used in subcommands to diagnose and exit early rather than
- // entering them during fuzzing when they use external libraries that we can't
- // keep fuzz-clean.
- auto TestAndDiagnoseIfFuzzingExternalLibraries(DriverEnv& driver_env,
- llvm::StringRef name) -> bool;
- private:
- // Subcommand information.
- CommandLine::CommandInfo info_;
- };
- } // namespace Carbon
- #endif // CARBON_TOOLCHAIN_DRIVER_DRIVER_SUBCOMMAND_H_
|