From 92ff35ef896461d6053ede69bd1b74bd983e9d3f Mon Sep 17 00:00:00 2001 From: Matti Tahvonen Date: Tue, 9 Mar 2010 16:26:44 +0000 Subject: [PATCH] fixes #4292 for ContainerHierarchicalWrapper svn changeset:11728/svn branch:6.3 --- .../vaadin/data/util/ContainerHierarchicalWrapper.java | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) 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); } -- 2.39.5