X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FBiblioInfo.h;h=11a6361da807387fead5b94929295f8b0a38a972;hb=4a75fe0310ac64a079edab0c07d8f8eebaf519c0;hp=6d9de140df454cc972a8f039aaf3e75ab493fe3f;hpb=b1306a979a92fead3878bc2a01cf8adba0e3918e;p=lyx.git diff --git a/src/BiblioInfo.h b/src/BiblioInfo.h index 6d9de140df..11a6361da8 100644 --- a/src/BiblioInfo.h +++ b/src/BiblioInfo.h @@ -11,11 +11,13 @@ * Full author contact details are available in file CREDITS. */ -#ifndef BIBLIO_H -#define BIBLIO_H +#ifndef BIBLIOINFO_H +#define BIBLIOINFO_H #include "support/docstring.h" +#include "Citation.h" + #include #include #include @@ -25,49 +27,14 @@ namespace lyx { class Buffer; -namespace biblio { - -enum CiteEngine { - ENGINE_BASIC, - ENGINE_NATBIB_AUTHORYEAR, - ENGINE_NATBIB_NUMERICAL, - ENGINE_JURABIB -}; - -enum CiteStyle { - CITE, - NOCITE, - CITET, - CITEP, - CITEALT, - CITEALP, - CITEAUTHOR, - CITEYEAR, - CITEYEARPAR -}; - - -class CitationStyle { -public: - /// - CitationStyle(CiteStyle s = CITE, bool f = false, bool force = false) - : style(s), full(f), forceUCase(force) {} - /// \param latex_str a LaTeX command, "cite", "Citep*", etc - CitationStyle(std::string const & latex_str); - /// - std::string const asLatexStr() const; - /// - CiteStyle style; - /// - bool full; - /// - bool forceUCase; -}; - +/// FIXME: To Citation.cpp? /// Returns a vector of available Citation styles. -std::vector const getCiteStyles(CiteEngine const ); +std::vector citeStyles(CiteEngine); +/// \param latex_str a LaTeX command, "cite", "Citep*", etc +CitationStyle citationStyleFromString(std::string const & latex_str); +/// the other way rounf +std::string citationStyleToString(CitationStyle const &); -} // namespace biblio /// Class to represent information about a BibTeX or /// bibliography entry. @@ -77,9 +44,11 @@ class BibTeXInfo { public: /// typedef std::map::const_iterator const_iterator; + /// + BibTeXInfo() : is_bibtex_(true) {} /// argument sets isBibTeX_, so should be false only if it's coming /// from a bibliography environment - BibTeXInfo(bool ib = true); + BibTeXInfo(bool ib) : is_bibtex_(ib) {} /// constructor that sets the entryType BibTeXInfo(docstring const & key, docstring const & type); /// Search for the given field and return the associated info. @@ -139,9 +108,6 @@ public: std::vector const getFields() const; /// Returns a sorted vector of BibTeX entry types in use std::vector const getEntries() const; - /// Fills keys with BibTeX information derived from the various insets - /// in a given buffer, in its master document. - void fillWithBibKeys(Buffer const * const buf); /// return the short form of an authorlist docstring const getAbbreviatedAuthor(docstring const & key) const; /// return the year from the bibtex data record @@ -190,6 +156,8 @@ public: /// const_iterator find(docstring const & f) const { return bimap_.find(f); } /// + void mergeBiblioInfo(BiblioInfo const & info); + /// BibTeXInfo & operator[](docstring const & f) { return bimap_[f]; } /// void addFieldName(docstring const & f) { field_names_.insert(f); } @@ -205,4 +173,5 @@ private: }; } // namespace lyx -#endif + +#endif // BIBLIOINFO_H