|
|
@ -21,6 +21,7 @@ namespace NzbDrone.Common
|
|
|
|
bool Exists(string processName);
|
|
|
|
bool Exists(string processName);
|
|
|
|
ProcessPriorityClass GetCurrentProcessPriority();
|
|
|
|
ProcessPriorityClass GetCurrentProcessPriority();
|
|
|
|
Process Start(string path, string args = null, Action<string> onOutputDataReceived = null, Action<string> onErrorDataReceived = null);
|
|
|
|
Process Start(string path, string args = null, Action<string> onOutputDataReceived = null, Action<string> onErrorDataReceived = null);
|
|
|
|
|
|
|
|
Process SpawnNewProcess(string path, string args = null);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public class ProcessProvider : IProcessProvider
|
|
|
|
public class ProcessProvider : IProcessProvider
|
|
|
@ -86,6 +87,8 @@ namespace NzbDrone.Common
|
|
|
|
process.Start();
|
|
|
|
process.Start();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public Process Start(string path, string args = null, Action<string> onOutputDataReceived = null, Action<string> onErrorDataReceived = null)
|
|
|
|
public Process Start(string path, string args = null, Action<string> onOutputDataReceived = null, Action<string> onErrorDataReceived = null)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
@ -147,6 +150,27 @@ namespace NzbDrone.Common
|
|
|
|
return process;
|
|
|
|
return process;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public Process SpawnNewProcess(string path, string args = null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (OsInfo.IsMono && path.EndsWith(".exe", StringComparison.InvariantCultureIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
args = path + " " + args;
|
|
|
|
|
|
|
|
path = "mono";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Logger.Info("Starting {0} {1}", path, args);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var startInfo = new ProcessStartInfo(path, args);
|
|
|
|
|
|
|
|
var process = new Process
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StartInfo = startInfo
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
process.Start();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return process;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public void WaitForExit(Process process)
|
|
|
|
public void WaitForExit(Process process)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Logger.Trace("Waiting for process {0} to exit.", process.ProcessName);
|
|
|
|
Logger.Trace("Waiting for process {0} to exit.", process.ProcessName);
|
|
|
|