/* * Copyright 2008-2010 the T2 Project ant the Others. * * 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.t2framework.confeito.util; import java.lang.reflect.Array; /** * <#if locale="en"> * <p> * ArrayUtil is an utility class for processing array. * * </p> * <#else> * <p> * * </p> * </#if> * * @author shot */ public class ArrayUtil { /** * * <#if locale="en"> * <p> * Check if array is empty or null. * </p> * <#else> * <p> * 配列が、nullか空の配列の場合にtrueを返します. * </p> * </#if> * * @param <T> * @param array * @return */ public static <T> boolean isEmpty(T[] array) { return array == null || array.length == 0; } /** * <#if locale="en"> * <p> * Add new value to exsisting array.The new value is indexed to the last. * * </p> * <#else> * <p> * * </p> * </#if> * * @param <T> * @param current * @param value * @return */ @SuppressWarnings("unchecked") public static <T> T[] add(T[] current, T value) { Assertion.notNull(current); T[] newone = (T[]) Array.newInstance(current.getClass() .getComponentType(), current.length + 1); copyAll(current, newone); newone[current.length] = value; return newone; } /** * <#if locale="en"> * <p> * Add new value, which sets as the first value, to existing array. * * </p> * <#else> * <p> * * </p> * </#if> * * @param <T> * @param current * @param value * @return */ @SuppressWarnings("unchecked") public static <T> T[] addFirst(T[] current, T value) { Assertion.notNull(current); T[] newone = (T[]) Array.newInstance(current.getClass() .getComponentType(), current.length + 1); copy(current, newone, 0, 1, current.length); newone[0] = value; return newone; } /** * <#if locale="en"> * <p> * Add array. * * </p> * <#else> * <p> * * </p> * </#if> * * @param <T> * @param from * @param to * @return */ @SuppressWarnings("unchecked") public static <T> T[] addAll(T[] from, T[] to) { Assertion.notNulls(from, to); T[] newone = (T[]) Array.newInstance( from.getClass().getComponentType(), from.length + to.length); copyAll(from, newone); copy(to, newone, 0, from.length, to.length); return newone; } /** * <#if locale="en"> * <p> * Copy array. * * </p> * <#else> * <p> * * </p> * </#if> * * @param <T> * @param from * @param to * @return */ public static <T> T[] copyAll(T[] from, T[] to) { System.arraycopy(from, 0, to, 0, from.length); return to; } /** * <#if locale="en"> * <p> * Copy array with from and to position. * * </p> * <#else> * <p> * * </p> * </#if> * * @param <T> * @param from * @param to * @param fromPos * @param toPos * @param length * @return */ public static <T> T[] copy(T[] from, T[] to, int fromPos, int toPos, int length) { System.arraycopy(from, fromPos, to, toPos, length); return to; } /** * <#if locale="en"> * <p> * Return true if the array contains the element. * * </p> * <#else> * <p> * * </p> * </#if> * * @param <T> * @param array * @param element * @return */ public static <T> boolean contains(T[] array, T element) { if (array == null || element == null) { return false; } for (T t : array) { if (element.equals(t)) { return true; } } return false; } }