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

org.eclipse.collections.impl.bimap.immutable.AbstractImmutableBiMap Maven / Gradle / Ivy

There is a newer version: 12.0.0.M3
Show newest version
/*
 * Copyright (c) 2015 Goldman Sachs.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * and Eclipse Distribution License v. 1.0 which accompany this distribution.
 * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
 * and the Eclipse Distribution License is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 */

package org.eclipse.collections.impl.bimap.immutable;

import java.io.Serializable;
import java.util.Collection;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

import org.eclipse.collections.api.bag.ImmutableBag;
import org.eclipse.collections.api.bag.primitive.ImmutableBooleanBag;
import org.eclipse.collections.api.bag.primitive.ImmutableByteBag;
import org.eclipse.collections.api.bag.primitive.ImmutableCharBag;
import org.eclipse.collections.api.bag.primitive.ImmutableDoubleBag;
import org.eclipse.collections.api.bag.primitive.ImmutableFloatBag;
import org.eclipse.collections.api.bag.primitive.ImmutableIntBag;
import org.eclipse.collections.api.bag.primitive.ImmutableLongBag;
import org.eclipse.collections.api.bag.primitive.ImmutableShortBag;
import org.eclipse.collections.api.bimap.ImmutableBiMap;
import org.eclipse.collections.api.block.function.Function;
import org.eclipse.collections.api.block.function.Function0;
import org.eclipse.collections.api.block.function.Function2;
import org.eclipse.collections.api.block.function.primitive.BooleanFunction;
import org.eclipse.collections.api.block.function.primitive.ByteFunction;
import org.eclipse.collections.api.block.function.primitive.CharFunction;
import org.eclipse.collections.api.block.function.primitive.DoubleFunction;
import org.eclipse.collections.api.block.function.primitive.FloatFunction;
import org.eclipse.collections.api.block.function.primitive.IntFunction;
import org.eclipse.collections.api.block.function.primitive.LongFunction;
import org.eclipse.collections.api.block.function.primitive.ShortFunction;
import org.eclipse.collections.api.block.predicate.Predicate;
import org.eclipse.collections.api.block.predicate.Predicate2;
import org.eclipse.collections.api.block.procedure.Procedure;
import org.eclipse.collections.api.block.procedure.Procedure2;
import org.eclipse.collections.api.map.ImmutableMap;
import org.eclipse.collections.api.map.MutableMap;
import org.eclipse.collections.api.multimap.set.ImmutableSetMultimap;
import org.eclipse.collections.api.partition.set.PartitionImmutableSet;
import org.eclipse.collections.api.partition.set.PartitionMutableSet;
import org.eclipse.collections.api.set.ImmutableSet;
import org.eclipse.collections.api.set.MutableSet;
import org.eclipse.collections.api.tuple.Pair;
import org.eclipse.collections.impl.bimap.AbstractBiMap;
import org.eclipse.collections.impl.bimap.mutable.HashBiMap;
import org.eclipse.collections.impl.block.factory.Predicates;
import org.eclipse.collections.impl.block.procedure.PartitionProcedure;
import org.eclipse.collections.impl.block.procedure.SelectInstancesOfProcedure;
import org.eclipse.collections.impl.factory.BiMaps;
import org.eclipse.collections.impl.factory.Sets;
import org.eclipse.collections.impl.list.fixed.ArrayAdapter;
import org.eclipse.collections.impl.multimap.set.UnifiedSetMultimap;
import org.eclipse.collections.impl.partition.set.PartitionUnifiedSet;
import org.eclipse.collections.impl.set.mutable.UnifiedSet;
import org.eclipse.collections.impl.utility.MapIterate;

public abstract class AbstractImmutableBiMap extends AbstractBiMap implements ImmutableBiMap, Map
{
    private final ImmutableMap delegate;
    private final AbstractImmutableBiMap inverse;

    private AbstractImmutableBiMap(ImmutableMap delegate, AbstractImmutableBiMap valuesToKeys)
    {
        this.delegate = delegate;
        this.inverse = valuesToKeys;
    }

