llvmc: Make ExecuteProgram() look in the driver directory first.
authorMikhail Glushenkov <foldr@codedgers.com>
Thu, 28 Oct 2010 19:33:08 +0000 (19:33 +0000)
committerMikhail Glushenkov <foldr@codedgers.com>
Thu, 28 Oct 2010 19:33:08 +0000 (19:33 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@117584 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CompilerDriver/Action.cpp

index 0be80496a3cb7a872aa40ce3005025f20a7a63e9..3503bd39db2714a6b8b6d39be5d15f6c353681e0 100644 (file)
@@ -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;