org.jitsi.utils.ArrayUtils Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jitsi-utils Show documentation
Show all versions of jitsi-utils Show documentation
A set of basic utilities used in Jitsi projects
/*
* Copyright @ 2018 - Present 8x8, Inc
*
* 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.jitsi.utils;
import java.lang.reflect.*;
import java.util.*;
/**
*
* @author Lyubomir Marinov
*/
public final class ArrayUtils
{
/**
* Adds a specific element to a specific array with a specific component
* type if the array does not contain the element yet.
*
* @param array the array to add element to
* @param componentType the component type of array
* @param element the element to add to array
* @return an array with the specified componentType and
* containing element. If array contained element
* already, returns array.
*/
@SuppressWarnings("unchecked")
public static T[] add(T[] array, Class componentType, T element)
{
if (element == null)
throw new NullPointerException("element");
if (array == null)
{
array = (T[]) Array.newInstance(componentType, 1);
}
else
{
for (T a : array)
{
if (element.equals(a))
return array;
}
T[] newArray
= (T[]) Array.newInstance(componentType, array.length + 1);
System.arraycopy(array, 0, newArray, 0, array.length);
array = newArray;
}
array[array.length - 1] = element;
return array;
}
/**
* Inserts the given element into an open (null) slot in the array if there
* is one, otherwise creates a new array and adds all existing elements
* and the given element
* @param element the element to add
* @param array the array to add to, if possible
* @param componentType the class type of the array (used if a new one
* needs to be allocated)
* @param the type of the element
* @return an array containing all the elements in the array that was passed,
* as well as the given element. May or may not be the original array.
*/
public static T[] insert(T element, T[] array, Class componentType)
{
T[] arrayToReturn = array;
boolean inserted = false;
for (int i = 0; i < array.length; ++i)
{
if (array[i] == null)
{
array[i] = element;
inserted = true;
break;
}
}
if (!inserted)
{
arrayToReturn = add(array, componentType, element);
}
return arrayToReturn;
}
/** Prevents the initialization of new {@code ArrayUtils} instances. */
private ArrayUtils()
{
}
/**
* Concatenates two arrays.
*
* @param first
* @param second
* @param
* @return
*/
public static T[] concat(T[] first, T[] second)
{
if (isNullOrEmpty(first))
{
return second;
}
else if (isNullOrEmpty(second))
{
return first;
}
else
{
T[] result = Arrays.copyOf(first, first.length + second.length);
System.arraycopy(second, 0, result, first.length, second.length);
return result;
}
}
/**
* Tests whether the array passed in as an argument is null or empty.
*
* @param array
* @param
* @return
*/
public static boolean isNullOrEmpty(T[] array)
{
return array == null || array.length == 0;
}
}