3 * \file InsetMathHull.h
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.
12 #ifndef MATH_HULLINSET_H
13 #define MATH_HULLINSET_H
15 #include "InsetMathGrid.h"
18 #include "DocIterator.h"
19 #include "OutputEnums.h"
21 #include <boost/scoped_ptr.hpp>
27 class ParConstIterator;
31 /// This provides an interface between "LyX insets" and "LyX math insets"
32 class InsetMathHull : public InsetMathGrid {
35 InsetMathHull(Buffer * buf);
37 InsetMathHull(Buffer * buf, HullType type);
39 virtual ~InsetMathHull();
41 void setBuffer(Buffer &);
43 void updateBuffer(ParIterator const &, UpdateType);
45 void addToToc(DocIterator const &) const;
47 InsetMathHull & operator=(InsetMathHull const &);
49 mode_type currentMode() const;
51 void metrics(MetricsInfo & mi, Dimension & dim) const;
53 void drawBackground(PainterInfo & pi, int x, int y) const;
55 void draw(PainterInfo &, int x, int y) const;
57 void metricsT(TextMetricsInfo const & mi, Dimension & dim) const;
59 void drawT(TextPainter &, int x, int y) const;
61 docstring label(row_type row) const;
63 void label(row_type row, docstring const & label);
65 std::vector<InsetLabel *> const & getLabels() { return label_; }
67 ColorCode backgroundColor(PainterInfo const &) const;
69 void numbered(row_type row, bool num);
71 bool numbered(row_type row) const;
73 bool numberedType() const;
77 void validate(LaTeXFeatures & features) const;
78 /// identifies HullInset
79 InsetMathHull const * asHullInset() const { return this; }
80 /// identifies HullInset
81 InsetMathHull * asHullInset() { return this; }
84 void addRow(row_type row);
86 void delRow(row_type row);
88 void swapRow(row_type row);
90 void addCol(col_type col);
92 void delCol(col_type col);
95 HullType getType() const;
97 void mutate(HullType newtype);
100 int defaultColSpace(col_type col);
102 char defaultColAlign(col_type col);
104 bool idxFirst(Cursor &) const;
106 bool idxLast(Cursor &) const;
109 void write(WriteStream & os) const;
111 void normalize(NormalStream &) const;
113 void infoize(odocstream & os) const;
116 void write(std::ostream & os) const;
118 void header_write(WriteStream &) const;
120 void footer_write(WriteStream &) const;
122 void read(Lexer & lex);
124 bool readQuiet(Lexer & lex);
126 int plaintext(odocstream &, OutputParams const &) const;
128 int docbook(odocstream &, OutputParams const &) const;
130 docstring xhtml(XHTMLStream &, OutputParams const &) const;
132 void mathmlize(MathStream &) const;
134 void htmlize(HtmlStream &) const;
136 void mathAsLatex(WriteStream &) const;
138 void toString(odocstream &) const;
140 void forToc(docstring &, size_t) const;
142 /// get notification when the cursor leaves this inset
143 bool notifyCursorLeaves(Cursor const & old, Cursor & cur);
145 //bool insetAllowed(InsetCode code) const;
147 void addPreview(DocIterator const & inset_pos,
148 graphics::PreviewLoader &) const;
149 /// Recreates the preview if preview is enabled.
150 void reloadPreview(DocIterator const & pos) const;
152 void initUnicodeMath() const;
155 static int displayMargin() { return 12; }
157 /// Force inset into LTR environment if surroundings are RTL
158 virtual bool forceLTR() const { return true; }
160 void recordLocation(DocIterator const & di);
163 docstring contextMenuName() const;
165 InsetCode lyxCode() const { return MATH_HULL_CODE; }
168 InsetMathHull(InsetMathHull const &);
170 virtual void doDispatch(Cursor & cur, FuncRequest & cmd);
172 /// do we want to handle this event?
173 bool getStatus(Cursor & cur, FuncRequest const & cmd,
174 FuncStatus & status) const;
176 docstring eolString(row_type row, bool fragile, bool latex,
177 bool last_eoln) const;
180 virtual Inset * clone() const;
181 /// Prepare the preview if preview is enabled.
182 /// \param forexport: whether this is intended for export
183 /// If so, we ignore LyXRC and wait for the image to be generated.
184 void preparePreview(DocIterator const & pos,
185 bool forexport = false) const;
186 /// like reloadPreview, but forces load
187 /// used by image export
188 void loadPreview(DocIterator const & pos) const;
190 void setType(HullType type);
192 void validate1(LaTeXFeatures & features);
194 docstring nicelabel(row_type row) const;
196 void doExtern(Cursor & cur, FuncRequest & func);
198 void glueall(HullType type);
200 * split every row at the first relation operator.
201 * The number of columns must be 1. One column is added.
202 * The first relation operator and everything after it goes to the
207 * split every row at the first relation operator.
208 * The number of columns must be < 3. One or two columns are added.
209 * The first relation operator goes to the second column.
210 * Everything after it goes to the third column.
213 /// change number of columns, split or combine columns if necessary.
214 void changeCols(col_type);
216 docstring standardFont() const;
218 ColorCode standardColor() const;
219 /// consistency check
221 /// can this change its number of rows?
222 bool rowChangeOK() const;
223 /// can this change its number of cols?
224 bool colChangeOK() const;
225 /// are any of the equations numbered?
226 bool haveNumbers() const;
228 /// "none", "simple", "display", "eqnarray",...
231 std::vector<bool> numbered_;
233 std::vector<docstring> numbers_;
235 std::vector<InsetLabel *> label_;
237 boost::scoped_ptr<RenderPreview> preview_;
239 mutable bool use_preview_;
243 typedef std::map<docstring, int> CounterMap;
244 /// used to store current values of important counters
245 CounterMap counter_map;
251 virtual void mutateToText();
253 virtual void revealCodes(Cursor & cur) const;
255 bool editable() const { return true; }
257 void edit(Cursor & cur, bool front,
258 EntryDirection entry_from = ENTRY_DIRECTION_IGNORE);
260 Inset * editXY(Cursor & cur, int x, int y);
262 DisplayType display() const;
266 void handleFont(Cursor & cur, docstring const & arg,
267 docstring const & font);
269 void handleFont2(Cursor & cur, docstring const & arg);
271 bool previewState(BufferView * bv) const;