/* * Copyright 2011 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.map.strategy.immutable; import java.util.Map; import com.gs.collections.api.block.HashingStrategy; import com.gs.collections.api.factory.map.strategy.ImmutableHashingStrategyMapFactory; import com.gs.collections.api.map.ImmutableMap; import com.gs.collections.impl.map.strategy.mutable.UnifiedMapWithHashingStrategy; import net.jcip.annotations.Immutable; @Immutable public final class ImmutableHashingStrategyMapFactoryImpl implements ImmutableHashingStrategyMapFactory { public <K, V> ImmutableMap<K, V> of(HashingStrategy<? super K> hashingStrategy) { return this.with(hashingStrategy); } public <K, V> ImmutableMap<K, V> with(HashingStrategy<? super K> hashingStrategy) { return new ImmutableEmptyMapWithHashingStrategy<K, V>(hashingStrategy); } public <K, V> ImmutableMap<K, V> of(HashingStrategy<? super K> hashingStrategy, K key, V value) { return this.with(hashingStrategy, key, value); } public <K, V> ImmutableMap<K, V> with(HashingStrategy<? super K> hashingStrategy, K key, V value) { return UnifiedMapWithHashingStrategy.newWithKeysValues(hashingStrategy, key, value).toImmutable(); } public <K, V> ImmutableMap<K, V> of(HashingStrategy<? super K> hashingStrategy, K key1, V value1, K key2, V value2) { return this.with( hashingStrategy, key1, value1, key2, value2); } public <K, V> ImmutableMap<K, V> with(HashingStrategy<? super K> hashingStrategy, K key1, V value1, K key2, V value2) { return UnifiedMapWithHashingStrategy.newWithKeysValues( hashingStrategy, key1, value1, key2, value2).toImmutable(); } public <K, V> ImmutableMap<K, V> of( HashingStrategy<? super K> hashingStrategy, K key1, V value1, K key2, V value2, K key3, V value3) { return this.with( hashingStrategy, key1, value1, key2, value2, key3, value3); } public <K, V> ImmutableMap<K, V> with( HashingStrategy<? super K> hashingStrategy, K key1, V value1, K key2, V value2, K key3, V value3) { return UnifiedMapWithHashingStrategy.newWithKeysValues( hashingStrategy, key1, value1, key2, value2, key3, value3).toImmutable(); } public <K, V> ImmutableMap<K, V> of( HashingStrategy<? super K> hashingStrategy, K key1, V value1, K key2, V value2, K key3, V value3, K key4, V value4) { return this.with( hashingStrategy, key1, value1, key2, value2, key3, value3, key4, value4); } public <K, V> ImmutableMap<K, V> with( HashingStrategy<? super K> hashingStrategy, K key1, V value1, K key2, V value2, K key3, V value3, K key4, V value4) { return UnifiedMapWithHashingStrategy.newWithKeysValues( hashingStrategy, key1, value1, key2, value2, key3, value3, key4, value4).toImmutable(); } /** * @deprecated use {@link #ofAll(Map)} instead (inlineable) */ @Deprecated public <K, V> ImmutableMap<K, V> ofMap(Map<K, V> map) { return this.ofAll(map); } public <K, V> ImmutableMap<K, V> ofAll(Map<K, V> map) { return this.withAll(map); } public <K, V> ImmutableMap<K, V> withAll(Map<K, V> map) { if (!(map instanceof UnifiedMapWithHashingStrategy<?, ?>)) { throw new IllegalArgumentException(); } UnifiedMapWithHashingStrategy<K, V> mapWithHashingStrategy = (UnifiedMapWithHashingStrategy<K, V>) map; if (mapWithHashingStrategy.isEmpty()) { return this.of(mapWithHashingStrategy.hashingStrategy()); } return new ImmutableUnifiedMapWithHashingStrategy<K, V>(mapWithHashingStrategy); } }