1 ///////////////////////////////////////////////////////////////////////////// 
   2 // Name:        wx/richtext/richtextbuffer.h 
   3 // Purpose:     Buffer for wxRichTextCtrl 
   4 // Author:      Julian Smart 
   8 // Copyright:   (c) Julian Smart 
   9 // Licence:     wxWindows licence 
  10 ///////////////////////////////////////////////////////////////////////////// 
  12 #ifndef _WX_RICHTEXTBUFFER_H_ 
  13 #define _WX_RICHTEXTBUFFER_H_ 
  20   Data is represented by a hierarchy of objects, all derived from 
  23   The top of the hierarchy is the buffer, a kind of wxRichTextParagraphLayoutBox. 
  24   These boxes will allow flexible placement of text boxes on a page, but 
  25   for now there is a single box representing the document, and this box is 
  26   a wxRichTextParagraphLayoutBox which contains further wxRichTextParagraph 
  27   objects, each of which can include text and images. 
  29   Each object maintains a range (start and end position) measured 
  30   from the start of the main parent box. 
  31   A paragraph object knows its range, and a text fragment knows its range 
  32   too. So, a character or image in a page has a position relative to the 
  33   start of the document, and a character in an embedded text box has 
  34   a position relative to that text box. For now, we will not be dealing with 
  35   embedded objects but it's something to bear in mind for later. 
  37   Note that internally, a range (5,5) represents a range of one character. 
  38   In the public wx[Rich]TextCtrl API, this would be passed to e.g. SetSelection 
  39   as (5,6). A paragraph with one character might have an internal range of (0, 1) 
  40   since the end of the paragraph takes up one position. 
  45   When Layout is called on an object, it is given a size which the object 
  46   must limit itself to, or one or more flexible directions (vertical 
  47   or horizontal). So for example a centered paragraph is given the page 
  48   width to play with (minus any margins), but can extend indefinitely 
  49   in the vertical direction. The implementation of Layout can then 
  50   cache the calculated size and position within the parent. 
  63 #include "wx/textctrl.h" 
  64 #include "wx/bitmap.h" 
  66 #include "wx/cmdproc.h" 
  67 #include "wx/txtstrm.h" 
  70 #include "wx/dataobj.h" 
  74 #define wxRichTextAttr wxTextAttr 
  75 #define wxTextAttrEx wxTextAttr 
  77 // Setting wxRICHTEXT_USE_OWN_CARET to 1 implements a 
  78 // caret reliably without using wxClientDC in case there 
  79 // are platform-specific problems with the generic caret. 
  80 #if defined(__WXGTK__) || defined(__WXMAC__) 
  81 #define wxRICHTEXT_USE_OWN_CARET 1 
  83 #define wxRICHTEXT_USE_OWN_CARET 0 
  86 // Switch off for binary compatibility, on for faster drawing 
  87 // Note: this seems to be buggy (overzealous use of extents) so 
  89 #define wxRICHTEXT_USE_OPTIMIZED_LINE_DRAWING 0 
  95 extern WXDLLIMPEXP_RICHTEXT 
const wxChar wxRichTextLineBreakChar
; 
  98  * File types in wxRichText context. 
 100 enum wxRichTextFileType
 
 102     wxRICHTEXT_TYPE_ANY 
= 0, 
 103     wxRICHTEXT_TYPE_TEXT
, 
 105     wxRICHTEXT_TYPE_HTML
, 
 111  * Forward declarations 
 114 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextCtrl
; 
 115 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextObject
; 
 116 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextCacheObject
; 
 117 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextObjectList
; 
 118 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextLine
; 
 119 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextParagraph
; 
 120 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextFileHandler
; 
 121 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextStyleSheet
; 
 122 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextListStyleDefinition
; 
 123 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextEvent
; 
 124 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextRenderer
; 
 125 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextBuffer
; 
 128  * Flags determining the available space, passed to Layout 
 131 #define wxRICHTEXT_FIXED_WIDTH      0x01 
 132 #define wxRICHTEXT_FIXED_HEIGHT     0x02 
 133 #define wxRICHTEXT_VARIABLE_WIDTH   0x04 
 134 #define wxRICHTEXT_VARIABLE_HEIGHT  0x08 
 136 // Only lay out the part of the buffer that lies within 
 137 // the rect passed to Layout. 
 138 #define wxRICHTEXT_LAYOUT_SPECIFIED_RECT 0x10 
 141  * Flags to pass to Draw 
 144 // Ignore paragraph cache optimization, e.g. for printing purposes 
 145 // where one line may be drawn higher (on the next page) compared 
 146 // with the previous line 
 147 #define wxRICHTEXT_DRAW_IGNORE_CACHE    0x01 
 150  * Flags returned from hit-testing 
 152 enum wxRichTextHitTestFlags
 
 154     // The point was not on this object 
 155     wxRICHTEXT_HITTEST_NONE 
=    0x01, 
 157     // The point was before the position returned from HitTest 
 158     wxRICHTEXT_HITTEST_BEFORE 
=  0x02, 
 160     // The point was after the position returned from HitTest 
 161     wxRICHTEXT_HITTEST_AFTER 
=   0x04, 
 163     // The point was on the position returned from HitTest 
 164     wxRICHTEXT_HITTEST_ON 
=      0x08, 
 166     // The point was on space outside content 
 167     wxRICHTEXT_HITTEST_OUTSIDE 
= 0x10 
 171  * Flags for GetRangeSize 
 174 #define wxRICHTEXT_FORMATTED        0x01 
 175 #define wxRICHTEXT_UNFORMATTED      0x02 
 176 #define wxRICHTEXT_CACHE_SIZE       0x04 
 177 #define wxRICHTEXT_HEIGHT_ONLY      0x08 
 180  * Flags for SetStyle/SetListStyle 
 183 #define wxRICHTEXT_SETSTYLE_NONE            0x00 
 185 // Specifies that this operation should be undoable 
 186 #define wxRICHTEXT_SETSTYLE_WITH_UNDO       0x01 
 188 // Specifies that the style should not be applied if the 
 189 // combined style at this point is already the style in question. 
 190 #define wxRICHTEXT_SETSTYLE_OPTIMIZE        0x02 
 192 // Specifies that the style should only be applied to paragraphs, 
 193 // and not the content. This allows content styling to be 
 194 // preserved independently from that of e.g. a named paragraph style. 
 195 #define wxRICHTEXT_SETSTYLE_PARAGRAPHS_ONLY 0x04 
 197 // Specifies that the style should only be applied to characters, 
 198 // and not the paragraph. This allows content styling to be 
 199 // preserved independently from that of e.g. a named paragraph style. 
 200 #define wxRICHTEXT_SETSTYLE_CHARACTERS_ONLY 0x08 
 202 // For SetListStyle only: specifies starting from the given number, otherwise 
 203 // deduces number from existing attributes 
 204 #define wxRICHTEXT_SETSTYLE_RENUMBER        0x10 
 206 // For SetListStyle only: specifies the list level for all paragraphs, otherwise 
 207 // the current indentation will be used 
 208 #define wxRICHTEXT_SETSTYLE_SPECIFY_LEVEL   0x20 
 210 // Resets the existing style before applying the new style 
 211 #define wxRICHTEXT_SETSTYLE_RESET           0x40 
 213 // Removes the given style instead of applying it 
 214 #define wxRICHTEXT_SETSTYLE_REMOVE          0x80 
 217  * Flags for text insertion 
 220 #define wxRICHTEXT_INSERT_NONE                              0x00 
 221 #define wxRICHTEXT_INSERT_WITH_PREVIOUS_PARAGRAPH_STYLE     0x01 
 222 #define wxRICHTEXT_INSERT_INTERACTIVE                       0x02 
 224 // A special flag telling the buffer to keep the first paragraph style 
 225 // as-is, when deleting a paragraph marker. In future we might pass a 
 226 // flag to InsertFragment and DeleteRange to indicate the appropriate mode. 
 227 #define wxTEXT_ATTR_KEEP_FIRST_PARA_STYLE   0x10000000 
 230  * Default superscript/subscript font multiplication factor 
 233 #define wxSCRIPT_MUL_FACTOR             1.5 
 236  * wxRichTextFontTable 
 237  * Manages quick access to a pool of fonts for rendering rich text 
 240 class WXDLLIMPEXP_RICHTEXT wxRichTextFontTable
: public wxObject
 
 243     wxRichTextFontTable(); 
 245     wxRichTextFontTable(const wxRichTextFontTable
& table
); 
 246     virtual ~wxRichTextFontTable(); 
 248     bool IsOk() const { return m_refData 
!= NULL
; } 
 250     wxFont 
FindFont(const wxTextAttr
& fontSpec
); 
 253     void operator= (const wxRichTextFontTable
& table
); 
 254     bool operator == (const wxRichTextFontTable
& table
) const; 
 255     bool operator != (const wxRichTextFontTable
& table
) const { return !(*this == table
); } 
 259     DECLARE_DYNAMIC_CLASS(wxRichTextFontTable
) 
 263  * wxRichTextRange class declaration 
 264  * This stores beginning and end positions for a range of data. 
 265  * TODO: consider renaming wxTextRange and using for all text controls. 
 268 class WXDLLIMPEXP_RICHTEXT wxRichTextRange
 
 273     wxRichTextRange() { m_start 
= 0; m_end 
= 0; } 
 274     wxRichTextRange(long start
, long end
) { m_start 
= start
; m_end 
= end
; } 
 275     wxRichTextRange(const wxRichTextRange
& range
) { m_start 
= range
.m_start
; m_end 
= range
.m_end
; } 
 276     ~wxRichTextRange() {} 
 278     void operator =(const wxRichTextRange
& range
) { m_start 
= range
.m_start
; m_end 
= range
.m_end
; } 
 279     bool operator ==(const wxRichTextRange
& range
) const { return (m_start 
== range
.m_start 
&& m_end 
== range
.m_end
); } 
 280     bool operator !=(const wxRichTextRange
& range
) const { return (m_start 
!= range
.m_start 
|| m_end 
!= range
.m_end
); } 
 281     wxRichTextRange 
operator -(const wxRichTextRange
& range
) const { return wxRichTextRange(m_start 
- range
.m_start
, m_end 
- range
.m_end
); } 
 282     wxRichTextRange 
