aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-03-18 20:26:19 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-03-18 20:26:19 +0000
commit0edefebc10fbc627d55d53936fc66178d1c08da1 (patch)
tree3e5b6b3f55b1ae6f343ceeec8927c6f660a69167
parent734932c7dc77a16b15d466588e10d76bcd6d13c7 (diff)
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
-rw-r--r--include/clang/Driver/ToolChain.h19
-rw-r--r--lib/Driver/Driver.cpp27
2 files changed, 44 insertions, 2 deletions
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 <string>
@@ -23,9 +24,21 @@ namespace driver {
/// ToolChain - Access to tools for a single platform.
class ToolChain {
+public:
+ typedef llvm::SmallVector<std::string, 4> 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);
}