/* * Copyright 2015. Appsi Mobile * * 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 com.appsimobile.util; import android.support.v4.util.CircularArray; import android.support.v4.util.SimpleArrayMap; import java.util.ArrayList; import java.util.Collection; import java.util.List; /** * Created by nmartens on 22/07/15. */ public class CollectionUtils { private static final ArrayList<?> EMPTY_ARRAY_LIST = new ArrayList<Object>() { @Override public boolean add(Object object) { throw new UnsupportedOperationException(); } @Override public void add(int index, Object object) { throw new UnsupportedOperationException(); } @Override public boolean addAll(Collection collection) { throw new UnsupportedOperationException(); } @Override public boolean addAll(int index, Collection collection) { throw new UnsupportedOperationException(); } }; @SuppressWarnings("unchecked") public static <T> ArrayList<T> emptyList() { return (ArrayList<T>) EMPTY_ARRAY_LIST; } public static <T> CircularArray<T> emptyArray() { return new CircularArray<>(1); } public static <T> void addKeys(SimpleArrayMap<T, ?> map, List<T> target) { int N = map.size(); for (int i = 0; i < N; i++) { T p = map.keyAt(i); target.add(p); } } public static <T> void addValues(SimpleArrayMap<?, T> map, List<T> target) { int N = map.size(); for (int i = 0; i < N; i++) { T p = map.valueAt(i); target.add(p); } } @SafeVarargs public static <T> ArrayList<T> asList(T... items) { ArrayList<T> result = new ArrayList<>(); if (items != null) { for (T t : items) { result.add(t); } } return result; } }