]> git.lyx.org Git - lyx.git/blob - src/insets/InsetArgument.h
Fix text direction issue for InsetInfo in RTL context
[lyx.git] / src / insets / InsetArgument.h
1 // -*- C++ -*-
2 /**
3  * \file InsetArgument.h
4  * This file is part of LyX, the document processor.
5  * Licence details can be found in the file COPYING.
6  *
7  * \author Martin Vermeer
8  *
9  * Full author contact details are available in file CREDITS.
10  */
11
12 #ifndef INSETARGUMENT_H
13 #define INSETARGUMENT_H
14
15
16 #include "InsetCollapsible.h"
17
18
19 namespace lyx {
20
21
22 /**
23  * InsetArgument. Used to insert a short version of sectioning header etc.
24  * automatically, or other optional LaTeX arguments
25  */
26 class InsetArgument : public InsetCollapsible
27 {
28 public:
29         ///
30         InsetArgument(Buffer *, std::string const &);
31
32         ///
33         InsetArgument const * asInsetArgument() const { return this; }
34
35         /// Outputting the parameter of a LaTeX command
36         void latexArgument(otexstream & os, OutputParams const & runparams_in,
37                            docstring const & ldelim, docstring const & rdelim,
38                            docstring const & presetarg) const;
39
40         std::string name() const { return name_; }
41
42         /// \name Public functions inherited from Inset class
43         //@{
44         ///
45         bool hasSettings() const { return false; }
46         ///
47         InsetCode lyxCode() const { return ARG_CODE; }
48         ///
49         docstring layoutName() const { return from_ascii("Argument"); }
50         /// Update the label string of this inset
51         void updateBuffer(ParIterator const &, UpdateType);
52         ///
53         void latex(otexstream &, OutputParams const &) const { }
54         ///
55         int plaintext(odocstringstream &, OutputParams const &, size_t) const { return 0; }
56         ///
57         int docbook(odocstream &, OutputParams const &) const { return 0; }
58         ///
59         docstring xhtml(XHTMLStream &, OutputParams const &) const
60                 { return docstring(); }
61         ///
62         void write(std::ostream & os) const;
63         ///
64         void read(Lexer & lex);
65         ///
66         bool neverIndent() const { return true; }
67         ///
68         std::string contextMenuName() const;
69         ///
70         bool isPassThru() const { return pass_thru_; }
71         ///
72         bool isTocCaption() const { return is_toc_caption_; }
73         ///
74         bool resetFontEdit() const { return false; }
75         //@}
76         /// \name Public functions inherited from InsetCollapsible class
77         //@{
78         ///
79         InsetLayout::InsetDecoration decoration() const;
80         ///
81         FontInfo getFont() const;
82         ///
83         FontInfo getLabelfont() const;
84         ///
85         ColorCode labelColor() const;
86         ///
87         void setButtonLabel();
88         //@}
89         ///
90         void addToToc(DocIterator const & dit, bool output_active,
91                       UpdateType utype, TocBackend & backend) const; //override
92
93 private:
94         ///
95         docstring toolTip(BufferView const & bv, int, int) const;
96         ///
97         void fixParagraphLanguage(Language const *);
98         ///
99         std::string name_;
100         ///
101         docstring labelstring_;
102         ///
103         docstring tooltip_;
104         ///
105         FontInfo font_;
106         ///
107         FontInfo labelfont_;
108         ///
109         std::string decoration_;
110         /// Are we in a pass-thru context?
111         bool pass_thru_context_;
112         /// Is the argument itself have an explicitly pass-thru?
113         bool pass_thru_local_;
114         /// Effective pass-thru setting (inherited or local)
115         bool pass_thru_;
116         ///
117         docstring pass_thru_chars_;
118         /// Does this argument provide content for the TOC?
119         bool is_toc_caption_;
120         /// The type of Toc this is the caption of, empty otherwise.
121         std::string caption_of_toc_;
122
123 protected:
124         /// \name Protected functions inherited from Inset class
125         //@{
126         ///
127         bool getStatus(Cursor &, FuncRequest const &, FuncStatus &) const;
128         ///
129         void doDispatch(Cursor & cur, FuncRequest & cmd);
130         ///
131         Inset * clone() const { return new InsetArgument(*this); }
132         /// Is the content of this inset part of the immediate (visible) text sequence?
133         bool isPartOfTextSequence() const { return false; }
134         //@}
135 };
136
137
138 } // namespace lyx
139
140 #endif // INSETARGUMENT_H