mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Fix for bugpoint -remote-client
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@75665 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -635,6 +635,7 @@ int GCC::ExecuteProgram(const std::string &ProgramFile, | |||||||
|  |  | ||||||
|   std::vector<const char*> ProgramArgs; |   std::vector<const char*> ProgramArgs; | ||||||
|  |  | ||||||
|  |   std::string Exec; | ||||||
|   if (RemoteClientPath.isEmpty()) |   if (RemoteClientPath.isEmpty()) | ||||||
|     ProgramArgs.push_back(OutputBinary.c_str()); |     ProgramArgs.push_back(OutputBinary.c_str()); | ||||||
|   else { |   else { | ||||||
| @@ -650,10 +651,10 @@ int GCC::ExecuteProgram(const std::string &ProgramFile, | |||||||
|       ProgramArgs.push_back(RemoteExtra.c_str()); |       ProgramArgs.push_back(RemoteExtra.c_str()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     // Full path to the binary | ||||||
|     char* env_pwd = getenv("PWD"); |     char* env_pwd = getenv("PWD"); | ||||||
|     std::string Exec = "cd "; |  | ||||||
|     Exec += env_pwd; |     Exec += env_pwd; | ||||||
|     Exec += "; ./"; |     Exec += "/"; | ||||||
|     Exec += OutputBinary.c_str(); |     Exec += OutputBinary.c_str(); | ||||||
|     ProgramArgs.push_back(Exec.c_str()); |     ProgramArgs.push_back(Exec.c_str()); | ||||||
|   } |   } | ||||||
| @@ -673,14 +674,21 @@ int GCC::ExecuteProgram(const std::string &ProgramFile, | |||||||
|  |  | ||||||
|   FileRemover OutputBinaryRemover(OutputBinary); |   FileRemover OutputBinaryRemover(OutputBinary); | ||||||
|  |  | ||||||
|   if (RemoteClientPath.isEmpty()) |   if (RemoteClientPath.isEmpty()) { | ||||||
|  |     DEBUG(std::cerr << "<run locally>" << std::flush;); | ||||||
|     return RunProgramWithTimeout(OutputBinary, &ProgramArgs[0], |     return RunProgramWithTimeout(OutputBinary, &ProgramArgs[0], | ||||||
|         sys::Path(InputFile), sys::Path(OutputFile), sys::Path(OutputFile), |         sys::Path(InputFile), sys::Path(OutputFile), sys::Path(OutputFile), | ||||||
|         Timeout, MemoryLimit); |         Timeout, MemoryLimit); | ||||||
|   else |   } else { | ||||||
|     return RunProgramWithTimeout(sys::Path(RemoteClientPath), &ProgramArgs[0], |     std::cout << "<run remotely>" << std::flush; | ||||||
|         sys::Path(InputFile), sys::Path(OutputFile), sys::Path(OutputFile), |     int RemoteClientStatus = RunProgramWithTimeout(sys::Path(RemoteClientPath), | ||||||
|         Timeout, MemoryLimit); |         &ProgramArgs[0], sys::Path(InputFile), sys::Path(OutputFile), | ||||||
|  |         sys::Path(OutputFile), Timeout, MemoryLimit); | ||||||
|  |     if (RemoteClientStatus != 0) { | ||||||
|  |       std::cerr << "Remote Client failed with an error: " << | ||||||
|  |         RemoteClientStatus << ".\n" << std::flush; | ||||||
|  |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| int GCC::MakeSharedObject(const std::string &InputFile, FileType fileType, | int GCC::MakeSharedObject(const std::string &InputFile, FileType fileType, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user