#include "ModuleList.h"
#include "support/debug.h"
+#include "LaTeXFeatures.h"
#include "Lexer.h"
+#include "support/FileName.h"
#include "support/filetools.h"
#include "support/lstrings.h"
ModuleList moduleList;
+LyXModule::LyXModule(string const & n, string const & f,
+ string const & d, vector<string> const & p) :
+ name(n), filename(f), description(d), packageList(p), checked(false)
+{}
+
+
+bool LyXModule::isAvailable() {
+ if (packageList.empty())
+ return true;
+ if (checked)
+ return available;
+ checked = true;
+ vector<string>::const_iterator it = packageList.begin();
+ vector<string>::const_iterator end = packageList.end();
+ for (; it != end; ++it) {
+ if (!LaTeXFeatures::isAvailable(*it))
+ available = false;
+ return available;
+ }
+ available = true;
+ return available;
+}
+
+
// used when sorting the module list.
class ModuleSorter
{
//Much of this is borrowed from TextClassList::read()
bool ModuleList::load()
{
- support::FileName const real_file = libFileSearch("", "lyxmodules.lst");
+ FileName const real_file = libFileSearch("", "lyxmodules.lst");
LYXERR(Debug::TCLASS, "Reading modules from `" << real_file << '\'');
if (real_file.empty()) {
vector<string> pkgs;
while (!packages.empty()) {
string p;
- packages = support::split(packages, p, ',');
+ packages = split(packages, p, ',');
pkgs.push_back(p);
}
// This code is run when we have
string const & filename, string const & description,
vector<string> const & pkgs)
{
- LyXModule lm;
- lm.name = moduleName;
- lm.filename = filename;
- lm.description = description;
- lm.packageList = pkgs;
+ LyXModule lm(moduleName, filename, description, pkgs);
modlist_.push_back(lm);
}