Fix bug connected with excluded modules and default modules: We need to make

sure that default modules do not exclude loaded modules and also that loaded
modules do not exclude them.


git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@26922 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Richard Heck 2008-10-16 15:29:56 +00:00
parent 21ad65c437
commit 8bc9c319d2

View File

@ -1494,10 +1494,15 @@ bool BufferParams::setBaseClass(string const & classname)
pimpl_->baseClass_ = classname; pimpl_->baseClass_ = classname;
// add any required modules not already in use // add any default modules not already in use
list<string> const & mods = baseClass()->defaultModules(); list<string> const & mods = baseClass()->defaultModules();
list<string>::const_iterator mit = mods.begin(); list<string>::const_iterator mit = mods.begin();
list<string>::const_iterator men = mods.end(); list<string>::const_iterator men = mods.end();
// we want to add these to the front, but in the right order,
// so we collect them here first.
list<string> modulesToAdd;
for (; mit != men; mit++) { for (; mit != men; mit++) {
string const & modName = *mit; string const & modName = *mit;
// see if we're already in use // see if we're already in use
@ -1514,12 +1519,25 @@ bool BufferParams::setBaseClass(string const & classname)
"' not added because removed by user."); "' not added because removed by user.");
continue; continue;
} }
// Now we want to check the list of selected modules to see if any of them // Now we want to check the list of selected modules to see if any of them
// exclude this one. // excludes this one, or if we exclude one of them.
LyXModule * thismod = moduleList[modName];
if (!thismod) {
LYXERR0("Adding default module " << modName <<
" even though it is unavailable.");
modulesToAdd.push_back(modName);
continue;
}
bool foundit = false; bool foundit = false;
vector<string> const ourExcMods = thismod->getExcludedModules();
vector<string>::const_iterator const eit = ourExcMods.begin();
vector<string>::const_iterator const een = ourExcMods.end();
// so iterate over the selected modules... // so iterate over the selected modules...
LayoutModuleList::const_iterator lit = layoutModules_.begin(); LayoutModuleList::const_iterator lit = layoutModules_.begin();
LayoutModuleList::const_iterator len = layoutModules_.end(); LayoutModuleList::const_iterator const len = layoutModules_.end();
for (; lit != len; lit++) { for (; lit != len; lit++) {
LyXModule * lm = moduleList[*lit]; LyXModule * lm = moduleList[*lit];
if (!lm) if (!lm)
@ -1533,12 +1551,22 @@ bool BufferParams::setBaseClass(string const & classname)
*lit << "'."); *lit << "'.");
break; break;
} }
if (find(eit, een, *lit) != een) {
foundit = true;
LYXERR(Debug::TCLASS, "Default module `" << modName <<
"' not added because it excludes loaded module `" <<
*lit << "'.");
break;
}
} }
if (!foundit) { if (!foundit) {
LYXERR(Debug::TCLASS, "Default module `" << modName << "' added."); LYXERR(Debug::TCLASS, "Default module `" << modName << "' added.");
layoutModules_.push_back(modName); modulesToAdd.push_back(modName);
} }
} }
layoutModules_.insert(layoutModules_.begin(), modulesToAdd.begin(), modulesToAdd.end());
return true; return true;
} }