From: Daniel Dunbar Date: Wed, 18 Mar 2009 20:26:19 +0000 (+0000) Subject: Driver: Support ToolChain specific path lists to search for files and X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=0edefebc10fbc627d55d53936fc66178d1c08da1;p=clang Driver: Support ToolChain specific path lists to search for files and programs. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67229 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/Driver/ToolChain.h b/include/clang/Driver/ToolChain.h index 3a07a325bd..5c00538f88 100644 --- a/include/clang/Driver/ToolChain.h +++ b/include/clang/Driver/ToolChain.h @@ -10,6 +10,7 @@ #ifndef CLANG_DRIVER_TOOLCHAIN_H_ #define CLANG_DRIVER_TOOLCHAIN_H_ +#include "llvm/ADT/SmallVector.h" #include "llvm/System/Path.h" #include @@ -23,9 +24,21 @@ namespace driver { /// ToolChain - Access to tools for a single platform. class ToolChain { +public: + typedef llvm::SmallVector path_list; + +private: const HostInfo &Host; std::string Arch, Platform, OS; + /// The list of toolchain specific path prefixes to search for + /// files. + path_list FilePaths; + + /// The list of toolchain specific path prefixes to search for + /// programs. + path_list ProgramPaths; + protected: ToolChain(const HostInfo &Host, const char *_Arch, const char *_Platform, const char *_OS); @@ -40,6 +53,12 @@ public: const std::string &getPlatform() const { return Platform; } const std::string &getOS() const { return OS; } + path_list getFilePaths() { return FilePaths; } + const path_list getFilePaths() const { return FilePaths; } + + path_list getProgramPaths() { return ProgramPaths; } + const path_list getProgramPaths() const { return ProgramPaths; } + // Tool access. /// TranslateArgs - Create a new derived argument list for any diff --git a/lib/Driver/Driver.cpp b/lib/Driver/Driver.cpp index 9d913a1601..f3d241017e 100644 --- a/lib/Driver/Driver.cpp +++ b/lib/Driver/Driver.cpp @@ -849,13 +849,36 @@ const char *Driver::GetNamedOutputPath(Compilation &C, llvm::sys::Path Driver::GetFilePath(const char *Name, const ToolChain &TC) const { - // FIXME: Implement. + const ToolChain::path_list &List = TC.getFilePaths(); + for (ToolChain::path_list::const_iterator + it = List.begin(), ie = List.end(); it != ie; ++it) { + llvm::sys::Path P(*it); + P.appendComponent(Name); + if (P.exists()) + return P; + } + return llvm::sys::Path(Name); } llvm::sys::Path Driver::GetProgramPath(const char *Name, const ToolChain &TC) const { - // FIXME: Implement. + const ToolChain::path_list &List = TC.getProgramPaths(); + for (ToolChain::path_list::const_iterator + it = List.begin(), ie = List.end(); it != ie; ++it) { + llvm::sys::Path P(*it); + P.appendComponent(Name); + if (P.exists()) + return P; + } + + // As a last resort, always search in our directory before pulling + // from the path. + llvm::sys::Path P(Dir); + P.appendComponent(Name); + if (P.exists()) + return P; + return llvm::sys::Path(Name); }