All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.bmd.android.collection.internal.SimpleArrayMapIterableImpl Maven / Gradle / Ivy

There is a newer version: 3.0.0
Show newest version
/**
 * 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.bmd.android.collection.internal;

import android.os.Parcelable;
import android.support.v4.util.SimpleArrayMap;

import com.bmd.android.collection.entry.ObjectSparseObjectEntry;
import com.bmd.android.collection.entry.ParcelableObjectSparseObjectEntry;
import com.bmd.android.collection.entry.SimpleArrayMapEntry;
import com.bmd.android.collection.filter.Filter;
import com.bmd.android.collection.filter.SimpleArrayMapFilterBuilder;
import com.bmd.android.collection.iterator.ElementSparseIterable;
import com.bmd.android.collection.iterator.SimpleArrayMapIterable;
import com.bmd.android.collection.translator.FullTranslator;
import com.bmd.android.collection.translator.Translator;
import com.bmd.android.collection.translator.Translators;

import java.lang.reflect.Array;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.SortedMap;
import java.util.TreeMap;

/**
 * Implementation of {@link com.bmd.android.collection.iterator.SimpleArrayMapIterable}.
 * 

* Created by davide on 3/11/14. * * @param The entry key type. * @param The entry value type. */ class SimpleArrayMapIterableImpl extends AbstractSparseIterable> implements SimpleArrayMapIterable { private final SimpleArrayMap mArrayMap; private SimpleArrayMapFilterBuilderImpl mExclusionBuilder; private SimpleArrayMapFilterBuilderImpl mInclusionBuilder; private Translator, K> mKeyTranslator; private Translator, V> mValueTranslator; public SimpleArrayMapIterableImpl(final SimpleArrayMap arrayMap) { mArrayMap = arrayMap; } SimpleArrayMapIterableImpl(final SimpleArrayMapIterableImpl other) { super(other); mArrayMap = other.mArrayMap; } @Override public SimpleArrayMapFilterBuilder but() { if (mExclusionBuilder == null) { mExclusionBuilder = new SimpleArrayMapFilterBuilderImpl(this, false); } return mExclusionBuilder; } @Override public SimpleArrayMapIterable but(final Filter> filter) { super.but(filter); return this; } @Override public SimpleArrayMapIterable doWhile( final Condition> condition) { super.doWhile(condition); return this; } @Override public SimpleArrayMapIterable forEach(final Action> action) { super.forEach(action); return this; } @Override public SimpleArrayMapFilterBuilder only() { if (mInclusionBuilder == null) { mInclusionBuilder = new SimpleArrayMapFilterBuilderImpl(this, true); } return mInclusionBuilder; } @Override public SimpleArrayMapIterable only(final Filter> filter) { super.only(filter); return this; } @Override public SimpleArrayMapIterable remove() { super.remove(); return this; } @Override public SimpleArrayMapIterable retain() { super.retain(); return this; } @Override public SimpleArrayMapIterable reverse() { super.reverse(); return this; } @Override public boolean containsAllKeys(final Object... keys) { for (final Object key : keys) { if (positionOfKey(key) < 0) { return false; } } return true; } @Override public boolean containsAllKeys(final Iterable keys) { for (final Object key : keys) { if (positionOfKey(key) < 0) { return false; } } return true; } @Override public boolean containsAllValues(final Object... values) { for (final Object value : values) { if (firstPositionOfValue(value) < 0) { return false; } } return true; } @Override public boolean containsAllValues(final Iterable values) { for (final Object value : values) { if (firstPositionOfValue(value) < 0) { return false; } } return true; } @Override public boolean containsAnyKey(final Object... keys) { for (final Object key : keys) { if (positionOfKey(key) >= 0) { return true; } } return false; } @Override public boolean containsAnyKey(final Iterable keys) { for (final Object key : keys) { if (positionOfKey(key) >= 0) { return true; } } return false; } @Override public boolean containsAnyValue(final Object... values) { for (final Object value : values) { if (firstPositionOfValue(value) >= 0) { return true; } } return false; } @Override public boolean containsAnyValue(final Iterable values) { for (final Object value : values) { if (firstPositionOfValue(value) >= 0) { return true; } } return false; } @Override public boolean containsKey(final Object key) { return positionOfKey(key) >= 0; } @Override public boolean containsValue(final Object value) { return firstPositionOfValue(value) >= 0; } @Override public SimpleArrayMapIterable fill(final Map map) { for (final SimpleArrayMapEntry entry : this) { map.put(entry.getKey(), entry.getValue()); } return this; } @Override public SimpleArrayMapIterable fillImmutable( final Collection> collection) { for (final SimpleArrayMapEntry entry : this) { collection.add(entry.toImmutable()); } return this; } @Override public SimpleArrayMapIterable fillImmutable(final T[] array) { return fillImmutable(array, 0); } @Override public SimpleArrayMapIterable fillImmutable(final T[] array, final int offset) { int i = offset; for (final SimpleArrayMapEntry entry : this) { //noinspection unchecked array[i++] = (T) entry.toImmutable(); } return this; } @Override public SimpleArrayMapIterable fillParcelable( final Collection> collection) { for (final SimpleArrayMapEntry entry : this) { collection.add(entry.toParcelable()); } return this; } @Override public SimpleArrayMapIterable fillParcelable(final T[] array) { return fillParcelable(array, 0); } @Override public SimpleArrayMapIterable fillParcelable(final T[] array, final int offset) { int i = offset; for (final SimpleArrayMapEntry entry : this) { //noinspection unchecked array[i++] = (T) entry.toParcelable(); } return this; } @Override public int firstIndexOfValue(final Object value) { if (value == null) { for (final SimpleArrayMapEntry entry : this) { if (entry.getValue() == null) { return entry.getIndex(); } } } else { for (final SimpleArrayMapEntry entry : this) { if (value.equals(entry.getValue())) { return entry.getIndex(); } } } return -1; } @Override public int firstPositionOfValue(final Object value) { int i = 0; if (value == null) { for (final SimpleArrayMapEntry entry : this) { if (entry.getValue() == null) { return i; } ++i; } } else { for (final SimpleArrayMapEntry entry : this) { if (value.equals(entry.getValue())) { return i; } ++i; } } return -1; } @Override public int indexOfKey(final Object key) { if (key == null) { for (final SimpleArrayMapEntry entry : this) { if (entry.getKey() == null) { return entry.getIndex(); } } } else { for (final SimpleArrayMapEntry entry : this) { if (key.equals(entry.getKey())) { return entry.getIndex(); } } } return -1; } @Override public boolean isEqualTo(final SimpleArrayMap array) { int count = 0; for (final SimpleArrayMapEntry entry : this) { final Object value = array.get(entry.getKey()); if (value == null) { if (entry.getValue() != null) { return false; } } else if (!value.equals(entry.getValue())) { return false; } ++count; } return (count == array.size()); } @Override public boolean isEqualTo(final Map map) { int count = 0; for (final SimpleArrayMapEntry entry : this) { final Object value = map.get(entry.getKey()); if (value == null) { if (entry.getValue() != null) { return false; } } else if (!value.equals(entry.getValue())) { return false; } ++count; } return (count == map.size()); } @Override public ElementSparseIterable keys() { if (mKeyTranslator == null) { mKeyTranslator = new Translator, K>() { @Override public K translate(final SimpleArrayMapEntry element) { return element.getKey(); } }; } return toElements(mKeyTranslator); } @Override public int positionOfKey(final Object key) { int i = 0; if (key == null) { for (final SimpleArrayMapEntry entry : this) { if (entry.getKey() == null) { return i; } ++i; } } else { for (final SimpleArrayMapEntry entry : this) { if (key.equals(entry.getKey())) { return i; } ++i; } } return -1; } @Override public SimpleArrayMapIterable putInto(final SimpleArrayMap other) { for (final SimpleArrayMapEntry entry : this) { other.put(entry.getKey(), entry.getValue()); } return this; } @Override public SimpleArrayMapIterable replaceValues(final Translator translator) { final SimpleArrayMap arrayMap = mArrayMap; for (final SimpleArrayMapEntry entry : this) { arrayMap.put(entry.getKey(), translator.translate(entry.getValue())); } return this; } @Override public T[] toImmutableArray(final Class type) { final ArrayList> list = toImmutableList(); //noinspection unchecked,SuspiciousToArrayCall return list.toArray((T[]) Array.newInstance(type, list.size())); } @Override public ArrayList> toImmutableList() { final ArrayList> list = new ArrayList>(); fillImmutable(list); return list; } @Override public Map toMap() { final HashMap map = new HashMap(); fill(map); return map; } @Override public T[] toParcelableArray(final Class type) { final ArrayList> list = toParcelableList(); //noinspection unchecked,SuspiciousToArrayCall return list.toArray((T[]) Array.newInstance(type, list.size())); } @Override public ArrayList> toParcelableList() { final ArrayList> list = new ArrayList>(); fillParcelable(list); return list; } @Override public SortedMap toSortedMap() { final TreeMap map = new TreeMap(); fill(map); return map; } @Override public SimpleArrayMap toSparseArray() { final SimpleArrayMap array = new SimpleArrayMap(); for (final SimpleArrayMapEntry entry : this) { array.put(entry.getKey(), entry.getValue()); } return array; } @Override public SimpleArrayMapIterable translate(final Translator keyTranslator, final Translator valueTranslator) { return new TranslatedSimpleArrayMapIterableImpl(this, Translators .full(keyTranslator), Translators.full(valueTranslator)); } @Override public SimpleArrayMapIterable translateKeys(final Translator keyTranslator) { final FullTranslator valueTranslator = Translators.identity(); return translate(keyTranslator, valueTranslator); } @Override public SimpleArrayMapIterable translateValues( final Translator valueTranslator) { final FullTranslator keyTranslator = Translators.identity(); return translate(keyTranslator, valueTranslator); } @Override public ElementSparseIterable values() { if (mValueTranslator == null) { mValueTranslator = new Translator, V>() { @Override public V translate(final SimpleArrayMapEntry element) { return element.getValue(); } }; } return toElements(mValueTranslator); } private static class TranslatedSimpleArrayMapIterableImpl extends SimpleArrayMapIterableImpl { private final SimpleArrayMapIterableImpl mIterable; private final FullTranslator mKeyTranslator; private final FullTranslator mValueTranslator; public TranslatedSimpleArrayMapIterableImpl(final SimpleArrayMapIterableImpl wrapped, final FullTranslator keyTranslator, final FullTranslator valueTranslator) { super((SimpleArrayMap) null); mIterable = wrapped; mKeyTranslator = keyTranslator; mValueTranslator = valueTranslator; } private TranslatedSimpleArrayMapIterableImpl( final TranslatedSimpleArrayMapIterableImpl other) { super(other); mIterable = other.mIterable; mKeyTranslator = other.mKeyTranslator; mValueTranslator = other.mValueTranslator; } @Override protected TranslatedSimpleArrayMapIterableImpl copy() { return new TranslatedSimpleArrayMapIterableImpl(this); } @Override protected SparseIterator> createIterator( final boolean isReverse) { final SimpleArrayMapIterableImpl iterable; if (isReverse) { iterable = mIterable.copy(); iterable.reverse(); } else { iterable = mIterable; } final SparseIterator> iterator = iterable.filteredIterator(false); return new TranslatedSimpleArrayMapIterator(iterator, mKeyTranslator, mValueTranslator); } @Override protected SparseIterator> rawIterator(final boolean isReverse) { final SparseIterator> iterator = mIterable.rawIterator(isReverse); return new TranslatedSimpleArrayMapIterator(iterator, mKeyTranslator, mValueTranslator); } @Override protected void clearFilters() { super.clearFilters(); mIterable.clearFilters(); } } @Override protected SimpleArrayMapIterableImpl copy() { return new SimpleArrayMapIterableImpl(this); } @Override protected SparseIterator> createIterator(final boolean isReverse) { if (isReverse) { return new SimpleArrayMapReverseIterator(mArrayMap); } return new SimpleArrayMapIterator(mArrayMap); } @Override protected SparseIterator> rawIterator(final boolean isReverse) { return createIterator(isReverse); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy