4 * This file is part of LyX, the document processor.
5 * Licence details can be found in the file COPYING.
9 * Full author contact details are available in file CREDITS.
15 #include "InsetCommand.h"
21 /// The reference inset
22 class InsetRef : public InsetCommand {
26 std::string latex_name;
30 std::string short_gui_name;
32 static type_info types[];
34 static int getType(std::string const & name);
36 static std::string const & getName(int type);
39 InsetRef(Buffer * buffer, InsetCommandParams const &);
42 bool isLabeled() const { return true; }
44 docstring screenLabel() const { return screen_label_; }
46 docstring toolTip(BufferView const &, int, int) const
49 bool hasSettings() const { return true; }
51 InsetCode lyxCode() const { return REF_CODE; }
53 DisplayType display() const { return Inline; }
55 int latex(odocstream &, OutputParams const &) const;
57 int plaintext(odocstream &, OutputParams const &) const;
59 int docbook(odocstream &, OutputParams const &) const;
61 docstring xhtml(XHTMLStream &, OutputParams const &) const;
62 /// the string that is passed to the TOC
63 void tocString(odocstream &) const;
65 void validate(LaTeXFeatures & features) const;
67 static ParamInfo const & findInfo(std::string const &);
69 static std::string defaultCommand() { return "ref"; }
71 static bool isCompatibleCommand(std::string const & s);
73 void updateBuffer(ParIterator const & it, UpdateType);
75 void addToToc(DocIterator const &);
78 InsetRef(InsetRef const &);
81 Inset * clone() const { return new InsetRef(*this); }
84 /// Force inset into LTR environment if surroundings are RTL
85 bool forceLTR() const { return true; }
87 mutable docstring screen_label_;
89 mutable docstring tooltip_;