2001-06-26 20:59:19 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/cmdproc.h
|
|
|
|
// Purpose: undo/redo capable command processing framework
|
|
|
|
// Author: Julian Smart (extracted from docview.h by VZ)
|
|
|
|
// Modified by:
|
|
|
|
// Created: 05.11.00
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Copyright: (c) wxWindows team
|
|
|
|
// Licence: wxWindows licence
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_CMDPROC_H_
|
|
|
|
#define _WX_CMDPROC_H_
|
|
|
|
|
2003-08-09 12:38:21 +00:00
|
|
|
#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
|
2001-06-26 20:59:19 +00:00
|
|
|
#pragma interface "cmdproc.h"
|
|
|
|
#endif
|
|
|
|
|
2003-07-18 19:47:19 +00:00
|
|
|
#include "wx/defs.h"
|
2001-06-26 20:59:19 +00:00
|
|
|
#include "wx/object.h"
|
|
|
|
#include "wx/list.h"
|
|
|
|
|
2003-02-25 12:43:06 +00:00
|
|
|
class WXDLLEXPORT wxMenu;
|
|
|
|
|
2001-06-26 20:59:19 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxCommand: a single command capable of performing itself
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
class WXDLLEXPORT wxCommand : public wxObject
|
|
|
|
{
|
|
|
|
public:
|
2003-07-10 08:36:14 +00:00
|
|
|
wxCommand(bool canUndoIt = FALSE, const wxString& name = wxEmptyString);
|
2001-06-26 20:59:19 +00:00
|
|
|
~wxCommand();
|
|
|
|
|
|
|
|
// Override this to perform a command
|
|
|
|
virtual bool Do() = 0;
|
|
|
|
|
|
|
|
// Override this to undo a command
|
|
|
|
virtual bool Undo() = 0;
|
|
|
|
|
|
|
|
virtual bool CanUndo() const { return m_canUndo; }
|
|
|
|
virtual wxString GetName() const { return m_commandName; }
|
|
|
|
|
|
|
|
protected:
|
|
|
|
bool m_canUndo;
|
|
|
|
wxString m_commandName;
|
|
|
|
|
|
|
|
private:
|
|
|
|
DECLARE_CLASS(wxCommand)
|
|
|
|
};
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxCommandProcessor: wxCommand manager
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
class WXDLLEXPORT wxCommandProcessor : public wxObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// if max number of commands is -1, it is unlimited
|
|
|
|
wxCommandProcessor(int maxCommands = -1);
|
|
|
|
virtual ~wxCommandProcessor();
|
|
|
|
|
|
|
|
// Pass a command to the processor. The processor calls Do(); if
|
|
|
|
// successful, is appended to the command history unless storeIt is FALSE.
|
|
|
|
virtual bool Submit(wxCommand *command, bool storeIt = TRUE);
|
|
|
|
|
|
|
|
// just store the command without executing it
|
|
|
|
virtual void Store(wxCommand *command);
|
|
|
|
|
|
|
|
virtual bool Undo();
|
|
|
|
virtual bool Redo();
|
|
|
|
virtual bool CanUndo() const;
|
|
|
|
virtual bool CanRedo() const;
|
|
|
|
|
2002-12-20 10:15:06 +00:00
|
|
|
// Initialises the current command and menu strings.
|
2001-06-26 20:59:19 +00:00
|
|
|
virtual void Initialize();
|
2002-12-20 10:15:06 +00:00
|
|
|
|
|
|
|
// Sets the Undo/Redo menu strings for the current menu.
|
2001-06-26 20:59:19 +00:00
|
|
|
virtual void SetMenuStrings();
|
|
|
|
|
2002-12-20 10:15:06 +00:00
|
|
|
// Gets the current Undo menu label.
|
|
|
|
wxString GetUndoMenuLabel() const;
|
|
|
|
|
|
|
|
// Gets the current Undo menu label.
|
|
|
|
wxString GetRedoMenuLabel() const;
|
|
|
|
|
2001-06-26 20:59:19 +00:00
|
|
|
#if wxUSE_MENUS
|
|
|
|
// Call this to manage an edit menu.
|
|
|
|
void SetEditMenu(wxMenu *menu) { m_commandEditMenu = menu; }
|
|
|
|
wxMenu *GetEditMenu() const { return m_commandEditMenu; }
|
|
|
|
#endif // wxUSE_MENUS
|
|
|
|
|
|
|
|
// command list access
|
|
|
|
wxList& GetCommands() const { return (wxList&) m_commands; }
|
|
|
|
wxCommand *GetCurrentCommand() const
|
|
|
|
{
|
2003-01-13 05:17:41 +00:00
|
|
|
return (wxCommand *)(m_currentCommand ? m_currentCommand->GetData() : NULL);
|
2001-06-26 20:59:19 +00:00
|
|
|
}
|
|
|
|
int GetMaxCommands() const { return m_maxNoCommands; }
|
|
|
|
virtual void ClearCommands();
|
|
|
|
|
2002-04-11 16:50:55 +00:00
|
|
|
// By default, the accelerators are "\tCtrl+Z" and "\tCtrl+Y"
|
|
|
|
const wxString& GetUndoAccelerator() const { return m_undoAccelerator; }
|
|
|
|
const wxString& GetRedoAccelerator() const { return m_redoAccelerator; }
|
|
|
|
|
|
|
|
void SetUndoAccelerator(const wxString& accel) { m_undoAccelerator = accel; }
|
|
|
|
void SetRedoAccelerator(const wxString& accel) { m_redoAccelerator = accel; }
|
|
|
|
|
2001-06-26 20:59:19 +00:00
|
|
|
protected:
|
|
|
|
// for further flexibility, command processor doesn't call wxCommand::Do()
|
|
|
|
// and Undo() directly but uses these functions which can be overridden in
|
|
|
|
// the derived class
|
|
|
|
virtual bool DoCommand(wxCommand& cmd);
|
|
|
|
virtual bool UndoCommand(wxCommand& cmd);
|
|
|
|
|
|
|
|
int m_maxNoCommands;
|
|
|
|
wxList m_commands;
|
2003-07-10 19:55:12 +00:00
|
|
|
wxList::compatibility_iterator m_currentCommand;
|
2001-06-26 20:59:19 +00:00
|
|
|
|
|
|
|
#if wxUSE_MENUS
|
|
|
|
wxMenu* m_commandEditMenu;
|
|
|
|
#endif // wxUSE_MENUS
|
|
|
|
|
2002-04-11 16:50:55 +00:00
|
|
|
wxString m_undoAccelerator;
|
|
|
|
wxString m_redoAccelerator;
|
|
|
|
|
2001-06-26 20:59:19 +00:00
|
|
|
private:
|
|
|
|
DECLARE_DYNAMIC_CLASS(wxCommandProcessor)
|
2003-01-02 23:38:11 +00:00
|
|
|
DECLARE_NO_COPY_CLASS(wxCommandProcessor)
|
2001-06-26 20:59:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // _WX_CMDPROC_H_
|