operator +(const wxRichTextRange
& range
) const { return wxRichTextRange(m_start 
+ range
.m_start
, m_end 
+ range
.m_end
); } 
 284     void SetRange(long start
, long end
) { m_start 
= start
; m_end 
= end
; } 
 286     void SetStart(long start
) { m_start 
= start
; } 
 287     long GetStart() const { return m_start
; } 
 289     void SetEnd(long end
) { m_end 
= end
; } 
 290     long GetEnd() const { return m_end
; } 
 292     /// Returns true if this range is completely outside 'range' 
 293     bool IsOutside(const wxRichTextRange
& range
) const { return range
.m_start 
> m_end 
|| range
.m_end 
< m_start
; } 
 295     /// Returns true if this range is completely within 'range' 
 296     bool IsWithin(const wxRichTextRange
& range
) const { return m_start 
>= range
.m_start 
&& m_end 
<= range
.m_end
; } 
 298     /// Returns true if the given position is within this range. Allow 
 299     /// for the possibility of an empty range - assume the position 
 300     /// is within this empty range. NO, I think we should not match with an empty range. 
 301     // bool Contains(long pos) const { return pos >= m_start && (pos <= m_end || GetLength() == 0); } 
 302     bool Contains(long pos
) const { return pos 
>= m_start 
&& pos 
<= m_end 
; } 
 304     /// Limit this range to be within 'range' 
 305     bool LimitTo(const wxRichTextRange
& range
) ; 
 307     /// Gets the length of the range 
 308     long GetLength() const { return m_end 
- m_start 
+ 1; } 
 310     /// Swaps the start and end 
 311     void Swap() { long tmp 
= m_start
; m_start 
= m_end
; m_end 
= tmp
; } 
 313     /// Convert to internal form: (n, n) is the range of a single character. 
 314     wxRichTextRange 
ToInternal() const { return wxRichTextRange(m_start
, m_end
-1); } 
 316     /// Convert from internal to public API form: (n, n+1) is the range of a single character. 
 317     wxRichTextRange 
FromInternal() const { return wxRichTextRange(m_start
, m_end
+1); } 
 324 #define wxRICHTEXT_ALL  wxRichTextRange(-2, -2) 
 325 #define wxRICHTEXT_NONE  wxRichTextRange(-1, -1) 
 328  * wxRichTextObject class declaration 
 329  * This is the base for drawable objects. 
 332 class WXDLLIMPEXP_RICHTEXT wxRichTextObject
: public wxObject
 
 334     DECLARE_CLASS(wxRichTextObject
) 
 338     wxRichTextObject(wxRichTextObject
* parent 
= NULL
); 
 339     virtual ~wxRichTextObject(); 
 343     /// Draw the item, within the given range. Some objects may ignore the range (for 
 344     /// example paragraphs) while others must obey it (lines, to implement wrapping) 
 345     virtual bool Draw(wxDC
& dc
, const wxRichTextRange
& range
, const wxRichTextRange
& selectionRange
, const wxRect
& rect
, int descent
, int style
) = 0; 
 347     /// Lay the item out at the specified position with the given size constraint. 
 348     /// Layout must set the cached size. 
 349     virtual bool Layout(wxDC
& dc
, const wxRect
& rect
, int style
) = 0; 
 351     /// Hit-testing: returns a flag indicating hit test details, plus 
 352     /// information about position 
 353     virtual int HitTest(wxDC
& WXUNUSED(dc
), const wxPoint
& WXUNUSED(pt
), long& WXUNUSED(textPosition
)) { return false; } 
 355     /// Finds the absolute position and row height for the given character position 
 356     virtual bool FindPosition(wxDC
& WXUNUSED(dc
), long WXUNUSED(index
), wxPoint
& WXUNUSED(pt
), int* WXUNUSED(height
), bool WXUNUSED(forceLineStart
)) { return false; } 
 358     /// Get the best size, i.e. the ideal starting size for this object irrespective 
 359     /// of available space. For a short text string, it will be the size that exactly encloses 
 360     /// the text. For a longer string, it might use the parent width for example. 
 361     virtual wxSize 
GetBestSize() const { return m_size
; } 
 363     /// Get the object size for the given range. Returns false if the range 
 364     /// is invalid for this object. 
 365     virtual bool GetRangeSize(const wxRichTextRange
& range
, wxSize
& size
, int& descent
, wxDC
& dc
, int flags
, wxPoint position 
= wxPoint(0,0), wxArrayInt
* partialExtents 
= NULL
) const  = 0; 
 367     /// Do a split, returning an object containing the second part, and setting 
 368     /// the first part in 'this'. 
 369     virtual wxRichTextObject
* DoSplit(long WXUNUSED(pos
)) { return NULL
; } 
 371     /// Calculate range. By default, guess that the object is 1 unit long. 
 372     virtual void CalculateRange(long start
, long& end
) { end 
= start 
; m_range
.SetRange(start
, end
); } 
 375     virtual bool DeleteRange(const wxRichTextRange
& WXUNUSED(range
)) { return false; } 
 377     /// Returns true if the object is empty 
 378     virtual bool IsEmpty() const { return false; } 
 380     /// Get any text in this object for the given range 
 381     virtual wxString 
GetTextForRange(const wxRichTextRange
& WXUNUSED(range
)) const { return wxEmptyString
; } 
 383     /// Returns true if this object can merge itself with the given one. 
 384     virtual bool CanMerge(wxRichTextObject
* WXUNUSED(object
)) const { return false; } 
 386     /// Returns true if this object merged itself with the given one. 
 387     /// The calling code will then delete the given object. 
 388     virtual bool Merge(wxRichTextObject
* WXUNUSED(object
)) { return false; } 
 390     /// Dump to output stream for debugging 
 391     virtual void Dump(wxTextOutputStream
& stream
); 
 395     /// Get/set the cached object size as calculated by Layout. 
 396     virtual wxSize 
GetCachedSize() const { return m_size
; } 
 397     virtual void SetCachedSize(const wxSize
& sz
) { m_size 
= sz
; } 
 399     /// Get/set the object position 
 400     virtual wxPoint 
GetPosition() const { return m_pos
; } 
 401     virtual void SetPosition(const wxPoint
& pos
) { m_pos 
= pos
; } 
 403     /// Get the rectangle enclosing the object 
 404     virtual wxRect 
GetRect() const { return wxRect(GetPosition(), GetCachedSize()); } 
 407     void SetRange(const wxRichTextRange
& range
) { m_range 
= range
; } 
 410     const wxRichTextRange
& GetRange() const { return m_range
; } 
 411     wxRichTextRange
& GetRange() { return m_range
; } 
 413     /// Get/set dirty flag (whether the object needs Layout to be called) 
 414     virtual bool GetDirty() const { return m_dirty
; } 
 415     virtual void SetDirty(bool dirty
) { m_dirty 
= dirty
; } 
 417     /// Is this composite? 
 418     virtual bool IsComposite() const { return false; } 
 420     /// Get/set the parent. 
 421     virtual wxRichTextObject
* GetParent() const { return m_parent
; } 
 422     virtual void SetParent(wxRichTextObject
* parent
) { m_parent 
= parent
; } 
 424     /// Set the margin around the object 
 425     virtual void SetMargins(int margin
); 
 426     virtual void SetMargins(int leftMargin
, int rightMargin
, int topMargin
, int bottomMargin
); 
 427     virtual int GetLeftMargin() const { return m_leftMargin
; } 
 428     virtual int GetRightMargin() const { return m_rightMargin
; } 
 429     virtual int GetTopMargin() const { return m_topMargin
; } 
 430     virtual int GetBottomMargin() const { return m_bottomMargin
; } 
 432     /// Set attributes object 
 433     void SetAttributes(const wxTextAttr
& attr
) { m_attributes 
= attr
; } 
 434     const wxTextAttr
& GetAttributes() const { return m_attributes
; } 
 435     wxTextAttr
& GetAttributes() { return m_attributes
; } 
 437     /// Set/get stored descent 
 438     void SetDescent(int descent
) { m_descent 
= descent
; } 
 439     int GetDescent() const { return m_descent
; } 
 441     /// Gets the containing buffer 
 442     wxRichTextBuffer
* GetBuffer() const; 
 447     virtual wxRichTextObject
* Clone() const { return NULL
; } 
 450     void Copy(const wxRichTextObject
& obj
); 
 452     /// Reference-counting allows us to use the same object in multiple 
 453     /// lists (not yet used) 
 454     void Reference() { m_refCount 
++; } 
 457     /// Convert units in tenths of a millimetre to device units 
 458     int ConvertTenthsMMToPixels(wxDC
& dc
, int units
); 
 459     static int ConvertTenthsMMToPixels(int ppi
, int units
); 
 464     int                     m_descent
; // Descent for this object (if any) 
 467     wxRichTextObject
*       m_parent
; 
 469     /// The range of this object (start position to end position) 
 470     wxRichTextRange         m_range
; 
 479     wxTextAttr          m_attributes
; 
 482 WX_DECLARE_LIST_WITH_DECL( wxRichTextObject
, wxRichTextObjectList
, class WXDLLIMPEXP_RICHTEXT 
); 
 485  * wxRichTextCompositeObject class declaration 
 486  * Objects of this class can contain other objects. 
 489 class WXDLLIMPEXP_RICHTEXT wxRichTextCompositeObject
: public wxRichTextObject
 
 491     DECLARE_CLASS(wxRichTextCompositeObject
) 
 495     wxRichTextCompositeObject(wxRichTextObject
* parent 
= NULL
); 
 496     virtual ~wxRichTextCompositeObject(); 
 500     /// Hit-testing: returns a flag indicating hit test details, plus 
 501     /// information about position 
 502     virtual int HitTest(wxDC
& dc
, const wxPoint
& pt
, long& textPosition
); 
 504     /// Finds the absolute position and row height for the given character position 
 505     virtual bool FindPosition(wxDC
& dc
, long index
, wxPoint
& pt
, int* height
, bool forceLineStart
); 
 508     virtual void CalculateRange(long start
, long& end
); 
 511     virtual bool DeleteRange(const wxRichTextRange
& range
); 
 513     /// Get any text in this object for the given range 
 514     virtual wxString 
GetTextForRange(const wxRichTextRange
& range
) const; 
 516     /// Dump to output stream for debugging 
 517     virtual void Dump(wxTextOutputStream
& stream
); 
 522     wxRichTextObjectList
& GetChildren() { return m_children
; } 
 523     const wxRichTextObjectList
