package org.eclipse.collections.impl.set.strategy.immutable;
import java.io.Serializable;
import java.util.Iterator;
import java.util.concurrent.ExecutorService;
import org.eclipse.collections.api.block.HashingStrategy;
import org.eclipse.collections.api.block.procedure.Procedure;
import org.eclipse.collections.api.set.ImmutableSet;
import org.eclipse.collections.api.set.ParallelUnsortedSetIterable;
import org.eclipse.collections.impl.UnmodifiableIteratorAdapter;
import org.eclipse.collections.impl.parallel.BatchIterable;
import org.eclipse.collections.impl.set.immutable.AbstractImmutableSet;
import org.eclipse.collections.impl.set.strategy.mutable.UnifiedSetWithHashingStrategy;
final class ImmutableUnifiedSetWithHashingStrategy<T>
extends AbstractImmutableSet<T>
implements Serializable, BatchIterable<T>
{
private static final long serialVersionUID = 1L;
private final UnifiedSetWithHashingStrategy<T> delegate;
private ImmutableUnifiedSetWithHashingStrategy(UnifiedSetWithHashingStrategy<T> delegate)
{
this.delegate = delegate;
}
public static <T> ImmutableSet<T> newSetWith(HashingStrategy<? super T> hashingStrategy, T... elements)
{
return new ImmutableUnifiedSetWithHashingStrategy<>(UnifiedSetWithHashingStrategy.newSetWith(hashingStrategy, elements));
}
public static <T> ImmutableSet<T> newSet(HashingStrategy<? super T> hashingStrategy, Iterable<T> iterable)
{
return new ImmutableUnifiedSetWithHashingStrategy<>(UnifiedSetWithHashingStrategy.newSet(hashingStrategy, iterable));
}
@Override
public int size()
{
return this.delegate.size();
}
@Override
public boolean equals(Object other)
{
return this.delegate.equals(other);
}
@Override
public int hashCode()
{
return this.delegate.hashCode();
}
@Override
public boolean contains(Object object)
{
return this.delegate.contains(object);
}
@Override
public Iterator<T> iterator()
{
return new UnmodifiableIteratorAdapter<>(this.delegate.iterator());
}
@Override
public T getFirst()
{
return this.delegate.getFirst();
}
@Override
public T getLast()
{
return this.delegate.getLast();
}
@Override
public T getOnly()
{
return this.delegate.getOnly();
}
@Override
public void each(Procedure<? super T> procedure)
{
this.delegate.forEach(procedure);
}
@Override
public int getBatchCount(int batchSize)
{
return this.delegate.getBatchCount(batchSize);
}
@Override
public void batchForEach(Procedure<? super T> procedure, int sectionIndex, int sectionCount)
{
this.delegate.batchForEach(procedure, sectionIndex, sectionCount);
}
private Object writeReplace()
{
return new ImmutableSetWithHashingStrategySerializationProxy<>(this, this.delegate.hashingStrategy());
}
@Override
public ParallelUnsortedSetIterable<T> asParallel(ExecutorService executorService, int batchSize)
{
return this.delegate.asParallel(executorService, batchSize);
}
}