    AbstractImmutableBiMap(ImmutableMap map, ImmutableMap inverse)
    {
        this.delegate = map;
        this.inverse = new Inverse(inverse, this);
    }

    @Override
    protected ImmutableMap getDelegate()
    {
        return this.delegate;
    }

    @Override
    protected ImmutableMap getInverse()
    {
        return this.inverse.delegate;
    }

    public ImmutableBiMap newWithKeyValue(K key, V value)
    {
        HashBiMap map = new HashBiMap(this.delegate.castToMap());
        map.put(key, value);
        return map.toImmutable();
    }

    public ImmutableBiMap newWithAllKeyValues(Iterable> keyValues)
    {
        HashBiMap map = new HashBiMap(this.delegate.castToMap());
        for (Pair keyValuePair : keyValues)
        {
            map.put(keyValuePair.getOne(), keyValuePair.getTwo());
        }
        return map.toImmutable();
    }

    public ImmutableBiMap newWithAllKeyValueArguments(Pair... keyValuePairs)
    {
        return this.newWithAllKeyValues(ArrayAdapter.adapt(keyValuePairs));
    }

    public ImmutableBiMap newWithoutKey(K key)
    {
        HashBiMap map = new HashBiMap(this.delegate.castToMap());
        map.removeKey(key);
        return map.toImmutable();
    }

    public ImmutableBiMap newWithoutAllKeys(Iterable keys)
    {
        HashBiMap map = new HashBiMap(this.delegate.castToMap());
        for (K key : keys)
        {
            map.removeKey(key);
        }
        return map.toImmutable();
    }

    public ImmutableBiMap inverse()
    {
        return this.inverse;
    }

    public ImmutableSetMultimap flip()
    {
        // TODO: We could optimize this since we know the values are unique
        return MapIterate.flip(this).toImmutable();
    }

    public ImmutableBiMap flipUniqueValues()
    {
        return this.inverse();
    }

    public V put(K key, V value)
    {
        throw new UnsupportedOperationException("Cannot call put() on " + this.getClass().getSimpleName());
    }

    public void putAll(Map map)
    {
        throw new UnsupportedOperationException("Cannot call putAll() on " + this.getClass().getSimpleName());
    }

    public V remove(Object key)
    {
        throw new UnsupportedOperationException("Cannot call remove() on " + this.getClass().getSimpleName());
    }

    public void clear()
    {
        throw new UnsupportedOperationException("Cannot call clear() on " + this.getClass().getSimpleName());
    }

    public Set keySet()
    {
        return this.delegate.castToMap().keySet();
    }

    public Collection values()
    {
        return this.delegate.castToMap().values();
    }

    public Set> entrySet()
    {
        return this.delegate.castToMap().entrySet();
    }

    public Iterator iterator()
    {
        return this.delegate.iterator();
    }

    public ImmutableBiMap toImmutable()
    {
        return this;
    }

    public Map castToMap()
    {
        return this;
    }

    public MutableMap toMap()
    {
        return this.getDelegate().toMap();
    }

    public  ImmutableBiMap collect(Function2> function)
    {
        ImmutableMap result = this.delegate.collect(function);
        return BiMaps.immutable.withAll(result);
    }

    public  ImmutableBag collect(Function function)
    {
        return this.delegate.collect(function);
    }

    public  ImmutableBiMap collectValues(Function2 function)
    {
        ImmutableMap result = this.delegate.collectValues(function);
        return BiMaps.immutable.withAll(result);
    }

    public ImmutableBooleanBag collectBoolean(BooleanFunction booleanFunction)
    {
        return this.delegate.collectBoolean(booleanFunction);
    }

    public ImmutableByteBag collectByte(ByteFunction byteFunction)
    {
        return this.delegate.collectByte(byteFunction);
    }

    public ImmutableCharBag collectChar(CharFunction charFunction)
    {
        return this.delegate.collectChar(charFunction);
    }

    public ImmutableDoubleBag collectDouble(DoubleFunction doubleFunction)
    {
        return this.delegate.collectDouble(doubleFunction);
    }

