
org.eclipse.collections.api.multimap.MutableMultimap Maven / Gradle / Ivy
/*
* 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 extends V> values);
boolean putAll(Multimap multimap);
RichIterable replaceValues(K key, Iterable extends V> values);
RichIterable removeAll(Object key);
void clear();
@Override
MutableMultimap flip();
@Override
MutableMultimap selectKeysValues(Predicate2 super K, ? super V> predicate);
@Override
MutableMultimap rejectKeysValues(Predicate2 super K, ? super V> predicate);
@Override
MutableMultimap selectKeysMultiValues(Predicate2 super K, ? super Iterable> predicate);
@Override
MutableMultimap rejectKeysMultiValues(Predicate2 super K, ? super Iterable> predicate);
@Override
MutableMultimap collectKeysValues(Function2 super K, ? super V, Pair> function);
@Override
MutableMultimap collectValues(Function super V, ? extends V2> 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