Version: 3.3.0
wxCommandProcessor Class Reference

#include <wx/cmdproc.h>

+ Inheritance diagram for wxCommandProcessor:

Detailed Description

wxCommandProcessor is a class that maintains a history of wxCommands, with undo/redo functionality built-in.

Derive a new class from this if you want different behaviour.

Library:  wxCore
Category:  Document/View Framework
See also
wxCommandProcessor Overview, wxCommand

Public Member Functions

 wxCommandProcessor (int maxCommands=-1)
 Constructor. More...
 
virtual ~wxCommandProcessor ()
 Destructor. More...
 
virtual bool CanUndo () const
 Returns true if the currently-active command can be undone, false otherwise. More...
 
virtual bool CanRedo () const
 Returns true if the currently-active command can be redone, false otherwise. More...
 
virtual void ClearCommands ()
 Deletes all commands in the list and sets the current command pointer to nullptr. More...
 
wxList & GetCommands ()
 Returns the list of commands. More...
 
wxCommandGetCurrentCommand () const
 Returns the current command. More...
 
wxMenuGetEditMenu () const
 Returns the edit menu associated with the command processor. More...
 
int GetMaxCommands () const
 Returns the maximum number of commands that the command processor stores. More...
 
const wxStringGetRedoAccelerator () const
 Returns the string that will be appended to the Redo menu item. More...
 
wxString GetRedoMenuLabel () const
 Returns the string that will be shown for the redo menu item. More...
 
const wxStringGetUndoAccelerator () const
 Returns the string that will be appended to the Undo menu item. More...
 
wxString GetUndoMenuLabel () const
 Returns the string that will be shown for the undo menu item. More...
 
virtual void Initialize ()
 Initializes the command processor, setting the current command to the last in the list (if any), and updating the edit menu (if one has been specified). More...
 
virtual bool IsDirty () const
 Returns a boolean value that indicates if changes have been made since the last save operation. More...
 
void MarkAsSaved ()
 You must call this method whenever the project is saved if you plan to use IsDirty(). More...
 
virtual bool Redo ()
 Executes (redoes) the current command (the command that has just been undone if any). More...
 
void SetEditMenu (wxMenu *menu)
 Tells the command processor to update the Undo and Redo items on this menu as appropriate. More...
 
virtual void SetMenuStrings ()
 Sets the menu labels according to the currently set menu and the current command state. More...
 
void SetRedoAccelerator (const wxString &accel)
 Sets the string that will be appended to the Redo menu item. More...
 
void SetUndoAccelerator (const wxString &accel)
 Sets the string that will be appended to the Undo menu item. More...
 
virtual bool Submit (wxCommand *command, bool storeIt=true)
 Submits a new command to the command processor. More...
 
virtual void Store (wxCommand *command)
 Just store the command without executing it. More...
 
virtual bool Undo ()
 Undoes the last command executed. More...
 
- Public Member Functions inherited from wxObject
 wxObject ()
 Default ctor; initializes to nullptr the internal reference data. More...
 
 wxObject (const wxObject &other)
 Copy ctor. More...
 
virtual ~wxObject ()
 Destructor. More...
 
virtual wxClassInfoGetClassInfo () const
 This virtual function is redefined for every class that requires run-time type information, when using the wxDECLARE_CLASS macro (or similar). More...
 
wxObjectRefDataGetRefData () const
 Returns the wxObject::m_refData pointer, i.e. the data referenced by this object. More...
 
bool IsKindOf (const wxClassInfo *info) const
 Determines whether this class is a subclass of (or the same class as) the given class. More...
 
bool IsSameAs (const wxObject &obj) const
 Returns true if this object has the same data pointer as obj. More...
 
void Ref (const wxObject &clone)
 Makes this object refer to the data in clone. More...
 
void SetRefData (wxObjectRefData *data)
 Sets the wxObject::m_refData pointer. More...
 
void UnRef ()
 Decrements the reference count in the associated data, and if it is zero, deletes the data. More...
 
void UnShare ()
 This is the same of AllocExclusive() but this method is public. More...
 
void operator delete (void *buf)
 The delete operator is defined for debugging versions of the library only, when the identifier __WXDEBUG__ is defined. More...
 
void * operator new (size_t size, const wxString &filename=nullptr, int lineNum=0)
 The new operator is defined for debugging versions of the library only, when the identifier __WXDEBUG__ is defined. More...
 

Additional Inherited Members

- Protected Member Functions inherited from wxObject
void AllocExclusive ()
 Ensure that this object's data is not shared with any other object. More...
 
virtual wxObjectRefDataCreateRefData () const
 Creates a new instance of the wxObjectRefData-derived class specific to this object and returns it. More...
 
