Fix LaTeXFeatures::useLayout() recursion test

It was broken in two ways: It was not threadsafe, and it did never detect
any recursion, since the counter was decremented for each non-recursive call
and never incremented again.
This commit is contained in:
Georg Baum 2014-07-07 22:16:13 +02:00
parent 29f6aebb3e
commit d9e234b6da
2 changed files with 9 additions and 6 deletions

View File

@ -426,9 +426,14 @@ void LaTeXFeatures::require(set<string> const & names)
void LaTeXFeatures::useLayout(docstring const & layoutname)
{
useLayout(layoutname, 0);
}
void LaTeXFeatures::useLayout(docstring const & layoutname, int level)
{
// Some code to avoid loops in dependency definition
static int level = 0;
const int maxlevel = 30;
if (level > maxlevel) {
lyxerr << "LaTeXFeatures::useLayout: maximum level of "
@ -448,9 +453,7 @@ void LaTeXFeatures::useLayout(docstring const & layoutname)
require(layout.requires());
if (!layout.depends_on().empty()) {
++level;
useLayout(layout.depends_on());
--level;
useLayout(layout.depends_on(), level + 1);
}
usedLayouts_.push_back(layoutname);
} else {
@ -458,8 +461,6 @@ void LaTeXFeatures::useLayout(docstring const & layoutname)
<< to_utf8(layoutname) << "' does not exist in this class"
<< endl;
}
--level;
}

View File

@ -157,6 +157,8 @@ public:
docstring const & htmlTitle() const { return htmltitle_; }
private:
///
void useLayout(docstring const &, int);
///
std::list<docstring> usedLayouts_;
///