| /******************************************************************************* |
| * Copyright (c) 2005, 2009 IBM Corporation and others. |
| * All rights reserved. This program and the accompanying materials |
| * are made available under the terms of the Eclipse Public License v1.0 |
| * which accompanies this distribution, and is available at |
| * http://www.eclipse.org/legal/epl-v10.html |
| * |
| * Contributors: |
| * IBM Corporation - initial API and implementation |
| * Wind River Systems - Fix for viewer state save/restore [188704] |
| *******************************************************************************/ |
| package org.eclipse.debug.internal.ui.viewers.model.provisional; |
| |
| |
| |
| |
| /** |
| * A model delta. Used to create model deltas. |
| * <p> |
| * Clients may instantiate this class; not intended to be subclassed. |
| * </p> |
| * @see org.eclipse.debug.internal.ui.viewers.IModelDelta |
| * @since 3.2 |
| */ |
| public class ModelDelta implements IModelDelta { |
| |
| private IModelDelta fParent; |
| private Object fElement; |
| private int fFlags; |
| private ModelDelta[] fNodes = EMPTY_NODES; |
| private Object fReplacement; |
| private int fIndex = -1; |
| private int fChildCount = -1; |
| private static final ModelDelta[] EMPTY_NODES = new ModelDelta[0]; |
| |
| /** |
| * Constructs a new delta for the given element. |
| * |
| * @param element model element |
| * @param flags change flags |
| */ |
| public ModelDelta(Object element, int flags) { |
| fElement = element; |
| fFlags = flags; |
| } |
| |
| /** |
| * Constructs a new delta for the given element to be replaced |
| * with the specified replacement element. |
| * |
| * @param element model element |
| * @param replacement replacement element |
| * @param flags change flags |
| */ |
| public ModelDelta(Object element, Object replacement, int flags) { |
| fElement = element; |
| fReplacement = replacement; |
| fFlags = flags; |
| } |
| |
| /** |
| * Constructs a new delta for the given element to be inserted at |
| * the specified index. |
| * |
| * @param element model element |
| * @param index insertion position |
| * @param flags change flags |
| */ |
| public ModelDelta(Object element, int index, int flags) { |
| fElement = element; |
| fIndex = index; |
| fFlags = flags; |
| } |
| |
| /** |
| * Constructs a new delta for the given element at the specified index |
| * relative to its parent with the given number of children. |
| * |
| * @param element model element |
| * @param index insertion position |
| * @param flags change flags |
| * @param childCount number of children this node has |
| */ |
| public ModelDelta(Object element, int index, int flags, int childCount) { |
| fElement = element; |
| fIndex = index; |
| fFlags = flags; |
| fChildCount = childCount; |
| } |
| |
| /* (non-Javadoc) |
| * @see org.eclipse.debug.internal.ui.viewers.IModelDelta#getElement() |
| */ |
| public Object getElement() { |
| return fElement; |
| } |
| |
| /* (non-Javadoc) |
| * @see org.eclipse.debug.internal.ui.viewers.IModelDelta#getFlags() |
| */ |
| public int getFlags() { |
| return fFlags; |
| } |
| |
| /** |
| * Adds a child node to this delta with the given element and change flags, |
| * and returns the child delta. |
| * |
| * @param element child element to add |
| * @param flags change flags for child |
| * @return newly created child delta |
| */ |
| public ModelDelta addNode(Object element, int flags) { |
| ModelDelta node = new ModelDelta(element, flags); |
| node.setParent(this); |
| addDelta(node); |
| return node; |
| } |
| |
| /** |
| * Returns the child delta for the given element, or <code>null</code> if none. |
| * |
| * @param element child element |
| * @return corresponding delta node, or <code>null</code> |
| */ |
| public ModelDelta getChildDelta(Object element) { |
| if (fNodes != null) { |
| for (int i = 0; i < fNodes.length; i++) { |
| ModelDelta delta = fNodes[i]; |
| if (element.equals(delta.getElement())) { |
| return delta; |
| } |
| } |
| } |
| return null; |
| } |
| |
| /** |
| * Adds a child node to this delta to replace the given element with the |
| * specified replacement element and change flags, and returns the |
| * newly created child delta. |
| * |
| * @param element child element to add to this delta |
| * @param replacement replacement element for the child element |
| * @param flags change flags |
| * @return newly created child delta |
| */ |
| public ModelDelta addNode(Object element, Object replacement, int flags) { |
| ModelDelta node = new ModelDelta(element, replacement, flags); |
| node.setParent(this); |
| addDelta(node); |
| return node; |
| } |
| |
| /** |
| * Adds a child delta to this delta to insert the specified element at |
| * the given index, and returns the newly created child delta. |
| * |
| * @param element child element in insert |
| * @param index index of insertion |
| * @param flags change flags |
| * @return newly created child delta |
| */ |
| public ModelDelta addNode(Object element, int index, int flags) { |
| ModelDelta node = new ModelDelta(element, index, flags); |
| node.setParent(this); |
| addDelta(node); |
| return node; |
| } |
| |
| /** |
| * Adds a child delta to this delta at the specified index with the |
| * given number of children, and returns the newly created child delta. |
| * |
| * @param element child element in insert |
| * @param index index of the element relative to parent |
| * @param flags change flags |
| * @param numChildren the number of children the element has |
| * @return newly created child delta |
| */ |
| public ModelDelta addNode(Object element, int index, int flags, int numChildren) { |
| ModelDelta node = new ModelDelta(element, index, flags, numChildren); |
| node.setParent(this); |
| addDelta(node); |
| return node; |
| } |
| |
| /** |
| * Sets the parent delta of this delta |
| * |
| * @param node parent delta |
| */ |
| void setParent(ModelDelta node) { |
| fParent = node; |
| } |
| |
| /* (non-Javadoc) |
| * @see org.eclipse.debug.internal.ui.viewers.IModelDelta#getParent() |
| */ |
| public IModelDelta getParentDelta() { |
| return fParent; |
| } |
| |
| /* (non-Javadoc) |
| * @see org.eclipse.debug.internal.ui.viewers.IModelDelta#getReplacementElement() |
| */ |
| public Object getReplacementElement() { |
| return fReplacement; |
| } |
| |
| /* (non-Javadoc) |
| * @see org.eclipse.debug.internal.ui.viewers.IModelDelta#getIndex() |
| */ |
| public int getIndex() { |
| return fIndex; |
| } |
| |
| /* (non-Javadoc) |
| * @see org.eclipse.debug.internal.ui.viewers.IModelDelta#getNodes() |
| */ |
| public IModelDelta[] getChildDeltas() { |
| return fNodes; |
| } |
| |
| private void addDelta(ModelDelta delta) { |
| if (fNodes.length == 0) { |
| fNodes = new ModelDelta[]{delta}; |
| } else { |
| ModelDelta[] nodes = new ModelDelta[fNodes.length + 1]; |
| System.arraycopy(fNodes, 0, nodes, 0, fNodes.length); |
| nodes[fNodes.length] = delta; |
| fNodes = nodes; |
| } |
| } |
| |
| public String toString() { |
| StringBuffer buf = new StringBuffer(); |
| buf.append("Model Delta Start\n"); //$NON-NLS-1$ |
| appendDetail(" ", buf, this); //$NON-NLS-1$ |
| buf.append("Model Delta End\n"); //$NON-NLS-1$ |
| return buf.toString(); |
| } |
| |
| private void appendDetail(String indent, StringBuffer buf, IModelDelta delta) { |
| buf.append(indent); |
| buf.append("Element: "); //$NON-NLS-1$ |
| buf.append(delta.getElement()); |
| buf.append('\n'); |
| buf.append(indent); |
| buf.append(" Flags: "); //$NON-NLS-1$ |
| int flags = delta.getFlags(); |
| if (flags == 0) { |
| buf.append("NO_CHANGE"); //$NON-NLS-1$ |
| } else { |
| if ((flags & IModelDelta.ADDED) > 0) { |
| buf.append("ADDED | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.CONTENT) > 0) { |
| buf.append("CONTENT | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.COLLAPSE) > 0) { |
| buf.append("COLLAPSE | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.EXPAND) > 0) { |
| buf.append("EXPAND | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.INSERTED) > 0) { |
| buf.append("INSERTED | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.REMOVED) > 0) { |
| buf.append("REMOVED | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.REPLACED) > 0) { |
| buf.append("REPLACED | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.SELECT) > 0) { |
| buf.append("SELECT | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.STATE) > 0) { |
| buf.append("STATE | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.INSTALL) > 0) { |
| buf.append("INSTALL | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.UNINSTALL) > 0) { |
| buf.append("UNINSTALL | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.REVEAL) > 0) { |
| buf.append("REVEAL | "); //$NON-NLS-1$ |
| } |
| if ((flags & IModelDelta.FORCE) > 0) { |
| buf.append("FORCE | "); //$NON-NLS-1$ |
| } |
| |
| } |
| buf.append('\n'); |
| buf.append(indent); |
| buf.append(" Index: "); //$NON-NLS-1$ |
| buf.append(delta.getIndex()); |
| buf.append(" Child Count: "); //$NON-NLS-1$ |
| buf.append(delta.getChildCount()); |
| buf.append('\n'); |
| IModelDelta[] nodes = delta.getChildDeltas(); |
| for (int i = 0; i < nodes.length; i++) { |
| appendDetail(indent + " ", buf, nodes[i]); //$NON-NLS-1$ |
| } |
| } |
| |
| /* (non-Javadoc) |
| * @see org.eclipse.debug.internal.ui.viewers.provisional.IModelDelta#getChildCount() |
| */ |
| public int getChildCount() { |
| return fChildCount; |
| } |
| |
| /* (non-Javadoc) |
| * @see org.eclipse.debug.internal.ui.viewers.provisional.IModelDelta#accept(org.eclipse.debug.internal.ui.viewers.provisional.IModelDeltaVisitor) |
| */ |
| public void accept(IModelDeltaVisitor visitor) { |
| doAccept(visitor, 0); |
| } |
| |
| protected void doAccept(IModelDeltaVisitor visitor, int depth) { |
| if (visitor.visit(this, depth)) { |
| IModelDelta[] childDeltas = getChildDeltas(); |
| for (int i = 0; i < childDeltas.length; i++) { |
| ((ModelDelta)childDeltas[i]).doAccept(visitor, depth+1); |
| } |
| } |
| } |
| |
| /** |
| * Sets this delta's element |
| * |
| * @param element |
| */ |
| public void setElement(Object element) { |
| fElement = element; |
| } |
| |
| /** |
| * Sets this delta's flags. |
| * |
| * @param flags |
| */ |
| public void setFlags(int flags) { |
| fFlags = flags; |
| } |
| |
| /** |
| * Sets this delta's index |
| * |
| * @param index |
| * @since 3.6 |
| */ |
| public void setIndex(int index) { |
| fIndex = index; |
| } |
| |
| /** |
| * Sets this delta's child count. |
| * |
| * @param count |
| */ |
| public void setChildCount(int count) { |
| fChildCount = count; |
| } |
| |
| } |