3 * \file CiteEnginesList.cpp
4 * This file is part of LyX, the document processor.
5 * Licence details can be found in the file COPYING.
8 * \author Jürgen Spitzmüller
10 * Full author contact details are available in file CREDITS.
15 #include "CiteEnginesList.h"
18 #include "LaTeXFeatures.h"
21 #include "support/debug.h"
22 #include "support/FileName.h"
23 #include "support/gettext.h"
24 #include "support/filetools.h"
25 #include "support/lstrings.h"
26 #include "support/Translator.h"
31 using namespace lyx::support;
36 //global variable: cite engine list
37 CiteEnginesList theCiteEnginesList;
40 LyXCiteEngine::LyXCiteEngine(string const & n, string const & i,
41 vector<string> const & cet, vector<string> const & dbs,
42 string const & d, vector<string> const & p,
43 vector<string> const & r, vector<string> const & e):
44 name_(n), id_(i), engine_types_(cet), default_biblios_(dbs), description_(d),
45 package_list_(p), required_engines_(r), excluded_engines_(e),
46 checked_(false), available_(false)
48 filename_ = id_ + ".citeengine";
52 vector<string> LyXCiteEngine::prerequisites() const
56 return prerequisites_;
60 bool LyXCiteEngine::isAvailable() const
62 if (package_list_.empty())
68 //check whether all of the required packages are available
69 vector<string>::const_iterator it = package_list_.begin();
70 vector<string>::const_iterator end = package_list_.end();
71 for (; it != end; ++it) {
72 if (!LaTeXFeatures::isAvailable(*it)) {
74 prerequisites_.push_back(*it);
81 bool LyXCiteEngine::hasEngineType(CiteEngineType const & et) const
83 return std::find(engine_types_.begin(), engine_types_.end(),
84 theCiteEnginesList.getTypeAsString(et)) != engine_types_.end();
88 bool LyXCiteEngine::isCompatible(string const & cename) const
91 if (find(excluded_engines_.begin(), excluded_engines_.end(), cename) !=
92 excluded_engines_.end())
95 LyXCiteEngine const * const lm = theCiteEnginesList[cename];
99 // does it exclude us?
100 vector<string> const excengs = lm->getExcludedEngines();
101 if (find(excengs.begin(), excengs.end(), id_) != excengs.end())
108 bool LyXCiteEngine::areCompatible(string const & eng1, string const & eng2)
110 LyXCiteEngine const * const lm1 = theCiteEnginesList[eng1];
112 return lm1->isCompatible(eng2);
113 LyXCiteEngine const * const lm2 = theCiteEnginesList[eng2];
115 return lm2->isCompatible(eng1);
116 // Can't check it either way.
121 string LyXCiteEngine::getDefaultBiblio(CiteEngineType const & cet) const
124 string const etp = theCiteEnginesList.getTypeAsString(cet) + ":";
125 //check whether all of the required packages are available
126 vector<string>::const_iterator it = default_biblios_.begin();
127 vector<string>::const_iterator end = default_biblios_.end();
128 for (; it != end; ++it) {
129 string const s = *it;
130 if (prefixIs(s, etp))
132 else if (!contains(s, ':') && res.empty())
139 bool LyXCiteEngine::isDefaultBiblio(string const & bf) const
141 if (find(default_biblios_.begin(), default_biblios_.end(), bf) != default_biblios_.end())
143 string const bfp = ":" + bf;
144 return find(default_biblios_.begin(), default_biblios_.end(), bfp) != default_biblios_.end();
148 // used when sorting the cite engine list.
151 int operator()(LyXCiteEngine const & ce1, LyXCiteEngine const & ce2) const
153 return _(ce1.getName()) < _(ce2.getName());
161 typedef Translator<string, CiteEngineType> CiteEngineTypeTranslator;
164 CiteEngineTypeTranslator const init_citeenginetypetranslator()
166 CiteEngineTypeTranslator translator("authoryear", ENGINE_TYPE_AUTHORYEAR);
167 translator.addPair("numerical", ENGINE_TYPE_NUMERICAL);
168 translator.addPair("default", ENGINE_TYPE_DEFAULT);
173 CiteEngineTypeTranslator const & citeenginetypetranslator()
175 static CiteEngineTypeTranslator const translator =
176 init_citeenginetypetranslator();
183 string CiteEnginesList::getTypeAsString(CiteEngineType const & et) const
185 return citeenginetypetranslator().find(et);
189 CiteEngineType CiteEnginesList::getType(string const & et) const
191 return citeenginetypetranslator().find(et);
195 // Much of this is borrowed from LayoutFileList::read()
196 bool CiteEnginesList::read()
198 FileName const real_file = libFileSearch("", "lyxciteengines.lst");
199 LYXERR(Debug::TCLASS, "Reading cite engines from `" << real_file << '\'');
201 if (real_file.empty()) {
202 LYXERR0("unable to find cite engines file `citeengines.lst'.\n"
203 << "No cite engines will be available.");
208 if (!lex.setFile(real_file)) {
209 LYXERR0("lyxlex was not able to set file: "
210 << real_file << ".\nNo cite engines will be available.");
215 LYXERR0("unable to open cite engines file `"
216 << to_utf8(makeDisplayPath(real_file.absFileName(), 1000))
217 << "'\nNo cite engines will be available.");
221 bool finished = false;
222 // Parse cite engines files
223 LYXERR(Debug::TCLASS, "Starting parsing of lyxciteengines.lst");
224 while (lex.isOK() && !finished) {
225 LYXERR(Debug::TCLASS, "\tline by line");
227 case Lexer::LEX_FEOF:
231 string const cename = lex.getString();
232 LYXERR(Debug::TCLASS, "Engine name: " << cename);
235 string const fname = lex.getString();
236 LYXERR(Debug::TCLASS, "Filename: " << fname);
239 string cet = lex.getString();
240 LYXERR(Debug::TCLASS, "Engine Type: " << cet);
242 while (!cet.empty()) {
244 cet = split(cet, p, '|');
249 string db = lex.getString();
250 LYXERR(Debug::TCLASS, "Default Biblio: " << db);
252 while (!db.empty()) {
254 db = split(db, p, '|');
259 string const desc = lex.getString();
260 LYXERR(Debug::TCLASS, "Description: " << desc);
264 string str = lex.getString();
265 LYXERR(Debug::TCLASS, "Packages: " << str);
267 while (!str.empty()) {
269 str = split(str, p, ',');
274 str = lex.getString();
275 LYXERR(Debug::TCLASS, "Required: " << str);
277 while (!str.empty()) {
279 str = split(str, p, '|');
284 str = lex.getString();
285 LYXERR(Debug::TCLASS, "Excluded: " << str);
287 while (!str.empty()) {
289 str = split(str, p, '|');
292 // This code is run when we have
293 // cename, fname, desc, pkgs, req and exc
294 addCiteEngine(cename, fname, cets, dbs, desc, pkgs, req, exc);
298 LYXERR(Debug::TCLASS, "End of parsing of lyxciteengines.lst");
300 if (!theCiteEnginesList.empty())
301 sort(theCiteEnginesList.begin(), theCiteEnginesList.end(), EngineSorter());
306 void CiteEnginesList::addCiteEngine(string const & cename,
307 string const & filename, vector<string> const & cets,
308 vector<string> const & dbs, string const & description,
309 vector<string> const & pkgs, vector<string> const & req,
310 vector<string> const & exc)
312 LyXCiteEngine ce(cename, filename, cets, dbs, description, pkgs, req, exc);
313 englist_.push_back(ce);
317 LyXCiteEnginesList::const_iterator CiteEnginesList::begin() const
319 return englist_.begin();
323 LyXCiteEnginesList::iterator CiteEnginesList::begin()
325 return englist_.begin();
329 LyXCiteEnginesList::const_iterator CiteEnginesList::end() const
331 return englist_.end();
335 LyXCiteEnginesList::iterator CiteEnginesList::end()
337 return englist_.end();
341 LyXCiteEngine const * CiteEnginesList::operator[](string const & str) const
343 LyXCiteEnginesList::const_iterator it = englist_.begin();
344 for (; it != englist_.end(); ++it)
345 if (it->getID() == str) {
346 LyXCiteEngine const & eng = *it;
353 LyXCiteEngine * CiteEnginesList::operator[](string const & str)
355 LyXCiteEnginesList::iterator it = englist_.begin();
356 for (; it != englist_.end(); ++it)
357 if (it->getID() == str) {
358 LyXCiteEngine & eng = *it;