    public ImmutableFloatBag collectFloat(FloatFunction floatFunction)
    {
        return this.delegate.collectFloat(floatFunction);
    }

    public ImmutableIntBag collectInt(IntFunction intFunction)
    {
        return this.delegate.collectInt(intFunction);
    }

    public ImmutableLongBag collectLong(LongFunction longFunction)
    {
        return this.delegate.collectLong(longFunction);
    }

    public ImmutableShortBag collectShort(ShortFunction shortFunction)
    {
        return this.delegate.collectShort(shortFunction);
    }

    public  ImmutableBag collectWith(Function2 function, P parameter)
    {
        return this.delegate.collectWith(function, parameter);
    }

    public  ImmutableBag collectIf(Predicate predicate, Function function)
    {
        return this.delegate.collectIf(predicate, function);
    }

    public  ImmutableBag flatCollect(Function> function)
    {
        return this.delegate.flatCollect(function);
    }

    public ImmutableBiMap select(Predicate2 predicate)
    {
        return MapIterate.selectMapOnEntry(this, predicate, HashBiMap.newMap()).toImmutable();
    }

    public ImmutableBiMap tap(Procedure procedure)
    {
        this.forEach(procedure);
        return this;
    }

    public ImmutableSet select(Predicate predicate)
    {
        return this.delegate.select(predicate, Sets.mutable.empty()).toImmutable();
    }

    public 

ImmutableSet selectWith(Predicate2 predicate, P parameter) { return this.delegate.selectWith(predicate, parameter, Sets.mutable.empty()).toImmutable(); } public ImmutableBiMap reject(Predicate2 predicate) { return MapIterate.rejectMapOnEntry(this, predicate, HashBiMap.newMap()).toImmutable(); } public ImmutableSet reject(Predicate predicate) { return this.delegate.reject(predicate, Sets.mutable.empty()).toImmutable(); } public

ImmutableSet rejectWith(Predicate2 predicate, P parameter) { return this.delegate.rejectWith(predicate, parameter, Sets.mutable.empty()).toImmutable(); } public PartitionImmutableSet partition(Predicate predicate) { PartitionMutableSet result = new PartitionUnifiedSet(); this.inverse.forEachKey(new PartitionProcedure(predicate, result)); return result.toImmutable(); } public

PartitionImmutableSet partitionWith(Predicate2 predicate, P parameter) { return this.partition(Predicates.bind(predicate, parameter)); } public ImmutableSet> zip(Iterable that) { return this.delegate.zip(that, new UnifiedSet>()).toImmutable(); } public ImmutableSet> zipWithIndex() { return this.delegate.zipWithIndex(new UnifiedSet>()).toImmutable(); } public ImmutableSetMultimap groupBy(Function function) { return this.delegate.groupBy(function, new UnifiedSetMultimap()).toImmutable(); } public ImmutableSetMultimap groupByEach(Function> function) { return this.delegate.groupByEach(function, new UnifiedSetMultimap()).toImmutable(); } public ImmutableBiMap groupByUniqueKey(Function function) { return BiMaps.immutable.withAll(this.delegate.groupByUniqueKey(function)); } public ImmutableMap aggregateBy(Function groupBy, Function0 zeroValueFactory, Function2 nonMutatingAggregator) { return this.delegate.aggregateBy(groupBy, zeroValueFactory, nonMutatingAggregator); } public ImmutableMap aggregateInPlaceBy(Function groupBy, Function0 zeroValueFactory, Procedure2 mutatingAggregator) { return this.delegate.aggregateInPlaceBy(groupBy, zeroValueFactory, mutatingAggregator); } public ImmutableSet selectInstancesOf(Class clazz) { MutableSet result = new UnifiedSet(); this.inverse.forEachKey(new SelectInstancesOfProcedure(clazz, result)); return result.toImmutable(); } private static class Inverse extends AbstractImmutableBiMap implements Serializable { Inverse(ImmutableMap delegate, AbstractImmutableBiMap inverse) { super(delegate, inverse); } protected Object writeReplace() { return new ImmutableBiMapSerializationProxy(this); } } }