Author: ruschein
Date: 2011-07-21 10:43:13 -0700 (Thu, 21 Jul 2011)
New Revision: 26237

Added:
   
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnEdit.java
   core3/core-task-impl/trunk/src/test/java/org/cytoscape/task/internal/table/
   
core3/core-task-impl/trunk/src/test/java/org/cytoscape/task/internal/table/RenameColumnEditTest.java
Modified:
   
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnTask.java
   
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnTaskFactory.java
   
core3/core-task-impl/trunk/src/main/resources/META-INF/spring/bundle-context.xml
Log:
Added undo/redo for column renaming.

Copied: 
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnEdit.java
 (from rev 26225, 
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/zoom/ZoomEdit.java)
===================================================================
--- 
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnEdit.java
                            (rev 0)
+++ 
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnEdit.java
    2011-07-21 17:43:13 UTC (rev 26237)
@@ -0,0 +1,35 @@
+package org.cytoscape.task.internal.table;
+
+
+import org.cytoscape.model.CyColumn;
+import org.cytoscape.util.swing.CyAbstractEdit;
+
+
+/** An undoable edit that will undo and redo the zooming of a network view. */
+final class RenameColumnEdit extends CyAbstractEdit {
+       private final CyColumn column;
+       private String oldName;
+
+       RenameColumnEdit(final CyColumn column) {
+               super("Rename Column");
+
+               this.column  = column;
+               this.oldName = column.getName();
+       }
+
+       public void redo() {
+               super.redo();
+
+               final String previousName = column.getName();
+               column.setName(oldName);
+               oldName = previousName;
+       }
+
+       public void undo() {
+               super.undo();
+
+               final String previousName = column.getName();
+               column.setName(oldName);
+               oldName = previousName;
+       }
+}

Modified: 
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnTask.java
===================================================================
--- 
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnTask.java
    2011-07-21 15:32:57 UTC (rev 26236)
+++ 
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnTask.java
    2011-07-21 17:43:13 UTC (rev 26237)
@@ -35,18 +35,24 @@
 import org.cytoscape.work.Tunable;
 import org.cytoscape.work.TunableValidator;
 import org.cytoscape.work.TunableValidator.ValidationState;
+import org.cytoscape.work.undo.UndoSupport;
 
 
 public final class RenameColumnTask extends AbstractTableColumnTask implements 
TunableValidator {
+       private final UndoSupport undoSupport;
+
        @Tunable(description="New column name:")
        public String newColumnName;
 
-       RenameColumnTask(final CyColumn column) {
+       RenameColumnTask(final UndoSupport undoSupport, final CyColumn column) {
                super(column);
+               this.undoSupport = undoSupport;
        }
 
        @Override
        public void run(final TaskMonitor taskMonitor) throws Exception {
+               undoSupport.getUndoableEditSupport().postEdit(new 
RenameColumnEdit(column));
+
                column.setName(newColumnName);
        }
 

Modified: 
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnTaskFactory.java
===================================================================
--- 
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnTaskFactory.java
     2011-07-21 15:32:57 UTC (rev 26236)
+++ 
core3/core-task-impl/trunk/src/main/java/org/cytoscape/task/internal/table/RenameColumnTaskFactory.java
     2011-07-21 17:43:13 UTC (rev 26237)
@@ -1,5 +1,5 @@
 /*
- Copyright (c) 2010, The Cytoscape Consortium (www.cytoscape.org)
+ Copyright (c) 2010-2011, The Cytoscape Consortium (www.cytoscape.org)
 
  This library is free software; you can redistribute it and/or modify it
  under the terms of the GNU Lesser General Public License as published
@@ -29,13 +29,19 @@
 
 
 import org.cytoscape.work.TaskIterator;
+import org.cytoscape.work.undo.UndoSupport;
 
 
 public final class RenameColumnTaskFactory extends 
AbstractTableColumnTaskFactory {
+       private final UndoSupport undoSupport;
+
+       public RenameColumnTaskFactory(final UndoSupport undoSupport) {
+               this.undoSupport = undoSupport;
+       }
        @Override
        public TaskIterator getTaskIterator() {
                if (column == null)
                        throw new IllegalStateException("you forgot to set the 
CyColumn on this task factory!");
-               return new TaskIterator(new RenameColumnTask(column));
+               return new TaskIterator(new RenameColumnTask(undoSupport, 
column));
        }
 }
\ No newline at end of file

Modified: 
core3/core-task-impl/trunk/src/main/resources/META-INF/spring/bundle-context.xml
===================================================================
--- 
core3/core-task-impl/trunk/src/main/resources/META-INF/spring/bundle-context.xml
    2011-07-21 15:32:57 UTC (rev 26236)
+++ 
core3/core-task-impl/trunk/src/main/resources/META-INF/spring/bundle-context.xml
    2011-07-21 17:43:13 UTC (rev 26237)
@@ -345,6 +345,7 @@
 
        <bean id="renameColumnTaskFactory"
                
class="org.cytoscape.task.internal.table.RenameColumnTaskFactory">
+               <constructor-arg ref="undoSupportServiceRef" />
        </bean>
 
        <bean id="copyValueToEntireColumnTaskFactory"

Copied: 
core3/core-task-impl/trunk/src/test/java/org/cytoscape/task/internal/table/RenameColumnEditTest.java
 (from rev 26226, 
core3/core-task-impl/trunk/src/test/java/org/cytoscape/task/internal/zoom/FitContentEditTest.java)
===================================================================
--- 
core3/core-task-impl/trunk/src/test/java/org/cytoscape/task/internal/table/RenameColumnEditTest.java
                                (rev 0)
+++ 
core3/core-task-impl/trunk/src/test/java/org/cytoscape/task/internal/table/RenameColumnEditTest.java
        2011-07-21 17:43:13 UTC (rev 26237)
@@ -0,0 +1,27 @@
+package org.cytoscape.task.internal.table;
+
+
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.times;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
+
+import org.cytoscape.model.CyColumn;
+
+import org.junit.Test;
+
+
+public class RenameColumnEditTest {
+       @Test
+       public void runTest() {
+               final CyColumn column = mock(CyColumn.class);
+               when(column.getName()).thenReturn("orig name");
+
+               final RenameColumnEdit renameEdit = new 
RenameColumnEdit(column);
+               when(column.getName()).thenReturn("new name");
+               renameEdit.undo();
+               verify(column, times(1)).setName("orig name");
+               renameEdit.redo();
+               verify(column, times(1)).setName("new name");
+       }
+}

-- 
You received this message because you are subscribed to the Google Groups 
"cytoscape-cvs" group.
To post to this group, send email to [email protected].
To unsubscribe from this group, send email to 
[email protected].
For more options, visit this group at 
http://groups.google.com/group/cytoscape-cvs?hl=en.

Reply via email to