virtual wxObjectRefDataCloneRefData (const wxObjectRefData *data) const
 Creates a new instance of the wxObjectRefData-derived class specific to this object and initializes it copying data. More...
 
- Protected Attributes inherited from wxObject
wxObjectRefDatam_refData
 Pointer to an object which is the object's reference-counted data. More...
 

Constructor & Destructor Documentation

◆ wxCommandProcessor()

wxCommandProcessor::wxCommandProcessor ( int  maxCommands = -1)

Constructor.

Parameters
maxCommandsMay be set to a positive integer to limit the number of commands stored to it, otherwise (and by default) the list of commands can grow arbitrarily.

◆ ~wxCommandProcessor()

virtual wxCommandProcessor::~wxCommandProcessor ( )
virtual

Destructor.

Member Function Documentation

◆ CanRedo()

virtual bool wxCommandProcessor::CanRedo ( ) const
virtual

Returns true if the currently-active command can be redone, false otherwise.

◆ CanUndo()

virtual bool wxCommandProcessor::CanUndo ( ) const
virtual

Returns true if the currently-active command can be undone, false otherwise.

◆ ClearCommands()

virtual void wxCommandProcessor::ClearCommands ( )
virtual

Deletes all commands in the list and sets the current command pointer to nullptr.

◆ GetCommands()

wxList& wxCommandProcessor::GetCommands ( )

Returns the list of commands.

◆ GetCurrentCommand()

wxCommand* wxCommandProcessor::GetCurrentCommand ( ) const

Returns the current command.

◆ GetEditMenu()

wxMenu* wxCommandProcessor::GetEditMenu ( ) const

Returns the edit menu associated with the command processor.

◆ GetMaxCommands()

int wxCommandProcessor::GetMaxCommands ( ) const

Returns the maximum number of commands that the command processor stores.

◆ GetRedoAccelerator()

const wxString& wxCommandProcessor::GetRedoAccelerator ( ) const

Returns the string that will be appended to the Redo menu item.

◆ GetRedoMenuLabel()

wxString wxCommandProcessor::GetRedoMenuLabel ( ) const

Returns the string that will be shown for the redo menu item.

◆ GetUndoAccelerator()

const wxString& wxCommandProcessor::GetUndoAccelerator ( ) const

Returns the string that will be appended to the Undo menu item.

◆ GetUndoMenuLabel()

wxString wxCommandProcessor::GetUndoMenuLabel ( ) const

Returns the string that will be shown for the undo menu item.

◆ Initialize()

virtual void wxCommandProcessor::Initialize ( )
virtual

Initializes the command processor, setting the current command to the last in the list (if any), and updating the edit menu (if one has been specified).

◆ IsDirty()

virtual bool wxCommandProcessor::IsDirty ( ) const
virtual

Returns a boolean value that indicates if changes have been made since the last save operation.

This only works if MarkAsSaved() is called whenever the project is saved.

◆ MarkAsSaved()

void wxCommandProcessor::MarkAsSaved ( )

You must call this method whenever the project is saved if you plan to use IsDirty().

◆ Redo()

virtual bool wxCommandProcessor::Redo ( )
virtual

Executes (redoes) the current command (the command that has just been undone if any).

◆ SetEditMenu()

void wxCommandProcessor::SetEditMenu ( wxMenu menu)

Tells the command processor to update the Undo and Redo items on this menu as appropriate.

Set this to nullptr if the menu is about to be destroyed and command operations may still be performed, or the command processor may try to access an invalid pointer.

◆ SetMenuStrings()

virtual void wxCommandProcessor::SetMenuStrings ( )
virtual

Sets the menu labels according to the currently set menu and the current command state.

◆ SetRedoAccelerator()

void wxCommandProcessor::SetRedoAccelerator ( const wxString accel)

Sets the string that will be appended to the Redo menu item.

◆ SetUndoAccelerator()

void wxCommandProcessor::SetUndoAccelerator ( const wxString accel)

Sets the string that will be appended to the Undo menu item.

◆ Store()

virtual void wxCommandProcessor::Store ( wxCommand command)
virtual

Just store the command without executing it.

The command is stored in the history list, and the associated edit menu (if any) updated appropriately.

◆ Submit()

virtual bool wxCommandProcessor::Submit ( wxCommand command,
bool  storeIt = true 
)
virtual

Submits a new command to the command processor.

The command processor calls wxCommand::Do() to execute the command; if it succeeds, the command is stored in the history list, and the associated edit menu (if any) updated appropriately. If it fails, the command is deleted immediately. Once Submit() has been called, the passed command should not be deleted directly by the application.

Parameters
commandThe command to submit
storeItIndicates whether the successful command should be stored in the history list.

◆ Undo()

virtual bool wxCommandProcessor::Undo ( )
virtual

Undoes the last command executed.