/* * Copyright 2014 Goldman Sachs. * * 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.gs.collections.impl.multimap.list; import java.io.Externalizable; import java.util.Collection; import com.gs.collections.api.block.predicate.Predicate2; import com.gs.collections.api.list.MutableList; import com.gs.collections.api.map.MutableMap; import com.gs.collections.api.multimap.Multimap; import com.gs.collections.api.multimap.bag.MutableBagMultimap; import com.gs.collections.api.tuple.Pair; import com.gs.collections.impl.list.mutable.FastList; import com.gs.collections.impl.map.mutable.UnifiedMap; import com.gs.collections.impl.utility.Iterate; public final class FastListMultimap<K, V> extends AbstractMutableListMultimap<K, V> implements Externalizable { private static final long serialVersionUID = 1L; // Default from FastList private static final int DEFAULT_CAPACITY = 1; private int initialListCapacity; public FastListMultimap() { this.initialListCapacity = DEFAULT_CAPACITY; } public FastListMultimap(int distinctKeys, int valuesPerKey) { super(Math.max(distinctKeys * 2, 16)); if (distinctKeys < 0 || valuesPerKey < 0) { throw new IllegalArgumentException("Both arguments must be positive."); } this.initialListCapacity = valuesPerKey; } public FastListMultimap(Multimap<? extends K, ? extends V> multimap) { this( multimap.keysView().size(), multimap instanceof FastListMultimap ? ((FastListMultimap<?, ?>) multimap).initialListCapacity : DEFAULT_CAPACITY); this.putAll(multimap); } public FastListMultimap(Pair<K, V>... pairs) { super(pairs); } public FastListMultimap(Iterable<Pair<K, V>> inputIterable) { super(inputIterable); } public static <K, V> FastListMultimap<K, V> newMultimap() { return new FastListMultimap<K, V>(); } public static <K, V> FastListMultimap<K, V> newMultimap(Multimap<? extends K, ? extends V> multimap) { return new FastListMultimap<K, V>(multimap); } public static <K, V> FastListMultimap<K, V> newMultimap(Pair<K, V>... pairs) { return new FastListMultimap<K, V>(pairs); } public static <K, V> FastListMultimap<K, V> newMultimap(Iterable<Pair<K, V>> inputIterable) { return new FastListMultimap<K, V>(inputIterable); } @Override protected MutableMap<K, MutableList<V>> createMap() { return UnifiedMap.newMap(); } @Override protected MutableMap<K, MutableList<V>> createMapWithKeyCount(int keyCount) { return UnifiedMap.newMap(keyCount); } @Override protected MutableList<V> createCollection() { return FastList.newList(this.initialListCapacity); } public void trimToSize() { for (Collection<V> collection : this.map.values()) { FastList<V> fastList = (FastList<V>) collection; fastList.trimToSize(); } } public FastListMultimap<K, V> newEmpty() { return new FastListMultimap<K, V>(); } public MutableBagMultimap<V, K> flip() { return Iterate.flip(this); } public FastListMultimap<K, V> selectKeysValues(Predicate2<? super K, ? super V> predicate) { return this.selectKeysValues(predicate, this.newEmpty()); } public FastListMultimap<K, V> rejectKeysValues(Predicate2<? super K, ? super V> predicate) { return this.rejectKeysValues(predicate, this.newEmpty()); } public FastListMultimap<K, V> selectKeysMultiValues(Predicate2<? super K, ? super Iterable<V>> predicate) { return this.selectKeysMultiValues(predicate, this.newEmpty()); } public FastListMultimap<K, V> rejectKeysMultiValues(Predicate2<? super K, ? super Iterable<V>> predicate) { return this.rejectKeysMultiValues(predicate, this.newEmpty()); } }