1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 /** The SmNode is the basic structure of formula data.
22 * Each token is stored in one node of specific kind.
23 * They can have SmNodeType. It allows to identify node type after abstraction.
24 * Here goes the subclasses tree:
28 * SmStructureNode Head of tree diagram
31 * SmExpressionNode { content }
32 * SmUnHorNode unary operators +-; -+; +x; -x; ...
33 * SmRootNode Root structure
34 * SmBinHorNode binary operators A + B
35 * SmBinVerNode over; frac; ...
36 * SmBinDiagonalNode wideslash
37 * SmSubSupNode csub, csup, lsub, from, to, ...
38 * SmBraceNode (); []; left lbrace right rbrace; ...
39 * SmBracebodyNode ( content ); [ content ]; ...
40 * SmVerticalBraceNode overbrace; underbrace;
41 * SmOperNode sum from to; int from to;
42 * SmAlignNode text alignment
43 * SmAttributeNode font attributes; bold;
44 * SmFontNode font serif; ...
46 * SmVisibleNode drawable node
47 * SmGraphicNode graphics display
49 * SmPolyLineNode overline; underline; widehat; ...
50 * SmBlankNode blank space; ~; ...
51 * SmTextNode "text"; func functname; ...
53 * SmGlyphSpecialNode %symbolname
54 * SmMathSymbolNode math symbols
55 * SmMathIdentifierNode variable
56 * SmRootSymbolNode root symbol
58 * SmErrorNode red ? for errors
68 #include "nodetype.hxx"
70 #include <editeng/editdata.hxx>
71 #include <rtl/ustrbuf.hxx>
73 enum class FontAttribute
{
81 template<> struct typed_flags
<FontAttribute
> : is_typed_flags
<FontAttribute
, 0x0003> {};
85 enum class FontSizeType
{
93 // flags to interdict respective status changes
94 enum class FontChangeMask
{
106 template<> struct typed_flags
<FontChangeMask
> : is_typed_flags
<FontChangeMask
, 0x003f> {};
113 class SmStructureNode
;
115 typedef std::vector
< SmNode
* > SmNodeArray
;
117 enum class SmScaleMode
124 class SmNode
: public SmRect
126 // Rendering info for SmRect
128 // Anclage to the code
130 ESelection m_aESelection
;
133 SmScaleMode meScaleMode
;
134 RectHorAlign meRectHorAlign
;
135 FontChangeMask mnFlags
;
136 FontAttribute mnAttributes
;
139 // index in accessible text; -1 if not (yet) applicable
140 sal_Int32 mnAccIndex
;
143 SmNode(SmNodeType eNodeType
, SmToken aNodeToken
);
146 SmNode(const SmNode
&) = delete;
147 SmNode
& operator=(const SmNode
&) = delete;
152 * Checks node visibility.
153 * Returns true if this is an instance of SmVisibleNode's subclass, false otherwise.
154 * @return node visibility
156 virtual bool IsVisible() const = 0;
159 * Gets the number of subnodes.
160 * @return number of subnodes
162 virtual size_t GetNumSubNodes() const = 0;
165 * Gets the subnode of index nIndex.
167 * @return subnode of index nIndex
169 virtual SmNode
* GetSubNode(size_t nIndex
) = 0;
170 const SmNode
* GetSubNode(size_t nIndex
) const
171 { return const_cast<SmNode
*>(this)->GetSubNode(nIndex
); }
173 virtual const SmNode
* GetLeftMost() const;
176 * Gets the FontChangeMask flags.
177 * @return FontChangeMask flags
179 FontChangeMask
&Flags() { return mnFlags
; }
182 * Gets the font attributes.
183 * @return font attributes
185 FontAttribute
&Attributes() { return mnAttributes
; }
188 * Checks if it is a visible node rendered invisible.
189 * @return rendered visibility
191 bool IsPhantom() const { return mbIsPhantom
; }
194 * Sets the render visibility of a visible node to bIsPhantom.
198 void SetPhantom(bool bIsPhantom
);
201 * Sets the font color.
205 void SetColor(const Color
&rColor
);
208 * Sets the font attribute nAttrib.
209 * Check FontAttribute class.
213 void SetAttribute(FontAttribute nAttrib
);
216 * Clears the font attribute nAttrib.
217 * Check FontAttribute class.
221 void ClearAttribute(FontAttribute nAttrib
);
227 const SmFace
& GetFont() const { return maFace
; };
228 SmFace
& GetFont() { return maFace
; };
231 * Sets the font to rFace.
235 void SetFont(const SmFace
&rFace
);
238 * Sets the font size to rRelSize with type nType.
239 * Check FontSizeType for details.
244 void SetFontSize(const Fraction
&rRelSize
, FontSizeType nType
);
247 * Sets the font size to rRelSize with type FontSizeType::ABSOLUT.
251 void SetSize(const Fraction
&rScale
);
254 * Prepare preliminary settings about font and text
255 * (e.g. maFace, meRectHorAlign, mnFlags, mnAttributes, etc.)
261 virtual void Prepare(const SmFormat
&rFormat
, const SmDocShell
&rDocShell
, int nDepth
);
264 * Prepare preliminary font attributes
265 * Called on Prepare(...).
268 void PrepareAttributes();
271 * Sets the alignment of the text.
272 * Check RectHorAlign class for details.
273 * The subtrees will be affected if bApplyToSubTree.
275 * @param bApplyToSubTree
278 void SetRectHorAlign(RectHorAlign eHorAlign
, bool bApplyToSubTree
= true );
281 * Gets the alignment of the text.
282 * @return alignment of the text
284 RectHorAlign
GetRectHorAlign() const { return meRectHorAlign
; }
287 * Parses itself to SmRect.
290 const SmRect
& GetRect() const { return *this; }
293 * Moves the rectangle by rVector.
297 void Move(const Point
&rVector
);
300 * Moves the rectangle to rPoint, being the top left corner the origin.
304 void MoveTo(const Point
&rPoint
) { Move(rPoint
- GetTopLeft()); }
307 * Prepares the SmRect to render.
312 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) = 0;
315 * Appends to rText the node text.
319 virtual void GetAccessibleText( OUStringBuffer
&rText
) const = 0;
322 * Gets the node accessible index.
323 * Used for visual editing.
324 * @return node accessible index
326 sal_Int32
GetAccessibleIndex() const { return mnAccIndex
; }
329 * Sets the node accessible index to nAccIndex.
330 * Used for visual editing.
334 void SetAccessibleIndex(sal_Int32 nAccIndex
) { mnAccIndex
= nAccIndex
; }
337 * Finds the node with accessible index nAccIndex.
338 * Used for visual editing.
340 * @return node with accessible index nAccIndex
342 const SmNode
* FindNodeWithAccessibleIndex(sal_Int32 nAccIndex
) const;
345 * Gets the line in the text where the node is located.
346 * It is used to do the visual <-> text correspondence.
349 sal_Int32
GetRow() const { return m_aESelection
.start
.nPara
; }
352 * Gets the column of the line in the text where the node is located.
353 * It is used to do the visual <-> text correspondence.
356 sal_Int32
GetColumn() const { return m_aESelection
.start
.nIndex
; }
359 * Gets the scale mode.
362 SmScaleMode
GetScaleMode() const { return meScaleMode
; }
365 * Sets the scale mode to eMode.
369 void SetScaleMode(SmScaleMode eMode
) { meScaleMode
= eMode
; }
371 //visual stuff TODO comment
372 virtual void AdaptToX(OutputDevice
&rDev
, tools::Long nWidth
);
373 virtual void AdaptToY(OutputDevice
&rDev
, tools::Long nHeight
);
376 * Gets the node type.
379 SmNodeType
GetType() const { return meType
; }
383 * The token contains the data extracted from the text mode.
384 * Ej: text, type (sub, sup, int,...), row and column,...
387 const SmToken
& GetToken() const { return maNodeToken
; }
388 SmToken
& GetToken() { return maNodeToken
; }
391 * Gets node position in input text.
392 * @return node position in input text
394 const ESelection
& GetSelection() const { return m_aESelection
; }
397 * Gets node position in input text.
400 void SetSelection(ESelection aESelection
) { m_aESelection
= aESelection
; }
403 * Finds the node from the position in the text.
404 * It is used to do the visual <-> text correspondence.
407 * @return the given node
409 const SmNode
* FindTokenAt(sal_uInt16 nRow
, sal_uInt16 nCol
) const;
412 * Finds the closest rectangle in the screen.
414 * @return the given node
416 const SmNode
* FindRectClosestTo(const Point
&rPoint
) const;
420 * Calls the method for this class on the visitor.
424 virtual void Accept(SmVisitor
* pVisitor
) = 0;
427 * Checks if the node is selected.
428 * @return the node is selected
430 bool IsSelected() const {return mbIsSelected
;}
433 * Sets the node to Selected.
437 void SetSelected(bool Selected
) {mbIsSelected
= Selected
;}
440 * Gets the parent node of this node.
441 * @return parent node
443 const SmStructureNode
* GetParent() const { return mpParentNode
; }
444 SmStructureNode
* GetParent() { return mpParentNode
; }
447 * Sets the parent node.
451 void SetParent(SmStructureNode
* parent
){ mpParentNode
= parent
; }
454 * Sets the token for this node.
458 void SetToken(SmToken
const & token
){ maNodeToken
= token
; }
461 SmStructureNode
* mpParentNode
;
465 /** Abstract baseclass for all composite node
467 * Subclasses of this class can have subnodes. Nodes that doesn't derivate from
468 * this class does not have subnodes.
470 class SmStructureNode
: public SmNode
472 SmNodeArray maSubNodes
;
475 SmStructureNode(SmNodeType eNodeType
, const SmToken
&rNodeToken
, size_t nSize
= 0)
476 : SmNode(eNodeType
, rNodeToken
)
477 , maSubNodes(nSize
) {}
480 virtual ~SmStructureNode() override
;
483 * Checks node visibility.
484 * Returns true if this is an instance of SmVisibleNode's subclass, false otherwise.
485 * @return node visibility
487 virtual bool IsVisible() const override
;
490 * Gets the number of subnodes.
491 * @return number of subnodes
493 virtual size_t GetNumSubNodes() const override
;
496 * Gets the subnode of index nIndex.
498 * @return subnode of index nIndex
500 using SmNode::GetSubNode
;
501 virtual SmNode
* GetSubNode(size_t nIndex
) override
;
504 * Gets the subnode of index nIndex, used for operators.
506 * @return subnode of index nIndex
508 SmNode
* GetSubNodeBinMo(size_t nIndex
) const;
511 * Does the cleaning of the subnodes.
514 void ClearSubNodes();
517 * Sets subnodes, used for operators.
523 void SetSubNodes(std::unique_ptr
<SmNode
> pFirst
, std::unique_ptr
<SmNode
> pSecond
,
524 std::unique_ptr
<SmNode
> pThird
= nullptr);
533 void SetSubNodes(SmNode
* pFirst
, SmNode
* pSecond
, SmNode
* pThird
);
536 * Sets subnodes, used for operators.
537 * The data is reordered so the items are correctly ordered.
543 void SetSubNodesBinMo(std::unique_ptr
<SmNode
> pFirst
, std::unique_ptr
<SmNode
> pSecond
,
544 std::unique_ptr
<SmNode
> pThird
= nullptr);
551 void SetSubNodes(SmNodeArray
&& rNodeArray
);
554 * Appends to rText the node text.
558 virtual void GetAccessibleText( OUStringBuffer
&rText
) const override
;
561 * Gets the first subnode.
562 * @return first subnode
564 SmNodeArray::iterator
begin() {return maSubNodes
.begin();}
567 * Gets the last subnode.
568 * @return last subnode
570 SmNodeArray::iterator
end() {return maSubNodes
.end();}
573 * Gets the last subnode.
574 * @return last subnode
576 SmNodeArray::reverse_iterator
rbegin() {return maSubNodes
.rbegin();}
579 * Gets the first subnode.
580 * @return first subnode
582 SmNodeArray::reverse_iterator
rend() {return maSubNodes
.rend();}
585 * Get the index of the child node pSubNode.
586 * Returns -1, if pSubNode isn't a subnode of this.
588 * @return index of the child node
590 int IndexOfSubNode(SmNode
const * pSubNode
);
593 * Sets the subnode pNode at nIndex.
594 * If necessary increases the subnodes length.
599 void SetSubNode(size_t nIndex
, SmNode
* pNode
);
602 /** Sets parent on children of this node */
603 void ClaimPaternity();
607 /** Abstract base class for all visible node
609 * Nodes that doesn't derivate from this class doesn't draw anything, but their
612 class SmVisibleNode
: public SmNode
615 SmVisibleNode(SmNodeType eNodeType
, const SmToken
&rNodeToken
)
616 : SmNode(eNodeType
, rNodeToken
) {}
621 * Checks node visibility.
622 * Returns true if this is an instance of SmVisibleNode's subclass, false otherwise.
623 * @return node visibility
625 virtual bool IsVisible() const override
;
628 * Gets the number of subnodes.
629 * @return number of subnodes
631 virtual size_t GetNumSubNodes() const override
;
634 * Gets the subnode of index nIndex.
636 * @return subnode of index nIndex
638 using SmNode::GetSubNode
;
639 virtual SmNode
* GetSubNode(size_t nIndex
) override
;
643 class SmGraphicNode
: public SmVisibleNode
646 SmGraphicNode(SmNodeType eNodeType
, const SmToken
&rNodeToken
)
647 : SmVisibleNode(eNodeType
, rNodeToken
) {}
652 * Appends to rText the node text.
656 virtual void GetAccessibleText( OUStringBuffer
&rText
) const override
;
660 /** Draws a rectangle
662 * Used for drawing the line in the OVER and OVERSTRIKE commands.
664 class SmRectangleNode final
: public SmGraphicNode
669 explicit SmRectangleNode(const SmToken
&rNodeToken
)
670 : SmGraphicNode(SmNodeType::Rectangle
, rNodeToken
)
673 //visual stuff TODO comment
674 virtual void AdaptToX(OutputDevice
&rDev
, tools::Long nWidth
) override
;
675 virtual void AdaptToY(OutputDevice
&rDev
, tools::Long nHeight
) override
;
678 * Prepares the SmRect to render.
683 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
687 * Calls the method for this class on the visitor.
691 void Accept(SmVisitor
* pVisitor
) override
;
695 /** Polygon line node
697 * Used to draw the slash of the WIDESLASH command by SmBinDiagonalNode.
699 class SmPolyLineNode final
: public SmGraphicNode
701 tools::Polygon maPoly
;
706 explicit SmPolyLineNode(const SmToken
&rNodeToken
);
709 * Gets the width of the rect.
712 tools::Long
GetWidth() const { return mnWidth
; }
715 * Gets the polygon to draw the node.
718 tools::Polygon
&GetPolygon() { return maPoly
; }
720 //visual stuff TODO comment
721 virtual void AdaptToX(OutputDevice
&rDev
, tools::Long nWidth
) override
;
722 virtual void AdaptToY(OutputDevice
&rDev
, tools::Long nHeight
) override
;
725 * Prepares the SmRect to render.
730 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
734 * Calls the method for this class on the visitor.
738 void Accept(SmVisitor
* pVisitor
) override
;
744 * @remarks This class also serves as baseclass for all nodes that contains text.
746 class SmTextNode
: public SmVisibleNode
749 sal_uInt16 mnFontDesc
;
750 /** Index within text where the selection starts
751 * @remarks Only valid if SmNode::IsSelected() is true
753 sal_Int32 mnSelectionStart
;
754 /** Index within text where the selection ends
755 * @remarks Only valid if SmNode::IsSelected() is true
757 sal_Int32 mnSelectionEnd
;
760 SmTextNode(SmNodeType eNodeType
, const SmToken
&rNodeToken
, sal_uInt16 nFontDescP
);
763 SmTextNode(const SmToken
&rNodeToken
, sal_uInt16 nFontDescP
);
766 * Returns the font type being used (text, variable, symbol, ...).
769 sal_uInt16
GetFontDesc() const { return mnFontDesc
; }
772 * Sets the node text to rText.
776 void SetText(const OUString
&rText
) { maText
= rText
; }
779 * Gets the node text.
782 const OUString
& GetText() const { return maText
; }
783 OUString
& GetText() { return maText
; }
786 * Change the text of this node, including the underlying token to rText.
790 void ChangeText(const OUString
&rText
);
793 * Try to guess the correct FontDesc, used during visual editing
796 void AdjustFontDesc();
799 * Index within GetText() where the selection starts.
800 * @remarks Only valid of SmNode::IsSelected() is true.
803 sal_Int32
GetSelectionStart() const { return mnSelectionStart
; }
806 * Index within GetText() where the selection ends.
807 * @remarks Only valid of SmNode::IsSelected() is true.
810 sal_Int32
GetSelectionEnd() const {return mnSelectionEnd
; }
813 * Sets the index within GetText() where the selection starts to index.
817 void SetSelectionStart(sal_Int32 index
) {mnSelectionStart
= index
;}
820 * Sets the index within GetText() where the selection ends to index.
824 void SetSelectionEnd(sal_Int32 index
) {mnSelectionEnd
= index
;}
827 * Prepare preliminary settings about font and text
828 * (e.g. maFace, meRectHorAlign, mnFlags, mnAttributes, etc.)
834 virtual void Prepare(const SmFormat
&rFormat
, const SmDocShell
&rDocShell
,
835 int nDepth
) override
;
838 * Prepares the SmRect to render.
843 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
846 * Appends to rText the node text.
850 virtual void GetAccessibleText( OUStringBuffer
&rText
) const override
;
854 * Calls the method for this class on the visitor.
858 void Accept(SmVisitor
* pVisitor
) override
;
861 * Converts the character from StarMath's private area symbols to a matching Unicode
862 * character, if necessary. To be used when converting GetText() to a normal text.
864 * @return unicode char
866 static sal_Unicode
ConvertSymbolToUnicode(sal_Unicode nIn
);
870 /** Special node for user defined characters
872 * Node used for pre- and user-defined characters from:
873 * officecfg/registry/data/org/openoffice/Office/Math.xcu
875 * This is just single characters, I think.
877 class SmSpecialNode
: public SmTextNode
880 SmSpecialNode(SmNodeType eNodeType
, const SmToken
&rNodeToken
, sal_uInt16 _nFontDesc
);
883 explicit SmSpecialNode(const SmToken
&rNodeToken
);
886 * Prepare preliminary settings about font and text
887 * (e.g. maFace, meRectHorAlign, mnFlags, mnAttributes, etc.)
893 virtual void Prepare(const SmFormat
&rFormat
, const SmDocShell
&rDocShell
,
894 int nDepth
) override
;
897 * Prepares the SmRect to render.
902 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
906 * Calls the method for this class on the visitor.
910 void Accept(SmVisitor
* pVisitor
) override
;
914 /** Glyph node for custom operators
916 * This node is used with commands: oper, uoper and boper.
917 * E.g. in "A boper op B", "op" will be an instance of SmGlyphSpecialNode.
918 * "boper" simply interprets "op", the following token, as a binary operator.
919 * The command "uoper" interprets the following token as unary operator.
920 * For these commands an instance of SmGlyphSpecialNode is used for the
921 * operator token, following the command.
923 class SmGlyphSpecialNode final
: public SmSpecialNode
926 explicit SmGlyphSpecialNode(const SmToken
&rNodeToken
)
927 : SmSpecialNode(SmNodeType::GlyphSpecial
, rNodeToken
, FNT_MATH
)
931 * Prepares the SmRect to render.
936 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
940 * Calls the method for this class on the visitor.
944 void Accept(SmVisitor
* pVisitor
) override
;
950 * Use for math symbols such as plus, minus and integral in the INT command.
952 class SmMathSymbolNode
: public SmSpecialNode
955 SmMathSymbolNode(SmNodeType eNodeType
, const SmToken
&rNodeToken
)
956 : SmSpecialNode(eNodeType
, rNodeToken
, FNT_MATH
)
958 SetText(GetToken().cMathChar
);
962 explicit SmMathSymbolNode(const SmToken
&rNodeToken
);
964 //visual stuff TODO comment
965 virtual void AdaptToX(OutputDevice
&rDev
, tools::Long nWidth
) override
;
966 virtual void AdaptToY(OutputDevice
&rDev
, tools::Long nHeight
) override
;
969 * Prepare preliminary settings about font and text
970 * (e.g. maFace, meRectHorAlign, mnFlags, mnAttributes, etc.)
976 virtual void Prepare(const SmFormat
&rFormat
, const SmDocShell
&rDocShell
,
977 int nDepth
) override
;
980 * Prepares the SmRect to render.
985 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
989 * Calls the method for this class on the visitor.
993 void Accept(SmVisitor
* pVisitor
) override
;
999 * This behaves essentially the same as SmMathSymbolNode and is only used to
1000 * represent math symbols that should be exported as <mi> elements rather than
1003 class SmMathIdentifierNode final
: public SmMathSymbolNode
1006 explicit SmMathIdentifierNode(const SmToken
&rNodeToken
)
1007 : SmMathSymbolNode(SmNodeType::MathIdent
, rNodeToken
) {}
1011 /** Root symbol node
1013 * Root symbol node used by SmRootNode to create the root symbol, in front of
1014 * the line with the line above. I don't think this node should be used for
1017 class SmRootSymbolNode final
: public SmMathSymbolNode
1019 tools::Long mnBodyWidth
; // width of body (argument) of root sign
1022 explicit SmRootSymbolNode(const SmToken
&rNodeToken
)
1023 : SmMathSymbolNode(SmNodeType::RootSymbol
, rNodeToken
)
1024 , mnBodyWidth(0) { }
1027 * Gets the body width.
1028 * Allows to know how long is the root and paint it.
1029 * @return body width
1031 tools::Long
GetBodyWidth() const {return mnBodyWidth
;};
1033 //visual stuff TODO comment
1034 virtual void AdaptToX(OutputDevice
&rDev
, tools::Long nHeight
) override
;
1035 virtual void AdaptToY(OutputDevice
&rDev
, tools::Long nHeight
) override
;
1039 * Calls the method for this class on the visitor.
1043 void Accept(SmVisitor
* pVisitor
) override
;
1049 * Used to create the <?> command, that denotes place where something can be
1051 * It is drawn as a square with a shadow.
1053 class SmPlaceNode final
: public SmMathSymbolNode
1056 explicit SmPlaceNode(const SmToken
&rNodeToken
)
1057 : SmMathSymbolNode(SmNodeType::Place
, rNodeToken
) { }
1058 SmPlaceNode() : SmMathSymbolNode(SmNodeType::Place
, SmToken(TPLACE
, MS_PLACE
, u
"<?>"_ustr
)) { };
1061 * Prepare preliminary settings about font and text
1062 * (e.g. maFace, meRectHorAlign, mnFlags, mnAttributes, etc.)
1068 virtual void Prepare(const SmFormat
&rFormat
, const SmDocShell
&rDocShell
,
1069 int nDepth
) override
;
1072 * Prepares the SmRect to render.
1077 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1081 * Calls the method for this class on the visitor.
1085 void Accept(SmVisitor
* pVisitor
) override
;
1089 /** Error node, for parsing errors
1091 * This node is used for parsing errors and draws a questionmark turned upside
1092 * down (inverted question mark).
1094 class SmErrorNode final
: public SmMathSymbolNode
1097 explicit SmErrorNode(const SmToken
&rNodeToken
)
1098 : SmMathSymbolNode(SmNodeType::Error
, rNodeToken
) { SetText(OUString(MS_ERROR
)); }
1101 * Prepare preliminary settings about font and text
1102 * (e.g. maFace, meRectHorAlign, mnFlags, mnAttributes, etc.)
1108 virtual void Prepare(const SmFormat
&rFormat
, const SmDocShell
&rDocShell
,
1109 int nDepth
) override
;
1112 * Prepares the SmRect to render.
1117 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1121 * Calls the method for this class on the visitor.
1125 void Accept(SmVisitor
* pVisitor
) override
;
1131 * This is the root node for the formula tree. This node is also used for the
1132 * STACK and BINOM commands. When used for root node, its
1133 * children are instances of SmLineNode, and in some obscure cases the child
1134 * can be an instance of SmExpressionNode, mainly when errors occur.
1136 class SmTableNode final
: public SmStructureNode
1138 tools::Long mnFormulaBaseline
;
1140 explicit SmTableNode(const SmToken
&rNodeToken
)
1141 : SmStructureNode(SmNodeType::Table
, rNodeToken
)
1142 , mnFormulaBaseline(0) { }
1144 virtual const SmNode
* GetLeftMost() const override
;
1147 * Prepares the SmRect to render.
1152 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1155 * Gets the formula baseline.
1156 * @return formula baseline
1158 tools::Long
GetFormulaBaseline() const;
1162 * Calls the method for this class on the visitor.
1166 void Accept(SmVisitor
* pVisitor
) override
;
1172 * Used as child of SmTableNode when the SmTableNode is the root node of the
1175 class SmLineNode
: public SmStructureNode
1177 bool mbUseExtraSpaces
;
1180 SmLineNode(SmNodeType eNodeType
, const SmToken
&rNodeToken
)
1181 : SmStructureNode(eNodeType
, rNodeToken
)
1182 , mbUseExtraSpaces(true) { }
1185 explicit SmLineNode(const SmToken
&rNodeToken
)
1186 : SmStructureNode(SmNodeType::Line
, rNodeToken
)
1187 , mbUseExtraSpaces(true) { }
1190 * Sets if it going to use extra spaces.
1191 * It is used to set if there has to be space between node while rendering.
1192 * By default it is true.
1196 void SetUseExtraSpaces(bool bVal
) { mbUseExtraSpaces
= bVal
; }
1199 * Checks if it is using extra spaces.
1200 * It is used for calculating space between nodes when rendering.
1201 * By default it is true.
1202 * @return is using extra spaces
1204 bool IsUseExtraSpaces() const { return mbUseExtraSpaces
; };
1207 * Prepare preliminary settings about font and text
1208 * (e.g. maFace, meRectHorAlign, mnFlags, mnAttributes, etc.)
1214 virtual void Prepare(const SmFormat
&rFormat
, const SmDocShell
&rDocShell
,
1215 int nDepth
) override
;
1218 * Prepares the SmRect to render.
1223 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1227 * Calls the method for this class on the visitor.
1231 void Accept(SmVisitor
* pVisitor
) override
;
1237 * Used whenever you have an expression such as "A OVER {B + C}", here there is
1238 * an expression node that allows "B + C" to be the denominator of the
1239 * SmBinVerNode, that the OVER command creates.
1241 class SmExpressionNode final
: public SmLineNode
1244 explicit SmExpressionNode(const SmToken
&rNodeToken
)
1245 : SmLineNode(SmNodeType::Expression
, rNodeToken
) { }
1248 * Prepares the SmRect to render.
1253 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1257 * Calls the method for this class on the visitor.
1261 void Accept(SmVisitor
* pVisitor
) override
;
1265 /** Unary horizontal node
1267 * The same as SmBinHorNode except this is for unary operators.
1269 class SmUnHorNode final
: public SmStructureNode
1272 explicit SmUnHorNode(const SmToken
&rNodeToken
)
1273 : SmStructureNode(SmNodeType::UnHor
, rNodeToken
, 2) { }
1276 * Prepares the SmRect to render.
1281 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1285 * Calls the method for this class on the visitor.
1289 void Accept(SmVisitor
* pVisitor
) override
;
1295 * Used for create square roots and other roots, example:
1296 * \f$ \sqrt[\mbox{[Argument]}]{\mbox{[Body]}} \f$.
1299 * 0: Argument (optional)<BR>
1300 * 1: Symbol (instance of SmRootSymbolNode)<BR>
1302 * Where argument is optional and may be NULL.
1304 class SmRootNode final
: public SmStructureNode
1307 explicit SmRootNode(const SmToken
&rNodeToken
)
1308 : SmStructureNode(SmNodeType::Root
, rNodeToken
, 3) { }
1311 * Prepares the SmRect to render.
1316 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1320 * Calls the method for this class on the visitor.
1324 void Accept(SmVisitor
* pVisitor
) override
;
1327 * Returns the node containing the data of the order of the root.
1328 * @return order data
1330 const SmNode
* Argument() const { return const_cast<SmRootNode
*>(this)->Argument(); }
1331 SmNode
* Argument() { assert( GetNumSubNodes() == 3 ); return GetSubNode( 0 ); }
1334 * Returns the node containing the data of the character used for the root.
1335 * @return symbol data
1337 const SmRootSymbolNode
* Symbol() const { return const_cast<SmRootNode
*>(this)->Symbol(); }
1338 SmRootSymbolNode
* Symbol() { assert( GetNumSubNodes() == 3 );
1339 assert( GetSubNode( 1 )->GetType()
1340 == SmNodeType::RootSymbol
);
1341 return static_cast< SmRootSymbolNode
* >
1342 ( GetSubNode( 1 )); }
1345 * Returns the node containing the data inside the root.
1348 const SmNode
* Body() const { return const_cast<SmRootNode
*>(this)->Body(); }
1349 SmNode
* Body() { assert( GetNumSubNodes() == 3 ); return GetSubNode( 2 ); }
1354 /** Binary horizontal node
1356 * This node is used for binary operators. In a formula such as "A + B".
1359 * 0: Left operand<BR>
1360 * 1: Binary operator<BR>
1361 * 2: Right operand<BR>
1363 * None of the children may be NULL.
1365 class SmBinHorNode final
: public SmStructureNode
1368 explicit SmBinHorNode(const SmToken
&rNodeToken
)
1369 : SmStructureNode(SmNodeType::BinHor
, rNodeToken
, 3) { }
1372 * Prepares the SmRect to render.
1377 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1381 * Calls the method for this class on the visitor.
1385 void Accept(SmVisitor
* pVisitor
) override
;
1388 * Returns the node containing the data of the binary operator.
1389 * @return symbol data
1391 const SmNode
* Symbol() const { return const_cast<SmBinHorNode
*>(this)->Symbol(); }
1392 SmNode
* Symbol() { assert( GetNumSubNodes() == 3 ); return GetSubNode( 1 ); }
1395 * Returns the node containing the data of the left operand.
1396 * @return left operand data
1398 const SmNode
* LeftOperand() const { return const_cast<SmBinHorNode
*>(this)->LeftOperand(); }
1399 SmNode
* LeftOperand() { assert( GetNumSubNodes() == 3 ); return GetSubNode( 0 ); }
1402 * Returns the node containing the data of the right operand.
1403 * @return right operand data
1405 const SmNode
* RightOperand() const { return const_cast<SmBinHorNode
*>(this)->RightOperand(); }
1406 SmNode
* RightOperand() { assert( GetNumSubNodes() == 3 ); return GetSubNode( 2 ); }
1410 /** Binary horizontal node
1412 * This node is used for creating the OVER command, consider the formula:
1413 * "numerator OVER denominator", which looks like
1414 * \f$ \frac{\mbox{numerator}}{\mbox{denominator}} \f$
1418 * 1: Line (instance of SmRectangleNode)<BR>
1419 * 2: Denominator<BR>
1420 * None of the children may be NULL.
1422 class SmBinVerNode final
: public SmStructureNode
1425 explicit SmBinVerNode(const SmToken
&rNodeToken
)
1426 : SmStructureNode(SmNodeType::BinVer
, rNodeToken
, 3) { }
1428 virtual const SmNode
* GetLeftMost() const override
;
1431 * Prepares the SmRect to render.
1436 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1440 * Calls the method for this class on the visitor.
1444 void Accept(SmVisitor
* pVisitor
) override
;
1448 /** Binary diagonal node
1450 * Used for implementing the WIDESLASH command, example: "A WIDESLASH B".
1453 * 0: Left operand<BR>
1454 * 1: right operand<BR>
1455 * 2: Line (instance of SmPolyLineNode).<BR>
1456 * None of the children may be NULL.
1458 class SmBinDiagonalNode final
: public SmStructureNode
1463 * Returns the position and size of the diagonal line by reference.
1468 * @return position and size of the diagonal line
1470 void GetOperPosSize(Point
&rPos
, Size
&rSize
, const Point
&rDiagPoint
, double fAngleDeg
) const;
1473 explicit SmBinDiagonalNode(const SmToken
&rNodeToken
)
1474 : SmStructureNode(SmNodeType::BinDiagonal
, rNodeToken
, 3)
1475 , mbAscending(false) { }
1478 * Checks if it is of ascending type.
1487 * @return ascending.
1489 bool IsAscending() const { return mbAscending
; }
1492 * Sets if the wideslash is ascending to bVal.
1496 void SetAscending(bool bVal
) { mbAscending
= bVal
; }
1499 * Prepares the SmRect to render.
1504 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1508 * Calls the method for this class on the visitor.
1512 void Accept(SmVisitor
* pVisitor
) override
;
1516 /** Enum used to index sub-/supscripts in the 'maSubNodes' array
1519 * See graphic for positions at char:
1534 { CSUB
, CSUP
, RSUB
, RSUP
, LSUB
, LSUP
1537 /** numbers of entries in the above enum (that is: the number of possible
1540 #define SUBSUP_NUM_ENTRIES 6
1542 /** Super- and subscript node
1544 * Used for creating super- and subscripts for commands such as:
1545 * "^", "_", "lsup", "lsub", "csup" and "csub".
1546 * Example: "A^2" which looks like: \f$ A^2 \f$
1548 * This node is also used for creating limits on SmOperNode, when
1549 * "FROM" and "TO" commands are used with "INT", "SUM" or similar.
1551 * Children of this node can be enumerated using the SmSubSup enum.
1552 * Please note that children may be NULL, except for the body.
1553 * It is recommended that you access children using GetBody() and
1556 class SmSubSupNode final
: public SmStructureNode
1561 explicit SmSubSupNode(const SmToken
&rNodeToken
)
1562 : SmStructureNode(SmNodeType::SubSup
, rNodeToken
, 1 + SUBSUP_NUM_ENTRIES
)
1563 , mbUseLimits(false) { }
1566 * Returns the node with the data of what has to be superindex or subindex.
1569 const SmNode
* GetBody() const { return const_cast<SmSubSupNode
*>(this)->GetBody(); }
1570 SmNode
* GetBody() { return GetSubNode(0); }
1573 * Checks if it is going to be used for a limit.
1574 * Example lim from { x toward 0 } { {sin x}over x } = 1
1575 * @return is a limit
1577 bool IsUseLimits() const { return mbUseLimits
; };
1580 * Sets if it is going to be used for a limit to bVal.
1584 void SetUseLimits(bool bVal
) { mbUseLimits
= bVal
; }
1587 * Gets the node with the data of what has to be superindex or subindex.
1588 * The position to check is given by eSubSup.
1589 * @remarks this method may return NULL.
1593 const SmNode
* GetSubSup(SmSubSup eSubSup
) const { return const_cast< SmSubSupNode
* >
1594 ( this )->GetSubSup( eSubSup
); }
1595 SmNode
* GetSubSup(SmSubSup eSubSup
) { return GetSubNode(1 + eSubSup
); };
1598 * Sets the node with the data of what has to be superindex or subindex.
1601 void SetBody(SmNode
* pBody
) { SetSubNode(0, pBody
); }
1604 * Sets the node with the data of what has to be superindex or subindex.
1605 * The position to check is given by eSubSup.
1609 void SetSubSup(SmSubSup eSubSup
, SmNode
* pScript
) { SetSubNode( 1 + eSubSup
, pScript
); }
1612 * Prepares the SmRect to render.
1617 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1621 * Calls the method for this class on the visitor.
1625 void Accept(SmVisitor
* pVisitor
) override
;
1630 /** Node for brace construction
1632 * Used for "lbrace [body] rbrace" and similar constructions.
1633 * Should look like \f$ \{\mbox{[body]}\} \f$
1636 * 0: Opening brace<BR>
1637 * 1: Body (usually SmBracebodyNode)<BR>
1638 * 2: Closing brace<BR>
1639 * None of the children can be NULL.
1641 * Note that child 1 (Body) is usually SmBracebodyNode, but it can also be e.g. SmExpressionNode.
1643 class SmBraceNode final
: public SmStructureNode
1646 explicit SmBraceNode(const SmToken
&rNodeToken
)
1647 : SmStructureNode(SmNodeType::Brace
, rNodeToken
, 3) { }
1650 * Returns the node containing the data of the opening brace.
1651 * @return opening brace data
1653 const SmMathSymbolNode
* OpeningBrace() const { return const_cast<SmBraceNode
*>
1654 (this)->OpeningBrace(); }
1655 SmMathSymbolNode
* OpeningBrace() { assert( GetNumSubNodes() == 3 );
1656 assert( GetSubNode( 0 )->GetType()
1657 == SmNodeType::Math
);
1658 return static_cast< SmMathSymbolNode
* >
1659 ( GetSubNode( 0 )); }
1662 * Returns the node containing the data of what is between braces.
1665 const SmNode
* Body() const { return const_cast<SmBraceNode
*>(this)->Body(); }
1666 SmNode
* Body() { assert( GetNumSubNodes() == 3 ); return GetSubNode( 1 ); }
1669 * Returns the node containing the data of the closing brace.
1670 * @return closing brace data
1672 const SmMathSymbolNode
* ClosingBrace() const { return const_cast<SmBraceNode
*>
1673 (this)->ClosingBrace(); }
1674 SmMathSymbolNode
* ClosingBrace() { assert( GetNumSubNodes() == 3 );
1675 assert( GetSubNode( 2 )->GetType()
1676 == SmNodeType::Math
);
1677 return static_cast< SmMathSymbolNode
* >
1678 ( GetSubNode( 2 )); }
1681 * Prepares the SmRect to render.
1686 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1690 * Calls the method for this class on the visitor.
1694 void Accept(SmVisitor
* pVisitor
) override
;
1698 /** Body of an SmBraceNode
1700 * This usually only has one child an SmExpressionNode, however, it can also
1701 * have other children.
1702 * Consider the formula "lbrace [body1] mline [body2] rbrace", looks like:
1703 * \f$ \{\mbox{[body1] | [body2]}\} \f$.
1704 * In this case SmBracebodyNode will have three children, "[body1]", "|" and
1707 class SmBracebodyNode final
: public SmStructureNode
1709 tools::Long mnBodyHeight
;
1712 explicit SmBracebodyNode(const SmToken
&rNodeToken
)
1713 : SmStructureNode(SmNodeType::Bracebody
, rNodeToken
)
1714 , mnBodyHeight(0) { }
1717 * Prepares the SmRect to render.
1722 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1723 tools::Long
GetBodyHeight() const { return mnBodyHeight
; }
1727 * Calls the method for this class on the visitor.
1731 void Accept(SmVisitor
* pVisitor
) override
;
1735 /** Node for vertical brace construction
1737 * Used to implement commands "[body] underbrace [script]" and
1738 * "[body] overbrace [script]".
1739 * Underbrace should look like this \f$ \underbrace{\mbox{body}}_{\mbox{script}}\f$.
1745 * (None of these children are optional, e.g. they must all be not NULL).
1747 class SmVerticalBraceNode final
: public SmStructureNode
1750 explicit SmVerticalBraceNode(const SmToken
&rNodeToken
)
1751 : SmStructureNode(SmNodeType::VerticalBrace
, rNodeToken
, 3) { }
1754 * Returns the node containing the data of what the brace is pointing for.
1758 const SmNode
* Body() const { return const_cast<SmVerticalBraceNode
*>(this)->Body(); }
1759 SmNode
* Body() { assert( GetNumSubNodes() == 3 ); return GetSubNode( 0 ); }
1762 * Returns the node containing the data of the brace.
1763 * @return brace data
1765 const SmMathSymbolNode
* Brace() const { return const_cast<SmVerticalBraceNode
*>
1767 SmMathSymbolNode
* Brace() { assert( GetNumSubNodes() == 3 );
1768 assert( GetSubNode( 1 )->GetType()
1769 == SmNodeType::Math
);
1770 return static_cast< SmMathSymbolNode
* >
1771 ( GetSubNode( 1 )); }
1774 * Returns the node containing the data of what is in the brace.
1776 * @return opening brace data
1778 const SmNode
* Script() const { return const_cast<SmVerticalBraceNode
*>(this)->Script(); }
1779 SmNode
* Script() { assert( GetNumSubNodes() == 3 ); return GetSubNode( 2 ); }
1782 * Prepares the SmRect to render.
1787 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1791 * Calls the method for this class on the visitor.
1795 void Accept(SmVisitor
* pVisitor
) override
;
1800 * Used for commands like SUM, INT and similar.
1803 * 0: Operation (instance of SmMathSymbolNode or SmSubSupNode)<BR>
1805 * None of the children may be NULL.
1808 class SmOperNode final
: public SmStructureNode
1811 explicit SmOperNode(const SmToken
&rNodeToken
)
1812 : SmStructureNode(SmNodeType::Oper
, rNodeToken
, 2) { }
1815 * Returns the node with the operator data
1816 * @return operator data
1818 const SmNode
* GetSymbol() const { return const_cast<SmOperNode
*>(this)->GetSymbol(); }
1819 SmNode
* GetSymbol();
1822 * Returns the height of the node in base to the symbol
1823 * ( rSymbol contains the operator data )
1824 * and the font format ( rFormat ).
1827 * @return node's height
1829 tools::Long
CalcSymbolHeight(const SmNode
&rSymbol
, const SmFormat
&rFormat
) const;
1832 * Prepares the SmRect to render.
1837 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1841 * Calls the method for this class on the visitor.
1845 void Accept(SmVisitor
* pVisitor
) override
;
1849 /** Node used for alignment
1851 * This node has exactly one child at index 0.
1853 class SmAlignNode final
: public SmStructureNode
1856 explicit SmAlignNode(const SmToken
&rNodeToken
)
1857 : SmStructureNode(SmNodeType::Align
, rNodeToken
) { }
1860 * Prepares the SmRect to render.
1865 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1869 * Calls the method for this class on the visitor.
1873 void Accept(SmVisitor
* pVisitor
) override
;
1879 * Used to give an attribute to another node. Used for commands such as:
1880 * UNDERLINE, OVERLINE, OVERSTRIKE, WIDEVEC, WIDEHARPOON, WIDEHAT and WIDETILDE.
1885 * None of these may be NULL.
1887 class SmAttributeNode final
: public SmStructureNode
1890 explicit SmAttributeNode(const SmToken
&rNodeToken
)
1891 : SmStructureNode(SmNodeType::Attribute
, rNodeToken
, 2) {}
1894 * Prepares the SmRect to render.
1899 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1903 * Calls the method for this class on the visitor.
1907 void Accept(SmVisitor
* pVisitor
) override
;
1910 * Gets the attribute data.
1911 * @return attribute data
1913 const SmNode
* Attribute() const { return const_cast<SmAttributeNode
*>(this)->Attribute(); }
1914 SmNode
* Attribute() { assert( GetNumSubNodes() == 2 ); return GetSubNode( 0 ); }
1917 * Gets the body data ( the nodes affected by the attribute ).
1920 const SmNode
* Body() const { return const_cast<SmAttributeNode
*>(this)->Body(); }
1921 SmNode
* Body() { assert( GetNumSubNodes() == 2 ); return GetSubNode( 1 ); }
1927 * Used to change the font of its children.
1929 class SmFontNode final
: public SmStructureNode
1931 FontSizeType meSizeType
;
1932 Fraction maFontSize
;
1935 explicit SmFontNode(const SmToken
&rNodeToken
)
1936 : SmStructureNode(SmNodeType::Font
, rNodeToken
)
1937 , meSizeType(FontSizeType::MULTIPLY
)
1941 * Sets font size to rValue in nType mode.
1942 * Check FontSizeType for details.
1947 void SetSizeParameter(const Fraction
&rValue
, FontSizeType nType
)
1948 { meSizeType
= nType
; maFontSize
= rValue
; }
1951 * Returns the font size.
1952 * @return font size.
1954 const Fraction
& GetSizeParameter() const {return maFontSize
;}
1957 * Returns the font size type.
1958 * Check FontSizeType for details.
1959 * @return font size type.
1961 FontSizeType
GetSizeType() const {return meSizeType
;}
1964 * Prepare preliminary settings about font and text
1965 * (e.g. maFace, meRectHorAlign, mnFlags, mnAttributes, etc.)
1971 virtual void Prepare(const SmFormat
&rFormat
, const SmDocShell
&rDocShell
,
1972 int nDepth
) override
;
1975 * Prepares the SmRect to render.
1980 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
1984 * Calls the method for this class on the visitor.
1988 void Accept(SmVisitor
* pVisitor
) override
;
1994 * Used to implement the MATRIX command, example:
1995 * "matrix{ 1 # 2 ## 3 # 4}".
1997 class SmMatrixNode final
: public SmStructureNode
1999 sal_uInt16 mnNumRows
,
2003 explicit SmMatrixNode(const SmToken
&rNodeToken
)
2004 : SmStructureNode(SmNodeType::Matrix
, rNodeToken
)
2009 * Gets the number of rows of the matrix.
2010 * @return rows number
2012 sal_uInt16
GetNumRows() const {return mnNumRows
;}
2015 * Gets the number of columns of the matrix.
2016 * @return columns number
2018 sal_uInt16
GetNumCols() const {return mnNumCols
;}
2021 * Sets the dimensions of the matrix.
2022 * @param nMatrixRows
2023 * @param nMatrixCols
2026 void SetRowCol(sal_uInt16 nMatrixRows
, sal_uInt16 nMatrixCols
)
2027 { mnNumRows
= nMatrixRows
; mnNumCols
= nMatrixCols
; }
2029 virtual const SmNode
* GetLeftMost() const override
;
2032 * Prepares the SmRect to render.
2037 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
2041 * Calls the method for this class on the visitor.
2045 void Accept(SmVisitor
* pVisitor
) override
;
2049 /** Node for whitespace
2051 * Used to implement the commands "~" and "`". This node is just a blank space.
2053 class SmBlankNode final
: public SmGraphicNode
2058 explicit SmBlankNode(const SmToken
&rNodeToken
)
2059 : SmGraphicNode(SmNodeType::Blank
, rNodeToken
)
2062 void IncreaseBy(const SmToken
&rToken
, sal_uInt32 nMultiplyBy
= 1);
2063 void Clear() { mnNum
= 0; }
2064 sal_uInt16
GetBlankNum() const { return mnNum
; }
2065 void SetBlankNum(sal_uInt16 nNumber
) { mnNum
= nNumber
; }
2068 * Prepare preliminary settings about font and text
2069 * (e.g. maFace, meRectHorAlign, mnFlags, mnAttributes, etc.)
2075 virtual void Prepare(const SmFormat
&rFormat
, const SmDocShell
&rDocShell
,
2076 int nDepth
) override
;
2079 * Prepares the SmRect to render.
2084 virtual void Arrange(OutputDevice
&rDev
, const SmFormat
&rFormat
) override
;
2088 * Calls the method for this class on the visitor.
2092 void Accept(SmVisitor
* pVisitor
) override
;
2096 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */