/**
* Copyright 2007 Gregory A. Kick
*
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.jvnet.jaxb2_commons.ppp;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
/**
* @author gk5885
*
*/
public class ParentTrackingArrayList<T extends Child> extends ArrayList<T>
{
/**
*
*/
private static final long serialVersionUID = 1L;
private Object parent;
/**
*
*/
public ParentTrackingArrayList(Object parent, Class<? extends List<?>> listClass)
{
super();
this.parent = parent;
}
/**
* @param c
*/
public ParentTrackingArrayList(Object parent, Collection<? extends T> c)
{
super(c);
for (T element : this)
{
element.setParent(parent);
}
}
/**
* @param initialCapacity
*/
public ParentTrackingArrayList(Object parent, int initialCapacity)
{
super(initialCapacity);
this.parent = parent;
}
/**
* @see java.util.ArrayList#add(int, java.lang.Object)
*/
@Override
public void add(int index, T element)
{
element.setParent(parent);
super.add(index, element);
}
/**
* @see java.util.ArrayList#add(java.lang.Object)
*/
@Override
public boolean add(T o)
{
o.setParent(parent);
return super.add(o);
}
/**
* @see java.util.ArrayList#addAll(java.util.Collection)
*/
@Override
public boolean addAll(Collection<? extends T> c)
{
for (T element : c)
{
element.setParent(parent);
}
return super.addAll(c);
}
/**
* @see java.util.ArrayList#addAll(int, java.util.Collection)
*/
@Override
public boolean addAll(int index, Collection<? extends T> c)
{
for (T element : c)
{
element.setParent(parent);
}
return super.addAll(index, c);
}
/**
* @see java.util.ArrayList#clear()
*/
@Override
public void clear()
{
for (T element : this)
{
element.setParent(null);
}
super.clear();
}
/**
* @see java.util.ArrayList#remove(int)
*/
@Override
public T remove(int index)
{
T element = super.remove(index);
element.setParent(null);
return element;
}
/**
* @see java.util.ArrayList#remove(java.lang.Object)
*/
@Override
public boolean remove(Object o)
{
T element = super.get(super.indexOf(o));
element.setParent(null);
return super.remove(o);
}
/**
* @see java.util.AbstractCollection#removeAll(java.util.Collection)
*/
@Override
public boolean removeAll(Collection<?> c)
{
for (T element : this)
{
if (c.contains(element))
{
element.setParent(null);
}
}
return super.removeAll(c);
}
/**
* @see java.util.ArrayList#set(int, java.lang.Object)
*/
@Override
public T set(int index, T element)
{
element.setParent(parent);
return super.set(index, element);
}
/**
* @see java.util.ArrayList#removeRange(int, int)
*/
@Override
protected void removeRange(int fromIndex, int toIndex)
{
for (int index = fromIndex; index < toIndex; index++)
{
this.get(index).setParent(null);
}
super.removeRange(fromIndex, toIndex);
}
}