#include "CiteEnginesList.h"
+#include "Citation.h"
#include "LaTeXFeatures.h"
#include "Lexer.h"
#include "support/gettext.h"
#include "support/filetools.h"
#include "support/lstrings.h"
+#include "support/Translator.h"
#include <algorithm>
LyXCiteEngine::LyXCiteEngine(string const & n, string const & i,
- vector<string> const & cet, string const & d,
- vector<string> const & p,
- vector<string> const & r, vector<string> const & e):
- name_(n), id_(i), engine_types_(cet), description_(d), package_list_(p),
- required_engines_(r), excluded_engines_(e),
- checked_(false), available_(false)
+ vector<string> const & cet, string const & cfm,
+ vector<string> const & dbs,
+ string const & d, vector<string> const & p):
+ name_(n), id_(i), engine_types_(cet), cite_framework_(cfm), default_biblios_(dbs),
+ description_(d), package_list_(p), checked_(false), available_(false)
{
filename_ = id_ + ".citeengine";
}
}
-bool LyXCiteEngine::isCompatible(string const & cename) const
+bool LyXCiteEngine::hasEngineType(CiteEngineType const & et) const
{
- // do we exclude it?
- if (find(excluded_engines_.begin(), excluded_engines_.end(), cename) !=
- excluded_engines_.end())
- return false;
+ return std::find(engine_types_.begin(), engine_types_.end(),
+ theCiteEnginesList.getTypeAsString(et)) != engine_types_.end();
+}
- LyXCiteEngine const * const lm = theCiteEnginesList[cename];
- if (!lm)
- return true;
- // does it exclude us?
- vector<string> const excengs = lm->getExcludedEngines();
- if (find(excengs.begin(), excengs.end(), id_) != excengs.end())
- return false;
+string LyXCiteEngine::getDefaultBiblio(CiteEngineType const & cet) const
+{
+ string res;
+ string const etp = theCiteEnginesList.getTypeAsString(cet) + ":";
+ //check whether all of the required packages are available
+ for (string const &s: default_biblios_) {
+ if (prefixIs(s, etp))
+ res = split(s, ':');
+ else if (!contains(s, ':') && res.empty())
+ res = s;
+ }
+ return res;
+}
- return true;
+
+bool LyXCiteEngine::isDefaultBiblio(string const & bf) const
+{
+ string const bfs = ":" + bf;
+ for (string const &s: default_biblios_)
+ if (suffixIs(s, bfs) || bf == s)
+ return true;
+
+ return false;
}
-bool LyXCiteEngine::areCompatible(string const & eng1, string const & eng2)
+bool LyXCiteEngine::requires(const string p) const
{
- LyXCiteEngine const * const lm1 = theCiteEnginesList[eng1];
- if (lm1)
- return lm1->isCompatible(eng2);
- LyXCiteEngine const * const lm2 = theCiteEnginesList[eng2];
- if (lm2)
- return lm2->isCompatible(eng1);
- // Can't check it either way.
- return true;
+ return find(package_list_.begin(), package_list_.end(), p) != package_list_.end();
}
};
+// Local translators
+namespace {
+
+typedef Translator<string, CiteEngineType> CiteEngineTypeTranslator;
+
+
+CiteEngineTypeTranslator const init_citeenginetypetranslator()
+{
+ CiteEngineTypeTranslator translator("authoryear", ENGINE_TYPE_AUTHORYEAR);
+ translator.addPair("numerical", ENGINE_TYPE_NUMERICAL);
+ translator.addPair("default", ENGINE_TYPE_DEFAULT);
+ return translator;
+}
+
+
+CiteEngineTypeTranslator const & citeenginetypetranslator()
+{
+ static CiteEngineTypeTranslator const translator =
+ init_citeenginetypetranslator();
+ return translator;
+}
+
+} // namespace anon
+
+
+string CiteEnginesList::getTypeAsString(CiteEngineType const & et) const
+{
+ return citeenginetypetranslator().find(et);
+}
+
+
+CiteEngineType CiteEnginesList::getType(string const & et) const
+{
+ return citeenginetypetranslator().find(et);
+}
+
+
// Much of this is borrowed from LayoutFileList::read()
bool CiteEnginesList::read()
{
cet = split(cet, p, '|');
cets.push_back(p);
}
+ if (!lex.next(true))
+ break;
+ string const citeframework = lex.getString();
+ LYXERR(Debug::TCLASS, "CiteFramework: " << citeframework);
+ if (!lex.next(true))
+ break;
+ string db = lex.getString();
+ LYXERR(Debug::TCLASS, "Default Biblio: " << db);
+ vector<string> dbs;
+ while (!db.empty()) {
+ string p;
+ db = split(db, p, '|');
+ dbs.push_back(p);
+ }
if (!lex.next(true))
break;
string const desc = lex.getString();
str = split(str, p, ',');
pkgs.push_back(p);
}
- if (!lex.next())
- break;
- str = lex.getString();
- LYXERR(Debug::TCLASS, "Required: " << str);
- vector<string> req;
- while (!str.empty()) {
- string p;
- str = split(str, p, '|');
- req.push_back(p);
- }
- if (!lex.next())
- break;
- str = lex.getString();
- LYXERR(Debug::TCLASS, "Excluded: " << str);
- vector<string> exc;
- while (!str.empty()) {
- string p;
- str = split(str, p, '|');
- exc.push_back(p);
- }
// This code is run when we have
- // cename, fname, desc, pkgs, req and exc
- addCiteEngine(cename, fname, cets, desc, pkgs, req, exc);
+ // cename, fname, cets, citeframework, dbs, desc, pkgs
+ addCiteEngine(cename, fname, cets, citeframework, dbs, desc, pkgs);
} // end switch
} //end while
void CiteEnginesList::addCiteEngine(string const & cename,
- string const & filename, vector<string> const & cets, string const & description,
- vector<string> const & pkgs, vector<string> const & req,
- vector<string> const & exc)
+ string const & filename, vector<string> const & cets,
+ string const & citeframework, vector<string> const & dbs,
+ string const & description, vector<string> const & pkgs)
{
- LyXCiteEngine ce(cename, filename, cets, description, pkgs, req, exc);
+ LyXCiteEngine ce(cename, filename, cets, citeframework, dbs, description, pkgs);
englist_.push_back(ce);
}