com.gs.collections.impl.set.strategy.immutable.ImmutableUnifiedSetWithHashingStrategy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gs-collections Show documentation
Show all versions of gs-collections Show documentation
GS Collections is a collections framework for Java. It has JDK-compatible List, Set and Map
implementations with a rich API and set of utility classes that work with any JDK compatible Collections,
Arrays, Maps or Strings. The iteration protocol was inspired by the Smalltalk collection framework.
/*
* Copyright 2015 Goldman Sachs.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.gs.collections.impl.set.strategy.immutable;
import java.io.Serializable;
import java.util.Iterator;
import java.util.concurrent.ExecutorService;
import com.gs.collections.api.block.HashingStrategy;
import com.gs.collections.api.block.procedure.Procedure;
import com.gs.collections.api.set.ImmutableSet;
import com.gs.collections.api.set.ParallelUnsortedSetIterable;
import com.gs.collections.impl.UnmodifiableIteratorAdapter;
import com.gs.collections.impl.parallel.BatchIterable;
import com.gs.collections.impl.set.immutable.AbstractImmutableSet;
import com.gs.collections.impl.set.strategy.mutable.UnifiedSetWithHashingStrategy;
import net.jcip.annotations.Immutable;
@Immutable
final class ImmutableUnifiedSetWithHashingStrategy
extends AbstractImmutableSet
implements Serializable, BatchIterable
{
private static final long serialVersionUID = 1L;
private final UnifiedSetWithHashingStrategy delegate;
private ImmutableUnifiedSetWithHashingStrategy(UnifiedSetWithHashingStrategy delegate)
{
this.delegate = delegate;
}
public static ImmutableSet newSetWith(HashingStrategy super T> hashingStrategy, T... elements)
{
return new ImmutableUnifiedSetWithHashingStrategy(UnifiedSetWithHashingStrategy.newSetWith(hashingStrategy, elements));
}
public static ImmutableSet newSet(HashingStrategy super T> hashingStrategy, Iterable iterable)
{
return new ImmutableUnifiedSetWithHashingStrategy(UnifiedSetWithHashingStrategy.newSet(hashingStrategy, iterable));
}
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);
}
public Iterator iterator()
{
return new UnmodifiableIteratorAdapter(this.delegate.iterator());
}
public T getFirst()
{
return this.delegate.getFirst();
}
public T getLast()
{
return this.delegate.getLast();
}
public void each(Procedure super T> procedure)
{
this.delegate.forEach(procedure);
}
public int getBatchCount(int batchSize)
{
return this.delegate.getBatchCount(batchSize);
}
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 asParallel(ExecutorService executorService, int batchSize)
{
return this.delegate.asParallel(executorService, batchSize);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy