com.mxgraph.util.mxUndoableEdit Maven / Gradle / Ivy
/**
* Copyright (c) 2007-2010, Gaudenz Alder, David Benson
*/
package com.mxgraph.util;
import java.util.ArrayList;
import java.util.List;
/**
* Implements a 2-dimensional rectangle with double precision coordinates.
*/
public class mxUndoableEdit
{
/**
* Defines the requirements for an undoable change.
*/
public interface mxUndoableChange
{
/**
* Undoes or redoes the change depending on its undo state.
*/
void execute();
}
/**
* Holds the source of the undoable edit.
*/
protected Object source;
/**
* Holds the list of changes that make up this undoable edit.
*/
protected List changes = new ArrayList();
/**
* Specifies this undoable edit is significant. Default is true.
*/
protected boolean significant = true;
/**
* Specifies the state of the undoable edit.
*/
protected boolean undone, redone;
/**
* Constructs a new undoable edit for the given source.
*/
public mxUndoableEdit(Object source)
{
this(source, true);
}
/**
* Constructs a new undoable edit for the given source.
*/
public mxUndoableEdit(Object source, boolean significant)
{
this.source = source;
this.significant = significant;
}
/**
* Hook to notify any listeners of the changes after an undo or redo
* has been carried out. This implementation is empty.
*/
public void dispatch()
{
// empty
}
/**
* Hook to free resources after the edit has been removed from the command
* history. This implementation is empty.
*/
public void die()
{
// empty
}
/**
* @return the source
*/
public Object getSource()
{
return source;
}
/**
* @return the changes
*/
public List getChanges()
{
return changes;
}
/**
* @return the significant
*/
public boolean isSignificant()
{
return significant;
}
/**
* @return the undone
*/
public boolean isUndone()
{
return undone;
}
/**
* @return the redone
*/
public boolean isRedone()
{
return redone;
}
/**
* Returns true if the this edit contains no changes.
*/
public boolean isEmpty()
{
return changes.isEmpty();
}
/**
* Adds the specified change to this edit. The change is an object that is
* expected to either have an undo and redo, or an execute function.
*/
public void add(mxUndoableChange change)
{
changes.add(change);
}
/**
*
*/
public void undo()
{
if (!undone)
{
int count = changes.size();
for (int i = count - 1; i >= 0; i--)
{
mxUndoableChange change = changes.get(i);
change.execute();
}
undone = true;
redone = false;
}
dispatch();
}
/**
*
*/
public void redo()
{
if (!redone)
{
int count = changes.size();
for (int i = 0; i < count; i++)
{
mxUndoableChange change = changes.get(i);
change.execute();
}
undone = false;
redone = true;
}
dispatch();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy