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

org.eclipse.collections.api.multimap.MutableMultimap Maven / Gradle / Ivy

There is a newer version: 12.0.0.M3
Show newest version
/*
 * Copyright (c) 2016 Goldman Sachs and others.
 * 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.api.multimap;

import org.eclipse.collections.api.RichIterable;
import org.eclipse.collections.api.block.function.Function;
import org.eclipse.collections.api.block.function.Function2;
import org.eclipse.collections.api.block.predicate.Predicate2;
import org.eclipse.collections.api.collection.MutableCollection;
import org.eclipse.collections.api.tuple.Pair;

/**
 * @since 1.0
 */
public interface MutableMultimap
        extends Multimap
{
    @Override
    MutableMultimap newEmpty();

    @Override
    MutableCollection get(K key);

    // Modification Operations

    boolean put(K key, V value);

    /**
     * Modification operation similar to put, however, takes the key-value pair as the input.
     *
     * @param keyValuePair
     *         key value pair to add in the multimap
     * @see #put(Object, Object)
     * @since 6.0
     */
    default boolean add(Pair keyValuePair)
    {
        return this.put(keyValuePair.getOne(), keyValuePair.getTwo());
    }

    boolean remove(Object key, Object value);

    // Bulk Operations
    default boolean putAllPairs(Pair... pairs)
    {
        boolean changed = false;
        for (Pair pair : pairs)
        {
            changed |= this.put(pair.getOne(), pair.getTwo());
        }
        return changed;
    }

    default boolean putAllPairs(Iterable> pairs)
    {
        boolean changed = false;
        for (Pair pair : pairs)
        {
            changed |= this.put(pair.getOne(), pair.getTwo());
        }
        return changed;
    }

    boolean putAll(K key, Iterable values);

     boolean putAll(Multimap multimap);

    RichIterable replaceValues(K key, Iterable values);

    RichIterable removeAll(Object key);

    void clear();

    @Override
    MutableMultimap flip();

    @Override
    MutableMultimap selectKeysValues(Predicate2 predicate);

    @Override
    MutableMultimap rejectKeysValues(Predicate2 predicate);

    @Override
    MutableMultimap selectKeysMultiValues(Predicate2> predicate);

    @Override
    MutableMultimap rejectKeysMultiValues(Predicate2> predicate);

    @Override
     MutableMultimap collectKeysValues(Function2> function);

    @Override
     MutableMultimap collectValues(Function function);

    /**
     * Returns a synchronized (thread-safe) multimap backed by this multimap.  In order to guarantee serial access,
     * it is critical that all access to the backing multimap is accomplished through the returned
     * multimap.
     * 

* The returned multimap does not pass the hashCode and equals operations through to the * backing multimap, but relies on Object's equals and hashCode methods. This is necessary to preserve * the contracts of these operations. *

* The returned multimap will be serializable if this multimap is serializable. * * @return a synchronized view of this multimap. * @since 8.0 */ MutableMultimap asSynchronized(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy