diff options
author | Sascha Brawer <brawer@dandelis.ch> | 2003-11-26 23:23:40 +0100 |
---|---|---|
committer | Michael Koch <mkoch@gcc.gnu.org> | 2003-11-26 22:23:40 +0000 |
commit | aef81a9acb17a9eadc5df75007b4364fbfa3a9de (patch) | |
tree | 549e886e60bcd55108bc0031071f65f863c0e849 /libjava/javax/swing/undo/AbstractUndoableEdit.java | |
parent | 034f23169e28ccf6d58dd77d669cccf8a3c91967 (diff) | |
download | gcc-aef81a9acb17a9eadc5df75007b4364fbfa3a9de.zip gcc-aef81a9acb17a9eadc5df75007b4364fbfa3a9de.tar.gz gcc-aef81a9acb17a9eadc5df75007b4364fbfa3a9de.tar.bz2 |
StateEdit.java (getPresentationName): Docfix.
2003-11-26 Sascha Brawer <brawer@dandelis.ch>
* javax/swing/undo/StateEdit.java (getPresentationName): Docfix.
* javax/swing/undo/AbstractUndoableEdit.java (canUndo, canRedo,
isSignificant): Likewise.
2003-11-26 Sascha Brawer <brawer@dandelis.ch>
* javax/swing/undo/CompoundEdit.java: Re-format, document.
(inProgress): Set initial value to true.
(undo, redo, die, canUndo, canRedo): Also call inherited
implementation; simplify code structure.
(getPresentationName, getUndoPresentationName,
getRedoPresentationName): Make behavior dependent on lastEdit.
(addEdit, isSignificant): Completely re-written.
2003-11-26 Sascha Brawer <brawer@dandelis.ch>
* javax/swing/undo/StateEdit.java: Re-format, document.
(undo, redo): Also call inherited implementation.
2003-11-26 Sascha Brawer <brawer@dandelis.ch>
* javax/swing/undo/StateEditable.java: Re-format, document.
2003-11-26 Sascha Brawer <brawer@dandelis.ch>
* javax/swing/undo/AbstractUndoableEdit.java: Re-format, document.
(AbstractUndoableEdit): Initialize hasBeenDone to true.
(canUndo, canRedo): Simplify.
(getUndoPresentationName, getRedoPresentationName): Support
localized message; call getPresentationName() only once.
From-SVN: r73967
Diffstat (limited to 'libjava/javax/swing/undo/AbstractUndoableEdit.java')
-rw-r--r-- | libjava/javax/swing/undo/AbstractUndoableEdit.java | 323 |
1 files changed, 214 insertions, 109 deletions
diff --git a/libjava/javax/swing/undo/AbstractUndoableEdit.java b/libjava/javax/swing/undo/AbstractUndoableEdit.java index d845e43..e694c0a 100644 --- a/libjava/javax/swing/undo/AbstractUndoableEdit.java +++ b/libjava/javax/swing/undo/AbstractUndoableEdit.java @@ -1,4 +1,4 @@ -/* AbstractTableModel.java -- +/* AbstractUndoableEdit.java Copyright (C) 2002, 2003 Free Software Foundation, Inc. This file is part of GNU Classpath. @@ -39,180 +39,285 @@ exception statement from your version. */ package javax.swing.undo; import java.io.Serializable; +import javax.swing.UIManager; + /** - * AbstractUndoableEdit - * @author Andrew Selkirk + * A default implementation of <code>UndoableEdit</code> that can be + * used as a base for implementing editing operations. + * + * @author Andrew Selkirk (aselkirk@sympatico.ca) + * @author Sascha Brawer (brawer@dandelis.ch) */ -public class AbstractUndoableEdit implements UndoableEdit, Serializable +public class AbstractUndoableEdit + implements UndoableEdit, Serializable { + /** + * The serialization ID. Verified using the <code>serialver</code> + * tool of Apple/Sun JDK 1.3.1 on MacOS X 10.1.5, and Sun JDK + * 1.4.1_01 on GNU/Linux. + */ static final long serialVersionUID = 580150227676302096L; - //------------------------------------------------------------- - // Constants -------------------------------------------------- - //------------------------------------------------------------- /** - * String returned by getRedoPresentationName() + * The constant string “Undo”, which was returned by + * {@link #getUndoPresentationName()} on early versions of the + * platform. However, this field has become obsolete with version + * 1.3.1. That method now retrieves a localized string from the + * {@link javax.swing.UIManager}, using the key + * <code>“AbstractUndoableEdit.undoText”</code>. */ - protected static final String RedoName = "Redo"; + protected static final String UndoName = "Undo"; + /** - * String returned by getUndoPresentationName() + * The constant string “Redo”, which was returned by + * {@link #getRedoPresentationName()} on early versions of the + * platform. However, this field has become obsolete with version + * 1.3.1. That method now retrieves a localized string from the + * {@link javax.swing.UIManager}, using the key + * <code>“AbstractUndoableEdit.redoText”</code>. */ - protected static final String UndoName = "Undo"; - + protected static final String RedoName = "Redo"; - //------------------------------------------------------------- - // Variables -------------------------------------------------- - //------------------------------------------------------------- /** - * TODO + * Indicates whether this editing action has been executed. A value + * of <code>true</code> means that the action was performed, or that + * a redo operation was successful. A value of <code>false</code> + * means that the action has not yet performed, or that an undo + * operation was successful. */ - private boolean hasBeenDone = false; + private boolean hasBeenDone; + /** - * The edit is alive + * Indicates whether this editing action is still alive. The value + * is set to <code>true</code> by the constructor, and to + * <code>false</code> by the {@link #die()} method. */ - private boolean alive = true; + private boolean alive; - //------------------------------------------------------------- - // Initialization --------------------------------------------- - //------------------------------------------------------------- - /** - * Create new AbstractUndoableEdit + * Constructs a new <code>AbstractUndoableEdit</code>. The initial + * state is that the editing action is alive, and + * <code>hasBeenDone</code> is <code>true</code>. */ public AbstractUndoableEdit() { - } // AbstractUndoableEdit() - + // The API specification is not clear, but Mauve test code has + // determined that hasBeenDone is initially set to true. + alive = hasBeenDone = true; + } - //------------------------------------------------------------- - // Interface: UndoableEdit ------------------------------------ - //------------------------------------------------------------- /** - * addEdit - * @param anEdit TODO - * @returns TODO + * Undoes this editing action. + * + * @throws CannotUndoException if {@link #canUndo()} returns + * <code>false</code>, for example because this action has already + * been undone. + * + * @see #canUndo() + * @see #redo() */ - public boolean addEdit(UndoableEdit anEdit) + public void undo() + throws CannotUndoException { - return false; - } // addEdit() - + if (!canUndo()) + throw new CannotUndoException(); + hasBeenDone = false; + } + + /** - * canRedo() - * @returns true if redoable, false otherwise + * Determines whether it would be possible to undo this editing + * action. + * + * @return <code>true</code> to indicate that this action can be + * undone, <code>false</code> otherwise. + * + * @see #undo() + * @see #canRedo() */ - public boolean canRedo() + public boolean canUndo() { - if (alive == true && hasBeenDone == false) - return true; - return false; - } // canRedo() - + return alive && hasBeenDone; + } + + /** - * canUndo() - * @returns true if undoable, false otherwise + * Redoes this editing action. + * + * @throws CannotRedoException if {@link #canRedo()} returns + * <code>false</code>, for example because this action has not + * yet been undone. + * + * @see #canRedo() + * @see #undo() */ - public boolean canUndo() + public void redo() + throws CannotRedoException { - if (alive == true && hasBeenDone == true) - return true; - return false; - } // canUndo() - + if (!canRedo()) + throw new CannotRedoException(); + hasBeenDone = true; + } + + /** - * die + * Determines whether it would be possible to redo this editing + * action. + * + * @return <code>true</code> to indicate that this action can be + * redone, <code>false</code> otherwise. + * + * @see #redo() + * @see #canUndo() */ - public void die() + public boolean canRedo() { - alive = false; - } // die() + return alive && !hasBeenDone; + } + /** - * getPresentation - * @returns TODO + * Informs this edit action that it will no longer be used. Some + * actions might use this information to release resources, for + * example open files. Called by {@link UndoManager} before this + * action is removed from the edit queue. */ - public String getPresentationName() + public void die() { - return ""; - } // getPresentationName() + alive = false; + } + /** - * getRedoPresentationName - * @returns TODO + * Incorporates another editing action into this one, thus forming a + * combined action. + * + * <p>The default implementation always returns <code>false</code>, + * indicating that the editing action could not be incorporated. + * + * @param edit the editing action to be incorporated. */ - public String getRedoPresentationName() + public boolean addEdit(UndoableEdit edit) { - if (getPresentationName().equals("")) - return RedoName; - return RedoName + " " + getPresentationName(); - } // getRedoPresentationName() - + return false; + } + + /** - * getUndoPresentationName - * @returns TODO + * Incorporates another editing action into this one, thus forming a + * combined action that replaces the argument action. + * + * <p>The default implementation always returns <code>false</code>, + * indicating that the argument action should not be replaced. + * + * @param edit the editing action to be replaced. */ - public String getUndoPresentationName() + public boolean replaceEdit(UndoableEdit edit) { - if (getPresentationName().equals("")) - return UndoName; - return UndoName + " " + getPresentationName(); - } // getUndoPresentationName() - + return false; + } + + /** - * isSignificant - * @returns true + * Determines whether this editing action is significant enough for + * being seperately undoable by the user. A typical significant + * action would be the resizing of an object. However, changing the + * selection in a text document would usually not be considered + * significant. + * + * <p>The default implementation returns <code>true</code>. + * + * @return <code>true</code> to indicate that the action is + * significant enough for being separately undoable, or + * <code>false</code> otherwise. */ public boolean isSignificant() { return true; - } // isSignificant() - + } + + /** - * redo - * @throws CannotRedoException TODO + * Returns a human-readable, localized name that describes this + * editing action and can be displayed to the user. + * + * <p>The default implementation returns an empty string. */ - public void redo() throws CannotRedoException + public String getPresentationName() { - if (! canRedo()) - throw new CannotRedoException(); - hasBeenDone = true; - } // redo() + return ""; + } + /** - * replaceEdit - * @param anEdit TODO - * @returns TODO + * Calculates a localized name for presenting the undo action to the + * user. + * + * <p>The default implementation returns the concatenation of the + * string “Undo” and the action name, which is + * determined by calling {@link #getPresentationName()}. + * + * <p>The string “Undo” is retrieved from the {@link + * javax.swing.UIManager}, using the key + * <code>“AbstractUndoableEdit.undoText”</code>. This + * allows the text to be localized. */ - public boolean replaceEdit(UndoableEdit anEdit) + public String getUndoPresentationName() { - return false; - } // replaceEdit() + String msg, pres; + + msg = UIManager.getString("AbstractUndoableEdit.undoText"); + if (msg == null) + msg = UndoName; + + pres = getPresentationName(); + if ((pres == null) || (pres.length() == 0)) + return msg; + else + return msg + ' ' + pres; + } + /** - * String representation - * @returns String representation + * Calculates a localized name for presenting the redo action to the + * user. + * + * <p>The default implementation returns the concatenation of the + * string “Redo” and the action name, which is + * determined by calling {@link #getPresentationName()}. + * + * <p>The string “Redo” is retrieved from the {@link + * javax.swing.UIManager}, using the key + * <code>“AbstractUndoableEdit.redoText”</code>. This + * allows the text to be localized. */ - public String toString() + public String getRedoPresentationName() { - return (super.toString() + " hasBeenDone: " + hasBeenDone - + " alive: " + alive); + String msg, pres; + + msg = UIManager.getString("AbstractUndoableEdit.redoText"); + if (msg == null) + msg = RedoName; + + pres = getPresentationName(); + if ((pres == null) || (pres.length() == 0)) + return msg; + else + return msg + ' ' + pres; } - /** - * undo - * @throws CannotUndoException TODO - */ - public void undo() throws CannotUndoException + + public String toString() { - if (! canUndo()) - throw new CannotUndoException(); - hasBeenDone = false; - } // undo() -} // AbstractUndoableEdit + return super.toString() + + " hasBeenDone: " + hasBeenDone + + " alive: " + alive; + } +} |