Merging from -r468106:814127 of collections_jdk5_branch - namely where this code was generified; mostly in r738956.

Also see the following revisions:

    ------------------------------------------------------------------------
    r555925 | skestle | 2007-07-13 03:39:24 -0700 (Fri, 13 Jul 2007) | 2 lines
    
    Added Edwin Tellman's patch for COLLECTIONS-243.  
    It all seems pretty reasonable, and it should all be checked again as the project is worked through
    ------------------------------------------------------------------------


git-svn-id: https://svn.apache.org/repos/asf/commons/proper/collections/trunk@815067 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Henri Yandell 2009-09-15 05:55:45 +00:00
parent 6f353fd695
commit 1dbcde91cb
1 changed files with 17 additions and 17 deletions

View File

@ -35,7 +35,7 @@ import org.apache.commons.collections.collection.SynchronizedCollection;
* *
* @author Stephen Colebourne * @author Stephen Colebourne
*/ */
public class SynchronizedList extends SynchronizedCollection implements List { public class SynchronizedList<E> extends SynchronizedCollection<E> implements List<E> {
/** Serialization version */ /** Serialization version */
private static final long serialVersionUID = -1403835447328619437L; private static final long serialVersionUID = -1403835447328619437L;
@ -46,8 +46,8 @@ public class SynchronizedList extends SynchronizedCollection implements List {
* @param list the list to decorate, must not be null * @param list the list to decorate, must not be null
* @throws IllegalArgumentException if list is null * @throws IllegalArgumentException if list is null
*/ */
public static List decorate(List list) { public static <T> List<T> decorate(List<T> list) {
return new SynchronizedList(list); return new SynchronizedList<T>(list);
} }
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
@ -57,7 +57,7 @@ public class SynchronizedList extends SynchronizedCollection implements List {
* @param list the list to decorate, must not be null * @param list the list to decorate, must not be null
* @throws IllegalArgumentException if list is null * @throws IllegalArgumentException if list is null
*/ */
protected SynchronizedList(List list) { protected SynchronizedList(List<E> list) {
super(list); super(list);
} }
@ -68,7 +68,7 @@ public class SynchronizedList extends SynchronizedCollection implements List {
* @param lock the lock to use, must not be null * @param lock the lock to use, must not be null
* @throws IllegalArgumentException if list is null * @throws IllegalArgumentException if list is null
*/ */
protected SynchronizedList(List list, Object lock) { protected SynchronizedList(List<E> list, Object lock) {
super(list, lock); super(list, lock);
} }
@ -77,24 +77,24 @@ public class SynchronizedList extends SynchronizedCollection implements List {
* *
* @return the decorated list * @return the decorated list
*/ */
protected List getList() { protected List<E> getList() {
return (List) collection; return (List<E>) collection;
} }
//----------------------------------------------------------------------- //-----------------------------------------------------------------------
public void add(int index, Object object) { public void add(int index, E object) {
synchronized (lock) { synchronized (lock) {
getList().add(index, object); getList().add(index, object);
} }
} }
public boolean addAll(int index, Collection coll) { public boolean addAll(int index, Collection<? extends E> coll) {
synchronized (lock) { synchronized (lock) {
return getList().addAll(index, coll); return getList().addAll(index, coll);
} }
} }
public Object get(int index) { public E get(int index) {
synchronized (lock) { synchronized (lock) {
return getList().get(index); return getList().get(index);
} }
@ -122,7 +122,7 @@ public class SynchronizedList extends SynchronizedCollection implements List {
* *
* @return an iterator that must be manually synchronized on the collection * @return an iterator that must be manually synchronized on the collection
*/ */
public ListIterator listIterator() { public ListIterator<E> listIterator() {
return getList().listIterator(); return getList().listIterator();
} }
@ -136,28 +136,28 @@ public class SynchronizedList extends SynchronizedCollection implements List {
* *
* @return an iterator that must be manually synchronized on the collection * @return an iterator that must be manually synchronized on the collection
*/ */
public ListIterator listIterator(int index) { public ListIterator<E> listIterator(int index) {
return getList().listIterator(index); return getList().listIterator(index);
} }
public Object remove(int index) { public E remove(int index) {
synchronized (lock) { synchronized (lock) {
return getList().remove(index); return getList().remove(index);
} }
} }
public Object set(int index, Object object) { public E set(int index, E object) {
synchronized (lock) { synchronized (lock) {
return getList().set(index, object); return getList().set(index, object);
} }
} }
public List subList(int fromIndex, int toIndex) { public List<E> subList(int fromIndex, int toIndex) {
synchronized (lock) { synchronized (lock) {
List list = getList().subList(fromIndex, toIndex); List<E> list = getList().subList(fromIndex, toIndex);
// the lock is passed into the constructor here to ensure that the sublist is // the lock is passed into the constructor here to ensure that the sublist is
// synchronized on the same lock as the parent list // synchronized on the same lock as the parent list
return new SynchronizedList(list, lock); return new SynchronizedList<E>(list, lock);
} }
} }