X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FBiblioInfo.h;h=11a6361da807387fead5b94929295f8b0a38a972;hb=4a75fe0310ac64a079edab0c07d8f8eebaf519c0;hp=20c0dff1586c75e52b07a143e0526c94459ae2df;hpb=14d7b574870c324508a2eaae5019fece2e5f7cee;p=lyx.git diff --git a/src/BiblioInfo.h b/src/BiblioInfo.h index 20c0dff158..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. @@ -106,20 +75,20 @@ public: docstring & operator[](docstring const & f) { return bimap_[f]; } /// - docstring const & allData() const { return allData_; } + docstring const & allData() const { return all_data_; } /// - void setAllData(docstring const & d) { allData_ = d; } + void setAllData(docstring const & d) { all_data_ = d; } /// - docstring entryType() const { return entryType_; } + docstring entryType() const { return entry_type_; } private: /// true if from BibTeX; false if from bibliography environment - bool isBibTeX_; + bool is_bibtex_; /// the BibTeX key for this entry - docstring bibKey_; + docstring bib_key_; /// a single string containing all BibTeX data associated with this key - docstring allData_; + docstring all_data_; /// the BibTeX entry type (article, book, incollection, ...) - docstring entryType_; + docstring entry_type_; /// our map: std::map bimap_; }; @@ -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,19 +156,22 @@ 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) { fieldNames_.insert(f); } + void addFieldName(docstring const & f) { field_names_.insert(f); } /// - void addEntryType(docstring const & f) { entryTypes_.insert(f); } + void addEntryType(docstring const & f) { entry_types_.insert(f); } private: /// - std::set fieldNames_; + std::set field_names_; /// - std::set entryTypes_; + std::set entry_types_; /// our map: keys --> BibTeXInfo std::map bimap_; }; } // namespace lyx -#endif + +#endif // BIBLIOINFO_H