]> git.lyx.org Git - lyx.git/blobdiff - src/insets/InsetCitation.h
Loop refactoring
[lyx.git] / src / insets / InsetCitation.h
index aedbd2e43b33a0c9d358795b0137a3283d31b1e1..b085a2c9428c30f5eb411225bc943b96dfec051a 100644 (file)
@@ -14,7 +14,6 @@
 #define INSET_CITATION_H
 
 #include "InsetCommand.h"
-
 #include "Citation.h"
 
 namespace lyx {
@@ -31,49 +30,75 @@ class InsetCitation : public InsetCommand
 public:
        ///
        InsetCitation(Buffer * buf, InsetCommandParams const &);
+       ///
+       ~InsetCitation();
+
+       ///
+       bool addKey(std::string const & key);
 
        /// \name Public functions inherited from Inset class
        //@{
        ///
-       bool isLabeled() const { return true; }
+       bool isLabeled() const override { return true; }
        ///
-       bool hasSettings() const { return true; }
+       bool hasSettings() const override { return true; }
        ///
-       docstring toolTip(BufferView const & bv, int x, int y) const;
+       docstring toolTip(BufferView const & bv, int x, int y) const override;
        ///
-       InsetCode lyxCode() const { return CITE_CODE; }
+       void doDispatch(Cursor & cur, FuncRequest & cmd) override;
        ///
-       int latex(odocstream &, OutputParams const &) const;
+       bool getStatus(Cursor & cur, FuncRequest const & cmd, FuncStatus &) const override;
        ///
-       int plaintext(odocstream &, OutputParams const &) const;
+       InsetCode lyxCode() const override { return CITE_CODE; }
        ///
-       int docbook(odocstream &, OutputParams const &) const;
+       void latex(otexstream &, OutputParams const &) const override;
        ///
-       docstring xhtml(XHTMLStream &, OutputParams const &) const;
+       int plaintext(odocstringstream & ods, OutputParams const & op,
+                     size_t max_length = INT_MAX) const override;
        ///
-       void tocString(odocstream &) const;
+       void docbook(XMLStream &, OutputParams const &) const override;
        ///
-       void validate(LaTeXFeatures &) const;
+       docstring xhtml(XMLStream &, OutputParams const &) const override;
        ///
-       void updateBuffer(ParIterator const & it, UpdateType);
+       void toString(odocstream &) const override;
        ///
-       void addToToc(DocIterator const &);
+       void forOutliner(docstring &, size_t const, bool const) const override;
        ///
-       docstring contextMenu(BufferView const & bv, int x, int y) const;
+       void updateBuffer(ParIterator const & it, UpdateType, bool const deleted = false) override;
+       ///
+       void addToToc(DocIterator const & di, bool output_active,
+                                 UpdateType utype, TocBackend & backend) const override;
+       ///
+       std::string contextMenuName() const override;
+       ///
+       bool forceLTR(OutputParams const &) const override;
        //@}
 
        /// \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 bool isCompatibleCommand(std::string const & cmd);
+       static bool isCompatibleCommand(std::string const &);
        //@}
+       ///
+       typedef std::vector<std::pair<docstring, docstring>> QualifiedList;
+       ///
+       void redoLabel() { cache.recalculate = true; }
+       ///
+       CitationStyle getCitationStyle(BufferParams const & bp, std::string const & input,
+                                      std::vector<CitationStyle> const & valid_styles) const;
+       ///
+       QualifiedList getQualifiedLists(docstring const & p) const;
+       ///
+       static bool last_literal;
+       /// Check whether citation contains necessary url/file entries
+       /// or external search script is available
+       bool openCitationPossible() const;
+       /// search and open citation source
+       void openCitation();
 
 private:
        /// tries to make a pretty label and makes a basic one if not
@@ -86,28 +111,20 @@ private:
        /// \name Private functions inherited from Inset class
        //@{
        ///
-       Inset * clone() const { return new InsetCitation(*this); }
+       Inset * clone() const override { return new InsetCitation(*this); }
        //@}
 
        /// \name Private functions inherited from InsetCommand class
        //@{
        ///
-       docstring screenLabel() const;
+       docstring screenLabel() const override;
        //@}
 
-       /// we'll eventually want to be able to get info on this from the 
-       /// various CiteEngines
-       static ParamInfo param_info_;
-
        ///
-       class Cache {
-       public:
-               ///
-               Cache() : engine(ENGINE_BASIC), params(CITE_CODE) {}
-               ///
-               CiteEngine engine;
+       struct Cache {
+               Cache() : recalculate(true) {}
                ///
-               InsetCommandParams params;
+               bool recalculate;
                ///
                docstring generated_label;
                ///