#include "insets/InsetBibtex.h"
#include "insets/InsetInclude.h"
-#include "support/assert.h"
+#include "support/lassert.h"
#include "support/docstream.h"
#include "support/gettext.h"
#include "support/lstrings.h"
using namespace std;
using namespace lyx::support;
-namespace lyx {
+namespace lyx {
//////////////////////////////////////////////////////////////////////
//
//
//////////////////////////////////////////////////////////////////////
-BibTeXInfo::BibTeXInfo(bool ib)
- : is_bibtex_(ib)
-{}
-
-
BibTeXInfo::BibTeXInfo(docstring const & key, docstring const & type)
: is_bibtex_(true), bib_key_(key), entry_type_(type)
{}
-
+
bool BibTeXInfo::hasField(docstring const & field) const
{
return count(field) == 1;
}
-static docstring familyName(docstring const & name)
+docstring familyName(docstring const & name)
{
if (name.empty())
return docstring();
vector<docstring> const BiblioInfo::getCiteStrings(
docstring const & key, Buffer const & buf) const
{
- biblio::CiteEngine const engine = buf.params().citeEngine();
- if (engine == biblio::ENGINE_BASIC ||
- engine == biblio::ENGINE_NATBIB_NUMERICAL)
+ CiteEngine const engine = buf.params().citeEngine();
+ if (engine == ENGINE_BASIC || engine == ENGINE_NATBIB_NUMERICAL)
return getNumericalStrings(key, buf);
else
return getAuthorYearStrings(key, buf);
if (author.empty() || year.empty())
return vector<docstring>();
- vector<biblio::CiteStyle> const & styles =
- biblio::getCiteStyles(buf.params().citeEngine());
+ vector<CiteStyle> const & styles = citeStyles(buf.params().citeEngine());
vector<docstring> vec(styles.size());
- for (vector<docstring>::size_type i = 0; i != vec.size(); ++i) {
+ for (size_t i = 0; i != vec.size(); ++i) {
docstring str;
switch (styles[i]) {
- case biblio::CITE:
- case biblio::CITEP:
+ case CITE:
+ case CITEP:
str = from_ascii("[#ID]");
break;
- case biblio::NOCITE:
+ case NOCITE:
str = _("Add to bibliography only.");
break;
- case biblio::CITET:
+ case CITET:
str = author + " [#ID]";
break;
- case biblio::CITEALT:
+ case CITEALT:
str = author + " #ID";
break;
- case biblio::CITEALP:
+ case CITEALP:
str = from_ascii("#ID");
break;
- case biblio::CITEAUTHOR:
+ case CITEAUTHOR:
str = author;
break;
- case biblio::CITEYEAR:
+ case CITEYEAR:
str = year;
break;
- case biblio::CITEYEARPAR:
+ case CITEYEARPAR:
str = '(' + year + ')';
break;
}
if (author.empty() || year.empty())
return vector<docstring>();
- vector<biblio::CiteStyle> const & styles =
- getCiteStyles(buf.params().citeEngine());
+ vector<CiteStyle> const & styles = citeStyles(buf.params().citeEngine());
vector<docstring> vec(styles.size());
- for (vector<docstring>::size_type i = 0; i != vec.size(); ++i) {
+ for (size_t i = 0; i != vec.size(); ++i) {
docstring str;
switch (styles[i]) {
- case biblio::CITE:
+ case CITE:
// jurabib only: Author/Annotator
// (i.e. the "before" field, 2nd opt arg)
str = author + "/<" + _("before") + '>';
break;
- case biblio::NOCITE:
+ case NOCITE:
str = _("Add to bibliography only.");
break;
- case biblio::CITET:
+ case CITET:
str = author + " (" + year + ')';
break;
- case biblio::CITEP:
+ case CITEP:
str = '(' + author + ", " + year + ')';
break;
- case biblio::CITEALT:
+ case CITEALT:
str = author + ' ' + year ;
break;
- case biblio::CITEALP:
+ case CITEALP:
str = author + ", " + year ;
break;
- case biblio::CITEAUTHOR:
+ case CITEAUTHOR:
str = author;
break;
- case biblio::CITEYEAR:
+ case CITEYEAR:
str = year;
break;
- case biblio::CITEYEARPAR:
+ case CITEYEARPAR:
str = '(' + year + ')';
break;
}
}
-void BiblioInfo::fillWithBibKeys(Buffer const * const buf)
-{
- /// if this is a child document and the parent is already loaded
- /// use the parent's list instead [ale990412]
- Buffer const * const tmp = buf->masterBuffer();
- LASSERT(tmp, /**/);
- if (tmp != buf) {
- this->fillWithBibKeys(tmp);
- return;
- }
-
- for (InsetIterator it = inset_iterator_begin(buf->inset()); it; ++it)
- it->fillWithBibKeys(*this, it);
+void BiblioInfo::mergeBiblioInfo(BiblioInfo const & info)
+{
+ bimap_.insert(info.begin(), info.end());
}
-namespace biblio {
-
//////////////////////////////////////////////////////////////////////
//
// CitationStyle
unsigned int const nCiteCommands =
sizeof(citeCommands) / sizeof(char *);
-CiteStyle const citeStyles[] = {
+CiteStyle const citeStylesArray[] = {
CITE, NOCITE, CITET, CITEP, CITEALT,
-CITEALP, CITEAUTHOR, CITEYEAR, CITEYEARPAR };
+ CITEALP, CITEAUTHOR, CITEYEAR, CITEYEARPAR };
unsigned int const nCiteStyles =
- sizeof(citeStyles) / sizeof(CiteStyle);
+ sizeof(citeStylesArray) / sizeof(CiteStyle);
CiteStyle const citeStylesFull[] = {
CITET, CITEP, CITEALT, CITEALP, CITEAUTHOR };
} // namespace anon
-CitationStyle::CitationStyle(string const & command)
- : style(CITE), full(false), forceUCase(false)
+CitationStyle citationStyleFromString(string const & command)
{
+ CitationStyle s;
if (command.empty())
- return;
+ return s;
string cmd = command;
if (cmd[0] == 'C') {
- forceUCase = true;
+ s.forceUpperCase = true;
cmd[0] = 'c';
}
- string::size_type const n = cmd.size() - 1;
+ size_t const n = cmd.size() - 1;
if (cmd != "cite" && cmd[n] == '*') {
- full = true;
- cmd = cmd.substr(0,n);
+ s.full = true;
+ cmd = cmd.substr(0, n);
}
char const * const * const last = citeCommands + nCiteCommands;
if (ptr != last) {
size_t idx = ptr - citeCommands;
- style = citeStyles[idx];
+ s.style = citeStylesArray[idx];
}
+ return s;
}
-string const CitationStyle::asLatexStr() const
+string citationStyleToString(const CitationStyle & s)
{
- string cite = citeCommands[style];
- if (full) {
+ string cite = citeCommands[s.style];
+ if (s.full) {
CiteStyle const * last = citeStylesFull + nCiteStylesFull;
- if (find(citeStylesFull, last, style) != last)
+ if (find(citeStylesFull, last, s.style) != last)
cite += '*';
}
- if (forceUCase) {
+ if (s.forceUpperCase) {
CiteStyle const * last = citeStylesUCase + nCiteStylesUCase;
- if (find(citeStylesUCase, last, style) != last)
+ if (find(citeStylesUCase, last, s.style) != last)
cite[0] = 'C';
}
return cite;
}
-
-vector<CiteStyle> const getCiteStyles(CiteEngine const engine)
+vector<CiteStyle> citeStyles(CiteEngine engine)
{
unsigned int nStyles = 0;
unsigned int start = 0;
break;
}
- typedef vector<CiteStyle> cite_vec;
-
- cite_vec styles(nStyles);
+ vector<CiteStyle> styles(nStyles);
size_t i = 0;
int j = start;
for (; i != styles.size(); ++i, ++j)
- styles[i] = citeStyles[j];
+ styles[i] = citeStylesArray[j];
return styles;
}
-} // namespace biblio
} // namespace lyx