blob: a60c6e736127ca3e70569c896707f54c54e8466e [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2005 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
*******************************************************************************/
package org.eclipse.jface.internal.databinding.beans;
import org.eclipse.jface.databinding.ChangeEvent;
import org.eclipse.jface.databinding.IChangeListener;
import org.eclipse.jface.databinding.ITree;
import org.eclipse.jface.databinding.IUpdatableTree;
import org.eclipse.jface.databinding.Updatable;
/**
* @since 3.2
*
*/
public class JavaBeanUpdatableTree extends Updatable implements IUpdatableTree {
private ITree tree;
private Class[] classTypes;
private boolean updating=false;
// The Tree updatable relies on the ITree to provide change notification
private IChangeListener treeListener = new IChangeListener() {
public void handleChange(ChangeEvent e) {
if (!updating) {
updating=true;
try {
fireChangeEvent(e.getChangeType(), e.getOldValue(), e.getNewValue(), e.getParent(), e.getPosition());
}
finally{
updating=false;
}
}
}
};
/**
* @param tree
*/
public JavaBeanUpdatableTree (ITree tree) {
this.tree = tree;
this.classTypes = tree.getTypes();
tree.addTreeChangeListener(treeListener);
}
private Object[] primRemoveElement(Object[] source, int index) {
Object[] newArray = new Object[source.length-1];
System.arraycopy(source, 0, newArray, 0, index);
System.arraycopy(source, index+1, newArray, index, source.length-index);
return newArray;
}
private Object[] primAddElement(Object[] source, Object element, int index) {
Object[] newArray = new Object[source.length+1];
System.arraycopy(source, 0, newArray, 0, index);
newArray[index]=element;
System.arraycopy(source, index+1, newArray, index+1, source.length-index);
return newArray;
}
public int addElement(Object parentElement, int index, Object value) {
updating=true;
try {
Object[] list = tree.getChildren(parentElement);
if (index <= 0 || index > list.length)
index = list.length;
Object[] newList = primAddElement(list, value, index);
tree.setChildren(parentElement, newList);
fireChangeEvent(ChangeEvent.ADD, null, value, parentElement, index);
return index;
} finally {
updating=false;
}
}
public void removeElement(Object parentElement, int index) {
updating=true;
try {
Object[] list = tree.getChildren(parentElement);
if (list == null || index < 0 || index >= list.length)
return;
Object o = list[index];
Object[] newList=primRemoveElement(list,index);
tree.setChildren(parentElement, newList);
fireChangeEvent(ChangeEvent.REMOVE, o, null, parentElement, index);
} finally {
updating=false;
}
}
public void setElement(Object parentElement, int index, Object value) {
updating = true;
try {
Object[] list = tree.getChildren(parentElement);
if (list==null || index<0 || index>=list.length) return;
Object oldValue = list[index];
list[index]= value;
fireChangeEvent(ChangeEvent.CHANGE, oldValue, value, parentElement, index);
} finally {
updating = false;
}
}
public void setElements(Object parentElement, Object[] values) {
updating = true;
try {
Object[] list = tree.getChildren(parentElement);
tree.setChildren(parentElement, values);
fireChangeEvent(ChangeEvent.REPLACE, list, values, parentElement, -1);
} finally {
updating = false;
}
}
public Object getElement(Object parentElement, int index) {
Object[] list = tree.getChildren(parentElement);
if (list==null || index<0 || index>=list.length) return null;
return list[index];
}
public Object[] getElements(Object parentElement) {
return tree.getChildren(parentElement);
}
public void dispose() {
super.dispose();
tree.removeTreeChangeListener(treeListener);
tree.dispose();
}
public Class[] getTypes() {
return classTypes;
}
}