* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
- * \author José Matos
+ * \author José Matos
*
* Full author contact details are available in file CREDITS.
*/
namespace lyx {
-
/// The reference inset
class InsetRef : public InsetCommand {
public:
///
std::string short_gui_name;
};
- static type_info types[];
- ///
- static int getType(std::string const & name);
- ///
- static std::string const & getName(int type);
+ static const type_info types[];
+ ///
+ InsetRef(Buffer * buffer, InsetCommandParams const &);
- InsetRef(Buffer const & buffer, InsetCommandParams const &);
+ ///
+ void changeTarget(docstring const & new_label);
+ /// \name Public functions inherited from Inset class
+ //@{
+ ///
+ docstring layoutName() const;
+ ///
+ void doDispatch(Cursor & cur, FuncRequest & cmd);
+ ///
+ bool getStatus(Cursor & cur, FuncRequest const & cmd, FuncStatus & status) const;
///
bool isLabeled() const { return true; }
///
- docstring screenLabel() const;
+ docstring toolTip(BufferView const &, int, int) const
+ { return tooltip_; }
///
- EDITABLE editable() const { return IS_EDITABLE; }
+ docstring getTOCString() const;
+ ///
+ bool hasSettings() const { return true; }
///
InsetCode lyxCode() const { return REF_CODE; }
///
- DisplayType display() const { return Inline; }
+ void latex(otexstream &, OutputParams const &) const;
+ ///
+ int plaintext(odocstringstream & ods, OutputParams const & op,
+ size_t max_length = INT_MAX) const;
///
- int latex(odocstream &, OutputParams const &) const;
+ void docbook(XMLStream &, OutputParams const &) const;
///
- int plaintext(odocstream &, OutputParams const &) const;
+ docstring xhtml(XMLStream &, OutputParams const &) const;
///
- int docbook(odocstream &, OutputParams const &) const;
- /// the string that is passed to the TOC
- void textString(odocstream &) const;
+ void toString(odocstream &) const;
+ ///
+ void forOutliner(docstring &, size_t const, bool const) const;
///
void validate(LaTeXFeatures & features) const;
///
+ void updateBuffer(ParIterator const & it, UpdateType, bool const deleted = false);
+ ///
+ void addToToc(DocIterator const & di, bool output_active,
+ UpdateType utype, TocBackend & backend) const;
+ ///
+ bool forceLTR(OutputParams const &) const;
+ //@}
+
+ /// \name Static public methods obligated for InsetCommand derived classes
+ //@{
+ ///
static ParamInfo const & findInfo(std::string const &);
///
- static std::string defaultCommand() { return "ref"; };
+ static std::string defaultCommand() { return "ref"; }
///
static bool isCompatibleCommand(std::string const & s);
+ //@}
///
- void updateLabels(ParIterator const & it);
- ///
- void addToToc(DocIterator const &);
+ bool outputActive() const { return active_; }
+
protected:
///
InsetRef(InsetRef const &);
+
private:
+ /// \name Private functions inherited from Inset class
+ //@{
///
Inset * clone() const { return new InsetRef(*this); }
+ //@}
+
+ /// \name Private functions inherited from InsetCommand class
+ //@{
///
- bool isLatex;
+ docstring screenLabel() const;
+ //@}
+
+ /// \return the label with things that need to be escaped escaped
+ docstring getEscapedLabel(OutputParams const &) const;
+ /// \return the command for a formatted reference to ref
+ /// \param label we're cross-referencing
+ /// \param argument for reference command
+ /// \param prefix of the label (before :)
+ docstring getFormattedCmd(docstring const & ref, docstring & label,
+ docstring & prefix, docstring const & caps) const;
+
///
mutable docstring screen_label_;
+ ///
+ mutable bool broken_;
+ ///
+ mutable bool active_;
+ ///
+ mutable docstring tooltip_;
};
+
} // namespace lyx
-#endif
+#endif // INSET_REF_H