& GetChildren() const { return m_children
; } 
 525     /// Get the child count 
 526     size_t GetChildCount() const ; 
 528     /// Get the nth child 
 529     wxRichTextObject
* GetChild(size_t n
) const ; 
 531     /// Get/set dirty flag 
 532     virtual bool GetDirty() const { return m_dirty
; } 
 533     virtual void SetDirty(bool dirty
) { m_dirty 
= dirty
; } 
 535     /// Is this composite? 
 536     virtual bool IsComposite() const { return true; } 
 538     /// Returns true if the buffer is empty 
 539     virtual bool IsEmpty() const { return GetChildCount() == 0; } 
 544     void Copy(const wxRichTextCompositeObject
& obj
); 
 547     void operator= (const wxRichTextCompositeObject
& obj
) { Copy(obj
); } 
 549     /// Append a child, returning the position 
 550     size_t AppendChild(wxRichTextObject
* child
) ; 
 552     /// Insert the child in front of the given object, or at the beginning 
 553     bool InsertChild(wxRichTextObject
* child
, wxRichTextObject
* inFrontOf
) ; 
 556     bool RemoveChild(wxRichTextObject
* child
, bool deleteChild 
= false) ; 
 558     /// Delete all children 
 559     bool DeleteChildren() ; 
 561     /// Recursively merge all pieces that can be merged. 
 562     bool Defragment(const wxRichTextRange
& range 
= wxRICHTEXT_ALL
); 
 565     wxRichTextObjectList    m_children
; 
 569  * wxRichTextBox class declaration 
 570  * This defines a 2D space to lay out objects 
 573 class WXDLLIMPEXP_RICHTEXT wxRichTextBox
: public wxRichTextCompositeObject
 
 575     DECLARE_DYNAMIC_CLASS(wxRichTextBox
) 
 579     wxRichTextBox(wxRichTextObject
* parent 
= NULL
); 
 580     wxRichTextBox(const wxRichTextBox
& obj
): wxRichTextCompositeObject() { Copy(obj
); } 
 585     virtual bool Draw(wxDC
& dc
, const wxRichTextRange
& range
, const wxRichTextRange
& selectionRange
, const wxRect
& rect
, int descent
, int style
); 
 588     virtual bool Layout(wxDC
& dc
, const wxRect
& rect
, int style
); 
 590     /// Get/set the object size for the given range. Returns false if the range 
 591     /// is invalid for this object. 
 592     virtual bool GetRangeSize(const wxRichTextRange
& range
, wxSize
& size
, int& descent
, wxDC
& dc
, int flags
, wxPoint position 
= wxPoint(0,0), wxArrayInt
* partialExtents 
= NULL
) const; 
 599     virtual wxRichTextObject
* Clone() const { return new wxRichTextBox(*this); } 
 602     void Copy(const wxRichTextBox
& obj
); 
 608  * wxRichTextParagraphBox class declaration 
 609  * This box knows how to lay out paragraphs. 
 612 class WXDLLIMPEXP_RICHTEXT wxRichTextParagraphLayoutBox
: public wxRichTextBox
 
 614     DECLARE_DYNAMIC_CLASS(wxRichTextParagraphLayoutBox
) 
 618     wxRichTextParagraphLayoutBox(wxRichTextObject
* parent 
= NULL
); 
 619     wxRichTextParagraphLayoutBox(const wxRichTextParagraphLayoutBox
& obj
): wxRichTextBox() { Init(); Copy(obj
); } 
 624     virtual bool Draw(wxDC
& dc
, const wxRichTextRange
& range
, const wxRichTextRange
& selectionRange
, const wxRect
& rect
, int descent
, int style
); 
 627     virtual bool Layout(wxDC
& dc
, const wxRect
& rect
, int style
); 
 629     /// Get/set the object size for the given range. Returns false if the range 
 630     /// is invalid for this object. 
 631     virtual bool GetRangeSize(const wxRichTextRange
& range
, wxSize
& size
, int& descent
, wxDC
& dc
, int flags
, wxPoint position 
= wxPoint(0,0), wxArrayInt
* partialExtents 
= NULL
) const; 
 634     virtual bool DeleteRange(const wxRichTextRange
& range
); 
 636     /// Get any text in this object for the given range 
 637     virtual wxString 
GetTextForRange(const wxRichTextRange
& range
) const; 
 641     /// Associate a control with the buffer, for operations that for example require refreshing the window. 
 642     void SetRichTextCtrl(wxRichTextCtrl
* ctrl
) { m_ctrl 
= ctrl
; } 
 644     /// Get the associated control. 
 645     wxRichTextCtrl
* GetRichTextCtrl() const { return m_ctrl
; } 
 647     /// Get/set whether the last paragraph is partial or complete 
 648     void SetPartialParagraph(bool partialPara
) { m_partialParagraph 
= partialPara
; } 
 649     bool GetPartialParagraph() const { return m_partialParagraph
; } 
 651     /// If this is a buffer, returns the current style sheet. The base layout box 
 652     /// class doesn't have an associated style sheet. 
 653     virtual wxRichTextStyleSheet
* GetStyleSheet() const { return NULL
; } 
 657     /// Initialize the object. 
 660     /// Clear all children 
 661     virtual void Clear(); 
 663     /// Clear and initialize with one blank paragraph 
 664     virtual void Reset(); 
 666     /// Convenience function to add a paragraph of text 
 667     virtual wxRichTextRange 
AddParagraph(const wxString
& text
, wxTextAttr
* paraStyle 
= NULL
); 
 669     /// Convenience function to add an image 
 670     virtual wxRichTextRange 
AddImage(const wxImage
& image
, wxTextAttr
* paraStyle 
= NULL
); 
 672     /// Adds multiple paragraphs, based on newlines. 
 673     virtual wxRichTextRange 
AddParagraphs(const wxString
& text
, wxTextAttr
* paraStyle 
= NULL
); 
 675     /// Get the line at the given position. If caretPosition is true, the position is 
 676     /// a caret position, which is normally a smaller number. 
 677     virtual wxRichTextLine
* GetLineAtPosition(long pos
, bool caretPosition 
= false) const; 
 679     /// Get the line at the given y pixel position, or the last line. 
 680     virtual wxRichTextLine
* GetLineAtYPosition(int y
) const; 
 682     /// Get the paragraph at the given character or caret position 
 683     virtual wxRichTextParagraph
* GetParagraphAtPosition(long pos
, bool caretPosition 
= false) const; 
 685     /// Get the line size at the given position 
 686     virtual wxSize 
GetLineSizeAtPosition(long pos
, bool caretPosition 
= false) const; 
 688     /// Given a position, get the number of the visible line (potentially many to a paragraph), 
 689     /// starting from zero at the start of the buffer. We also have to pass a bool (startOfLine) 
 690     /// that indicates whether the caret is being shown at the end of the previous line or at the start 
 691     /// of the next, since the caret can be shown at 2 visible positions for the same underlying 
 693     virtual long GetVisibleLineNumber(long pos
, bool caretPosition 
= false, bool startOfLine 
= false) const; 
 695     /// Given a line number, get the corresponding wxRichTextLine object. 
 696     virtual wxRichTextLine
* GetLineForVisibleLineNumber(long lineNumber
) const; 
 698     /// Get the leaf object in a paragraph at this position. 
 699     /// Given a line number, get the corresponding wxRichTextLine object. 
 700     virtual wxRichTextObject
* GetLeafObjectAtPosition(long position
) const; 
 702     /// Get the paragraph by number 
 703     virtual wxRichTextParagraph
* GetParagraphAtLine(long paragraphNumber
) const; 
 705     /// Get the paragraph for a given line 
 706     virtual wxRichTextParagraph
* GetParagraphForLine(wxRichTextLine
* line
) const; 
 708     /// Get the length of the paragraph 
 709     virtual int GetParagraphLength(long paragraphNumber
) const; 
 711     /// Get the number of paragraphs 
 712     virtual int GetParagraphCount() const { return static_cast<int>(GetChildCount()); } 
 714     /// Get the number of visible lines 
 715     virtual int GetLineCount() const; 
 717     /// Get the text of the paragraph 
 718     virtual wxString 
