- java.lang.Object
-
- javax.swing.undo.AbstractUndoableEdit
-
- javax.swing.undo.CompoundEdit
-
- javax.swing.undo.UndoManager
-
- All Implemented Interfaces:
Serializable
,EventListener
,UndoableEditListener
,UndoableEdit
public class UndoManager extends CompoundEdit implements UndoableEditListener
UndoManager
manages a list ofUndoableEdits
, providing a way to undo or redo the appropriate edits. There are two ways to add edits to anUndoManager
. Add the edit directly using theaddEdit
method, or add theUndoManager
to a bean that supportsUndoableEditListener
. The following examples creates anUndoManager
and adds it as anUndoableEditListener
to aJTextField
:UndoManager undoManager = new UndoManager(); JTextField tf = ...; tf.getDocument().addUndoableEditListener(undoManager);
UndoManager
maintains an ordered list of edits and the index of the next edit in that list. The index of the next edit is either the size of the current list of edits, or ifundo
has been invoked it corresponds to the index of the last significant edit that was undone. Whenundo
is invoked all edits from the index of the next edit to the last significant edit are undone, in reverse order. For example, consider anUndoManager
consisting of the following edits: A b c D. Edits with a upper-case letter in bold are significant, those in lower-case and italicized are insignificant.Figure 1 As shown in figure 1, if D was just added, the index of the next edit will be 4. Invoking
undo
results in invokingundo
on D and setting the index of the next edit to 3 (edit c), as shown in the following figure.Figure 2 The last significant edit is A, so that invoking
undo
again invokesundo
on c, b, and A, in that order, setting the index of the next edit to 0, as shown in the following figure.Figure 3 Invoking
redo
results in invokingredo
on all edits between the index of the next edit and the next significant edit (or the end of the list). Continuing with the previous example ifredo
were invoked,redo
would in turn be invoked on A, b and c. In addition the index of the next edit is set to 3 (as shown in figure 2).Adding an edit to an
UndoManager
results in removing all edits from the index of the next edit to the end of the list. Continuing with the previous example, if a new edit, e, is added the edit D is removed from the list (after havingdie
invoked on it). If c is not incorporated by the next edit (c.addEdit(e)
returns true), or replaced by it (e.replaceEdit(c)
returns true), the new edit is added after c, as shown in the following figure.Figure 4 Once
end
has been invoked on anUndoManager
the superclass behavior is used for allUndoableEdit
methods. Refer toCompoundEdit
for more details on its behavior.Unlike the rest of Swing, this class is thread safe.
Warning: Serialized objects of this class will not be compatible with future Swing releases. The current serialization support is appropriate for short term storage or RMI between applications running the same version of Swing. As of 1.4, support for long term storage of all JavaBeans™ has been added to the
java.beans
package. Please seeXMLEncoder
.- See Also:
- Serialized Form
-
-
Field Summary
-
Fields declared in class javax.swing.undo.AbstractUndoableEdit
RedoName, UndoName
-
Fields declared in class javax.swing.undo.CompoundEdit
edits
-
-
Constructor Summary
Constructors Constructor Description UndoManager()
Creates a newUndoManager
.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
addEdit(UndoableEdit anEdit)
Adds anUndoableEdit
to thisUndoManager
, if it's possible.boolean
canRedo()
Returns true if edits may be redone.boolean
canUndo()
Returns true if edits may be undone.boolean
canUndoOrRedo()
Returns true if it is possible to invokeundo
orredo
.void
discardAllEdits()
Empties the undo manager sending each edit adie
message in the process.protected UndoableEdit
editToBeRedone()
Returns the next significant edit to be redone ifredo
is invoked.protected UndoableEdit
editToBeUndone()
Returns the next significant edit to be undone ifundo
is invoked.void
end()
Turns thisUndoManager
into a normalCompoundEdit
.int
getLimit()
Returns the maximum number of edits thisUndoManager
holds.String
getRedoPresentationName()
Returns a description of the redoable form of this edit.String
getUndoOrRedoPresentationName()
Convenience method that returns eithergetUndoPresentationName
orgetRedoPresentationName
.String
getUndoPresentationName()
Returns a description of the undoable form of this edit.void
redo()
Redoes the appropriate edits.protected void
redoTo(UndoableEdit edit)
Redoes all changes from the index of the next edit toedit
, updating the index of the next edit appropriately.void
setLimit(int l)
Sets the maximum number of edits thisUndoManager
holds.String
toString()
Returns a string that displays and identifies this object's properties.protected void
trimEdits(int from, int to)
Removes edits in the specified range.protected void
trimForLimit()
Reduces the number of queued edits to a range of size limit, centered on the index of the next edit.void
undo()
Undoes the appropriate edits.void
undoableEditHappened(UndoableEditEvent e)
AnUndoableEditListener
method.void
undoOrRedo()
Convenience method that invokes one ofundo
orredo
.protected void
undoTo(UndoableEdit edit)
Undoes all changes from the index of the next edit toedit
, updating the index of the next edit appropriately.-
Methods declared in class javax.swing.undo.AbstractUndoableEdit
replaceEdit
-
Methods declared in class javax.swing.undo.CompoundEdit
die, getPresentationName, isInProgress, isSignificant, lastEdit
-
-
-
-
Method Detail
-
getLimit
public int getLimit()
Returns the maximum number of edits thisUndoManager
holds. A value less than 0 indicates the number of edits is not limited.- Returns:
- the maximum number of edits this
UndoManager
holds - See Also:
addEdit(javax.swing.undo.UndoableEdit)
,setLimit(int)
-
discardAllEdits
public void discardAllEdits()
Empties the undo manager sending each edit adie
message in the process.- See Also:
AbstractUndoableEdit.die()
-
trimForLimit
protected void trimForLimit()
Reduces the number of queued edits to a range of size limit, centered on the index of the next edit.
-
trimEdits
protected void trimEdits(int from, int to)
Removes edits in the specified range. All edits in the given range (inclusive, and in reverse order) will havedie
invoked on them and are removed from the list of edits. This has no effect iffrom
>to
.- Parameters:
from
- the minimum index to removeto
- the maximum index to remove
-
setLimit
public void setLimit(int l)
Sets the maximum number of edits thisUndoManager
holds. A value less than 0 indicates the number of edits is not limited. If edits need to be discarded to shrink the limit,die
will be invoked on them in the reverse order they were added. The default is 100.- Parameters:
l
- the new limit- Throws:
RuntimeException
- if thisUndoManager
is not in progress (end
has been invoked)- See Also:
CompoundEdit.isInProgress()
,end()
,addEdit(javax.swing.undo.UndoableEdit)
,getLimit()
-
editToBeUndone
protected UndoableEdit editToBeUndone()
Returns the next significant edit to be undone ifundo
is invoked. This returnsnull
if there are no edits to be undone.- Returns:
- the next significant edit to be undone
-
editToBeRedone
protected UndoableEdit editToBeRedone()
Returns the next significant edit to be redone ifredo
is invoked. This returnsnull
if there are no edits to be redone.- Returns:
- the next significant edit to be redone
-
undoTo
protected void undoTo(UndoableEdit edit) throws CannotUndoException
Undoes all changes from the index of the next edit toedit
, updating the index of the next edit appropriately.- Parameters:
edit
- the edit to be undo to- Throws:
CannotUndoException
- if one of the edits throwsCannotUndoException
-
redoTo
protected void redoTo(UndoableEdit edit) throws CannotRedoException
Redoes all changes from the index of the next edit toedit
, updating the index of the next edit appropriately.- Parameters:
edit
- the edit to be redo to- Throws:
CannotRedoException
- if one of the edits throwsCannotRedoException
-
undoOrRedo
public void undoOrRedo() throws CannotRedoException, CannotUndoException
Convenience method that invokes one ofundo
orredo
. If any edits have been undone (the index of the next edit is less than the length of the edits list) this invokesredo
, otherwise it invokesundo
.- Throws:
CannotUndoException
- if one of the edits throwsCannotUndoException
CannotRedoException
- if one of the edits throwsCannotRedoException
- See Also:
canUndoOrRedo()
,getUndoOrRedoPresentationName()
-
canUndoOrRedo
public boolean canUndoOrRedo()
Returns true if it is possible to invokeundo
orredo
.- Returns:
- true if invoking
canUndoOrRedo
is valid - See Also:
undoOrRedo()
-
undo
public void undo() throws CannotUndoException
Undoes the appropriate edits. Ifend
has been invoked this calls through to the superclass, otherwise this invokesundo
on all edits between the index of the next edit and the last significant edit, updating the index of the next edit appropriately.- Specified by:
undo
in interfaceUndoableEdit
- Overrides:
undo
in classCompoundEdit
- Throws:
CannotUndoException
- if one of the edits throwsCannotUndoException
or there are no edits to be undone- See Also:
CompoundEdit.end()
,canUndo()
,editToBeUndone()
-
canUndo
public boolean canUndo()
Returns true if edits may be undone. Ifend
has been invoked, this returns the value from super. Otherwise this returns true if there are any edits to be undone (editToBeUndone
returns non-null
).- Specified by:
canUndo
in interfaceUndoableEdit
- Overrides:
canUndo
in classCompoundEdit
- Returns:
- true if there are edits to be undone
- See Also:
CompoundEdit.canUndo()
,editToBeUndone()
-
redo
public void redo() throws CannotRedoException
Redoes the appropriate edits. Ifend
has been invoked this calls through to the superclass. Otherwise this invokesredo
on all edits between the index of the next edit and the next significant edit, updating the index of the next edit appropriately.- Specified by:
redo
in interfaceUndoableEdit
- Overrides:
redo
in classCompoundEdit
- Throws:
CannotRedoException
- if one of the edits throwsCannotRedoException
or there are no edits to be redone- See Also:
CompoundEdit.end()
,canRedo()
,editToBeRedone()
-
canRedo
public boolean canRedo()
Returns true if edits may be redone. Ifend
has been invoked, this returns the value from super. Otherwise, this returns true if there are any edits to be redone (editToBeRedone
returns non-null
).- Specified by:
canRedo
in interfaceUndoableEdit
- Overrides:
canRedo
in classCompoundEdit
- Returns:
- true if there are edits to be redone
- See Also:
CompoundEdit.canRedo()
,editToBeRedone()
-
addEdit
public boolean addEdit(UndoableEdit anEdit)
Adds anUndoableEdit
to thisUndoManager
, if it's possible. This removes all edits from the index of the next edit to the end of the edits list. Ifend
has been invoked the edit is not added andfalse
is returned. Ifend
hasn't been invoked this returnstrue
.- Specified by:
addEdit
in interfaceUndoableEdit
- Overrides:
addEdit
in classCompoundEdit
- Parameters:
anEdit
- the edit to be added- Returns:
- true if
anEdit
can be incorporated into this edit - See Also:
CompoundEdit.end()
,CompoundEdit.addEdit(javax.swing.undo.UndoableEdit)
-
end
public void end()
Turns thisUndoManager
into a normalCompoundEdit
. This removes all edits that have been undone.- Overrides:
end
in classCompoundEdit
- See Also:
CompoundEdit.end()
-
getUndoOrRedoPresentationName
public String getUndoOrRedoPresentationName()
Convenience method that returns eithergetUndoPresentationName
orgetRedoPresentationName
. If the index of the next edit equals the size of the edits list,getUndoPresentationName
is returned, otherwisegetRedoPresentationName
is returned.- Returns:
- undo or redo name
-
getUndoPresentationName
public String getUndoPresentationName()
Returns a description of the undoable form of this edit. Ifend
has been invoked this calls into super. Otherwise if there are edits to be undone, this returns the value from the next significant edit that will be undone. If there are no edits to be undone andend
has not been invoked this returns the value from theUIManager
property "AbstractUndoableEdit.undoText".- Specified by:
getUndoPresentationName
in interfaceUndoableEdit
- Overrides:
getUndoPresentationName
in classCompoundEdit
- Returns:
- a description of the undoable form of this edit
- See Also:
undo()
,CompoundEdit.getUndoPresentationName()
-
getRedoPresentationName
public String getRedoPresentationName()
Returns a description of the redoable form of this edit. Ifend
has been invoked this calls into super. Otherwise if there are edits to be redone, this returns the value from the next significant edit that will be redone. If there are no edits to be redone andend
has not been invoked this returns the value from theUIManager
property "AbstractUndoableEdit.redoText".- Specified by:
getRedoPresentationName
in interfaceUndoableEdit
- Overrides:
getRedoPresentationName
in classCompoundEdit
- Returns:
- a description of the redoable form of this edit
- See Also:
redo()
,CompoundEdit.getRedoPresentationName()
-
undoableEditHappened
public void undoableEditHappened(UndoableEditEvent e)
AnUndoableEditListener
method. This invokesaddEdit
withe.getEdit()
.- Specified by:
undoableEditHappened
in interfaceUndoableEditListener
- Parameters:
e
- theUndoableEditEvent
theUndoableEditEvent
will be added from- See Also:
addEdit(javax.swing.undo.UndoableEdit)
-
toString
public String toString()
Returns a string that displays and identifies this object's properties.- Overrides:
toString
in classCompoundEdit
- Returns:
- a String representation of this object
-
-