org.eclipse.collections.impl.set.fixed.DoubletonSet Maven / Gradle / Ivy
/*
* Copyright (c) 2015 Goldman Sachs.
* 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.impl.set.fixed;
import java.io.Externalizable;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.util.Iterator;
import java.util.NoSuchElementException;
import java.util.Set;
import net.jcip.annotations.NotThreadSafe;
import org.eclipse.collections.api.block.procedure.Procedure;
import org.eclipse.collections.api.block.procedure.Procedure2;
import org.eclipse.collections.api.block.procedure.primitive.ObjectIntProcedure;
import org.eclipse.collections.api.set.MutableSet;
import org.eclipse.collections.impl.block.factory.Comparators;
@NotThreadSafe
final class DoubletonSet
extends AbstractMemoryEfficientMutableSet
implements Externalizable
{
private static final long serialVersionUID = 1L;
private T element1;
private T element2;
@SuppressWarnings("UnusedDeclaration")
public DoubletonSet()
{
// For Externalizable use only
}
DoubletonSet(T obj1, T obj2)
{
this.element1 = obj1;
this.element2 = obj2;
}
public int size()
{
return 2;
}
@Override
public boolean equals(Object o)
{
if (o == this)
{
return true;
}
if (!(o instanceof Set))
{
return false;
}
Set> collection = (Set>) o;
return collection.size() == this.size() && collection.contains(this.element1) && collection.contains(this.element2);
}
@Override
public int hashCode()
{
return this.nullSafeHashCode(this.element1) + this.nullSafeHashCode(this.element2);
}
// Weird implementation of clone() is ok on final classes
@Override
public DoubletonSet clone()
{
return new DoubletonSet(this.element1, this.element2);
}
@Override
public boolean contains(Object obj)
{
return Comparators.nullSafeEquals(obj, this.element1)
|| Comparators.nullSafeEquals(obj, this.element2);
}
public Iterator iterator()
{
return new DoubletonSetIterator();
}
public T getFirst()
{
return this.element1;
}
public T getLast()
{
return this.element2;
}
public void each(Procedure super T> procedure)
{
procedure.value(this.element1);
procedure.value(this.element2);
}
@Override
public void forEachWithIndex(ObjectIntProcedure super T> objectIntProcedure)
{
objectIntProcedure.value(this.element1, 0);
objectIntProcedure.value(this.element2, 1);
}
@Override
public void forEachWith(Procedure2 super T, ? super P> procedure, P parameter)
{
procedure.value(this.element1, parameter);
procedure.value(this.element2, parameter);
}
public void writeExternal(ObjectOutput out) throws IOException
{
out.writeObject(this.element1);
out.writeObject(this.element2);
}
public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException
{
this.element1 = (T) in.readObject();
this.element2 = (T) in.readObject();
}
private class DoubletonSetIterator
extends MemoryEfficientSetIterator
{
@Override
protected T getElement(int i)
{
if (i == 0)
{
return DoubletonSet.this.element1;
}
if (i == 1)
{
return DoubletonSet.this.element2;
}
throw new NoSuchElementException("i=" + i);
}
}
public MutableSet with(T element)
{
return this.contains(element) ? this : new TripletonSet(this.element1, this.element2, element);
}
public MutableSet without(T element)
{
if (Comparators.nullSafeEquals(element, this.element1))
{
return new SingletonSet(this.element2);
}
if (Comparators.nullSafeEquals(element, this.element2))
{
return new SingletonSet(this.element1);
}
return this;
}
}