GetParagraphText(long paragraphNumber
) const; 
 720     /// Convert zero-based line column and paragraph number to a position. 
 721     virtual long XYToPosition(long x
, long y
) const; 
 723     /// Convert zero-based position to line column and paragraph number 
 724     virtual bool PositionToXY(long pos
, long* x
, long* y
) const; 
 726     /// Set text attributes: character and/or paragraph styles. 
 727     virtual bool SetStyle(const wxRichTextRange
& range
, const wxTextAttr
& style
, int flags 
= wxRICHTEXT_SETSTYLE_WITH_UNDO
); 
 729     /// Get the conbined text attributes for this position. 
 730     virtual bool GetStyle(long position
, wxTextAttr
& style
); 
 732     /// Get the content (uncombined) attributes for this position. 
 733     virtual bool GetUncombinedStyle(long position
, wxTextAttr
& style
); 
 735     /// Implementation helper for GetStyle. If combineStyles is true, combine base, paragraph and 
 736     /// context attributes. 
 737     virtual bool DoGetStyle(long position
, wxTextAttr
& style
, bool combineStyles 
= true); 
 739     /// Get the combined style for a range - if any attribute is different within the range, 
 740     /// that attribute is not present within the flags 
 741     virtual bool GetStyleForRange(const wxRichTextRange
& range
, wxTextAttr
& style
); 
 743     /// Combines 'style' with 'currentStyle' for the purpose of summarising the attributes of a range of 
 745     bool CollectStyle(wxTextAttr
& currentStyle
, const wxTextAttr
& style
, long& multipleStyleAttributes
, int& multipleTextEffectAttributes
, int& absentStyleAttributes
, int& absentTextEffectAttributes
); 
 748     virtual bool SetListStyle(const wxRichTextRange
& range
, wxRichTextListStyleDefinition
* def
, int flags 
= wxRICHTEXT_SETSTYLE_WITH_UNDO
, int startFrom 
= 1, int specifiedLevel 
= -1); 
 749     virtual bool SetListStyle(const wxRichTextRange
& range
, const wxString
& defName
, int flags 
= wxRICHTEXT_SETSTYLE_WITH_UNDO
, int startFrom 
= 1, int specifiedLevel 
= -1); 
 751     /// Clear list for given range 
 752     virtual bool ClearListStyle(const wxRichTextRange
& range
, int flags 
= wxRICHTEXT_SETSTYLE_WITH_UNDO
); 
 754     /// Number/renumber any list elements in the given range. 
 755     /// def/defName can be NULL/empty to indicate that the existing list style should be used. 
 756     virtual bool NumberList(const wxRichTextRange
& range
, wxRichTextListStyleDefinition
* def 
= NULL
, int flags 
= wxRICHTEXT_SETSTYLE_WITH_UNDO
, int startFrom 
= 1, int specifiedLevel 
= -1); 
 757     virtual bool NumberList(const wxRichTextRange
& range
, const wxString
& defName
, int flags 
= wxRICHTEXT_SETSTYLE_WITH_UNDO
, int startFrom 
= 1, int specifiedLevel 
= -1); 
 759     /// Promote the list items within the given range. promoteBy can be a positive or negative number, e.g. 1 or -1 
 760     /// def/defName can be NULL/empty to indicate that the existing list style should be used. 
 761     virtual bool PromoteList(int promoteBy
, const wxRichTextRange
& range
, wxRichTextListStyleDefinition
* def 
= NULL
, int flags 
= wxRICHTEXT_SETSTYLE_WITH_UNDO
, int specifiedLevel 
= -1); 
 762     virtual bool PromoteList(int promoteBy
, const wxRichTextRange
& range
, const wxString
& defName
, int flags 
= wxRICHTEXT_SETSTYLE_WITH_UNDO
, int specifiedLevel 
= -1); 
 764     /// Helper for NumberList and PromoteList, that does renumbering and promotion simultaneously 
 765     /// def/defName can be NULL/empty to indicate that the existing list style should be used. 
 766     virtual bool DoNumberList(const wxRichTextRange
& range
, const wxRichTextRange
& promotionRange
, int promoteBy
, wxRichTextListStyleDefinition
* def
, int flags 
= wxRICHTEXT_SETSTYLE_WITH_UNDO
, int startFrom 
= 1, int specifiedLevel 
= -1); 
 768     /// Fills in the attributes for numbering a paragraph after previousParagraph. 
 769     virtual bool FindNextParagraphNumber(wxRichTextParagraph
* previousParagraph
, wxTextAttr
& attr
) const; 
 771     /// Test if this whole range has character attributes of the specified kind. If any 
 772     /// of the attributes are different within the range, the test fails. You 
 773     /// can use this to implement, for example, bold button updating. style must have 
 774     /// flags indicating which attributes are of interest. 
 775     virtual bool HasCharacterAttributes(const wxRichTextRange
& range
, const wxTextAttr
& style
) const; 
 777     /// Test if this whole range has paragraph attributes of the specified kind. If any 
 778     /// of the attributes are different within the range, the test fails. You 
 779     /// can use this to implement, for example, centering button updating. style must have 
 780     /// flags indicating which attributes are of interest. 
 781     virtual bool HasParagraphAttributes(const wxRichTextRange
& range
, const wxTextAttr
& style
) const; 
 784     virtual wxRichTextObject
* Clone() const { return new wxRichTextParagraphLayoutBox(*this); } 
 786     /// Insert fragment into this box at the given position. If partialParagraph is true, 
 787     /// it is assumed that the last (or only) paragraph is just a piece of data with no paragraph 
 789     virtual bool InsertFragment(long position
, wxRichTextParagraphLayoutBox
& fragment
); 
 791     /// Make a copy of the fragment corresponding to the given range, putting it in 'fragment'. 
 792     virtual bool CopyFragment(const wxRichTextRange
& range
, wxRichTextParagraphLayoutBox
& fragment
); 
 794     /// Apply the style sheet to the buffer, for example if the styles have changed. 
 795     virtual bool ApplyStyleSheet(wxRichTextStyleSheet
* styleSheet
); 
 798     void Copy(const wxRichTextParagraphLayoutBox
& obj
); 
 801     void operator= (const wxRichTextParagraphLayoutBox
& obj
) { Copy(obj
); } 
 804     virtual void UpdateRanges() { long end
; CalculateRange(0, end
); } 
 807     virtual wxString 
GetText() const; 
 809     /// Set default style for new content. Setting it to a default attribute 
 810     /// makes new content take on the 'basic' style. 
 811     virtual bool SetDefaultStyle(const wxTextAttr
& style
); 
 813     /// Get default style 
 814     virtual const wxTextAttr
& GetDefaultStyle() const { return m_defaultAttributes
; } 
 816     /// Set basic (overall) style 
 817     virtual void SetBasicStyle(const wxTextAttr
& style
) { m_attributes 
= style
; } 
 819     /// Get basic (overall) style 
 820     virtual const wxTextAttr
& GetBasicStyle() const { return m_attributes
; } 
 822     /// Invalidate the buffer. With no argument, invalidates whole buffer. 
 823     void Invalidate(const wxRichTextRange
& invalidRange 
= wxRICHTEXT_ALL
); 
 825     /// Get invalid range, rounding to entire paragraphs if argument is true. 
 826     wxRichTextRange 
GetInvalidRange(bool wholeParagraphs 
= false) const; 
 829     wxRichTextCtrl
* m_ctrl
; 
 830     wxTextAttr  m_defaultAttributes
; 
 832     /// The invalidated range that will need full layout 
 833     wxRichTextRange m_invalidRange
; 
 835     // Is the last paragraph partial or complete? 
 836     bool            m_partialParagraph
; 
 840  * wxRichTextLine class declaration 
 841  * This object represents a line in a paragraph, and stores 
 842  * offsets from the start of the paragraph representing the 
 843  * start and end positions of the line. 
 846 class WXDLLIMPEXP_RICHTEXT wxRichTextLine
 
 851     wxRichTextLine(wxRichTextParagraph
* parent
); 
 852     wxRichTextLine(const wxRichTextLine
& obj
) { Init( NULL
); Copy(obj
); } 
 853     virtual ~wxRichTextLine() {} 
 860     void SetRange(const wxRichTextRange
& range
) { m_range 
= range
; } 
 861     void SetRange(long from
, long to
) { m_range 
= wxRichTextRange(from
, to
); } 
 863     /// Get the parent paragraph 
 864     wxRichTextParagraph
* GetParent() { return m_parent
; } 
 867     const wxRichTextRange
& GetRange() const { return m_range
; } 
 868     wxRichTextRange
& GetRange() { return m_range
; } 
 870     /// Get the absolute range 
 871     wxRichTextRange 
GetAbsoluteRange() const; 
 873     /// Get/set the line size as calculated by Layout. 
 874     virtual wxSize 
GetSize() const { return m_size
; } 
 875     virtual void SetSize(const wxSize
& sz
) { m_size 
= sz
; } 
 877     /// Get/set the object position relative to the parent 
 878     virtual wxPoint 
GetPosition() const { return m_pos
; } 
 879     virtual void SetPosition(const wxPoint
& pos
) { m_pos 
= pos
; } 
 881     /// Get the absolute object position 
 882     virtual wxPoint 
GetAbsolutePosition() const; 
 884     /// Get the rectangle enclosing the line 
 885     virtual wxRect 
GetRect() const { return wxRect(GetAbsolutePosition(), GetSize()); } 
 887     /// Set/get stored descent 
 888     void SetDescent(int descent
) { m_descent 
= descent
; } 
 889     int GetDescent() const { return m_descent
; } 
 891 #if wxRICHTEXT_USE_OPTIMIZED_LINE_DRAWING 
 892     wxArrayInt
& GetObjectSizes() { return m_objectSizes
; } 
 893     const wxArrayInt
& GetObjectSizes() const { return m_objectSizes
; } 
 899     void Init(wxRichTextParagraph
* parent
); 
 902     void Copy(const wxRichTextLine
& obj
); 
 905     virtual wxRichTextLine
* Clone() const { return new wxRichTextLine(*this); } 
 909     /// The range of the line (start position to end position) 
 910     /// This is relative to the parent paragraph. 
 911     wxRichTextRange     m_range
; 
 913     /// Size and position measured relative to top of paragraph 
 917     /// Maximum descent for this line (location of text baseline) 
 921     wxRichTextParagraph
* m_parent
; 
 923 #if wxRICHTEXT_USE_OPTIMIZED_LINE_DRAWING 
 924     wxArrayInt          m_objectSizes
; 
 928 WX_DECLARE_LIST_WITH_DECL( wxRichTextLine
, wxRichTextLineList 
, class WXDLLIMPEXP_RICHTEXT 
); 
 931  * wxRichTextParagraph class declaration 
 932  * This object represents a single paragraph (or in a straight text editor, a line). 
 935 class WXDLLIMPEXP_RICHTEXT wxRichTextParagraph
: public wxRichTextBox
 
 937     DECLARE_DYNAMIC_CLASS(wxRichTextParagraph
) 
 941     wxRichTextParagraph(wxRichTextObject
* parent 
= NULL
, wxTextAttr
* style 
= NULL
); 
 942     wxRichTextParagraph(const wxString
& text
, wxRichTextObject
* parent 
= NULL
, wxTextAttr
* paraStyle 
= NULL
, wxTextAttr
* charStyle 
= NULL
); 
 943     virtual ~wxRichTextParagraph(); 
 944     wxRichTextParagraph(const wxRichTextParagraph
& obj
): wxRichTextBox() { Copy(obj
); } 
 949     virtual bool Draw(wxDC
& dc
, const wxRichTextRange
& range
, const wxRichTextRange
& selectionRange
, const wxRect
& rect
, int descent
, int style
); 
 952     virtual bool Layout(wxDC
& dc
, const wxRect
& rect
, int style
); 
 954     /// Get/set the object size for the given range. Returns false if the range 
 955     /// is invalid for this object. 
 956     virtual bool GetRangeSize(const wxRichTextRange
& range
, wxSize
& size
, int& descent
, wxDC
& dc
, int flags
, wxPoint position 
= wxPoint(0,0), wxArrayInt
* partialExtents 
= NULL
) const; 
 958     /// Finds the absolute position and row height for the given character position 
 959     virtual bool FindPosition(wxDC
& dc
, long index
, wxPoint
& pt
, int* height
, bool forceLineStart
); 
 961     /// Hit-testing: returns a flag indicating hit test details, plus 
 962     /// information about position 
 963     virtual int HitTest(wxDC
& dc
, const wxPoint
& pt
, long& textPosition
); 
 966     virtual void CalculateRange(long start
, long& end
); 
 970     /// Get the cached lines 
 971     wxRichTextLineList
