aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMikhail Glushenkov <foldr@codedgers.com>2010-10-28 19:33:08 +0000
committerMikhail Glushenkov <foldr@codedgers.com>2010-10-28 19:33:08 +0000
commit9f36e7389fcd3079417eb141881b5c3743b389e5 (patch)
tree92b3ad8b582b709272fe055d4c13901fbf0976e1
parent8a5ff478db80fdc0753378563b8f1c139136607a (diff)
llvmc: Make ExecuteProgram() look in the driver directory first.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@117584 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/CompilerDriver/Action.cpp9
1 files changed, 6 insertions, 3 deletions
diff --git a/lib/CompilerDriver/Action.cpp b/lib/CompilerDriver/Action.cpp
index 0be80496a3..3503bd39db 100644
--- a/lib/CompilerDriver/Action.cpp
+++ b/lib/CompilerDriver/Action.cpp
@@ -14,6 +14,7 @@
#include "llvm/CompilerDriver/Action.h"
#include "llvm/CompilerDriver/BuiltinOptions.h"
#include "llvm/CompilerDriver/Error.h"
+#include "llvm/CompilerDriver/Main.h"
#include "llvm/Support/raw_ostream.h"
#include "llvm/Support/SystemUtils.h"
@@ -28,7 +29,6 @@ using namespace llvmc;
namespace llvmc {
-extern int Main(int argc, char** argv);
extern const char* ProgramName;
}
@@ -55,10 +55,13 @@ namespace {
int ExecuteProgram (const std::string& name,
const StrVector& args) {
- sys::Path prog = sys::Program::FindProgramByName(name);
+ sys::Path prog(name);
- if (prog.isEmpty()) {
+ if (!prog.isAbsolute())
prog = FindExecutable(name, ProgramName, (void *)(intptr_t)&Main);
+
+ if (prog.isEmpty()) {
+ prog = sys::Program::FindProgramByName(name);
if (prog.isEmpty()) {
PrintError("Can't find program '" + name + "'");
return -1;