// the .aux file is checked for signs of bibtex. Bibtex is then run
// if needed.
+ // memoir (at least) writes an empty *idx file in the first place.
+ // A second latex run is needed.
+ rerun = fs::exists(changeExtension(file, ".idx"))
+ && fs::is_empty(changeExtension(file, ".idx"));
+
// run makeindex
if (head.haschanged(onlyFilename(changeExtension(file, ".idx")))) {
// no checks for now
lyxerr[Debug::LATEX] << "Running MakeIndex." << endl;
message(_("Running MakeIndex."));
- rerun = runMakeIndex(onlyFilename(changeExtension(file, ".idx")), runparams);
+ rerun |= runMakeIndex(onlyFilename(changeExtension(file, ".idx")), runparams);
}
// run bibtex
// 1.5
// The inclusion of files generated by external programs like
- // makeindex or bibtex might have done changes to pagenumbereing,
+ // makeindex or bibtex might have done changes to pagenumbering,
// etc. And because of this we must run the external programs
// again to make sure everything is redone correctly.
// Also there should be no need to run the external programs any
string token;
while (getline(ifs, token)) {
+ // MikTeX sometimes inserts \0 in the log file. They can't be
+ // removed directly with the existing string utility
+ // functions, so convert them first to \r, and remove all
+ // \r's afterwards, since we need to remove them anyway.
+ token = subst(token, '\0', '\r');
+ token = subst(token, "\r", "");
+
lyxerr[Debug::LATEX] << "Log line: " << token << endl;
if (token.empty())
static regex reg3("No file ([^ ]+)\\..*");
static regex reg4("\\\\openout[0-9]+.*=.*`([^ ]+)'\\..*");
// If an index should be created, MikTex does not write a line like
- // \openout# = 'sample,idx'.
- // but intstead only a line like this into the log:
+ // \openout# = 'sample.idx'.
+ // but instead only a line like this into the log:
// Writing index file sample.idx
static regex reg5("Writing index file ([^ ]+).*");
+ // If a toc should be created, MikTex does not write a line like
+ // \openout# = `sample.toc'.
+ // but only a line like this into the log:
+ // \tf@toc=\write#
+ // This line is also written by tetex.
+ // This line is not present if no toc should be created.
+ static regex miktexTocReg("\\\\tf@toc=\\\\write.*");
ifstream ifs(logfile.c_str());
while (ifs) {
string token;
getline(ifs, token);
- token = rtrim(token, "\r");
+ // MikTeX sometimes inserts \0 in the log file. They can't be
+ // removed directly with the existing string utility
+ // functions, so convert them first to \r, and remove all
+ // \r's afterwards, since we need to remove them anyway.
+ token = subst(token, '\0', '\r');
+ token = subst(token, "\r", "");
if (token.empty())
continue;
first = what[0].second;
handleFoundFile(what.str(1), head);
}
- } else if (regex_match(token, sub, reg2)) {
+ } else if (regex_match(token, sub, reg2))
handleFoundFile(sub.str(1), head);
- } else if (regex_match(token, sub, reg3)) {
+ else if (regex_match(token, sub, reg3))
handleFoundFile(sub.str(1), head);
- } else if (regex_match(token, sub, reg4)) {
+ else if (regex_match(token, sub, reg4))
handleFoundFile(sub.str(1), head);
- } else if (regex_match(token, sub, reg5)) {
+ else if (regex_match(token, sub, reg5))
handleFoundFile(sub.str(1), head);
- }
+ else if (regex_match(token, sub, miktexTocReg))
+ handleFoundFile(changeExtension(file, ".toc"), head);
}
// Make sure that the main .tex file is in the dependancy file.