& GetLines() { return m_cachedLines
; } 
 976     void Copy(const wxRichTextParagraph
& obj
); 
 979     virtual wxRichTextObject
* Clone() const { return new wxRichTextParagraph(*this); } 
 981     /// Clear the cached lines 
 986     /// Apply paragraph styles such as centering to the wrapped lines 
 987     virtual void ApplyParagraphStyle(const wxTextAttr
& attr
, const wxRect
& rect
, wxDC
& dc
); 
 989     /// Insert text at the given position 
 990     virtual bool InsertText(long pos
, const wxString
& text
); 
 992     /// Split an object at this position if necessary, and return 
 993     /// the previous object, or NULL if inserting at beginning. 
 994     virtual wxRichTextObject
* SplitAt(long pos
, wxRichTextObject
** previousObject 
= NULL
); 
 996     /// Move content to a list from this point 
 997     virtual void MoveToList(wxRichTextObject
* obj
, wxList
& list
); 
 999     /// Add content back from list 
1000     virtual void MoveFromList(wxList
& list
); 
1002     /// Get the plain text searching from the start or end of the range. 
1003     /// The resulting string may be shorter than the range given. 
1004     bool GetContiguousPlainText(wxString
& text
, const wxRichTextRange
& range
, bool fromStart 
= true); 
1006     /// Find a suitable wrap position. wrapPosition is the last position in the line to the left 
1008     bool FindWrapPosition(const wxRichTextRange
& range
, wxDC
& dc
, int availableSpace
, long& wrapPosition
, wxArrayInt
* partialExtents
); 
1010     /// Find the object at the given position 
1011     wxRichTextObject
* FindObjectAtPosition(long position
); 
1013     /// Get the bullet text for this paragraph. 
1014     wxString 
GetBulletText(); 
1016     /// Allocate or reuse a line object 
1017     wxRichTextLine
* AllocateLine(int pos
); 
1019     /// Clear remaining unused line objects, if any 
1020     bool ClearUnusedLines(int lineCount
); 
1022     /// Get combined attributes of the base style, paragraph style and character style. We use this to dynamically 
1023     /// retrieve the actual style. 
1024     wxTextAttr 
GetCombinedAttributes(const wxTextAttr
& contentStyle
) const; 
1026     /// Get combined attributes of the base style and paragraph style. 
1027     wxTextAttr 
GetCombinedAttributes() const; 
1029     /// Get the first position from pos that has a line break character. 
1030     long GetFirstLineBreakPosition(long pos
); 
1032     /// Create default tabstop array 
1033     static void InitDefaultTabs(); 
1035     /// Clear default tabstop array 
1036     static void ClearDefaultTabs(); 
1038     /// Get default tabstop array 
1039     static const wxArrayInt
& GetDefaultTabs() { return sm_defaultTabs
; } 
1042     /// The lines that make up the wrapped paragraph 
1043     wxRichTextLineList m_cachedLines
; 
1045     /// Default tabstops 
1046     static wxArrayInt  sm_defaultTabs
; 
1050  * wxRichTextPlainText class declaration 
1051  * This object represents a single piece of text. 
1054 class WXDLLIMPEXP_RICHTEXT wxRichTextPlainText
: public wxRichTextObject
 
1056     DECLARE_DYNAMIC_CLASS(wxRichTextPlainText
) 
1060     wxRichTextPlainText(const wxString
& text 
= wxEmptyString
, wxRichTextObject
* parent 
= NULL
, wxTextAttr
* style 
= NULL
); 
1061     wxRichTextPlainText(const wxRichTextPlainText
& obj
): wxRichTextObject() { Copy(obj
); } 
1066     virtual bool Draw(wxDC
& dc
, const wxRichTextRange
& range
, const wxRichTextRange
& selectionRange
, const wxRect
& rect
, int descent
, int style
); 
1068     /// Lay the item out 
1069     virtual bool Layout(wxDC
& dc
, const wxRect
& rect
, int style
); 
1071     /// Get/set the object size for the given range. Returns false if the range 
1072     /// is invalid for this object. 
1073     virtual bool GetRangeSize(const wxRichTextRange
& range
, wxSize
& size
, int& descent
, wxDC
& dc
, int flags
, wxPoint position 
= wxPoint(0,0), wxArrayInt
* partialExtents 
= NULL
) const; 
1075     /// Get any text in this object for the given range 
1076     virtual wxString 
GetTextForRange(const wxRichTextRange
& range
) const; 
1078     /// Do a split, returning an object containing the second part, and setting 
1079     /// the first part in 'this'. 
1080     virtual wxRichTextObject
* DoSplit(long pos
); 
1083     virtual void CalculateRange(long start
, long& end
); 
1086     virtual bool DeleteRange(const wxRichTextRange
& range
); 
1088     /// Returns true if the object is empty 
1089     virtual bool IsEmpty() const { return m_text
.empty(); } 
1091     /// Returns true if this object can merge itself with the given one. 
1092     virtual bool CanMerge(wxRichTextObject
* object
) const; 
1094     /// Returns true if this object merged itself with the given one. 
1095     /// The calling code will then delete the given object. 
1096     virtual bool Merge(wxRichTextObject
* object
); 
1098     /// Dump to output stream for debugging 
1099     virtual void Dump(wxTextOutputStream
& stream
); 
1101     /// Get the first position from pos that has a line break character. 
1102     long GetFirstLineBreakPosition(long pos
); 
1107     const wxString
& GetText() const { return m_text
; } 
1110     void SetText(const wxString
& text
) { m_text 
= text
; } 
1115     void Copy(const wxRichTextPlainText
& obj
); 
1118     virtual wxRichTextObject
* Clone() const { return new wxRichTextPlainText(*this); } 
1120     bool DrawTabbedString(wxDC
& dc
, const wxTextAttr
& attr
, const wxRect
& rect
, wxString
& str
, wxCoord
& x
, wxCoord
& y
, bool selected
); 
1127  * wxRichTextImageBlock stores information about an image, in binary in-memory form 
1130 class WXDLLIMPEXP_FWD_BASE wxDataInputStream
; 
1131 class WXDLLIMPEXP_FWD_BASE wxDataOutputStream
; 
1133 class WXDLLIMPEXP_RICHTEXT wxRichTextImageBlock
: public wxObject
 
1136     wxRichTextImageBlock(); 
1137     wxRichTextImageBlock(const wxRichTextImageBlock
& block
); 
1138     virtual ~wxRichTextImageBlock(); 
1143     // Load the original image into a memory block. 
1144     // If the image is not a JPEG, we must convert it into a JPEG 
1145     // to conserve space. 
1146     // If it's not a JPEG we can make use of 'image', already scaled, so we don't have to 
1147     // load the image a 2nd time. 
1148     virtual bool MakeImageBlock(const wxString
& filename
, wxBitmapType imageType
, 
1149                                 wxImage
& image
, bool convertToJPEG 
= true); 
1151     // Make an image block from the wxImage in the given 
1153     virtual bool MakeImageBlock(wxImage
& image
, wxBitmapType imageType
, int quality 
= 80); 
1156     bool Write(const wxString
& filename
); 
1158     // Write data in hex to a stream 
1159     bool WriteHex(wxOutputStream
& stream
); 
1161     // Read data in hex from a stream 
1162     bool ReadHex(wxInputStream
& stream
, int length
, wxBitmapType imageType
); 
1164     // Copy from 'block' 
1165     void Copy(const wxRichTextImageBlock
& block
); 
1167     // Load a wxImage from the block 
1168     bool Load(wxImage
& image
); 
1171     void operator=(const wxRichTextImageBlock
& block
); 
1175     unsigned char* GetData() const { return m_data
; } 
1176     size_t GetDataSize() const { return m_dataSize
; } 
1177     wxBitmapType 
GetImageType() const { return m_imageType
; } 
1179     void SetData(unsigned char* image
) { m_data 
= image
; } 
1180     void SetDataSize(size_t size
) { m_dataSize 
= size
; } 
1181     void SetImageType(wxBitmapType imageType
) { m_imageType 
= imageType
; } 
1183     bool Ok() const { return IsOk(); } 
1184     bool IsOk() const { return GetData() != NULL
; } 
1186     // Gets the extension for the block's type 
1187     wxString 
GetExtension() const; 
1191     // Allocate and read from stream as a block of memory 
1192     static unsigned char* ReadBlock(wxInputStream
& stream
, size_t size
); 
1193     static unsigned char* ReadBlock(const wxString
& filename
, size_t size
); 
1195     // Write memory block to stream 
1196     static bool WriteBlock(wxOutputStream
& stream
, unsigned char* block
, size_t size
); 
1198     // Write memory block to file 
1199     static bool WriteBlock(const wxString
& filename
, unsigned char* block
, size_t size
); 
1202     // Size in bytes of the image stored. 
1203     // This is in the raw, original form such as a JPEG file. 
1204     unsigned char*      m_data
; 
1206     wxBitmapType        m_imageType
; 
1211  * wxRichTextImage class declaration 
1212  * This object represents an image. 
1215 class WXDLLIMPEXP_RICHTEXT wxRichTextImage
: public wxRichTextObject
 
1217     DECLARE_DYNAMIC_CLASS(wxRichTextImage
) 
1221     wxRichTextImage(wxRichTextObject
* parent 
= NULL
): wxRichTextObject(parent
) { } 
1222     wxRichTextImage(const wxImage
& image
, wxRichTextObject
* parent 
= NULL
, wxTextAttr
* charStyle 
= NULL
); 
1223     wxRichTextImage(const wxRichTextImageBlock
& imageBlock
, wxRichTextObject
* parent 
= NULL
, wxTextAttr
* charStyle 
= NULL
); 
1224     wxRichTextImage(const wxRichTextImage
& obj
): wxRichTextObject() { Copy(obj
); } 
1229     virtual bool Draw(wxDC
& dc
, const wxRichTextRange
& range
, const wxRichTextRange
& selectionRange
, const wxRect
& rect
, int descent
, int style
); 
1231     /// Lay the item out 
1232     virtual bool Layout(wxDC
& dc
, const wxRect
& rect
, int style
); 
1234     /// Get the object size for the given range. Returns false if the range 
1235     /// is invalid for this object. 
1236     virtual bool GetRangeSize(const wxRichTextRange
& range
, wxSize
& size
, int& descent
, wxDC
& dc
, int flags
, wxPoint position 
= wxPoint(0,0), wxArrayInt
* partialExtents 
= NULL
) const; 
1238     /// Returns true if the object is empty 
1239     virtual bool IsEmpty() const { return !m_image
.Ok(); } 
1244     const wxImage
& GetImage() const { return m_image
; } 
1247     void SetImage(const wxImage
& image
) { m_image 
= image
; } 
1249     /// Get the image block containing the raw data 
1250     wxRichTextImageBlock
& GetImageBlock() { return m_imageBlock
; } 
1255     void Copy(const wxRichTextImage
& obj
); 
1258     virtual wxRichTextObject
* Clone() const { return new wxRichTextImage(*this); } 
1260     /// Load wxImage from the block 
1261     virtual bool LoadFromBlock(); 
1263     /// Make block from the wxImage 
1264     virtual bool MakeBlock(); 
1267     // TODO: reduce the multiple representations of data 
1270     wxRichTextImageBlock    m_imageBlock
; 
1275  * wxRichTextBuffer class declaration 
1276  * This is a kind of box, used to represent the whole buffer 
1279 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextCommand
; 
1280 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextAction
; 
1282 class WXDLLIMPEXP_RICHTEXT wxRichTextBuffer
: public wxRichTextParagraphLayoutBox
 
