diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2013-03-19 00:36:57 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2013-03-19 00:36:57 +0000 |
commit | d15a8918fb9c0d66f2ff081172fd49811a907952 (patch) | |
tree | 1be9bb39d06743bd5219277f811018615bdf9125 /clang/lib/Driver/ToolChains.cpp | |
parent | 7029ce1a0ce6bb88bebeb182376641d2c4a70bb0 (diff) | |
download | bcm5719-llvm-d15a8918fb9c0d66f2ff081172fd49811a907952.tar.gz bcm5719-llvm-d15a8918fb9c0d66f2ff081172fd49811a907952.zip |
Finish refactoring the tool selection logic.
The general pattern now is that Foobar::constructTool only creates tools
defined in the tools::foobar namespace and then delegates to the parent.
The remaining duplicated code is now in the tools themselves.
llvm-svn: 177368
Diffstat (limited to 'clang/lib/Driver/ToolChains.cpp')
-rw-r--r-- | clang/lib/Driver/ToolChains.cpp | 40 |
1 files changed, 4 insertions, 36 deletions
diff --git a/clang/lib/Driver/ToolChains.cpp b/clang/lib/Driver/ToolChains.cpp index 802d0ce244c..0e29ba026d5 100644 --- a/clang/lib/Driver/ToolChains.cpp +++ b/clang/lib/Driver/ToolChains.cpp @@ -174,15 +174,6 @@ void Generic_ELF::anchor() {} Tool *Darwin::constructTool(Action::ActionClass AC) const { switch (AC) { - case Action::InputClass: - case Action::BindArchClass: - llvm_unreachable("Invalid tool kind."); - case Action::PreprocessJobClass: - case Action::AnalyzeJobClass: - case Action::MigrateJobClass: - case Action::PrecompileJobClass: - case Action::CompileJobClass: - return new tools::Clang(*this); case Action::AssembleJobClass: return new tools::darwin::Assemble(*this); case Action::LinkJobClass: @@ -193,6 +184,8 @@ Tool *Darwin::constructTool(Action::ActionClass AC) const { return new tools::darwin::Dsymutil(*this); case Action::VerifyJobClass: return new tools::darwin::VerifyDebug(*this); + default: + return ToolChain::constructTool(AC); } } @@ -1359,31 +1352,18 @@ Generic_GCC::~Generic_GCC() { Tool *Generic_GCC::constructTool(Action::ActionClass AC) const { switch (AC) { - case Action::InputClass: - case Action::BindArchClass: - llvm_unreachable("Invalid tool kind."); case Action::PreprocessJobClass: return new tools::gcc::Preprocess(*this); case Action::PrecompileJobClass: return new tools::gcc::Precompile(*this); - case Action::AnalyzeJobClass: - case Action::MigrateJobClass: - return new tools::Clang(*this); case Action::CompileJobClass: return new tools::gcc::Compile(*this); case Action::AssembleJobClass: return new tools::gcc::Assemble(*this); case Action::LinkJobClass: return new tools::gcc::Link(*this); - - // This is a bit ungeneric, but the only platform using a driver - // driver is Darwin. - case Action::LipoJobClass: - return new tools::darwin::Lipo(*this); - case Action::DsymutilJobClass: - return new tools::darwin::Dsymutil(*this); - case Action::VerifyJobClass: - return new tools::darwin::VerifyDebug(*this); + default: + return ToolChain::constructTool(AC); } } @@ -1518,7 +1498,6 @@ Tool *Hexagon_TC::constructTool(Action::ActionClass AC) const { case Action::LinkJobClass: return new tools::hexagon::Link(*this); default: - assert(false && "Unsupported action for Hexagon target."); return Linux::constructTool(AC); } } @@ -1637,17 +1616,6 @@ bool TCEToolChain::isPICDefaultForced() const { return false; } -Tool *TCEToolChain::constructTool(Action::ActionClass AC) const { - switch (AC) { - case Action::PreprocessJobClass: - return new tools::gcc::Preprocess(*this); - case Action::AnalyzeJobClass: - return new tools::Clang(*this); - default: - llvm_unreachable("Unsupported action for TCE target."); - } -} - /// OpenBSD - OpenBSD tool chain which can call as(1) and ld(1) directly. OpenBSD::OpenBSD(const Driver &D, const llvm::Triple& Triple, const ArgList &Args) |