diff options
author | Chris Lattner <sabre@nondot.org> | 2005-02-13 23:13:47 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-02-13 23:13:47 +0000 |
commit | 45495c524841aa94107d5331f5522c5c6d2024cd (patch) | |
tree | 73412b4d737095e8b5afe236db7c65352ffcfc67 /lib/Support | |
parent | 7456e3ce3874ed99807a1394011c4b0c6e2ecaa0 (diff) |
Move helper function here.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@20168 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Support')
-rw-r--r-- | lib/Support/ToolRunner.cpp | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/lib/Support/ToolRunner.cpp b/lib/Support/ToolRunner.cpp index a07046a0d0..c68bd42157 100644 --- a/lib/Support/ToolRunner.cpp +++ b/lib/Support/ToolRunner.cpp @@ -14,6 +14,7 @@ #define DEBUG_TYPE "toolrunner" #include "llvm/Support/ToolRunner.h" #include "llvm/Config/config.h" // for HAVE_LINK_R +#include "llvm/System/Program.h" #include "llvm/Support/Debug.h" #include "llvm/Support/FileUtilities.h" #include <fstream> @@ -22,6 +23,26 @@ using namespace llvm; ToolExecutionError::~ToolExecutionError() throw() { } +/// RunProgramWithTimeout - This function provides an alternate interface to the +/// sys::Program::ExecuteAndWait interface. +/// @see sys:Program::ExecuteAndWait +static int RunProgramWithTimeout(const sys::Path &ProgramPath, + const char **Args, + const sys::Path &StdInFile, + const sys::Path &StdOutFile, + const sys::Path &StdErrFile, + unsigned NumSeconds = 0) { + const sys::Path* redirects[3]; + redirects[0] = &StdInFile; + redirects[1] = &StdOutFile; + redirects[2] = &StdErrFile; + + return + sys::Program::ExecuteAndWait(ProgramPath, Args, 0, redirects, NumSeconds); +} + + + static void ProcessFailure(sys::Path ProgPath, const char** Args) { std::ostringstream OS; OS << "\nError running tool:\n "; @@ -370,6 +391,10 @@ int GCC::ExecuteProgram(const std::string &ProgramFile, sys::Path OutputBinary (ProgramFile+".gcc.exe"); OutputBinary.makeUnique(); GCCArgs.push_back(OutputBinary.c_str()); // Output to the right file... + GCCArgs.push_back("-L/home/vadve/shared/localtools/x86/lib"); + GCCArgs.push_back("-lf2c"); // Hard-code the math library... + GCCArgs.push_back("-lpng"); // Hard-code the math library... + GCCArgs.push_back("-lz"); // Hard-code the math library... GCCArgs.push_back("-lm"); // Hard-code the math library... GCCArgs.push_back("-O2"); // Optimize the program a bit... #if defined (HAVE_LINK_R) @@ -385,6 +410,9 @@ int GCC::ExecuteProgram(const std::string &ProgramFile, } std::vector<const char*> ProgramArgs; + //ProgramArgs.push_back("valgrind"); + //ProgramArgs.push_back("--tool=memcheck"); + ProgramArgs.push_back(OutputBinary.c_str()); // Add optional parameters to the running program from Argv for (unsigned i=0, e = Args.size(); i != e; ++i) |