1284     DECLARE_DYNAMIC_CLASS(wxRichTextBuffer
) 
1288     wxRichTextBuffer() { Init(); } 
1289     wxRichTextBuffer(const wxRichTextBuffer
& obj
): wxRichTextParagraphLayoutBox() { Init(); Copy(obj
); } 
1290     virtual ~wxRichTextBuffer() ; 
1294     /// Gets the command processor 
1295     wxCommandProcessor
* GetCommandProcessor() const { return m_commandProcessor
; } 
1297     /// Set style sheet, if any. 
1298     void SetStyleSheet(wxRichTextStyleSheet
* styleSheet
) { m_styleSheet 
= styleSheet
; } 
1299     virtual wxRichTextStyleSheet
* GetStyleSheet() const { return m_styleSheet
; } 
1301     /// Set style sheet and notify of the change 
1302     bool SetStyleSheetAndNotify(wxRichTextStyleSheet
* sheet
); 
1304     /// Push style sheet to top of stack 
1305     bool PushStyleSheet(wxRichTextStyleSheet
* styleSheet
); 
1307     /// Pop style sheet from top of stack 
1308     wxRichTextStyleSheet
* PopStyleSheet(); 
1310     /// Set/get table storing fonts 
1311     wxRichTextFontTable
& GetFontTable() { return m_fontTable
; } 
1312     const wxRichTextFontTable
& GetFontTable() const { return m_fontTable
; } 
1313     void SetFontTable(const wxRichTextFontTable
& table
) { m_fontTable 
= table
; } 
1320     /// Clears the buffer, adds an empty paragraph, and clears the command processor. 
1321     virtual void ResetAndClearCommands(); 
1324     virtual bool LoadFile(const wxString
& filename
, wxRichTextFileType type 
= wxRICHTEXT_TYPE_ANY
); 
1327     virtual bool SaveFile(const wxString
& filename
, wxRichTextFileType type 
= wxRICHTEXT_TYPE_ANY
); 
1329     /// Load from a stream 
1330     virtual bool LoadFile(wxInputStream
& stream
, wxRichTextFileType type 
= wxRICHTEXT_TYPE_ANY
); 
1332     /// Save to a stream 
1333     virtual bool SaveFile(wxOutputStream
& stream
, wxRichTextFileType type 
= wxRICHTEXT_TYPE_ANY
); 
1335     /// Set the handler flags, controlling loading and saving 
1336     void SetHandlerFlags(int flags
) { m_handlerFlags 
= flags
; } 
1338     /// Get the handler flags, controlling loading and saving 
1339     int GetHandlerFlags() const { return m_handlerFlags
; } 
1341     /// Convenience function to add a paragraph of text 
1342     virtual wxRichTextRange 
AddParagraph(const wxString
& text
, wxTextAttr
* paraStyle 
= NULL
) { Modify(); return wxRichTextParagraphLayoutBox::AddParagraph(text
, paraStyle
); } 
1344     /// Begin collapsing undo/redo commands. Note that this may not work properly 
1345     /// if combining commands that delete or insert content, changing ranges for 
1346     /// subsequent actions. 
1347     virtual bool BeginBatchUndo(const wxString
& cmdName
); 
1349     /// End collapsing undo/redo commands 
1350     virtual bool EndBatchUndo(); 
1352     /// Collapsing commands? 
1353     virtual bool BatchingUndo() const { return m_batchedCommandDepth 
> 0; } 
1355     /// Submit immediately, or delay according to whether collapsing is on 
1356     virtual bool SubmitAction(wxRichTextAction
* action
); 
1358     /// Get collapsed command 
1359     virtual wxRichTextCommand
* GetBatchedCommand() const { return m_batchedCommand
; } 
1361     /// Begin suppressing undo/redo commands. The way undo is suppressed may be implemented 
1362     /// differently by each command. If not dealt with by a command implementation, then 
1363     /// it will be implemented automatically by not storing the command in the undo history 
1364     /// when the action is submitted to the command processor. 
1365     virtual bool BeginSuppressUndo(); 
1367     /// End suppressing undo/redo commands. 
1368     virtual bool EndSuppressUndo(); 
1370     /// Collapsing commands? 
1371     virtual bool SuppressingUndo() const { return m_suppressUndo 
> 0; } 
1373     /// Copy the range to the clipboard 
1374     virtual bool CopyToClipboard(const wxRichTextRange
& range
); 
1376     /// Paste the clipboard content to the buffer 
1377     virtual bool PasteFromClipboard(long position
); 
1379     /// Can we paste from the clipboard? 
1380     virtual bool CanPasteFromClipboard() const; 
1382     /// Begin using a style 
1383     virtual bool BeginStyle(const wxTextAttr
& style
); 
1386     virtual bool EndStyle(); 
1389     virtual bool EndAllStyles(); 
1391     /// Clear the style stack 
1392     virtual void ClearStyleStack(); 
1394     /// Get the size of the style stack, for example to check correct nesting 
1395     virtual size_t GetStyleStackSize() const { return m_attributeStack
.GetCount(); } 
1397     /// Begin using bold 
1401     bool EndBold() { return EndStyle(); } 
1403     /// Begin using italic 
1406     /// End using italic 
1407     bool EndItalic() { return EndStyle(); } 
1409     /// Begin using underline 
1410     bool BeginUnderline(); 
1412     /// End using underline 
1413     bool EndUnderline() { return EndStyle(); } 
1415     /// Begin using point size 
1416     bool BeginFontSize(int pointSize
); 
1418     /// End using point size 
1419     bool EndFontSize() { return EndStyle(); } 
1421     /// Begin using this font 
1422     bool BeginFont(const wxFont
& font
); 
1424     /// End using a font 
1425     bool EndFont() { return EndStyle(); } 
1427     /// Begin using this colour 
1428     bool BeginTextColour(const wxColour
& colour
); 
1430     /// End using a colour 
1431     bool EndTextColour() { return EndStyle(); } 
1433     /// Begin using alignment 
1434     bool BeginAlignment(wxTextAttrAlignment alignment
); 
1437     bool EndAlignment() { return EndStyle(); } 
1439     /// Begin left indent 
1440     bool BeginLeftIndent(int leftIndent
, int leftSubIndent 
= 0); 
1443     bool EndLeftIndent() { return EndStyle(); } 
1445     /// Begin right indent 
1446     bool BeginRightIndent(int rightIndent
); 
1448     /// End right indent 
1449     bool EndRightIndent() { return EndStyle(); } 
1451     /// Begin paragraph spacing 
1452     bool BeginParagraphSpacing(int before
, int after
); 
1454     /// End paragraph spacing 
1455     bool EndParagraphSpacing() { return EndStyle(); } 
1457     /// Begin line spacing 
1458     bool BeginLineSpacing(int lineSpacing
); 
1460     /// End line spacing 
1461     bool EndLineSpacing() { return EndStyle(); } 
1463     /// Begin numbered bullet 
1464     bool BeginNumberedBullet(int bulletNumber
, int leftIndent
, int leftSubIndent
, int bulletStyle 
= wxTEXT_ATTR_BULLET_STYLE_ARABIC
|wxTEXT_ATTR_BULLET_STYLE_PERIOD
); 
1466     /// End numbered bullet 
1467     bool EndNumberedBullet() { return EndStyle(); } 
1469     /// Begin symbol bullet 
1470     bool BeginSymbolBullet(const wxString
& symbol
, int leftIndent
, int leftSubIndent
, int bulletStyle 
= wxTEXT_ATTR_BULLET_STYLE_SYMBOL
); 
1472     /// End symbol bullet 
1473     bool EndSymbolBullet() { return EndStyle(); } 
1475     /// Begin standard bullet 
1476     bool BeginStandardBullet(const wxString
& bulletName
, int leftIndent
, int leftSubIndent
, int bulletStyle 
= wxTEXT_ATTR_BULLET_STYLE_STANDARD
); 
1478     /// End standard bullet 
1479     bool EndStandardBullet() { return EndStyle(); } 
1481     /// Begin named character style 
1482     bool BeginCharacterStyle(const wxString
& characterStyle
); 
1484     /// End named character style 
1485     bool EndCharacterStyle() { return EndStyle(); } 
1487     /// Begin named paragraph style 
1488     bool BeginParagraphStyle(const wxString
& paragraphStyle
); 
1490     /// End named character style 
1491     bool EndParagraphStyle() { return EndStyle(); } 
1493     /// Begin named list style 
1494     bool BeginListStyle(const wxString
& listStyle
, int level 
= 1, int number 
= 1); 
1496     /// End named character style 
1497     bool EndListStyle() { return EndStyle(); } 
1500     bool BeginURL(const wxString
& url
, const wxString
& characterStyle 
= wxEmptyString
); 
1503     bool EndURL() { return EndStyle(); } 
1507     /// Add an event handler 
1508     bool AddEventHandler(wxEvtHandler
* handler
); 
1510     /// Remove an event handler 
1511     bool RemoveEventHandler(wxEvtHandler
* handler
, bool deleteHandler 
= false); 
1513     /// Clear event handlers 
1514     void ClearEventHandlers(); 
1516     /// Send event to event handlers. If sendToAll is true, will send to all event handlers, 
1517     /// otherwise will stop at the first successful one. 
1518     bool SendEvent(wxEvent
& event
, bool sendToAll 
= true); 
1523     void Copy(const wxRichTextBuffer
& obj
); 
1526     virtual wxRichTextObject
* Clone() const { return new wxRichTextBuffer(*this); } 
1528     /// Submit command to insert paragraphs 
1529     bool InsertParagraphsWithUndo(long pos
, const wxRichTextParagraphLayoutBox
& paragraphs
, wxRichTextCtrl
* ctrl
, int flags 
= 0); 
1531     /// Submit command to insert the given text 
1532     bool InsertTextWithUndo(long pos
, const wxString
& text
, wxRichTextCtrl
* ctrl
, int flags 
= 0); 
1534     /// Submit command to insert a newline 
1535     bool InsertNewlineWithUndo(long pos
, wxRichTextCtrl
* ctrl
, int flags 
= 0); 
1537     /// Submit command to insert the given image 
1538     bool InsertImageWithUndo(long pos
, const wxRichTextImageBlock
& imageBlock
, wxRichTextCtrl
* ctrl
, int flags 
= 0); 
1540     /// Submit command to delete this range 
1541     bool DeleteRangeWithUndo(const wxRichTextRange
& range
, wxRichTextCtrl
* ctrl
); 
1544     void Modify(bool modify 
= true) { m_modified 
= modify
; } 
1545     bool IsModified() const { return m_modified
; } 
1547     /// Get the style that is appropriate for a new paragraph at this position. 
1548     /// If the previous paragraph has a paragraph style name, look up the next-paragraph 
1550     wxTextAttr 
GetStyleForNewParagraph(long pos
, bool caretPosition 
= false, bool lookUpNewParaStyle
=false) const; 
1552     /// Dumps contents of buffer for debugging purposes 
1553     virtual void Dump(); 
1554     virtual void Dump(wxTextOutputStream
& stream
) { wxRichTextParagraphLayoutBox::Dump(stream
); } 
1556     /// Returns the file handlers 
1557     static wxList
& GetHandlers() { return sm_handlers
; } 
1559     /// Adds a handler to the end 
1560     static void AddHandler(wxRichTextFileHandler 
*handler
); 
1562     /// Inserts a handler at the front 
1563     static void InsertHandler(wxRichTextFileHandler 
*handler
); 
1565     /// Removes a handler 
1566     static bool RemoveHandler(const wxString
& name
); 
1568     /// Finds a handler by name 
1569     static wxRichTextFileHandler 
*FindHandler(const wxString
& name
); 
1571     /// Finds a handler by extension and type 
1572     static wxRichTextFileHandler 
*FindHandler(const wxString
& extension
, wxRichTextFileType imageType
); 
1574     /// Finds a handler by filename or, if supplied, type 
1575     static wxRichTextFileHandler 
*FindHandlerFilenameOrType(const wxString
& filename
, 
1576                                                             wxRichTextFileType imageType
); 
1578     /// Finds a handler by type 
1579     static wxRichTextFileHandler 
*FindHandler(wxRichTextFileType imageType
); 
1581     /// Gets a wildcard incorporating all visible handlers. If 'types' is present, 
1582     /// will be filled with the file type corresponding to each filter. This can be 
1583     /// used to determine the type to pass to LoadFile given a selected filter. 
1584     static wxString 
GetExtWildcard(bool combine 
= false, bool save 
= false, wxArrayInt
* types 
= NULL
); 
1586     /// Clean up handlers 
1587     static void CleanUpHandlers(); 
1589     /// Initialise the standard handlers 
1590     static void InitStandardHandlers(); 
1593     static wxRichTextRenderer
* GetRenderer() { return sm_renderer
; } 
1595     /// Set renderer, deleting old one 
1596     static void SetRenderer(wxRichTextRenderer
* renderer
); 
1598     /// Minimum margin between bullet and paragraph in 10ths of a mm 
1599     static int GetBulletRightMargin() { return sm_bulletRightMargin
; } 
1600     static void SetBulletRightMargin(int margin
) { sm_bulletRightMargin 
= margin
; } 
1602     /// Factor to multiply by character height to get a reasonable bullet size 
1603     static float GetBulletProportion() { return sm_bulletProportion
; } 
1604     static void SetBulletProportion(float prop
) { sm_bulletProportion 
= prop
; } 
1606     /// Scale factor for calculating dimensions 
1607     double GetScale() const { return m_scale
; } 
1608     void SetScale(double scale
) { m_scale 
= scale
; } 
1612     /// Command processor 
1613     wxCommandProcessor
*     m_commandProcessor
; 
1615     /// Table storing fonts 
1616     wxRichTextFontTable     m_fontTable
; 
1618     /// Has been modified? 
1621     /// Collapsed command stack 
1622     int                     m_batchedCommandDepth
; 
1624     /// Name for collapsed command 
1625     wxString                m_batchedCommandsName
; 
1627     /// Current collapsed command accumulating actions 
1628     wxRichTextCommand
*      m_batchedCommand
; 
1630     /// Whether to suppress undo 
1633     /// Style sheet, if any 
1634     wxRichTextStyleSheet
*   m_styleSheet
; 
1636     /// List of event handlers that will be notified of events 
1637     wxList                  m_eventHandlers
; 
1639     /// Stack of attributes for convenience functions 
1640     wxList                  m_attributeStack
; 
1642     /// Flags to be passed to handlers 
1646     static wxList           sm_handlers
; 
1649     static wxRichTextRenderer
* sm_renderer
; 
1651     /// Minimum margin between bullet and paragraph in 10ths of a mm 
1652     static int              sm_bulletRightMargin
; 
1654     /// Factor to multiply by character height to get a reasonable bullet size 
1655     static float            sm_bulletProportion
; 
1657     /// Scaling factor in use: needed to calculate correct dimensions when printing 
1662  * The command identifiers 
1666 enum wxRichTextCommandId
 
