/* 
 | 
 * Java port of Bullet (c) 2008 Martin Dvorak <jezek2@advel.cz> 
 | 
 * 
 | 
 * Bullet Continuous Collision Detection and Physics Library 
 | 
 * Copyright (c) 2003-2008 Erwin Coumans  http://www.bulletphysics.com/ 
 | 
 * 
 | 
 * This software is provided 'as-is', without any express or implied warranty. 
 | 
 * In no event will the authors be held liable for any damages arising from 
 | 
 * the use of this software. 
 | 
 *  
 | 
 * Permission is granted to anyone to use this software for any purpose,  
 | 
 * including commercial applications, and to alter it and redistribute it 
 | 
 * freely, subject to the following restrictions: 
 | 
 *  
 | 
 * 1. The origin of this software must not be misrepresented; you must not 
 | 
 *    claim that you wrote the original software. If you use this software 
 | 
 *    in a product, an acknowledgment in the product documentation would be 
 | 
 *    appreciated but is not required. 
 | 
 * 2. Altered source versions must be plainly marked as such, and must not be 
 | 
 *    misrepresented as being the original software. 
 | 
 * 3. This notice may not be removed or altered from any source distribution. 
 | 
 */ 
 | 
  
 | 
package com.bulletphysics.util; 
 | 
  
 | 
import java.io.Externalizable; 
 | 
import java.io.IOException; 
 | 
import java.io.ObjectInput; 
 | 
import java.io.ObjectOutput; 
 | 
import java.util.AbstractList; 
 | 
import java.util.RandomAccess; 
 | 
  
 | 
/** 
 | 
 * 
 | 
 * @author jezek2 
 | 
 */ 
 | 
public final class ObjectArrayList<T> extends AbstractList<T> implements RandomAccess, Externalizable { 
 | 
  
 | 
    private T[] array; 
 | 
    private int size; 
 | 
  
 | 
    public ObjectArrayList() { 
 | 
        this(16); 
 | 
    } 
 | 
     
 | 
    @SuppressWarnings("unchecked") 
 | 
    public ObjectArrayList(int initialCapacity) { 
 | 
        array = (T[])new Object[initialCapacity]; 
 | 
    } 
 | 
     
 | 
    @Override 
 | 
    public boolean add(T value) { 
 | 
        if (size == array.length) { 
 | 
            expand(); 
 | 
        } 
 | 
         
 | 
        array[size++] = value; 
 | 
        return true; 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public void add(int index, T value) { 
 | 
        if (size == array.length) { 
 | 
            expand(); 
 | 
        } 
 | 
  
 | 
        int num = size - index; 
 | 
        if (num > 0) { 
 | 
            System.arraycopy(array, index, array, index+1, num); 
 | 
        } 
 | 
  
 | 
        array[index] = value; 
 | 
        size++; 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public T remove(int index) { 
 | 
        if (index < 0 || index >= size) throw new IndexOutOfBoundsException(); 
 | 
        T prev = array[index]; 
 | 
        System.arraycopy(array, index+1, array, index, size-index-1); 
 | 
        array[size-1] = null; 
 | 
        size--; 
 | 
        return prev; 
 | 
    } 
 | 
     
 | 
    @SuppressWarnings("unchecked") 
 | 
    private void expand() { 
 | 
        T[] newArray = (T[])new Object[array.length << 1]; 
 | 
        System.arraycopy(array, 0, newArray, 0, array.length); 
 | 
        array = newArray; 
 | 
    } 
 | 
  
 | 
    public void removeQuick(int index) { 
 | 
        System.arraycopy(array, index+1, array, index, size - index - 1); 
 | 
        array[size-1] = null; 
 | 
        size--; 
 | 
    } 
 | 
  
 | 
    public T get(int index) { 
 | 
        if (index >= size) throw new IndexOutOfBoundsException(); 
 | 
        return array[index]; 
 | 
    } 
 | 
  
 | 
    public T getQuick(int index) { 
 | 
        return array[index]; 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public T set(int index, T value) { 
 | 
        if (index >= size) throw new IndexOutOfBoundsException(); 
 | 
        T old = array[index]; 
 | 
        array[index] = value; 
 | 
        return old; 
 | 
    } 
 | 
  
 | 
    public void setQuick(int index, T value) { 
 | 
        array[index] = value; 
 | 
    } 
 | 
  
 | 
    public int size() { 
 | 
        return size; 
 | 
    } 
 | 
     
 | 
    public int capacity() { 
 | 
        return array.length; 
 | 
    } 
 | 
     
 | 
    @Override 
 | 
    public void clear() { 
 | 
        size = 0; 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public int indexOf(Object o) { 
 | 
        int _size = size; 
 | 
        T[] _array = array; 
 | 
        for (int i=0; i<_size; i++) { 
 | 
            if (o == null? _array[i] == null : o.equals(_array[i])) { 
 | 
                return i; 
 | 
            } 
 | 
        } 
 | 
        return -1; 
 | 
    } 
 | 
  
 | 
    public void writeExternal(ObjectOutput out) throws IOException { 
 | 
        out.writeInt(size); 
 | 
        for (int i=0; i<size; i++) { 
 | 
            out.writeObject(array[i]); 
 | 
        } 
 | 
    } 
 | 
  
 | 
    public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException { 
 | 
        size = in.readInt(); 
 | 
        int cap = 16; 
 | 
        while (cap < size) cap <<= 1; 
 | 
        array = (T[])new Object[cap]; 
 | 
        for (int i=0; i<size; i++) { 
 | 
            array[i] = (T)in.readObject(); 
 | 
        } 
 | 
    } 
 | 
     
 | 
} 
 |