X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2FInsetCitation.h;h=0cdde7b2ee7ece7666fcaa85ffcece71dc95a36c;hb=90f7007a2e6c78ffd031e4636ff909ab1bc2ddec;hp=1318c3767b171dcbdc589b2497c058cbfac4532b;hpb=db8c16d554ebb1dcb319e44d318572de6eff024b;p=lyx.git diff --git a/src/insets/InsetCitation.h b/src/insets/InsetCitation.h index 1318c3767b..0cdde7b2ee 100644 --- a/src/insets/InsetCitation.h +++ b/src/insets/InsetCitation.h @@ -5,74 +5,106 @@ * Licence details can be found in the file COPYING. * * \author Angus Leeming - * \author Herbert Voß + * \author Herbert Voß * * Full author contact details are available in file CREDITS. */ -#ifndef INSET_CITE_H -#define INSET_CITE_H - +#ifndef INSET_CITATION_H +#define INSET_CITATION_H #include "InsetCommand.h" -#include "InsetCode.h" - -#include "BiblioInfo.h" +#include "Citation.h" namespace lyx { +///////////////////////////////////////////////////////////////////////// +// +// InsetCitation +// +///////////////////////////////////////////////////////////////////////// -/** Used to insert citations - */ -class InsetCitation : public InsetCommand { +/// Used to insert citations +class InsetCitation : public InsetCommand +{ public: /// - InsetCitation(InsetCommandParams const &); + InsetCitation(Buffer * buf, InsetCommandParams const &); + + /// \name Public functions inherited from Inset class + //@{ /// - docstring screenLabel() const; + bool isLabeled() const { return true; } + /// + bool hasSettings() const { return true; } /// - EDITABLE editable() const { return IS_EDITABLE; } + docstring toolTip(BufferView const & bv, int x, int y) const; + /// + void doDispatch(Cursor & cur, FuncRequest & cmd); /// InsetCode lyxCode() const { return CITE_CODE; } /// - int latex(odocstream &, OutputParams const &) const; + void latex(otexstream &, OutputParams const &) const; /// int plaintext(odocstream &, OutputParams const &) const; /// int docbook(odocstream &, OutputParams const &) const; - /// the string that is passed to the TOC - void textString(odocstream &) const; /// - void validate(LaTeXFeatures &) const; + docstring xhtml(XHTMLStream &, OutputParams const &) const; + /// + void toString(odocstream &) const; + /// + void forToc(docstring &, size_t) const; + /// + void validate(LaTeXFeatures &) const {} + /// + void updateBuffer(ParIterator const & it, UpdateType); + /// + void addToToc(DocIterator const &) const; + /// + std::string contextMenuName() const; + //@} + + /// \name Static public methods obligated for InsetCommand derived classes + //@{ /// static ParamInfo const & findInfo(std::string const &); - //FIXME This is the locus of the design problem we have. - //It really ought to do what default_cite_command() does, - //but to do that it needs to know what CiteEngine we are - //using. /// - static std::string defaultCommand() { return "cite"; }; + static std::string defaultCommand() { return "cite"; } /// static bool isCompatibleCommand(std::string const & cmd); + //@} + private: + /// tries to make a pretty label and makes a basic one if not + docstring generateLabel(bool for_xhtml = false) const; + /// makes a pretty label + docstring complexLabel(bool for_xhtml = false) const; + /// makes a very basic label, in case we can't make a pretty one + docstring basicLabel(bool for_xhtml = false) const; + + /// \name Private functions inherited from Inset class + //@{ /// - Inset * clone() const { return new InsetCitation(params()); } - /// we'll eventually want to be able to get info on this from the + Inset * clone() const { return new InsetCitation(*this); } + //@} + + /// \name Private functions inherited from InsetCommand class + //@{ + /// + docstring screenLabel() const; + //@} + + /// we'll eventually want to be able to get info on this from the /// various CiteEngines static ParamInfo param_info_; - /// This function does the donkey work of creating the pretty label - docstring generateLabel() const; /// - class Cache { - public: - /// - Cache() : engine(biblio::ENGINE_BASIC), params(CITE_CODE) {} - /// - biblio::CiteEngine engine; + struct Cache { + Cache() : recalculate(true) {}; /// - InsetCommandParams params; + bool recalculate; /// docstring generated_label; /// @@ -85,4 +117,4 @@ private: } // namespace lyx -#endif // INSET_CITE_H +#endif // INSET_CITATION_H