From: Matti Tahvonen Date: Tue, 9 Mar 2010 16:26:44 +0000 (+0000) Subject: fixes #4292 for ContainerHierarchicalWrapper X-Git-Tag: 6.7.0.beta1~1965 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=92ff35ef896461d6053ede69bd1b74bd983e9d3f;p=vaadin-framework.git fixes #4292 for ContainerHierarchicalWrapper svn changeset:11728/svn branch:6.3 --- diff --git a/src/com/vaadin/data/util/ContainerHierarchicalWrapper.java b/src/com/vaadin/data/util/ContainerHierarchicalWrapper.java index e692f11498..03be24b669 100644 --- a/src/com/vaadin/data/util/ContainerHierarchicalWrapper.java +++ b/src/com/vaadin/data/util/ContainerHierarchicalWrapper.java @@ -181,6 +181,14 @@ public class ContainerHierarchicalWrapper implements Container.Hierarchical, */ private void removeFromHierarchyWrapper(Object itemId) { + LinkedList oprhanedChildren = children.remove(itemId); + if (oprhanedChildren != null) { + for (Object object : oprhanedChildren) { + // make orphaned children root nodes + setParent(object, null); + } + } + if (isRoot(itemId)) { roots.remove(itemId); } @@ -192,7 +200,6 @@ public class ContainerHierarchicalWrapper implements Container.Hierarchical, } } parent.remove(itemId); - children.remove(itemId); noChildrenAllowed.remove(itemId); }