2009-12-03 02:08:29 +00:00
|
|
|
/* Copyright (c) 2008-2009, Avian Contributors
|
2008-02-19 18:06:52 +00:00
|
|
|
|
|
|
|
Permission to use, copy, modify, and/or distribute this software
|
|
|
|
for any purpose with or without fee is hereby granted, provided
|
|
|
|
that the above copyright notice and this permission notice appear
|
|
|
|
in all copies.
|
|
|
|
|
|
|
|
There is NO WARRANTY for this software. See license.txt for
|
|
|
|
details. */
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
package java.util;
|
|
|
|
|
|
|
|
public class Arrays {
|
|
|
|
private Arrays() { }
|
|
|
|
|
2007-08-24 01:57:42 +00:00
|
|
|
public static String toString(Object[] a) {
|
|
|
|
return asList(a).toString();
|
|
|
|
}
|
|
|
|
|
2007-07-22 19:06:21 +00:00
|
|
|
private static boolean equal(Object a, Object b) {
|
|
|
|
return (a == null && b == null) || (a != null && a.equals(b));
|
|
|
|
}
|
|
|
|
|
2008-02-28 18:37:10 +00:00
|
|
|
public static void sort(Object[] array) {
|
|
|
|
sort(array, new Comparator() {
|
|
|
|
public int compare(Object a, Object b) {
|
|
|
|
return ((Comparable) a).compareTo(b);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2007-12-03 23:32:54 +00:00
|
|
|
public static <T> void sort(T[] array, Comparator<? super T> comparator) {
|
|
|
|
// insertion sort
|
|
|
|
for (int j = 1; j < array.length; ++j) {
|
|
|
|
T t = array[j];
|
|
|
|
int i = j - 1;
|
|
|
|
while (i >= 0 && comparator.compare(array[i], t) > 0) {
|
|
|
|
array[i + 1] = array[i];
|
|
|
|
i = i - 1;
|
|
|
|
}
|
|
|
|
array[i + 1] = t;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
public static <T> List<T> asList(final T ... array) {
|
|
|
|
return new List<T>() {
|
2007-08-24 01:57:42 +00:00
|
|
|
public String toString() {
|
|
|
|
return Collections.toString(this);
|
|
|
|
}
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
public int size() {
|
|
|
|
return array.length;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean add(T element) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2008-02-28 18:37:10 +00:00
|
|
|
public boolean addAll(Collection<? extends T> collection) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2007-09-26 16:32:39 +00:00
|
|
|
public void add(int index, T element) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2009-04-22 21:24:26 +00:00
|
|
|
public boolean contains(Object element) {
|
2007-07-22 19:06:21 +00:00
|
|
|
for (int i = 0; i < array.length; ++i) {
|
|
|
|
if (equal(element, array[i])) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2009-08-04 23:58:31 +00:00
|
|
|
public int indexOf(Object element) {
|
|
|
|
for (int i = 0; i < array.length; ++i) {
|
|
|
|
if (equal(element, array[i])) {
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int lastIndexOf(Object element) {
|
|
|
|
for (int i = array.length - 1; i >= 0; --i) {
|
|
|
|
if (equal(element, array[i])) {
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
public T get(int index) {
|
|
|
|
return array[index];
|
|
|
|
}
|
|
|
|
|
2007-11-14 16:32:36 +00:00
|
|
|
public T set(int index, T value) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2009-08-04 23:36:25 +00:00
|
|
|
public Object[] toArray() {
|
|
|
|
return toArray(new Object[size()]);
|
|
|
|
}
|
|
|
|
|
2007-09-26 14:57:34 +00:00
|
|
|
public <S> S[] toArray(S[] a) {
|
|
|
|
return (S[])array;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isEmpty() {
|
|
|
|
return size() == 0;
|
|
|
|
}
|
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
public T remove(int index) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
2009-04-22 21:24:26 +00:00
|
|
|
public boolean remove(Object element) {
|
2007-07-22 03:47:29 +00:00
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
|
|
|
public void clear() {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
|
|
|
|
public Iterator<T> iterator() {
|
2009-08-04 23:24:29 +00:00
|
|
|
return listIterator();
|
|
|
|
}
|
|
|
|
|
|
|
|
public ListIterator<T> listIterator(int index) {
|
|
|
|
return new Collections.ArrayListIterator(this, index);
|
|
|
|
}
|
|
|
|
|
|
|
|
public ListIterator<T> listIterator() {
|
|
|
|
return listIterator(0);
|
2007-07-22 03:47:29 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
2008-07-14 00:28:27 +00:00
|
|
|
|
|
|
|
public static void fill(int[] array, int value) {
|
|
|
|
for (int i=0;i<array.length;i++) {
|
|
|
|
array[i] = value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void fill(char[] array, char value) {
|
|
|
|
for (int i=0;i<array.length;i++) {
|
|
|
|
array[i] = value;
|
|
|
|
}
|
|
|
|
}
|
2010-08-15 12:01:33 +00:00
|
|
|
|
|
|
|
public static <T> void fill(T[] array, T value) {
|
|
|
|
for (int i=0;i<array.length;i++) {
|
|
|
|
array[i] = value;
|
|
|
|
}
|
|
|
|
}
|
2008-07-14 00:28:27 +00:00
|
|
|
|
2007-07-22 03:47:29 +00:00
|
|
|
}
|