package org.jcodec.common; import java.util.Arrays; /** * This class is part of JCodec ( www.jcodec.org ) This software is distributed * under FreeBSD License * * @author Jay Codec * */ public class IntArrayList { private static final int DEFAULT_GROW_AMOUNT = 128; private int[] storage; private int size; private int growAmount; public IntArrayList() { this(DEFAULT_GROW_AMOUNT); } public IntArrayList(int growAmount) { this.growAmount = growAmount; this.storage = new int[growAmount]; } public int[] toArray() { int[] result = new int[size]; System.arraycopy(storage, 0, result, 0, size); return result; } public void add(int val) { if (size >= storage.length) { int[] ns = new int[storage.length + growAmount]; System.arraycopy(storage, 0, ns, 0, storage.length); storage = ns; } storage[size++] = val; } public void set(int index, int value) { storage[index] = value; } public int get(int index) { return storage[index]; } public void fill(int start, int end, int val) { if (end > storage.length) { int[] ns = new int[end + growAmount]; System.arraycopy(storage, 0, ns, 0, storage.length); storage = ns; } Arrays.fill(storage, start, end, val); size = Math.max(size, end); } public int size() { return size; } public void addAll(int[] other) { if (size + other.length >= storage.length) { int[] ns = new int[size + growAmount + other.length]; System.arraycopy(storage, 0, ns, 0, size); storage = ns; } System.arraycopy(other, 0, storage, size, other.length); size += other.length; } public void clear() { size = 0; } }