summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSilenio Quarti <silenio_quarti@ca.ibm.com>2013-03-14 10:51:05 -0400
committerSilenio Quarti <silenio_quarti@ca.ibm.com>2013-03-14 10:51:05 -0400
commit2744fe7246528e8acfac964a83726c422e6a5863 (patch)
treede87c62909ca08b4f4db6af309ac0a27cf65cbcb
parent4ac2f80fba8d31c29a136ddd0e4b344e6bd3a230 (diff)
downloadeclipse.platform.swt-2744fe7246528e8acfac964a83726c422e6a5863.tar.gz
eclipse.platform.swt-2744fe7246528e8acfac964a83726c422e6a5863.tar.xz
eclipse.platform.swt-2744fe7246528e8acfac964a83726c422e6a5863.zip
Bug 403346 - TreeViewers throw NPE's on collapsed multi-selections
-rw-r--r--bundles/org.eclipse.swt/Eclipse SWT/win32/org/eclipse/swt/widgets/Tree.java7
1 files changed, 6 insertions, 1 deletions
diff --git a/bundles/org.eclipse.swt/Eclipse SWT/win32/org/eclipse/swt/widgets/Tree.java b/bundles/org.eclipse.swt/Eclipse SWT/win32/org/eclipse/swt/widgets/Tree.java
index e3fd80a933..f40580da9b 100644
--- a/bundles/org.eclipse.swt/Eclipse SWT/win32/org/eclipse/swt/widgets/Tree.java
+++ b/bundles/org.eclipse.swt/Eclipse SWT/win32/org/eclipse/swt/widgets/Tree.java
@@ -3486,7 +3486,12 @@ public TreeItem [] getSelection () {
int itemCount = (int)/*64*/OS.SendMessage (handle, OS.TVM_GETCOUNT, 0, 0);
boolean bigSelection = result.length > itemCount / 2;
if (count != getSelection (hItem, tvItem, result, 0, count, bigSelection, false)) {
- getSelection (hItem, tvItem, result, 0, count, bigSelection, true);
+ count = getSelection (hItem, tvItem, result, 0, count, bigSelection, true);
+ }
+ if (count != result.length) {
+ TreeItem[] newResult = new TreeItem[count];
+ System.arraycopy (result, 0, newResult, 0, count);
+ result = newResult;
}
OS.SetWindowLongPtr (handle, OS.GWLP_WNDPROC, oldProc);
return result;