]> git.lyx.org Git - lyx.git/blob - src/insets/InsetText.h
This patch introduces an optional argument to Buffer::updateLabels(), so
[lyx.git] / src / insets / InsetText.h
1 // -*- C++ -*-
2 /**
3  * \file InsetText.h
4  * This file is part of LyX, the document processor.
5  * Licence details can be found in the file COPYING.
6  *
7  * \author Jürgen Vigna
8  *
9  * Full author contact details are available in file CREDITS.
10  */
11
12 #ifndef INSETTEXT_H
13 #define INSETTEXT_H
14
15 #include "Inset.h"
16
17 #include "ColorCode.h"
18 #include "Text.h"
19
20 #include "insets/InsetLayout.h"
21
22 namespace lyx {
23
24 class CompletionList;
25 class CursorSlice;
26 class Dimension;
27 class ParagraphList;
28 class InsetCaption;
29 class InsetTabular;
30
31 /**
32  A text inset is like a TeX box to write full text
33  (including styles and other insets) in a given space.
34  */
35 class InsetText : public Inset {
36 public:
37         enum UsePlain {
38                 DefaultLayout,
39                 PlainLayout
40         };
41         /// \param buffer
42         /// \param useplain whether to use the plain layout
43         /// This is needed because we cannot call the virtual function
44         /// usePlainLayout() from within the constructor.
45         explicit InsetText(Buffer * buffer, UsePlain type = DefaultLayout);
46         ///
47         InsetText(InsetText const &);
48         ///
49         void setBuffer(Buffer &);
50
51         ///
52         Dimension const dimension(BufferView const &) const;
53
54         /// empty inset to empty par
55         void clear();
56         ///
57         void read(Lexer & lex);
58         ///
59         void write(std::ostream & os) const;
60         ///
61         void metrics(MetricsInfo & mi, Dimension & dim) const;
62         ///
63         void draw(PainterInfo & pi, int x, int y) const;
64         ///
65         bool editable() const { return true; }
66         ///
67         bool canTrackChanges() const { return true; }
68         ///
69         InsetText * asInsetText() { return this; }
70         ///
71         InsetText const * asInsetText() const { return this; }
72         ///
73         Text & text() { return text_; }
74         Text const & text() const { return text_; }
75         ///
76         int latex(odocstream &, OutputParams const &) const;
77         ///
78         int plaintext(odocstream &, OutputParams const &) const;
79         ///
80         int docbook(odocstream &, OutputParams const &) const;
81         ///
82         docstring xhtml(XHTMLStream &, OutputParams const &) const;
83         ///
84         enum XHTMLOptions {
85                 JustText = 0,
86                 WriteOuterTag = 1,
87                 WriteLabel = 2,
88                 WriteInnerTag = 4,
89                 WriteEverything = 7
90         };
91         ///
92         docstring insetAsXHTML(XHTMLStream &, OutputParams const &, 
93                                XHTMLOptions) const;
94         // FIXME XHTMLStream to be removed
95         docstring xhtml(odocstream &, OutputParams const &) const 
96                 { return docstring (); }
97         ///
98         void validate(LaTeXFeatures & features) const;
99
100         /// return x,y of given position relative to the inset's baseline
101         void cursorPos(BufferView const & bv, CursorSlice const & sl,
102                 bool boundary, int & x, int & y) const;
103         ///
104         InsetCode lyxCode() const { return TEXT_CODE; }
105         ///
106         void setText(docstring const &, Font const &, bool trackChanges);
107         ///
108         void setAutoBreakRows(bool);
109         ///
110         bool getAutoBreakRows() const { return text_.autoBreakRows_; }
111         ///
112         void setDrawFrame(bool);
113         ///
114         ColorCode frameColor() const;
115         ///
116         void setFrameColor(ColorCode);
117         ///
118         bool showInsetDialog(BufferView *) const;
119         ///
120         Text * getText(int i) const {
121                 return (i == 0) ? const_cast<Text*>(&text_) : 0;
122         }
123         ///
124         virtual bool getStatus(Cursor & cur, FuncRequest const & cmd, FuncStatus &) const;
125
126         ///
127         void fixParagraphsFont();
128
129         /// set the change for the entire inset
130         void setChange(Change const & change);
131         /// accept the changes within the inset
132         void acceptChanges();
133         /// reject the changes within the inset
134         void rejectChanges();
135
136         /// append text onto the existing text
137         void appendParagraphs(ParagraphList &);
138
139         ///
140         void addPreview(DocIterator const &, graphics::PreviewLoader &) const;
141
142         ///
143         void edit(Cursor & cur, bool front, EntryDirection entry_from);
144         ///
145         Inset * editXY(Cursor & cur, int x, int y);
146
147         /// number of cells in this inset
148         size_t nargs() const { return 1; }
149         ///
150         ParagraphList & paragraphs();
151         ///
152         ParagraphList const & paragraphs() const;
153         ///
154         bool insetAllowed(InsetCode) const { return !getLayout().isPassThru(); }
155         /// Allow spellchecking, except for insets with latex_language
156         bool allowSpellCheck() const { return !getLayout().isPassThru(); }
157         ///
158         virtual bool isMacroScope() const { return false; }
159         ///
160         virtual bool allowMultiPar() const { return getLayout().isMultiPar(); }
161         ///
162         /// should paragraphs be forced to use the empty layout?
163         virtual bool forcePlainLayout(idx_type = 0) const 
164                 { return getLayout().forcePlainLayout(); }
165         /// should the user be allowed to customize alignment, etc.?
166         virtual bool allowParagraphCustomization(idx_type = 0) const 
167                 { return getLayout().allowParagraphCustomization(); }
168
169         /// Update the counters of this inset and of its contents
170         virtual void updateLabels(ParIterator const &, bool);
171         /// the string that is passed to the TOC
172         void tocString(odocstream &) const;
173         ///
174         void addToToc(DocIterator const &);
175         ///
176         Inset * clone() const { return new InsetText(*this); }
177         ///
178         bool notifyCursorLeaves(Cursor const & old, Cursor & cur);
179
180         ///
181         bool completionSupported(Cursor const &) const;
182         ///
183         bool inlineCompletionSupported(Cursor const & cur) const;
184         ///
185         bool automaticInlineCompletion() const;
186         ///
187         bool automaticPopupCompletion() const;
188         ///
189         bool showCompletionCursor() const;
190         ///
191         CompletionList const * createCompletionList(Cursor const & cur) const;
192         ///
193         docstring completionPrefix(Cursor const & cur) const;
194         ///
195         bool insertCompletion(Cursor & cur, docstring const & s, bool finished);
196         ///
197         void completionPosAndDim(Cursor const &, int & x, int & y, Dimension & dim) const;
198
199         ///
200         virtual docstring contextMenu(BufferView const & bv, int x, int y) const;
201         ///
202         void doDispatch(Cursor & cur, FuncRequest & cmd);
203 protected:
204         ///
205         InsetCaption const * getCaptionInset() const;
206         ///
207         docstring getCaptionText(OutputParams const &) const;
208         ///
209         docstring getCaptionHTML(OutputParams const &) const;
210 private:
211         ///
212         void initParagraphs(UsePlain type);
213         ///
214         void setParagraphOwner();
215         ///
216         bool drawFrame_;
217         ///
218         ColorCode frame_color_;
219         ///
220         mutable pit_type old_pit;
221         ///
222         mutable Text text_;
223 };
224
225
226 InsetText::XHTMLOptions operator|(InsetText::XHTMLOptions a1, InsetText::XHTMLOptions a2);
227
228 } // namespace lyx
229
230 #endif