/*
 * Copyright (c) 2019 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.factory.bag;

import java.util.stream.Stream;

import org.eclipse.collections.api.bag.MutableBag;
import org.eclipse.collections.api.tuple.primitive.ObjectIntPair;

A factory which creates instances of type MutableBag.
/** * A factory which creates instances of type {@link MutableBag}. */
public interface MutableBagFactory {
Since:6.0
/** * @since 6.0 */
<T> MutableBag<T> empty();
Same as empty().
/** * Same as {@link #empty()}. */
default <T> MutableBag<T> of() { return this.empty(); }
Same as empty().
/** * Same as {@link #empty()}. */
default <T> MutableBag<T> with() { return this.empty(); }
Same as with(Object[]).
/** * Same as {@link #with(Object[])}. */
default <T> MutableBag<T> of(T... elements) { return this.with(elements); }
Since:10.3
/** * Same as {@link #withOccurrences(Object, int)}. * * @since 10.3 */
default <T> MutableBag<T> ofOccurrences(T element, int occurrence) { return this.withOccurrences(element, occurrence); }
Since:10.3
/** * Same as {@link #withOccurrences(Object, int, Object, int)}. * * @since 10.3 */
default <T> MutableBag<T> ofOccurrences(T element1, int occurrence1, T element2, int occurrence2) { return this.withOccurrences(element1, occurrence1, element2, occurrence2); }
Since:10.3
/** * Same as {@link #withOccurrences(Object, int, Object, int, Object, int)}. * * @since 10.3 */
default <T> MutableBag<T> ofOccurrences(T element1, int occurrence1, T element2, int occurrence2, T element3, int occurrence3) { return this.withOccurrences(element1, occurrence1, element2, occurrence2, element3, occurrence3); }
Since:10.3
/** * Same as {@link #withOccurrences(Object, int, Object, int, Object, int, Object, int)}. * * @since 10.3 */
default <T> MutableBag<T> ofOccurrences(T element1, int occurrence1, T element2, int occurrence2, T element3, int occurrence3, T element4, int occurrence4) { return this.withOccurrences(element1, occurrence1, element2, occurrence2, element3, occurrence3, element4, occurrence4); } /** * Same as {@link #withOccurrences(ObjectIntPair[])}. * * @since 10.3 */ default <T> MutableBag<T> ofOccurrences(ObjectIntPair<T>... elementsWithOccurrences) { return this.withOccurrences(elementsWithOccurrences); } <T> MutableBag<T> with(T... elements);
Since:10.3
/** * @since 10.3 */
default <T> MutableBag<T> withOccurrences(T element, int occurrence) { MutableBag<T> bag = this.empty(); bag.addOccurrences(element, occurrence); return bag; }
Since:10.3
/** * @since 10.3 */
default <T> MutableBag<T> withOccurrences(T element1, int occurrence1, T element2, int occurrence2) { MutableBag<T> bag = this.empty(); bag.addOccurrences(element1, occurrence1); bag.addOccurrences(element2, occurrence2); return bag; }
Since:10.3
/** * @since 10.3 */
default <T> MutableBag<T> withOccurrences(T element1, int occurrence1, T element2, int occurrence2, T element3, int occurrence3) { MutableBag<T> bag = this.empty(); bag.addOccurrences(element1, occurrence1); bag.addOccurrences(element2, occurrence2); bag.addOccurrences(element3, occurrence3); return bag; }
Since:10.3
/** * @since 10.3 */
default <T> MutableBag<T> withOccurrences(T element1, int occurrence1, T element2, int occurrence2, T element3, int occurrence3, T element4, int occurrence4) { MutableBag<T> bag = this.empty(); bag.addOccurrences(element1, occurrence1); bag.addOccurrences(element2, occurrence2); bag.addOccurrences(element3, occurrence3); bag.addOccurrences(element4, occurrence4); return bag; }
Since:10.3
/** * @since 10.3 */
default <T> MutableBag<T> withOccurrences(ObjectIntPair<T>... elementsWithOccurrences) { MutableBag<T> bag = this.empty(); for (ObjectIntPair<T> itemToAdd : elementsWithOccurrences) { bag.addOccurrences(itemToAdd.getOne(), itemToAdd.getTwo()); } return bag; } /** * Same as {@link #withAll(Iterable)}. */ default <T> MutableBag<T> ofAll(Iterable<? extends T> items) { return this.withAll(items); } <T> MutableBag<T> withAll(Iterable<? extends T> items);
Since:10.0.
/** * @since 10.0. */
<T> MutableBag<T> fromStream(Stream<? extends T> stream); }