1670     wxRICHTEXT_CHANGE_STYLE
 
1674  * Command classes for undo/redo 
1678 class WXDLLIMPEXP_FWD_RICHTEXT wxRichTextAction
; 
1679 class WXDLLIMPEXP_RICHTEXT wxRichTextCommand
: public wxCommand
 
1682     // Ctor for one action 
1683     wxRichTextCommand(const wxString
& name
, wxRichTextCommandId id
, wxRichTextBuffer
* buffer
, 
1684         wxRichTextCtrl
* ctrl
, bool ignoreFirstTime 
= false); 
1686     // Ctor for multiple actions 
1687     wxRichTextCommand(const wxString
& name
); 
1689     virtual ~wxRichTextCommand(); 
1694     void AddAction(wxRichTextAction
* action
); 
1695     void ClearActions(); 
1697     wxList
& GetActions() { return m_actions
; } 
1705  * wxRichTextAction class declaration 
1706  * There can be more than one action in a command. 
1709 class WXDLLIMPEXP_RICHTEXT wxRichTextAction
: public wxObject
 
1712     wxRichTextAction(wxRichTextCommand
* cmd
, const wxString
& name
, wxRichTextCommandId id
, wxRichTextBuffer
* buffer
, 
1713         wxRichTextCtrl
* ctrl
, bool ignoreFirstTime 
= false); 
1715     virtual ~wxRichTextAction(); 
1720     /// Update the control appearance 
1721     void UpdateAppearance(long caretPosition
, bool sendUpdateEvent 
= false, 
1722                             wxArrayInt
* optimizationLineCharPositions 
= NULL
, wxArrayInt
* optimizationLineYPositions 
= NULL
, bool isDoCmd 
= true); 
1724     /// Replace the buffer paragraphs with the given fragment. 
1725     void ApplyParagraphs(const wxRichTextParagraphLayoutBox
& fragment
); 
1727     /// Get the fragments 
1728     wxRichTextParagraphLayoutBox
& GetNewParagraphs() { return m_newParagraphs
; } 
1729     wxRichTextParagraphLayoutBox
& GetOldParagraphs() { return m_oldParagraphs
; } 
1731     /// Calculate arrays for refresh optimization 
1732     void CalculateRefreshOptimizations(wxArrayInt
& optimizationLineCharPositions
, wxArrayInt
& optimizationLineYPositions
); 
1734     /// Set/get the position used for e.g. insertion 
1735     void SetPosition(long pos
) { m_position 
= pos
; } 
1736     long GetPosition() const { return m_position
; } 
1738     /// Set/get the range for e.g. deletion 
1739     void SetRange(const wxRichTextRange
& range
) { m_range 
= range
; } 
1740     const wxRichTextRange
& GetRange() const { return m_range
; } 
1743     const wxString
& GetName() const { return m_name
; } 
1750     wxRichTextBuffer
*               m_buffer
; 
1753     wxRichTextCtrl
*                 m_ctrl
; 
1755     // Stores the new paragraphs 
1756     wxRichTextParagraphLayoutBox    m_newParagraphs
; 
1758     // Stores the old paragraphs 
1759     wxRichTextParagraphLayoutBox    m_oldParagraphs
; 
1761     // The affected range 
1762     wxRichTextRange                 m_range
; 
1764     // The insertion point for this command 
1767     // Ignore 1st 'Do' operation because we already did it 
1770     // The command identifier 
1771     wxRichTextCommandId             m_cmdId
; 
1778 // Include style sheet when loading and saving 
1779 #define wxRICHTEXT_HANDLER_INCLUDE_STYLESHEET       0x0001 
1781 // Save images to memory file system in HTML handler 
1782 #define wxRICHTEXT_HANDLER_SAVE_IMAGES_TO_MEMORY    0x0010 
1784 // Save images to files in HTML handler 
1785 #define wxRICHTEXT_HANDLER_SAVE_IMAGES_TO_FILES     0x0020 
1787 // Save images as inline base64 data in HTML handler 
1788 #define wxRICHTEXT_HANDLER_SAVE_IMAGES_TO_BASE64    0x0040 
1790 // Don't write header and footer (or BODY), so we can include the fragment 
1791 // in a larger document 
1792 #define wxRICHTEXT_HANDLER_NO_HEADER_FOOTER         0x0080 
1794 // Convert the more common face names to names that will work on the current platform 
1795 // in a larger document 
1796 #define wxRICHTEXT_HANDLER_CONVERT_FACENAMES        0x0100 
1799  * wxRichTextFileHandler 
1800  * Base class for file handlers 
1803 class WXDLLIMPEXP_RICHTEXT wxRichTextFileHandler
: public wxObject
 
