Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPawel Piech2011-12-01 20:11:58 +0000
committerPawel Piech2011-12-01 20:11:58 +0000
commit442033718d71f1bf4a24506ba2f5a065ffd25221 (patch)
tree6d5007903ef9e9ad6cccc74b31608839b418446f /org.eclipse.debug.ui/ui/org/eclipse/debug/internal/ui/viewers/model/ChildrenUpdate.java
parent95d71ceea2950ced3f11676734c7c019051a2c77 (diff)
downloadeclipse.platform.debug-442033718d71f1bf4a24506ba2f5a065ffd25221.tar.gz
eclipse.platform.debug-442033718d71f1bf4a24506ba2f5a065ffd25221.tar.xz
eclipse.platform.debug-442033718d71f1bf4a24506ba2f5a065ffd25221.zip
Bug 161435 - [flex] Promote asynchronous viewer framework to API -v20111201-2011
(merge flex_viewer_refactor branch into master)
Diffstat (limited to 'org.eclipse.debug.ui/ui/org/eclipse/debug/internal/ui/viewers/model/ChildrenUpdate.java')
-rw-r--r--org.eclipse.debug.ui/ui/org/eclipse/debug/internal/ui/viewers/model/ChildrenUpdate.java102
1 files changed, 70 insertions, 32 deletions
diff --git a/org.eclipse.debug.ui/ui/org/eclipse/debug/internal/ui/viewers/model/ChildrenUpdate.java b/org.eclipse.debug.ui/ui/org/eclipse/debug/internal/ui/viewers/model/ChildrenUpdate.java
index 6375f6bdd..766c7601f 100644
--- a/org.eclipse.debug.ui/ui/org/eclipse/debug/internal/ui/viewers/model/ChildrenUpdate.java
+++ b/org.eclipse.debug.ui/ui/org/eclipse/debug/internal/ui/viewers/model/ChildrenUpdate.java
@@ -14,7 +14,6 @@ package org.eclipse.debug.internal.ui.viewers.model;
import org.eclipse.debug.internal.ui.viewers.model.provisional.IChildrenUpdate;
import org.eclipse.debug.internal.ui.viewers.model.provisional.IElementContentProvider;
-import org.eclipse.debug.internal.ui.viewers.model.provisional.IPresentationContext;
import org.eclipse.jface.viewers.TreePath;
/**
@@ -37,24 +36,25 @@ public class ChildrenUpdate extends ViewerUpdateMonitor implements IChildrenUpda
* @param element the element
* @param index the index of the element
* @param elementContentProvider the content provider for the element
- * @param context the presentation context
*/
- public ChildrenUpdate(ModelContentProvider provider, Object viewerInput, TreePath elementPath, Object element, int index, IElementContentProvider elementContentProvider, IPresentationContext context) {
- super(provider, viewerInput, elementPath, element, elementContentProvider, context);
+ public ChildrenUpdate(TreeModelContentProvider provider, Object viewerInput, TreePath elementPath, Object element, int index, IElementContentProvider elementContentProvider) {
+ super(provider, viewerInput, elementPath, element, elementContentProvider, provider.getPresentationContext());
fIndex = index;
fLength = 1;
}
-
- /*
- * (non-Javadoc)
- *
- * @see org.eclipse.debug.ui.viewers.AsynchronousRequestMonitor#performUpdate()
- */
- protected void performUpdate() {
- TreeModelContentProvider provider = (TreeModelContentProvider) getContentProvider();
+
+ public ChildrenUpdate(TreeModelContentProvider provider, Object viewerInput, TreePath elementPath, Object element, int index, int length, IElementContentProvider elementContentProvider) {
+ super(provider, viewerInput, elementPath, element, elementContentProvider, provider.getPresentationContext());
+ fIndex = index;
+ fLength = length;
+ }
+
+
+ protected void performUpdate(boolean updateFilterOnly) {
+ TreeModelContentProvider provider = getContentProvider();
TreePath elementPath = getElementPath();
if (fElements != null) {
- ITreeModelContentProviderTarget viewer = provider.getViewer();
+ IInternalTreeModelViewer viewer = provider.getViewer();
for (int i = 0; i < fElements.length; i++) {
int modelIndex = fIndex + i;
Object element = fElements[i];
@@ -62,36 +62,54 @@ public class ChildrenUpdate extends ViewerUpdateMonitor implements IChildrenUpda
int viewIndex = provider.modelToViewIndex(elementPath, modelIndex);
if (provider.shouldFilter(elementPath, element)) {
if (provider.addFilteredIndex(elementPath, modelIndex, element)) {
- if (ModelContentProvider.DEBUG_CONTENT_PROVIDER && ModelContentProvider.DEBUG_TEST_PRESENTATION_ID(getPresentationContext())) {
- System.out.println("REMOVE(" + getElement() + ", modelIndex: " + modelIndex + " viewIndex: " + viewIndex + ", " + element + ")"); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ //$NON-NLS-5$
- }
- viewer.remove(elementPath, viewIndex);
+ if (!updateFilterOnly) {
+ if (TreeModelContentProvider.DEBUG_CONTENT_PROVIDER && TreeModelContentProvider.DEBUG_TEST_PRESENTATION_ID(getPresentationContext())) {
+ System.out.println("REMOVE(" + getElement() + ", modelIndex: " + modelIndex + " viewIndex: " + viewIndex + ", " + element + ")"); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ //$NON-NLS-5$
+ }
+ viewer.remove(elementPath, viewIndex);
+ }
}
} else {
if (provider.isFiltered(elementPath, modelIndex)) {
provider.clearFilteredChild(elementPath, modelIndex);
- int insertIndex = provider.modelToViewIndex(elementPath, modelIndex);
- if (ModelContentProvider.DEBUG_CONTENT_PROVIDER) {
- System.out.println("insert(" + getElement() + ", modelIndex: " + modelIndex + " insertIndex: " + insertIndex + ", " + element + ")"); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ //$NON-NLS-5$
- }
- viewer.insert(elementPath, element, insertIndex);
- } else {
- if (ModelContentProvider.DEBUG_CONTENT_PROVIDER && ModelContentProvider.DEBUG_TEST_PRESENTATION_ID(getPresentationContext())) {
+ if (!updateFilterOnly) {
+ int insertIndex = provider.modelToViewIndex(elementPath, modelIndex);
+ if (TreeModelContentProvider.DEBUG_CONTENT_PROVIDER) {
+ System.out.println("insert(" + getElement() + ", modelIndex: " + modelIndex + " insertIndex: " + insertIndex + ", " + element + ")"); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ //$NON-NLS-5$
+ }
+ viewer.insert(elementPath, element, insertIndex);
+ }
+ } else if (!updateFilterOnly){
+ if (TreeModelContentProvider.DEBUG_CONTENT_PROVIDER && TreeModelContentProvider.DEBUG_TEST_PRESENTATION_ID(getPresentationContext())) {
System.out.println("replace(" + getElement() + ", modelIndex: " + modelIndex + " viewIndex: " + viewIndex + ", " + element + ")"); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$ //$NON-NLS-5$
}
viewer.replace(elementPath, viewIndex, element);
}
- TreePath childPath = elementPath.createChildPath(element);
- provider.updateHasChildren(childPath);
- provider.restorePendingStateOnUpdate(childPath, modelIndex, false, false, false);
+ if (!updateFilterOnly) {
+ TreePath childPath = elementPath.createChildPath(element);
+ provider.updateHasChildren(childPath);
+ provider.getStateTracker().restorePendingStateOnUpdate(childPath, modelIndex, false, false, false);
+ }
}
}
}
- provider.restorePendingStateOnUpdate(elementPath, -1, true, true, true);
- } else {
+ if (!updateFilterOnly) {
+ provider.getStateTracker().restorePendingStateOnUpdate(elementPath, -1, true, true, true);
+ }
+ } else if (!updateFilterOnly) {
provider.updateHasChildren(elementPath);
}
+
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see org.eclipse.debug.ui.viewers.AsynchronousRequestMonitor#performUpdate()
+ */
+ protected void performUpdate() {
+ performUpdate(false);
}
/* (non-Javadoc)
@@ -122,7 +140,7 @@ public class ChildrenUpdate extends ViewerUpdateMonitor implements IChildrenUpda
fIndex = Math.min(fIndex, otherStart);
end = Math.max(end, otherEnd);
fLength = end - fIndex;
- if (ModelContentProvider.DEBUG_CONTENT_PROVIDER && ModelContentProvider.DEBUG_TEST_PRESENTATION_ID(getPresentationContext())) {
+ if (TreeModelContentProvider.DEBUG_CONTENT_PROVIDER && TreeModelContentProvider.DEBUG_TEST_PRESENTATION_ID(getPresentationContext())) {
System.out.println("coalesced: " + this.toString()); //$NON-NLS-1$
}
return true;
@@ -166,7 +184,7 @@ public class ChildrenUpdate extends ViewerUpdateMonitor implements IChildrenUpda
buf.append(" {"); //$NON-NLS-1$
buf.append(getOffset());
buf.append("->"); //$NON-NLS-1$
- buf.append(getOffset() + getLength());
+ buf.append(getOffset() + getLength() - 1);
buf.append("}"); //$NON-NLS-1$
return buf.toString();
}
@@ -194,5 +212,25 @@ public class ChildrenUpdate extends ViewerUpdateMonitor implements IChildrenUpda
void setOffset(int offset) {
fIndex = offset;
}
-}
+
+ Object[] getElements() {
+ return fElements;
+ }
+
+ protected boolean doEquals(ViewerUpdateMonitor update) {
+ return
+ update instanceof ChildrenUpdate &&
+ ((ChildrenUpdate)update).getOffset() == getOffset() &&
+ ((ChildrenUpdate)update).getLength() == getLength() &&
+ getViewerInput().equals(update.getViewerInput()) &&
+ getElementPath().equals(getElementPath());
+ }
+
+ protected int doHashCode() {
+ return (int)Math.pow(
+ (getClass().hashCode() + getViewerInput().hashCode() + getElementPath().hashCode()) * (getOffset() + 2),
+
+ getLength() + 2);
+ }
+}

Back to the top