X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2FInsetIndex.h;h=c66be3004913b67d37f753923ba8f5bed1c314c6;hb=bbfc419c10010c1ebf6ab59adf2eaf6f63104a9e;hp=1d8f045af451b0fcde873a303896ede776a978bc;hpb=3742ece3ecec5aabca410d4306d5ad103dae3e2b;p=features.git diff --git a/src/insets/InsetIndex.h b/src/insets/InsetIndex.h index 1d8f045af4..c66be30049 100644 --- a/src/insets/InsetIndex.h +++ b/src/insets/InsetIndex.h @@ -4,7 +4,7 @@ * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * - * \author Lars Gullik Bjønnes + * \author Lars Gullik Bjønnes * * Full author contact details are available in file CREDITS. */ @@ -19,33 +19,75 @@ namespace lyx { +class InsetIndexParams { +public: + /// + explicit InsetIndexParams(docstring const & b = docstring()) + : index(b) {} + /// + void write(std::ostream & os) const; + /// + void read(Lexer & lex); + /// + docstring index; +}; + + /** Used to insert index labels */ class InsetIndex : public InsetCollapsable { public: /// - InsetIndex(Buffer const &); + InsetIndex(Buffer const &, InsetIndexParams const &); + /// + static std::string params2string(InsetIndexParams const &); + /// + static void string2params(std::string const &, InsetIndexParams &); private: /// - EDITABLE editable() const { return HIGHLY_EDITABLE; } + bool hasSettings() const; /// InsetCode lyxCode() const { return INDEX_CODE; } /// docstring name() const { return from_ascii("Index"); } /// + ColorCode labelColor() const; + /// void write(std::ostream & os) const; /// + void read(Lexer & lex); + /// int docbook(odocstream &, OutputParams const &) const; + /// At the moment, this does nothing. See development/HTML.notes + /// for some remarks on what could be done. + docstring xhtml(odocstream &, OutputParams const &) const; /// int latex(odocstream &, OutputParams const &) const; + /// + bool showInsetDialog(BufferView *) const; + /// + bool getStatus(Cursor &, FuncRequest const &, FuncStatus &) const; + /// + void doDispatch(Cursor & cur, FuncRequest & cmd); /// should paragraph indendation be omitted in any case? bool neverIndent() const { return true; } /// - void addToToc(ParConstIterator const &) const; + void addToToc(DocIterator const &); + /// + docstring const buttonLabel(BufferView const & bv) const; + /// + docstring toolTip(BufferView const & bv, int x, int y) const; + /// Updates needed features for this inset. + void validate(LaTeXFeatures & features) const; + /// + docstring contextMenu(BufferView const & bv, int x, int y) const; /// Inset * clone() const { return new InsetIndex(*this); } + /// - bool hasFontChanges() const; + friend class InsetIndexParams; + /// + InsetIndexParams params_; }; @@ -53,21 +95,31 @@ class InsetPrintIndex : public InsetCommand { public: /// InsetPrintIndex(InsetCommandParams const &); + /// + InsetCode lyxCode() const { return INDEX_PRINT_CODE; } /// static ParamInfo const & findInfo(std::string const &); /// static std::string defaultCommand() { return "printindex"; }; /// - static bool isCompatibleCommand(std::string const & s) - { return s == "printindex"; } + static bool isCompatibleCommand(std::string const & s); + /// + int latex(odocstream &, OutputParams const &) const; + /// Does nothing yet. + docstring xhtml(odocstream &, OutputParams const &) const; + /// + void doDispatch(Cursor & cur, FuncRequest & cmd); + /// + bool getStatus(Cursor &, FuncRequest const &, FuncStatus &) const; + /// + virtual docstring contextMenu(BufferView const & bv, int x, int y) const; private: /// Updates needed features for this inset. void validate(LaTeXFeatures & features) const; /// - EDITABLE editable() const { return NOT_EDITABLE; } - /// - InsetCode lyxCode() const; + bool hasSettings() const; + /// DisplayType display() const { return AlignCenter; } ///