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

View File

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