]> git.argeo.org Git - gpl/argeo-slc.git/blobdiff - plugins/org.argeo.slc.client.ui/src/main/java/org/argeo/slc/client/ui/commands/DeleteItems.java
enhance management of context menus and commands. Remove a few bugs.
[gpl/argeo-slc.git] / plugins / org.argeo.slc.client.ui / src / main / java / org / argeo / slc / client / ui / commands / DeleteItems.java
index 5858f67be18883789ac6cbf04eb8c1cf55ec45f7..68865282546426501c1a03c2f2a0afa5c06aad24 100644 (file)
@@ -15,9 +15,9 @@
  */\r
 package org.argeo.slc.client.ui.commands;\r
 \r
-import java.util.ArrayList;\r
+import java.util.HashMap;\r
 import java.util.Iterator;\r
-import java.util.List;\r
+import java.util.Map;\r
 \r
 import javax.jcr.Node;\r
 import javax.jcr.RepositoryException;\r
@@ -54,7 +54,7 @@ public class DeleteItems extends AbstractHandler {
                                .getActiveWorkbenchWindow(event).getActivePage().getSelection();\r
 \r
                // confirmation\r
-               StringBuffer buf = new StringBuffer("");\r
+               StringBuilder buf = new StringBuilder("");\r
                Iterator<?> lst = ((IStructuredSelection) selection).iterator();\r
                while (lst.hasNext()) {\r
                        Object obj = lst.next();\r
@@ -67,7 +67,7 @@ public class DeleteItems extends AbstractHandler {
                String msg = "Nothing to delete";\r
                // remove last separator\r
                if (buf.lastIndexOf(", ") > -1) {\r
-                       msg = "Do you want to delete following objects: "\r
+                       msg = "Do you want to delete following objects (and their children): "\r
                                        + buf.substring(0, buf.lastIndexOf(", ")) + "?";\r
                }\r
                Boolean ok = MessageDialog.openConfirm(\r
@@ -81,29 +81,37 @@ public class DeleteItems extends AbstractHandler {
                        protected IStatus run(IProgressMonitor monitor) {\r
                                if (selection != null\r
                                                && selection instanceof IStructuredSelection) {\r
-                                       List<Node> nodes = new ArrayList<Node>();\r
+                                       Map<String, Node> nodes = new HashMap<String, Node>();\r
                                        Iterator<?> it = ((IStructuredSelection) selection)\r
                                                        .iterator();\r
                                        Object obj = null;\r
-                                       while (it.hasNext()) {\r
-                                               obj = it.next();\r
-                                               if (obj instanceof ResultFolder) {\r
-                                                       Node node = ((ResultFolder) obj).getNode();\r
-                                                       nodes.add(node);\r
-                                               } else if (obj instanceof SingleResultNode) {\r
-                                                       Node node = ((SingleResultNode) obj).getNode();\r
-                                                       nodes.add(node);\r
-                                               }\r
-                                       }\r
                                        try {\r
+\r
+                                               while (it.hasNext()) {\r
+                                                       obj = it.next();\r
+                                                       if (obj instanceof ResultFolder) {\r
+                                                               Node node = ((ResultFolder) obj).getNode();\r
+                                                               nodes.put(node.getPath(), node);\r
+                                                       } else if (obj instanceof SingleResultNode) {\r
+                                                               Node node = ((SingleResultNode) obj).getNode();\r
+                                                               nodes.put(node.getPath(), node);\r
+                                                       }\r
+                                               }\r
                                                if (!nodes.isEmpty()) {\r
-                                                       Session session = nodes.get(0).getSession();\r
+                                                       Session session = null;\r
                                                        monitor.beginTask("Delete results", nodes.size());\r
-                                                       for (Node node : nodes) {\r
-                                                               Node parent = node.getParent();\r
-                                                               node.remove();\r
-                                                               ResultParentUtils.updatePassedStatus(parent,\r
-                                                                               true);\r
+                                                       for (String path : nodes.keySet()) {\r
+                                                               if (session == null)\r
+                                                                       session = nodes.get(path).getSession();\r
+\r
+                                                               // check if the item has not already been\r
+                                                               // deleted while deleting one of its ancestor\r
+                                                               if (session.itemExists(path)) {\r
+                                                                       Node parent = nodes.get(path).getParent();\r
+                                                                       nodes.get(path).remove();\r
+                                                                       ResultParentUtils.updatePassedStatus(\r
+                                                                                       parent, true);\r
+                                                               }\r
                                                                monitor.worked(1);\r
                                                        }\r
                                                        session.save();\r