Home · All Classes · Main Classes · Grouped Classes · Modules · Functions

QUndoCommand Class Reference
[QtGui module]

The QUndoCommand class is the base class of all commands stored on a QUndoStack. More...

 #include <QUndoCommand>

This class was introduced in Qt 4.2.

Public Functions


Detailed Description

The QUndoCommand class is the base class of all commands stored on a QUndoStack.

For an overview of Qt's Undo Framework, see the overview document.

A QUndoCommand represents a single editing action on a document; for example, inserting or deleting a block of text in a text editor. QUndoCommand can apply a change to the document with redo() and undo the change with undo(). The implementations for these functions must be provided in a derived class.

 class AppendText : public QUndoCommand
 {
 public:
     AppendText(QString *doc, const QString &text)
         : m_document(doc), m_text(text) { setText("append text"); }
     virtual void undo()
         { m_document->chop(m_text.length()); }
     virtual void redo()
         { m_document->append(m_text); }
 private:
     QString *m_document;
     QString m_text;
 };

A QUndoCommand has an associated text(). This is a short string describing what the command does. It is used to update the text properties of the stack's undo and redo actions; see QUndoStack::createUndoAction() and QUndoStack::createRedoAction().

To support command compression, QUndoCommand has an id() and the virtual function mergeWith(). These functions are used by QUndoStack::push().

To support command macros, a QUndoCommand object can have any number of child commands. Undoing or redoing the parent command will cause the child commands to be undone or redone. A command can be assigned to a parent explicitly in the constructor.

 QUndoCommand *insertRed = new QUndoCommand(); // an empty command
 insertRed->setText("insert red text");

 new InsertText(document, idx, text, insertRed); // becomes child of insertRed
 new SetColor(document, idx, text.length(), Qt::red, insertRed);

 stack.push(insertRed);

Another way to create macros is to use the convenience functions QUndoStack::beginMacro() and QUndoStack::endMacro().

See also QUndoStack.


Member Function Documentation

QUndoCommand::QUndoCommand ( QUndoCommand * parent = 0 )

Constructs a QUndoCommand object with parent parent.

If parent is not 0, this command is appended to parent's child list. The parent command then owns this command and will delete it in its destructor.

See also ~QUndoCommand().

QUndoCommand::QUndoCommand ( const QString & text, QUndoCommand * parent = 0 )

Constructs a QUndoCommand object with the given parent and text.

If parent is not 0, this command is appended to parent's child list. The parent command then owns this command and will delete it in its destructor.

See also ~QUndoCommand().

QUndoCommand::~QUndoCommand ()   [virtual]

Destroys the QUndoCommand object and all child commands. If the command was in a QUndoGroup, removes it grom the group.

See also QUndoCommand().

int QUndoCommand::id () const   [virtual]

Returns the ID of this command.

A command ID is used in command compression. It must be an integer unique to this command's class, or -1 if the command doesn't support compression.

If the command supports compression this function must be overridden in the derived class to return the correct ID. The base implementation returns -1.

QUndoStack will only try to merge two commands if they have the same ID, and the ID is not -1.

See also mergeWith() and QUndoStack::push().

bool QUndoCommand::mergeWith ( const QUndoCommand * command )   [virtual]

Attempts to merge this command with the specified command. Returns true on success; otherwise returns false.

If this function returns true, calling this command's redo() must have the same effect as redoing both this command and the specified command. Similarly, calling this command's undo() must have the same effect as undoing both the specified command and this command.

QUndoStack will only try to merge two commands if they have the same id, and the id is not -1.

The default implementation returns false.

 bool AppendText::mergeWith(const QUndoCommand *other)
 {
     if (other->id() != id()) // make sure other is also an AppendText command
         return false;
     m_text += static_cast<const AppendText*>(other)->m_text;
     return true;
 }

See also id() and QUndoStack::push().

void QUndoCommand::redo ()   [virtual]

Applies a change to the document. This function must be implemented in the derived class. Calling QUndoStack::push(), QUndoStack::undo() or QUndoStack::redo() from this funciton leads to undefined beahavior.

The default implementation calls redo() on all child commands.

See also undo().

void QUndoCommand::setText ( const QString & text )

Sets the command's text to be the text specified.

The specified text should be a short user-readable string describing what this command does.

See also text(), QUndoStack::createUndoAction(), and QUndoStack::createRedoAction().

QString QUndoCommand::text () const

Returns a short text string describing what this command does; for example, "insert text".

The text is used when the text properties of the stack's undo and redo actions are updated.

See also setText(), QUndoStack::createUndoAction(), and QUndoStack::createRedoAction().

void QUndoCommand::undo ()   [virtual]

Reverts a change to the document. After undo() is called, the state of the document should be the same as before redo() was called. This function must be implemented in the derived class. Calling QUndoStack::push(), QUndoStack::undo() or QUndoStack::redo() from this funciton leads to undefined beahavior.

The default implementation calls undo() on all child commands in reverse order.

See also redo().


Copyright © 2007 Trolltech Trademarks
Qt 4.2.3