mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-22 16:37:28 +00:00
Properly check return values so TIMEOUT is recognized.
This commit is contained in:
parent
49098aa318
commit
c6b3f35c8c
@ -595,8 +595,8 @@ Converters::RetVal Converters::convert(Buffer const * buffer,
|
|||||||
// FIXME KILLED
|
// FIXME KILLED
|
||||||
// Check changed return value here.
|
// Check changed return value here.
|
||||||
RetVal const retval = runLaTeX(*buffer, command, runparams, errorList);
|
RetVal const retval = runLaTeX(*buffer, command, runparams, errorList);
|
||||||
if (retval != SUCCESS)
|
if (retval != SUCCESS)
|
||||||
return retval;
|
return retval;
|
||||||
} else {
|
} else {
|
||||||
if (conv.need_aux() && !run_latex) {
|
if (conv.need_aux() && !run_latex) {
|
||||||
// We are not importing, we have a buffer
|
// We are not importing, we have a buffer
|
||||||
@ -866,7 +866,7 @@ Converters::RetVal Converters::runLaTeX(Buffer const & buffer, string const & co
|
|||||||
});
|
});
|
||||||
int const result = latex.run(terr);
|
int const result = latex.run(terr);
|
||||||
|
|
||||||
if (result == Systemcall::KILLED) {
|
if (result == Systemcall::KILLED || result == Systemcall::TIMEOUT) {
|
||||||
Alert::error(_("Export canceled"),
|
Alert::error(_("Export canceled"),
|
||||||
_("The export process was terminated by the user."));
|
_("The export process was terminated by the user."));
|
||||||
return KILLED;
|
return KILLED;
|
||||||
|
@ -281,16 +281,16 @@ int LaTeX::run(TeXErrors & terr)
|
|||||||
message(runMessage(count));
|
message(runMessage(count));
|
||||||
|
|
||||||
int exit_code = startscript();
|
int exit_code = startscript();
|
||||||
if (exit_code == Systemcall::KILLED)
|
if (exit_code == Systemcall::KILLED || exit_code == Systemcall::TIMEOUT)
|
||||||
return Systemcall::KILLED;
|
return exit_code;
|
||||||
|
|
||||||
scanres = scanLogFile(terr);
|
scanres = scanLogFile(terr);
|
||||||
if (scanres & ERROR_RERUN) {
|
if (scanres & ERROR_RERUN) {
|
||||||
LYXERR(Debug::LATEX, "Rerunning LaTeX");
|
LYXERR(Debug::LATEX, "Rerunning LaTeX");
|
||||||
terr.clearErrors();
|
terr.clearErrors();
|
||||||
exit_code = startscript();
|
exit_code = startscript();
|
||||||
if (exit_code == Systemcall::KILLED)
|
if (exit_code == Systemcall::KILLED || exit_code == Systemcall::TIMEOUT)
|
||||||
return Systemcall::KILLED;
|
return exit_code;
|
||||||
scanres = scanLogFile(terr);
|
scanres = scanLogFile(terr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -322,8 +322,8 @@ int LaTeX::run(TeXErrors & terr)
|
|||||||
// onlyFileName() is needed for cygwin
|
// onlyFileName() is needed for cygwin
|
||||||
int const ret =
|
int const ret =
|
||||||
runMakeIndex(onlyFileName(idxfile.absFileName()), runparams);
|
runMakeIndex(onlyFileName(idxfile.absFileName()), runparams);
|
||||||
if (ret == Systemcall::KILLED)
|
if (ret == Systemcall::KILLED || ret == Systemcall::TIMEOUT)
|
||||||
return Systemcall::KILLED;
|
return ret;
|
||||||
FileName const ilgfile(changeExtension(file.absFileName(), ".ilg"));
|
FileName const ilgfile(changeExtension(file.absFileName(), ".ilg"));
|
||||||
if (ilgfile.exists())
|
if (ilgfile.exists())
|
||||||
iscanres = scanIlgFile(terr);
|
iscanres = scanIlgFile(terr);
|
||||||
@ -338,8 +338,8 @@ int LaTeX::run(TeXErrors & terr)
|
|||||||
// FIXME: Sort out the real problem in DepTable.
|
// FIXME: Sort out the real problem in DepTable.
|
||||||
if (head.haschanged(nlofile) || (nlofile.exists() && nlofile.isFileEmpty())) {
|
if (head.haschanged(nlofile) || (nlofile.exists() && nlofile.isFileEmpty())) {
|
||||||
int const ret = runMakeIndexNomencl(file, ".nlo", ".nls");
|
int const ret = runMakeIndexNomencl(file, ".nlo", ".nls");
|
||||||
if (ret == Systemcall::KILLED)
|
if (ret == Systemcall::KILLED || ret == Systemcall::TIMEOUT)
|
||||||
return Systemcall::KILLED;
|
return ret;
|
||||||
rerun = true;
|
rerun = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -375,8 +375,8 @@ int LaTeX::run(TeXErrors & terr)
|
|||||||
updateBibtexDependencies(head, bibtex_info);
|
updateBibtexDependencies(head, bibtex_info);
|
||||||
int exit_code;
|
int exit_code;
|
||||||
rerun |= runBibTeX(bibtex_info, runparams, exit_code);
|
rerun |= runBibTeX(bibtex_info, runparams, exit_code);
|
||||||
if (exit_code == Systemcall::KILLED)
|
if (exit_code == Systemcall::KILLED || exit_code == Systemcall::TIMEOUT)
|
||||||
return Systemcall::KILLED;
|
return exit_code;
|
||||||
FileName const blgfile(changeExtension(file.absFileName(), ".blg"));
|
FileName const blgfile(changeExtension(file.absFileName(), ".blg"));
|
||||||
if (blgfile.exists())
|
if (blgfile.exists())
|
||||||
bscanres = scanBlgFile(head, terr);
|
bscanres = scanBlgFile(head, terr);
|
||||||
@ -406,8 +406,8 @@ int LaTeX::run(TeXErrors & terr)
|
|||||||
LYXERR(Debug::LATEX, "Run #" << count);
|
LYXERR(Debug::LATEX, "Run #" << count);
|
||||||
message(runMessage(count));
|
message(runMessage(count));
|
||||||
int exit_code = startscript();
|
int exit_code = startscript();
|
||||||
if (exit_code == Systemcall::KILLED)
|
if (exit_code == Systemcall::KILLED || exit_code == Systemcall::TIMEOUT)
|
||||||
return Systemcall::KILLED;
|
return exit_code;
|
||||||
scanres = scanLogFile(terr);
|
scanres = scanLogFile(terr);
|
||||||
|
|
||||||
// update the depedencies
|
// update the depedencies
|
||||||
@ -436,8 +436,8 @@ int LaTeX::run(TeXErrors & terr)
|
|||||||
updateBibtexDependencies(head, bibtex_info);
|
updateBibtexDependencies(head, bibtex_info);
|
||||||
int exit_code;
|
int exit_code;
|
||||||
rerun |= runBibTeX(bibtex_info, runparams, exit_code);
|
rerun |= runBibTeX(bibtex_info, runparams, exit_code);
|
||||||
if (exit_code == Systemcall::KILLED)
|
if (exit_code == Systemcall::KILLED || exit_code == Systemcall::TIMEOUT)
|
||||||
return Systemcall::KILLED;
|
return exit_code;
|
||||||
FileName const blgfile(changeExtension(file.absFileName(), ".blg"));
|
FileName const blgfile(changeExtension(file.absFileName(), ".blg"));
|
||||||
if (blgfile.exists())
|
if (blgfile.exists())
|
||||||
bscanres = scanBlgFile(head, terr);
|
bscanres = scanBlgFile(head, terr);
|
||||||
@ -459,8 +459,8 @@ int LaTeX::run(TeXErrors & terr)
|
|||||||
// onlyFileName() is needed for cygwin
|
// onlyFileName() is needed for cygwin
|
||||||
int const ret = runMakeIndex(onlyFileName(changeExtension(
|
int const ret = runMakeIndex(onlyFileName(changeExtension(
|
||||||
file.absFileName(), ".idx")), runparams);
|
file.absFileName(), ".idx")), runparams);
|
||||||
if (ret == Systemcall::KILLED)
|
if (ret == Systemcall::KILLED || ret == Systemcall::TIMEOUT)
|
||||||
return Systemcall::KILLED;
|
return ret;
|
||||||
FileName const ilgfile(changeExtension(file.absFileName(), ".ilg"));
|
FileName const ilgfile(changeExtension(file.absFileName(), ".ilg"));
|
||||||
if (ilgfile.exists())
|
if (ilgfile.exists())
|
||||||
iscanres = scanIlgFile(terr);
|
iscanres = scanIlgFile(terr);
|
||||||
|
@ -424,6 +424,7 @@ bool queryStopCommand(QString const & cmd)
|
|||||||
|
|
||||||
bool SystemcallPrivate::waitWhile(State waitwhile, bool process_events, int timeout)
|
bool SystemcallPrivate::waitWhile(State waitwhile, bool process_events, int timeout)
|
||||||
{
|
{
|
||||||
|
timeout = 1000;
|
||||||
if (!process_)
|
if (!process_)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
@ -440,7 +441,7 @@ bool SystemcallPrivate::waitWhile(State waitwhile, bool process_events, int time
|
|||||||
while (!timedout) {
|
while (!timedout) {
|
||||||
if (process_->waitForFinished(timeout))
|
if (process_->waitForFinished(timeout))
|
||||||
return true;
|
return true;
|
||||||
bool stop = queryStopCommand(cmd_);
|
bool const stop = queryStopCommand(cmd_);
|
||||||
// The command may have finished in the meantime
|
// The command may have finished in the meantime
|
||||||
if (process_->state() == QProcess::NotRunning)
|
if (process_->state() == QProcess::NotRunning)
|
||||||
return true;
|
return true;
|
||||||
@ -475,7 +476,7 @@ bool SystemcallPrivate::waitWhile(State waitwhile, bool process_events, int time
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (timer.elapsed() > timeout) {
|
if (timer.elapsed() > timeout) {
|
||||||
bool stop = queryStopCommand(cmd_);
|
bool const stop = queryStopCommand(cmd_);
|
||||||
// The command may have finished in the meantime
|
// The command may have finished in the meantime
|
||||||
if (process_->state() == QProcess::NotRunning)
|
if (process_->state() == QProcess::NotRunning)
|
||||||
break;
|
break;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user