wxWidgets/interface/wx/richtext/richtextbuffer.h

1170 lines
35 KiB
C
Raw Normal View History

/////////////////////////////////////////////////////////////////////////////
// Name: richtext/richtextbuffer.h
// Purpose: interface of wxRichTextBuffer
// Author: wxWidgets team
// RCS-ID: $Id$
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
/*!
* File types in wxRichText context.
*/
enum wxRichTextFileType
{
wxRICHTEXT_TYPE_ANY = 0,
wxRICHTEXT_TYPE_TEXT,
wxRICHTEXT_TYPE_XML,
wxRICHTEXT_TYPE_HTML,
wxRICHTEXT_TYPE_RTF,
wxRICHTEXT_TYPE_PDF
};
/*!
* Flags determining the available space, passed to Layout
*/
#define wxRICHTEXT_FIXED_WIDTH 0x01
#define wxRICHTEXT_FIXED_HEIGHT 0x02
#define wxRICHTEXT_VARIABLE_WIDTH 0x04
#define wxRICHTEXT_VARIABLE_HEIGHT 0x08
// Only lay out the part of the buffer that lies within
// the rect passed to Layout.
#define wxRICHTEXT_LAYOUT_SPECIFIED_RECT 0x10
/*!
* Flags to pass to Draw
*/
// Ignore paragraph cache optimization, e.g. for printing purposes
// where one line may be drawn higher (on the next page) compared
// with the previous line
#define wxRICHTEXT_DRAW_IGNORE_CACHE 0x01
/*!
* Flags returned from hit-testing
*/
enum wxRichTextHitTestFlags
{
/// The point was not on this object
wxRICHTEXT_HITTEST_NONE = 0x01,
/// The point was before the position returned from HitTest
wxRICHTEXT_HITTEST_BEFORE = 0x02,
/// The point was after the position returned from HitTest
wxRICHTEXT_HITTEST_AFTER = 0x04,
/// The point was on the position returned from HitTest
wxRICHTEXT_HITTEST_ON = 0x08,
/// The point was on space outside content
wxRICHTEXT_HITTEST_OUTSIDE = 0x10
};
/*!
* Flags for GetRangeSize
*/
#define wxRICHTEXT_FORMATTED 0x01
#define wxRICHTEXT_UNFORMATTED 0x02
#define wxRICHTEXT_CACHE_SIZE 0x04
#define wxRICHTEXT_HEIGHT_ONLY 0x08
/*!
* Flags for SetStyle/SetListStyle
*/
#define wxRICHTEXT_SETSTYLE_NONE 0x00
// Specifies that this operation should be undoable
#define wxRICHTEXT_SETSTYLE_WITH_UNDO 0x01
// Specifies that the style should not be applied if the
// combined style at this point is already the style in question.
#define wxRICHTEXT_SETSTYLE_OPTIMIZE 0x02
// Specifies that the style should only be applied to paragraphs,
// and not the content. This allows content styling to be
// preserved independently from that of e.g. a named paragraph style.
#define wxRICHTEXT_SETSTYLE_PARAGRAPHS_ONLY 0x04
// Specifies that the style should only be applied to characters,
// and not the paragraph. This allows content styling to be
// preserved independently from that of e.g. a named paragraph style.
#define wxRICHTEXT_SETSTYLE_CHARACTERS_ONLY 0x08
// For SetListStyle only: specifies starting from the given number, otherwise
// deduces number from existing attributes
#define wxRICHTEXT_SETSTYLE_RENUMBER 0x10
// For SetListStyle only: specifies the list level for all paragraphs, otherwise
// the current indentation will be used
#define wxRICHTEXT_SETSTYLE_SPECIFY_LEVEL 0x20
// Resets the existing style before applying the new style
#define wxRICHTEXT_SETSTYLE_RESET 0x40
// Removes the given style instead of applying it
#define wxRICHTEXT_SETSTYLE_REMOVE 0x80
/*!
* Flags for text insertion
*/
#define wxRICHTEXT_INSERT_NONE 0x00
#define wxRICHTEXT_INSERT_WITH_PREVIOUS_PARAGRAPH_STYLE 0x01
#define wxRICHTEXT_INSERT_INTERACTIVE 0x02
// A special flag telling the buffer to keep the first paragraph style
// as-is, when deleting a paragraph marker. In future we might pass a
// flag to InsertFragment and DeleteRange to indicate the appropriate mode.
#define wxTEXT_ATTR_KEEP_FIRST_PARA_STYLE 0x10000000
/*!
* Default superscript/subscript font multiplication factor
*/
#define wxSCRIPT_MUL_FACTOR 1.5
/**
@class wxRichTextBuffer
This class represents the whole buffer associated with a wxRichTextCtrl.
@library{wxrichtext}
@category{richtext}
@see wxTextAttr, wxRichTextCtrl
*/
class wxRichTextBuffer : public wxRichTextParagraphLayoutBox
{
public:
/**
Default constructor.
*/
wxRichTextBuffer();
/**
Copy ctor.
*/
wxRichTextBuffer(const wxRichTextBuffer& obj);
/**
Destructor.
*/
virtual ~wxRichTextBuffer();
/**
Adds an event handler to the buffer's list of handlers.
A buffer associated with a control has the control as the only event handler,
but the application is free to add more if further notification is required.
All handlers are notified of an event originating from the buffer, such as
the replacement of a style sheet during loading.
The buffer never deletes any of the event handlers, unless RemoveEventHandler()
is called with @true as the second argument.
*/
bool AddEventHandler(wxEvtHandler* handler);
/**
Adds a file handler.
*/
static void AddHandler(wxRichTextFileHandler* handler);
/**
Adds a paragraph of text.
*/
virtual wxRichTextRange AddParagraph(const wxString& text,
wxTextAttr* paraStyle = 0);
/**
Returns @true if the buffer is currently collapsing commands into a single
notional command.
*/
virtual bool BatchingUndo() const;
/**
Begins using alignment.
*/
bool BeginAlignment(wxTextAttrAlignment alignment);
/**
Begins collapsing undo/redo commands. Note that this may not work properly
if combining commands that delete or insert content, changing ranges for
subsequent actions.
@a cmdName should be the name of the combined command that will appear
next to Undo and Redo in the edit menu.
*/
virtual bool BeginBatchUndo(const wxString& cmdName);
/**
Begin applying bold.
*/
bool BeginBold();
/**
Begins applying the named character style.
*/
bool BeginCharacterStyle(const wxString& characterStyle);
/**
Begins using this font.
*/
bool BeginFont(const wxFont& font);
/**
Begins using the given point size.
*/
bool BeginFontSize(int pointSize);
/**
Begins using italic.
*/
bool BeginItalic();
/**
Begin using @a leftIndent for the left indent, and optionally @a leftSubIndent for
the sub-indent. Both are expressed in tenths of a millimetre.
The sub-indent is an offset from the left of the paragraph, and is used for all
but the first line in a paragraph. A positive value will cause the first line to appear
to the left of the subsequent lines, and a negative value will cause the first line to be
indented relative to the subsequent lines.
*/
bool BeginLeftIndent(int leftIndent, int leftSubIndent = 0);
/**
Begins line spacing using the specified value. @e spacing is a multiple, where
10 means single-spacing, 15 means 1.5 spacing, and 20 means double spacing.
The ::wxTextAttrLineSpacing enumeration values are defined for convenience.
*/
bool BeginLineSpacing(int lineSpacing);
/**
Begins using a specified list style.
Optionally, you can also pass a level and a number.
*/
bool BeginListStyle(const wxString& listStyle, int level = 1,
int number = 1);
/**
Begins a numbered bullet.
This call will be needed for each item in the list, and the
application should take care of incrementing the numbering.
@a bulletNumber is a number, usually starting with 1.
@a leftIndent and @a leftSubIndent are values in tenths of a millimetre.
@a bulletStyle is a bitlist of the following values:
wxRichTextBuffer uses indentation to render a bulleted item.
The left indent is the distance between the margin and the bullet.
The content of the paragraph, including the first line, starts
at leftMargin + leftSubIndent.
So the distance between the left edge of the bullet and the
left of the actual paragraph is leftSubIndent.
*/
bool BeginNumberedBullet(int bulletNumber, int leftIndent,
int leftSubIndent,
int bulletStyle = wxTEXT_ATTR_BULLET_STYLE_ARABIC|wxTEXT_ATTR_BULLET_STYLE_PERIOD);
/**
Begins paragraph spacing; pass the before-paragraph and after-paragraph spacing
in tenths of a millimetre.
*/
bool BeginParagraphSpacing(int before, int after);
/**
Begins applying the named paragraph style.
*/
bool BeginParagraphStyle(const wxString& paragraphStyle);
/**
Begins a right indent, specified in tenths of a millimetre.
*/
bool BeginRightIndent(int rightIndent);
/**
Begins applying a standard bullet, using one of the standard bullet names
(currently @c standard/circle or @c standard/square.
See BeginNumberedBullet() for an explanation of how indentation is used to
render the bulleted paragraph.
*/
bool BeginStandardBullet(const wxString& bulletName,
int leftIndent,
int leftSubIndent,
int bulletStyle = wxTEXT_ATTR_BULLET_STYLE_STANDARD);
/**
Begins using a specified style.
*/
virtual bool BeginStyle(const wxTextAttr& style);
/**
Begins suppressing undo/redo commands. The way undo is suppressed may be
implemented differently by each command.
If not dealt with by a command implementation, then it will be implemented
automatically by not storing the command in the undo history when the
action is submitted to the command processor.
*/
virtual bool BeginSuppressUndo();
/**
Begins applying a symbol bullet, using a character from the current font.
See BeginNumberedBullet() for an explanation of how indentation is used
to render the bulleted paragraph.
*/
bool BeginSymbolBullet(const wxString& symbol, int leftIndent,
int leftSubIndent,
int bulletStyle = wxTEXT_ATTR_BULLET_STYLE_SYMBOL);
/**
Begins using the specified text foreground colour.
*/
bool BeginTextColour(const wxColour& colour);
/**
Begins applying wxTEXT_ATTR_URL to the content.
Pass a URL and optionally, a character style to apply, since it is common
to mark a URL with a familiar style such as blue text with underlining.
*/
bool BeginURL(const wxString& url,
const wxString& characterStyle = wxEmptyString);
/**
Begins using underline.
*/
bool BeginUnderline();
/**
Returns @true if content can be pasted from the clipboard.
*/
virtual bool CanPasteFromClipboard() const;
/**
Cleans up the file handlers.
*/
static void CleanUpHandlers();
/**
Clears the buffer.
*/
virtual void Clear();
/**
Clears the list style from the given range, clearing list-related attributes
and applying any named paragraph style associated with each paragraph.
@a flags is a bit list of the following:
- wxRICHTEXT_SETSTYLE_WITH_UNDO: specifies that this command will be undoable.
@see SetListStyle(), PromoteList(), NumberList()
*/
virtual bool ClearListStyle(const wxRichTextRange& range,
int flags = wxRICHTEXT_SETSTYLE_WITH_UNDO);
/**
Clears the style stack.
*/
virtual void ClearStyleStack();
/**
Clones the object.
*/
virtual wxRichTextObject* Clone() const;
/**
Copies the given buffer.
*/
void Copy(const wxRichTextBuffer& obj);
/**
Copy the given range to the clipboard.
*/
virtual bool CopyToClipboard(const wxRichTextRange& range);
/**
Submits a command to delete the given range.
*/
bool DeleteRangeWithUndo(const wxRichTextRange& range,
wxRichTextCtrl* ctrl);
//@{
/**
Dumps the contents of the buffer for debugging purposes.
*/
void Dump();
void Dump(wxTextOutputStream& stream);
//@}
/**
Ends alignment.
*/
bool EndAlignment();
/**
Ends all styles that have been started with a Begin... command.
*/
virtual bool EndAllStyles();
/**
Ends collapsing undo/redo commands, and submits the combined command.
*/
virtual bool EndBatchUndo();
/**
Ends using bold.
*/
bool EndBold();
/**
Ends using the named character style.
*/
bool EndCharacterStyle();
/**
Ends using a font.
*/
bool EndFont();
/**
Ends using a point size.
*/
bool EndFontSize();
/**
Ends using italic.
*/
bool EndItalic();
/**
Ends using a left indent.
*/
bool EndLeftIndent();
/**
Ends using a line spacing.
*/
bool EndLineSpacing();
/**
Ends using a specified list style.
*/
bool EndListStyle();
/**
Ends a numbered bullet.
*/
bool EndNumberedBullet();
/**
Ends paragraph spacing.
*/
bool EndParagraphSpacing();
/**
Ends applying a named character style.
*/
bool EndParagraphStyle();
/**
Ends using a right indent.
*/
bool EndRightIndent();
/**
Ends using a standard bullet.
*/
bool EndStandardBullet();
/**
Ends the current style.
*/
virtual bool EndStyle();
/**
Ends suppressing undo/redo commands.
*/
virtual bool EndSuppressUndo();
/**
Ends using a symbol bullet.
*/
bool EndSymbolBullet();
/**
Ends using a text foreground colour.
*/
bool EndTextColour();
/**
Ends applying a URL.
*/
bool EndURL();
/**
Ends using underline.
*/
bool EndUnderline();
/**
Finds a handler by type.
*/
static wxRichTextFileHandler* FindHandler(wxRichTextFileType imageType);
/**
Finds a handler by extension and type.
*/
static wxRichTextFileHandler* FindHandler(const wxString& extension, wxRichTextFileType imageType);
/**
Finds a handler by name.
*/
static wxRichTextFileHandler* FindHandler(const wxString& name);
/**
Finds a handler by filename or, if supplied, type.
*/
static wxRichTextFileHandler* FindHandlerFilenameOrType(const wxString& filename, wxRichTextFileType imageType);
/**
Gets the basic (overall) style.
This is the style of the whole buffer before further styles are applied,
unlike the default style, which only affects the style currently being
applied (for example, setting the default style to bold will cause
subsequently inserted text to be bold).
*/
virtual const wxTextAttr& GetBasicStyle() const;
/**
Gets the collapsed command.
*/
virtual wxRichTextCommand* GetBatchedCommand() const;
/**
Gets the command processor.
A text buffer always creates its own command processor when it is initialized.
*/
wxCommandProcessor* GetCommandProcessor() const;
/**
Returns the current default style, affecting the style currently being applied
(for example, setting the default style to bold will cause subsequently
inserted text to be bold).
*/
virtual const wxTextAttr& GetDefaultStyle() const;
/**
Gets a wildcard incorporating all visible handlers.
If @a types is present, it will be filled with the file type corresponding
to each filter. This can be used to determine the type to pass to LoadFile()
given a selected filter.
*/
static wxString GetExtWildcard(bool combine = false, bool save = false,
wxArrayInt* types = NULL);
/**
Returns the list of file handlers.
*/
static wxList& GetHandlers();
/**
Returns the object to be used to render certain aspects of the content, such as
bullets.
*/
static wxRichTextRenderer* GetRenderer();
/**
Gets the attributes at the given position.
This function gets the combined style - that is, the style you see on the
screen as a result of combining base style, paragraph style and character
style attributes. To get the character or paragraph style alone,
use GetUncombinedStyle().
*/
virtual bool GetStyle(long position, wxTextAttr& style);
/**
This function gets a style representing the common, combined attributes in the
given range.
Attributes which have different values within the specified range will not be
included the style flags.
The function is used to get the attributes to display in the formatting dialog:
the user can edit the attributes common to the selection, and optionally specify the
values of further attributes to be applied uniformly.
To apply the edited attributes, you can use SetStyle() specifying
the wxRICHTEXT_SETSTYLE_OPTIMIZE flag, which will only apply attributes that
are different from the @e combined attributes within the range.
So, the user edits the effective, displayed attributes for the range,
but his choice won't be applied unnecessarily to content. As an example,
say the style for a paragraph specifies bold, but the paragraph text doesn't
specify a weight.
The combined style is bold, and this is what the user will see on-screen and
in the formatting dialog. The user now specifies red text, in addition to bold.
When applying with SetStyle(), the content font weight attributes won't be
changed to bold because this is already specified by the paragraph.
However the text colour attributes @e will be changed to show red.
*/
virtual bool GetStyleForRange(const wxRichTextRange& range,
wxTextAttr& style);
/**
Returns the current style sheet associated with the buffer, if any.
*/
virtual wxRichTextStyleSheet* GetStyleSheet() const;
/**
Get the size of the style stack, for example to check correct nesting.
*/
virtual size_t GetStyleStackSize() const;
/**
Gets the attributes at the given position.
This function gets the @e uncombined style - that is, the attributes associated
with the paragraph or character content, and not necessarily the combined
attributes you see on the screen. To get the combined attributes, use GetStyle().
If you specify (any) paragraph attribute in @e style's flags, this function
will fetch the paragraph attributes.
Otherwise, it will return the character attributes.
*/
virtual bool GetUncombinedStyle(long position, wxTextAttr& style);
/**
Finds the text position for the given position, putting the position in
@a textPosition if one is found.
@a pt is in logical units (a zero y position is at the beginning of the buffer).
@return One of the ::wxRichTextHitTestFlags values.
*/
virtual int HitTest(wxDC& dc, const wxPoint& pt, long& textPosition);
/**
Initialisation.
*/
void Init();
/**
Initialises the standard handlers.
Currently, only the plain text loading/saving handler is initialised by default.
*/
static void InitStandardHandlers();
/**
Inserts a handler at the front of the list.
*/
static void InsertHandler(wxRichTextFileHandler* handler);
/**
Submits a command to insert the given image.
*/
bool InsertImageWithUndo(long pos, const wxRichTextImageBlock& imageBlock,
wxRichTextCtrl* ctrl, int flags = 0);
/**
Submits a command to insert a newline.
*/
bool InsertNewlineWithUndo(long pos, wxRichTextCtrl* ctrl, int flags = 0);
/**
Submits a command to insert the given text.
*/
bool InsertTextWithUndo(long pos, const wxString& text,
wxRichTextCtrl* ctrl, int flags = 0);
/**
Returns @true if the buffer has been modified.
*/
bool IsModified() const;
/**
Loads content from a stream.
*/
virtual bool LoadFile(wxInputStream& stream,
wxRichTextFileType type = wxRICHTEXT_TYPE_ANY);
/**
Loads content from a file.
*/
virtual bool LoadFile(const wxString& filename,
wxRichTextFileType type = wxRICHTEXT_TYPE_ANY);
/**
Marks the buffer as modified or unmodified.
*/
void Modify(bool modify = true);
//@{
/**
Numbers the paragraphs in the given range.
Pass flags to determine how the attributes are set.
Either the style definition or the name of the style definition (in the current
sheet) can be passed.
@a flags is a bit list of the following:
- wxRICHTEXT_SETSTYLE_WITH_UNDO: specifies that this command will be undoable.
- wxRICHTEXT_SETSTYLE_RENUMBER: specifies that numbering should start from
@a startFrom, otherwise existing attributes are used.
- wxRICHTEXT_SETSTYLE_SPECIFY_LEVEL: specifies that @a listLevel should be used
as the level for all paragraphs, otherwise the current indentation will be used.
@see SetListStyle(), PromoteList(), ClearListStyle()
*/
bool NumberList(const wxRichTextRange& range,
const wxRichTextListStyleDefinition* style,
int flags = wxRICHTEXT_SETSTYLE_WITH_UNDO,
int startFrom = -1,
int listLevel = -1);
bool Number(const wxRichTextRange& range,
const wxString& styleName,
int flags = wxRICHTEXT_SETSTYLE_WITH_UNDO,
int startFrom = -1,
int listLevel = -1);
//@}
/**
Pastes the clipboard content to the buffer at the given position.
*/
virtual bool PasteFromClipboard(long position);
//@{
/**
Promotes or demotes the paragraphs in the given range.
A positive @a promoteBy produces a smaller indent, and a negative number
produces a larger indent. Pass flags to determine how the attributes are set.
Either the style definition or the name of the style definition (in the current
sheet) can be passed.
@a flags is a bit list of the following:
- wxRICHTEXT_SETSTYLE_WITH_UNDO: specifies that this command will be undoable.
- wxRICHTEXT_SETSTYLE_RENUMBER: specifies that numbering should start from
@a startFrom, otherwise existing attributes are used.
- wxRICHTEXT_SETSTYLE_SPECIFY_LEVEL: specifies that @a listLevel should be used
as the level for all paragraphs, otherwise the current indentation will be used.
@see SetListStyle(), SetListStyle(), ClearListStyle()
*/
bool PromoteList(int promoteBy, const wxRichTextRange& range,
const wxRichTextListStyleDefinition* style,
int flags = wxRICHTEXT_SETSTYLE_WITH_UNDO,
int listLevel = -1);
bool PromoteList(int promoteBy, const wxRichTextRange& range,
const wxString& styleName,
int flags = wxRICHTEXT_SETSTYLE_WITH_UNDO,
int listLevel = -1);
//@}
/**
Removes an event handler from the buffer's list of handlers, deleting the
object if @a deleteHandler is @true.
*/
bool RemoveEventHandler(wxEvtHandler* handler,
bool deleteHandler = false);
/**
Removes a handler.
*/
static bool RemoveHandler(const wxString& name);
/**
Clears the buffer, adds a new blank paragraph, and clears the command history.
*/
virtual void ResetAndClearCommands();
/**
Saves content to a stream.
*/
virtual bool SaveFile(wxOutputStream& stream,
wxRichTextFileType type = wxRICHTEXT_TYPE_ANY);
/**
Saves content to a file.
*/
virtual bool SaveFile(const wxString& filename,
wxRichTextFileType type = wxRICHTEXT_TYPE_ANY);
/**
Sets the basic (overall) style. This is the style of the whole
buffer before further styles are applied, unlike the default style, which
only affects the style currently being applied (for example, setting the default
style to bold will cause subsequently inserted text to be bold).
*/
virtual void SetBasicStyle(const wxTextAttr& style);
/**
Sets the default style, affecting the style currently being applied
(for example, setting the default style to bold will cause subsequently
inserted text to be bold).
This is not cumulative - setting the default style will replace the previous
default style.
*/
virtual bool SetDefaultStyle(const wxTextAttr& style);
//@{
/**
Sets the list attributes for the given range, passing flags to determine how
the attributes are set.
Either the style definition or the name of the style definition (in the current
sheet) can be passed.
@a flags is a bit list of the following:
- wxRICHTEXT_SETSTYLE_WITH_UNDO: specifies that this command will be undoable.
- wxRICHTEXT_SETSTYLE_RENUMBER: specifies that numbering should start from
@a startFrom, otherwise existing attributes are used.
- wxRICHTEXT_SETSTYLE_SPECIFY_LEVEL: specifies that @a listLevel should be used
as the level for all paragraphs, otherwise the current indentation will be used.
@see NumberList(), PromoteList(), ClearListStyle().
*/
bool SetListStyle(const wxRichTextRange& range,
const wxRichTextListStyleDefinition* style,
int flags = wxRICHTEXT_SETSTYLE_WITH_UNDO,
int startFrom = -1,
int listLevel = -1);
bool SetListStyle(const wxRichTextRange& range,
const wxString& styleName,
int flags = wxRICHTEXT_SETSTYLE_WITH_UNDO,
int startFrom = -1,
int listLevel = -1);
//@}
/**
Sets @a renderer as the object to be used to render certain aspects of the
content, such as bullets.
You can override default rendering by deriving a new class from
wxRichTextRenderer or wxRichTextStdRenderer, overriding one or more
virtual functions, and setting an instance of the class using this function.
*/
static void SetRenderer(wxRichTextRenderer* renderer);
/**
Sets the attributes for the given range. Pass flags to determine how the
attributes are set.
The end point of range is specified as the last character position of the span
of text. So, for example, to set the style for a character at position 5,
use the range (5,5).
This differs from the wxRichTextCtrl API, where you would specify (5,6).
@a flags may contain a bit list of the following values:
- wxRICHTEXT_SETSTYLE_NONE: no style flag.
- wxRICHTEXT_SETSTYLE_WITH_UNDO: specifies that this operation should be
undoable.
- wxRICHTEXT_SETSTYLE_OPTIMIZE: specifies that the style should not be applied
if the combined style at this point is already the style in question.
- wxRICHTEXT_SETSTYLE_PARAGRAPHS_ONLY: specifies that the style should only be
applied to paragraphs, and not the content.
This allows content styling to be preserved independently from that
of e.g. a named paragraph style.
- wxRICHTEXT_SETSTYLE_CHARACTERS_ONLY: specifies that the style should only be
applied to characters, and not the paragraph.
This allows content styling to be preserved independently from that
of e.g. a named paragraph style.
- wxRICHTEXT_SETSTYLE_RESET: resets (clears) the existing style before applying
the new style.
- wxRICHTEXT_SETSTYLE_REMOVE: removes the specified style.
Only the style flags are used in this operation.
*/
virtual bool SetStyle(const wxRichTextRange& range, const wxTextAttr& style,
int flags = wxRICHTEXT_SETSTYLE_WITH_UNDO);
/**
Sets the current style sheet, if any.
This will allow the application to use named character and paragraph
styles found in the style sheet.
*/
void SetStyleSheet(wxRichTextStyleSheet* styleSheet);
/**
Submit an action immediately, or delay it according to whether collapsing is on.
*/
virtual bool SubmitAction(wxRichTextAction* action);
/**
Returns @true if undo suppression is currently on.
*/
virtual bool SuppressingUndo() const;
};
/**
@class wxRichTextFileHandler
This is the base class for file handlers, for loading and/or saving content
associated with a wxRichTextBuffer.
@library{wxrichtext}
@category{richtext}
*/
class wxRichTextFileHandler : public wxObject
{
public:
/**
Constructor.
*/
wxRichTextFileHandler(const wxString& name = wxEmptyString,
const wxString& ext = wxEmptyString,
int type = 0);
/**
Override this function and return @true if this handler can we handle
@a filename.
By default, this function checks the extension.
*/
virtual bool CanHandle(const wxString& filename) const;
/**
Override and return @true if this handler can load content.
*/
virtual bool CanLoad() const;
/**
Override and return @true if this handler can save content.
*/
virtual bool CanSave() const;
/**
Returns the encoding associated with the handler (if any).
*/
const wxString& GetEncoding() const;
/**
Returns the extension associated with the handler.
*/
wxString GetExtension() const;
/**
Returns flags that change the behaviour of loading or saving.
See the documentation for each handler class to see what flags are
relevant for each handler.
*/
int GetFlags() const;
/**
Returns the name of the handler.
*/
wxString GetName() const;
/**
Returns the type of the handler.
*/
int GetType() const;
/**
Returns @true if this handler should be visible to the user.
*/
virtual bool IsVisible() const;
//@{
/**
Loads content from a stream or file.
Not all handlers will implement file loading.
*/
bool LoadFile(wxRichTextBuffer* buffer, wxInputStream& stream);
bool LoadFile(wxRichTextBuffer* buffer, const wxString& filename);
//@}
//@{
/**
Saves content to a stream or file.
Not all handlers will implement file saving.
*/
bool SaveFile(wxRichTextBuffer* buffer, wxOutputStream& stream);
bool SaveFile(wxRichTextBuffer* buffer, const wxString& filename);
//@}
/**
Sets the encoding to use when saving a file.
If empty, a suitable encoding is chosen.
*/
void SetEncoding(const wxString& encoding);
/**
Sets the default extension to recognise.
*/
void SetExtension(const wxString& ext);
/**
Sets flags that change the behaviour of loading or saving.
See the documentation for each handler class to see what flags are relevant
for each handler.
You call this function directly if you are using a file handler explicitly
(without going through the text control or buffer LoadFile/SaveFile API).
Or, you can call the control or buffer's SetHandlerFlags function to set
the flags that will be used for subsequent load and save operations.
*/
void SetFlags(int flags);
/**
Sets the name of the handler.
*/
void SetName(const wxString& name);
/**
Sets the handler type.
*/
void SetType(int type);
/**
Sets whether the handler should be visible to the user (via the application's
load and save dialogs).
*/
virtual void SetVisible(bool visible);
protected:
/**
Override to load content from @a stream into @a buffer.
*/
virtual bool DoLoadFile(wxRichTextBuffer* buffer,
wxInputStream& stream) = 0;
/**
Override to save content to @a stream from @a buffer.
*/
virtual bool DoSaveFile(wxRichTextBuffer* buffer,
wxOutputStream& stream) = 0;
};
/**
@class wxRichTextRange
This class stores beginning and end positions for a range of data.
@library{wxrichtext}
@category{richtext}
*/
class wxRichTextRange
{
public:
//@{
/**
Constructors.
*/
wxRichTextRange(long start, long end);
wxRichTextRange(const wxRichTextRange& range);
wxRichTextRange();
//@}
/**
Destructor.
*/
~wxRichTextRange();
/**
Returns @true if the given position is within this range.
Does not match if the range is empty.
*/
bool Contains(long pos) const;
/**
Converts the internal range, which uses the first and last character positions
of the range, to the API-standard range, whose end is one past the last
character in the range.
In other words, one is added to the end position.
*/
wxRichTextRange FromInternal() const;
/**
Returns the end position.
*/
long GetEnd() const;
/**
Returns the length of the range.
*/
long GetLength() const;
/**
Returns the start of the range.
*/
long GetStart() const;
/**
Returns @true if this range is completely outside @e range.
*/
bool IsOutside(const wxRichTextRange& range) const;
/**
Returns @true if this range is completely within @e range.
*/
bool IsWithin(const wxRichTextRange& range) const;
/**
Limits this range to be within @e range.
*/
bool LimitTo(const wxRichTextRange& range);
/**
Sets the end of the range.
*/
void SetEnd(long end);
/**
Sets the range.
*/
void SetRange(long start, long end);
/**
Sets the start of the range.
*/
void SetStart(long start);
/**
Swaps the start and end.
*/
void Swap();
/**
Converts the API-standard range, whose end is one past the last character in
the range, to the internal form, which uses the first and last character
positions of the range.
In other words, one is subtracted from the end position.
*/
wxRichTextRange ToInternal() const;
/**
Adds @a range to this range.
*/
wxRichTextRange operator+(const wxRichTextRange& range) const;
/**
Subtracts @a range from this range.
*/
wxRichTextRange operator-(const wxRichTextRange& range) const;
/**
Assigns @a range to this range.
*/
void operator=(const wxRichTextRange& range);
/**
Returns @true if @a range is the same as this range.
*/
bool operator==(const wxRichTextRange& range) const;
};