mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-10 18:58:10 +00:00
Fix bug #11210
On Windows, start viewers in detached processes in order to avoid a crash of the QProcess destructor when their thread terminates. The opening of a console window is avoided by redirecting to the null device all standard I/O channels.
This commit is contained in:
parent
676318115a
commit
83fc0f924c
@ -258,28 +258,6 @@ int Systemcall::startscript(Starttype how, string const & what,
|
|||||||
SystemcallPrivate d(infile, outfile, errfile);
|
SystemcallPrivate d(infile, outfile, errfile);
|
||||||
bool do_events = process_events || how == WaitLoop;
|
bool do_events = process_events || how == WaitLoop;
|
||||||
|
|
||||||
#ifdef Q_OS_WIN32
|
|
||||||
// QProcess::startDetached cannot provide environment variables. When the
|
|
||||||
// environment variables are set using the latexEnvCmdPrefix and the process
|
|
||||||
// is started with QProcess::startDetached, a console window is shown every
|
|
||||||
// time a viewer is started. To avoid this, we fall back on Windows to the
|
|
||||||
// original implementation that creates a QProcess object.
|
|
||||||
d.startProcess(cmd, path, lpath, false);
|
|
||||||
if (!d.waitWhile(SystemcallPrivate::Starting, do_events, -1)) {
|
|
||||||
if (d.state == SystemcallPrivate::Error) {
|
|
||||||
LYXERR0("Systemcall: '" << cmd << "' did not start!");
|
|
||||||
LYXERR0("error " << d.errorMessage());
|
|
||||||
return NOSTART;
|
|
||||||
} else if (d.state == SystemcallPrivate::Killed) {
|
|
||||||
LYXERR0("Killed: " << cmd);
|
|
||||||
return KILLED;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (how == DontWait) {
|
|
||||||
d.releaseProcess();
|
|
||||||
return OK;
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
d.startProcess(cmd, path, lpath, how == DontWait);
|
d.startProcess(cmd, path, lpath, how == DontWait);
|
||||||
if (how == DontWait && d.state == SystemcallPrivate::Running)
|
if (how == DontWait && d.state == SystemcallPrivate::Running)
|
||||||
return OK;
|
return OK;
|
||||||
@ -295,7 +273,6 @@ int Systemcall::startscript(Starttype how, string const & what,
|
|||||||
return KILLED;
|
return KILLED;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
if (!d.waitWhile(SystemcallPrivate::Running, do_events,
|
if (!d.waitWhile(SystemcallPrivate::Running, do_events,
|
||||||
os::timeout_min() * 60 * 1000)) {
|
os::timeout_min() * 60 * 1000)) {
|
||||||
@ -393,6 +370,15 @@ void SystemcallPrivate::startProcess(QString const & cmd, string const & path,
|
|||||||
cmd_ = cmd;
|
cmd_ = cmd;
|
||||||
if (detached) {
|
if (detached) {
|
||||||
state = SystemcallPrivate::Running;
|
state = SystemcallPrivate::Running;
|
||||||
|
#ifdef Q_OS_WIN32
|
||||||
|
// Avoid opening a console window when a viewer is started
|
||||||
|
if (in_file_.empty())
|
||||||
|
process_->setStandardInputFile(QProcess::nullDevice());
|
||||||
|
if (out_file_.empty())
|
||||||
|
process_->setStandardOutputFile(QProcess::nullDevice());
|
||||||
|
if (err_file_.empty())
|
||||||
|
process_->setStandardErrorFile(QProcess::nullDevice());
|
||||||
|
#endif
|
||||||
if (!QProcess::startDetached(toqstr(latexEnvCmdPrefix(path, lpath)) + cmd_)) {
|
if (!QProcess::startDetached(toqstr(latexEnvCmdPrefix(path, lpath)) + cmd_)) {
|
||||||
state = SystemcallPrivate::Error;
|
state = SystemcallPrivate::Error;
|
||||||
return;
|
return;
|
||||||
|
Loading…
Reference in New Issue
Block a user