1805     DECLARE_CLASS(wxRichTextFileHandler
) 
1807     wxRichTextFileHandler(const wxString
& name 
= wxEmptyString
, const wxString
& ext 
= wxEmptyString
, int type 
= 0) 
1808         : m_name(name
), m_extension(ext
), m_type(type
), m_flags(0), m_visible(true) 
1812     bool LoadFile(wxRichTextBuffer 
*buffer
, wxInputStream
& stream
) 
1813     { return DoLoadFile(buffer
, stream
); } 
1814     bool SaveFile(wxRichTextBuffer 
*buffer
, wxOutputStream
& stream
) 
1815     { return DoSaveFile(buffer
, stream
); } 
1818 #if wxUSE_FFILE && wxUSE_STREAMS 
1819     virtual bool LoadFile(wxRichTextBuffer 
*buffer
, const wxString
& filename
); 
1820     virtual bool SaveFile(wxRichTextBuffer 
*buffer
, const wxString
& filename
); 
1821 #endif // wxUSE_STREAMS && wxUSE_STREAMS 
1823     /// Can we handle this filename (if using files)? By default, checks the extension. 
1824     virtual bool CanHandle(const wxString
& filename
) const; 
1826     /// Can we save using this handler? 
1827     virtual bool CanSave() const { return false; } 
1829     /// Can we load using this handler? 
1830     virtual bool CanLoad() const { return false; } 
1832     /// Should this handler be visible to the user? 
1833     virtual bool IsVisible() const { return m_visible
; } 
1834     virtual void SetVisible(bool visible
) { m_visible 
= visible
; } 
1836     /// The name of the nandler 
1837     void SetName(const wxString
& name
) { m_name 
= name
; } 
1838     wxString 
GetName() const { return m_name
; } 
1840     /// The default extension to recognise 
1841     void SetExtension(const wxString
& ext
) { m_extension 
= ext
; } 
1842     wxString 
GetExtension() const { return m_extension
; } 
1844     /// The handler type 
1845     void SetType(int type
) { m_type 
= type
; } 
1846     int GetType() const { return m_type
; } 
1848     /// Flags controlling how loading and saving is done 
1849     void SetFlags(int flags
) { m_flags 
= flags
; } 
1850     int GetFlags() const { return m_flags
; } 
1852     /// Encoding to use when saving a file. If empty, a suitable encoding is chosen 
1853     void SetEncoding(const wxString
& encoding
) { m_encoding 
= encoding
; } 
1854     const wxString
& GetEncoding() const { return m_encoding
; } 
1859     virtual bool DoLoadFile(wxRichTextBuffer 
*buffer
, wxInputStream
& stream
) = 0; 
1860     virtual bool DoSaveFile(wxRichTextBuffer 
*buffer
, wxOutputStream
& stream
) = 0; 
1864     wxString  m_encoding
; 
1865     wxString  m_extension
; 
1872  * wxRichTextPlainTextHandler 
1873  * Plain text handler 
1876 class WXDLLIMPEXP_RICHTEXT wxRichTextPlainTextHandler
: public wxRichTextFileHandler
 
1878     DECLARE_CLASS(wxRichTextPlainTextHandler
) 
1880     wxRichTextPlainTextHandler(const wxString
& name 
= wxT("Text"), 
1881                                const wxString
& ext 
= wxT("txt"), 
1882                                wxRichTextFileType type 
= wxRICHTEXT_TYPE_TEXT
) 
1883         : wxRichTextFileHandler(name
, ext
, type
) 
1886     /// Can we save using this handler? 
1887     virtual bool CanSave() const { return true; } 
1889     /// Can we load using this handler? 
1890     virtual bool CanLoad() const { return true; } 
1895     virtual bool DoLoadFile(wxRichTextBuffer 
*buffer
, wxInputStream
& stream
); 
1896     virtual bool DoSaveFile(wxRichTextBuffer 
*buffer
, wxOutputStream
& stream
); 
1904  * The data object for a wxRichTextBuffer 
1907 class WXDLLIMPEXP_RICHTEXT wxRichTextBufferDataObject
: public wxDataObjectSimple
 
1910     // ctor doesn't copy the pointer, so it shouldn't go away while this object 
1912     wxRichTextBufferDataObject(wxRichTextBuffer
* richTextBuffer 
= NULL
); 
1913     virtual ~wxRichTextBufferDataObject(); 
1915     // after a call to this function, the buffer is owned by the caller and it 
1916     // is responsible for deleting it 
1917     wxRichTextBuffer
* GetRichTextBuffer(); 
1919     // Returns the id for the new data format 
1920     static const wxChar
* GetRichTextBufferFormatId() { return ms_richTextBufferFormatId
; } 
1922     // base class pure virtuals 
1924     virtual wxDataFormat 
GetPreferredFormat(Direction dir
) const; 
1925     virtual size_t GetDataSize() const; 
1926     virtual bool GetDataHere(void *pBuf
) const; 
1927     virtual bool SetData(size_t len
, const void *buf
); 
1931     virtual size_t GetDataSize(const wxDataFormat
&) const { return GetDataSize(); } 
1932     virtual bool GetDataHere(const wxDataFormat
&, void *buf
) const { return GetDataHere(buf
); } 
1933     virtual bool SetData(const wxDataFormat
&, size_t len
, const void *buf
) { return SetData(len
, buf
); } 
1936     wxDataFormat            m_formatRichTextBuffer
;     // our custom format 
1937     wxRichTextBuffer
*       m_richTextBuffer
;           // our data 
1938     static const wxChar
*    ms_richTextBufferFormatId
;  // our format id 
1944  * wxRichTextRenderer isolates common drawing functionality 
1947 class WXDLLIMPEXP_RICHTEXT wxRichTextRenderer
: public wxObject
 
1950     wxRichTextRenderer() {} 
1951     virtual ~wxRichTextRenderer() {} 
1953     /// Draw a standard bullet, as specified by the value of GetBulletName 
1954     virtual bool DrawStandardBullet(wxRichTextParagraph
* paragraph
, wxDC
& dc
, const wxTextAttr
& attr
, const wxRect
& rect
) = 0; 
1956     /// Draw a bullet that can be described by text, such as numbered or symbol bullets 
1957     virtual bool DrawTextBullet(wxRichTextParagraph
* paragraph
, wxDC
& dc
, const wxTextAttr
& attr
, const wxRect
& rect
, const wxString
& text
) = 0; 
1959     /// Draw a bitmap bullet, where the bullet bitmap is specified by the value of GetBulletName 
1960     virtual bool DrawBitmapBullet(wxRichTextParagraph
* paragraph
, wxDC
& dc
, const wxTextAttr
& attr
, const wxRect
& rect
) = 0; 
1962     /// Enumerate the standard bullet names currently supported 
1963     virtual bool EnumerateStandardBulletNames(wxArrayString
& bulletNames
) = 0; 
1967  * wxRichTextStdRenderer: standard renderer 
1970 class WXDLLIMPEXP_RICHTEXT wxRichTextStdRenderer
: public wxRichTextRenderer
 
1973     wxRichTextStdRenderer() {} 
1975     /// Draw a standard bullet, as specified by the value of GetBulletName 
1976     virtual bool DrawStandardBullet(wxRichTextParagraph
* paragraph
, wxDC
& dc
, const wxTextAttr
& attr
, const wxRect
& rect
); 
1978     /// Draw a bullet that can be described by text, such as numbered or symbol bullets 
1979     virtual bool DrawTextBullet(wxRichTextParagraph
* paragraph
, wxDC
& dc
, const wxTextAttr
& attr
, const wxRect
& rect
, const wxString
& text
); 
1981     /// Draw a bitmap bullet, where the bullet bitmap is specified by the value of GetBulletName 
1982     virtual bool DrawBitmapBullet(wxRichTextParagraph
* paragraph
, wxDC
& dc
, const wxTextAttr
& attr
, const wxRect
& rect
); 
1984     /// Enumerate the standard bullet names currently supported 
1985     virtual bool EnumerateStandardBulletNames(wxArrayString
& bulletNames
); 
1993 inline bool wxRichTextHasStyle(int flags
, int style
) 
1995     return ((flags 
& style
) == style
); 
1998 /// Compare two attribute objects 
1999 WXDLLIMPEXP_RICHTEXT 
bool wxTextAttrEq(const wxTextAttr
& attr1
, const wxTextAttr
& attr2
); 
2000 WXDLLIMPEXP_RICHTEXT 
bool wxTextAttrEq(const wxTextAttr
& attr1
, const wxTextAttr
& attr2
); 
2002 /// Compare two attribute objects, but take into account the flags 
2003 /// specifying attributes of interest. 
2004 WXDLLIMPEXP_RICHTEXT 
bool wxTextAttrEqPartial(const wxTextAttr
& attr1
, const wxTextAttr
& attr2
, int flags
); 
2006 /// Apply one style to another 
2007 WXDLLIMPEXP_RICHTEXT 
bool wxRichTextApplyStyle(wxTextAttr
& destStyle
, const wxTextAttr
& style
, wxTextAttr
* compareWith 
= NULL
); 
2009 // Remove attributes 
2010 WXDLLIMPEXP_RICHTEXT 
bool wxRichTextRemoveStyle(wxTextAttr
& destStyle
, const wxTextAttr
& style
); 
2012 /// Combine two bitlists 
2013 WXDLLIMPEXP_RICHTEXT 
bool wxRichTextCombineBitlists(int& valueA
, int valueB
, int& flagsA
, int flagsB
); 
2015 /// Compare two bitlists 
2016 WXDLLIMPEXP_RICHTEXT 
bool wxRichTextBitlistsEqPartial(int valueA
, int valueB
, int flags
); 
2018 /// Split into paragraph and character styles 
2019 WXDLLIMPEXP_RICHTEXT 
bool wxRichTextSplitParaCharStyles(const wxTextAttr
& style
, wxTextAttr
& parStyle
, wxTextAttr
& charStyle
); 
2022 WXDLLIMPEXP_RICHTEXT 
bool wxRichTextTabsEq(const wxArrayInt
& tabs1
, const wxArrayInt
& tabs2
); 
2024 /// Convert a decimal to Roman numerals 
2025 WXDLLIMPEXP_RICHTEXT wxString 
wxRichTextDecimalToRoman(long n
); 
2027 WXDLLIMPEXP_RICHTEXT 
void wxRichTextModuleInit(); 
2033     // _WX_RICHTEXTBUFFER_H_