com.gs.collections.impl.set.mutable.primitive.BooleanHashSet 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.mutable.primitive;
import java.io.Externalizable;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.util.NoSuchElementException;
import com.gs.collections.api.BooleanIterable;
import com.gs.collections.api.LazyBooleanIterable;
import com.gs.collections.api.bag.primitive.MutableBooleanBag;
import com.gs.collections.api.block.function.primitive.BooleanToObjectFunction;
import com.gs.collections.api.block.function.primitive.ObjectBooleanToObjectFunction;
import com.gs.collections.api.block.predicate.primitive.BooleanPredicate;
import com.gs.collections.api.block.procedure.primitive.BooleanProcedure;
import com.gs.collections.api.iterator.BooleanIterator;
import com.gs.collections.api.iterator.MutableBooleanIterator;
import com.gs.collections.api.list.primitive.MutableBooleanList;
import com.gs.collections.api.set.MutableSet;
import com.gs.collections.api.set.primitive.BooleanSet;
import com.gs.collections.api.set.primitive.ImmutableBooleanSet;
import com.gs.collections.api.set.primitive.MutableBooleanSet;
import com.gs.collections.impl.bag.mutable.primitive.BooleanHashBag;
import com.gs.collections.impl.block.factory.primitive.BooleanPredicates;
import com.gs.collections.impl.factory.primitive.BooleanSets;
import com.gs.collections.impl.lazy.primitive.LazyBooleanIterableAdapter;
import com.gs.collections.impl.list.mutable.primitive.BooleanArrayList;
import com.gs.collections.impl.set.mutable.UnifiedSet;
public class BooleanHashSet implements MutableBooleanSet, Externalizable
{
private static final long serialVersionUID = 1L;
// state = 0 ==> []
// state = 1 ==> [F]
// state = 2 ==> [T]
// state = 3 ==> [T, F]
private int state;
private static class EmptyBooleanIterator implements MutableBooleanIterator
{
public boolean next()
{
throw new NoSuchElementException();
}
public boolean hasNext()
{
return false;
}
public void remove()
{
throw new IllegalStateException();
}
}
private class FalseBooleanIterator implements MutableBooleanIterator
{
private int currentIndex;
public boolean hasNext()
{
return this.currentIndex == 0;
}
public boolean next()
{
if (this.currentIndex == 0)
{
this.currentIndex++;
return false;
}
this.currentIndex = -1;
throw new NoSuchElementException();
}
public void remove()
{
if (this.currentIndex == 0 || this.currentIndex == -1)
{
throw new IllegalStateException();
}
this.currentIndex = -1;
BooleanHashSet.this.remove(false);
}
}
private class TrueBooleanIterator implements MutableBooleanIterator
{
private int currentIndex;
public boolean hasNext()
{
return this.currentIndex == 0;
}
public boolean next()
{
if (this.currentIndex == 0)
{
this.currentIndex++;
return true;
}
this.currentIndex = -1;
throw new NoSuchElementException();
}
public void remove()
{
if (this.currentIndex == 0 || this.currentIndex == -1)
{
throw new IllegalStateException();
}
this.currentIndex = -1;
BooleanHashSet.this.remove(true);
}
}
private class FalseTrueBooleanIterator implements MutableBooleanIterator
{
private int currentIndex;
public boolean hasNext()
{
return this.currentIndex < 2;
}
public boolean next()
{
switch (this.currentIndex)
{
case 0:
this.currentIndex++;
return false;
case 1:
this.currentIndex++;
return true;
default:
throw new NoSuchElementException();
}
}
public void remove()
{
switch (this.currentIndex)
{
case 0:
throw new IllegalStateException();
case 1:
if (!BooleanHashSet.this.remove(false))
{
throw new IllegalStateException();
}
return;
case 2:
if (!BooleanHashSet.this.remove(true))
{
throw new IllegalStateException();
}
}
}
}
public BooleanHashSet()
{
}
public BooleanHashSet(BooleanHashSet set)
{
this.state = set.state;
}
public BooleanHashSet(boolean... elements)
{
this();
this.addAll(elements);
}
public static BooleanHashSet newSetWith(boolean... source)
{
return new BooleanHashSet(source);
}
public static BooleanHashSet newSet(BooleanIterable source)
{
if (source instanceof BooleanHashSet)
{
return new BooleanHashSet((BooleanHashSet) source);
}
return BooleanHashSet.newSetWith(source.toArray());
}
public boolean add(boolean element)
{
if (this.contains(element))
{
return false;
}
this.state |= element ? 2 : 1;
return true;
}
public boolean addAll(boolean... source)
{
int initialState = this.state;
for (boolean item : source)
{
if (this.state == 3)
{
return this.state != initialState;
}
this.add(item);
}
return this.state != initialState;
}
public boolean addAll(BooleanIterable source)
{
return this.addAll(source.toArray());
}
public boolean remove(boolean value)
{
if (!this.contains(value))
{
return false;
}
int initialState = this.state;
this.state &= value ? ~2 : ~1;
return initialState != this.state;
}
public boolean removeAll(BooleanIterable source)
{
if (this.isEmpty() || source.isEmpty())
{
return false;
}
boolean modified = false;
BooleanIterator iterator = source.booleanIterator();
while (iterator.hasNext())
{
if (this.state == 0)
{
return modified;
}
boolean item = iterator.next();
if (this.remove(item))
{
modified = true;
}
}
return modified;
}
public boolean removeAll(boolean... source)
{
if (this.isEmpty() || source.length == 0)
{
return false;
}
boolean modified = false;
for (boolean item : source)
{
if (this.state == 0)
{
return modified;
}
if (this.remove(item))
{
modified = true;
}
}
return modified;
}
public boolean retainAll(BooleanIterable source)
{
if (this.state == 0
|| (source.contains(true) && source.contains(false))
|| (this.state == 2 && source.contains(true))
|| (this.state == 1 && source.contains(false)))
{
return false;
}
if (source.contains(true))
{
this.state -= 1;
}
else if (source.contains(false))
{
this.state -= 2;
}
else
{
this.state = 0;
}
return true;
}
public boolean retainAll(boolean... source)
{
return this.retainAll(BooleanHashSet.newSetWith(source));
}
public void clear()
{
this.state = 0;
}
public MutableBooleanIterator booleanIterator()
{
switch (this.state)
{
case 0:
return new EmptyBooleanIterator();
case 1:
return new FalseBooleanIterator();
case 2:
return new TrueBooleanIterator();
case 3:
return new FalseTrueBooleanIterator();
default:
throw new AssertionError("Invalid state");
}
}
public void forEach(BooleanProcedure procedure)
{
this.each(procedure);
}
/**
* @since 7.0.
*/
public void each(BooleanProcedure procedure)
{
switch (this.state)
{
case 0:
return;
case 1:
procedure.value(false);
return;
case 2:
procedure.value(true);
return;
case 3:
procedure.value(false);
procedure.value(true);
return;
default:
throw new AssertionError("Invalid state");
}
}
public T injectInto(T injectedValue, ObjectBooleanToObjectFunction super T, ? extends T> function)
{
T result = injectedValue;
switch (this.state)
{
case 0:
return result;
case 1:
result = function.valueOf(result, false);
return result;
case 2:
result = function.valueOf(result, true);
return result;
case 3:
result = function.valueOf(result, false);
result = function.valueOf(result, true);
return result;
default:
throw new AssertionError("Invalid state");
}
}
public int count(BooleanPredicate predicate)
{
switch (this.state)
{
case 0:
return 0;
case 1:
return predicate.accept(false) ? 1 : 0;
case 2:
return predicate.accept(true) ? 1 : 0;
case 3:
int count = 0;
if (predicate.accept(false))
{
count++;
}
if (predicate.accept(true))
{
count++;
}
return count;
default:
throw new AssertionError("Invalid state");
}
}
public boolean anySatisfy(BooleanPredicate predicate)
{
return this.count(predicate) > 0;
}
public boolean allSatisfy(BooleanPredicate predicate)
{
return this.count(predicate) == this.size();
}
public boolean noneSatisfy(BooleanPredicate predicate)
{
return this.count(predicate) == 0;
}
public BooleanHashSet select(BooleanPredicate predicate)
{
BooleanHashSet set = new BooleanHashSet();
switch (this.state)
{
case 0:
return set;
case 1:
if (predicate.accept(false))
{
set.add(false);
}
return set;
case 2:
if (predicate.accept(true))
{
set.add(true);
}
return set;
case 3:
if (predicate.accept(false))
{
set.add(false);
}
if (predicate.accept(true))
{
set.add(true);
}
return set;
default:
throw new AssertionError("Invalid state");
}
}
public BooleanHashSet reject(BooleanPredicate predicate)
{
return this.select(BooleanPredicates.not(predicate));
}
public boolean detectIfNone(BooleanPredicate predicate, boolean ifNone)
{
switch (this.state)
{
case 0:
return ifNone;
case 1:
return !predicate.accept(false) && ifNone;
case 2:
return predicate.accept(true) || ifNone;
case 3:
if (predicate.accept(false))
{
return false;
}
if (predicate.accept(true))
{
return true;
}
return ifNone;
default:
throw new AssertionError("Invalid state");
}
}
public MutableSet collect(BooleanToObjectFunction extends V> function)
{
UnifiedSet target = UnifiedSet.newSet(this.size());
switch (this.state)
{
case 0:
return target;
case 1:
return target.with(function.valueOf(false));
case 2:
return target.with(function.valueOf(true));
case 3:
target.add(function.valueOf(false));
target.add(function.valueOf(true));
return target;
default:
throw new AssertionError("Invalid state");
}
}
public boolean[] toArray()
{
switch (this.state)
{
case 0:
return new boolean[0];
case 1:
return new boolean[]{false};
case 2:
return new boolean[]{true};
case 3:
return new boolean[]{false, true};
default:
throw new AssertionError("Invalid state");
}
}
public boolean contains(boolean value)
{
if (this.state == 3)
{
return true;
}
if (value)
{
return this.state == 2;
}
return this.state == 1;
}
public boolean containsAll(boolean... source)
{
if (this.state == 3)
{
return true;
}
for (boolean item : source)
{
if (!this.contains(item))
{
return false;
}
}
return true;
}
public boolean containsAll(BooleanIterable source)
{
if (this.state == 3)
{
return true;
}
for (BooleanIterator iterator = source.booleanIterator(); iterator.hasNext(); )
{
if (!this.contains(iterator.next()))
{
return false;
}
}
return true;
}
public BooleanHashSet with(boolean element)
{
if (this.state == 3)
{
return this;
}
this.add(element);
return this;
}
public BooleanHashSet without(boolean element)
{
if (this.state == 0)
{
return this;
}
this.remove(element);
return this;
}
public BooleanHashSet withAll(BooleanIterable elements)
{
if (this.state == 3)
{
return this;
}
this.addAll(elements.toArray());
return this;
}
public BooleanHashSet withoutAll(BooleanIterable elements)
{
if (this.state == 0)
{
return this;
}
this.removeAll(elements);
return this;
}
public MutableBooleanSet asUnmodifiable()
{
return new UnmodifiableBooleanSet(this);
}
public MutableBooleanSet asSynchronized()
{
return new SynchronizedBooleanSet(this);
}
public BooleanSet freeze()
{
return this.toImmutable();
}
public ImmutableBooleanSet toImmutable()
{
switch (this.state)
{
case 0:
return BooleanSets.immutable.with();
case 1:
return BooleanSets.immutable.with(false);
case 2:
return BooleanSets.immutable.with(true);
case 3:
return BooleanSets.immutable.with(false, true);
default:
throw new AssertionError("Invalid state");
}
}
public int size()
{
switch (this.state)
{
case 0:
return 0;
case 1:
case 2:
return 1;
case 3:
return 2;
default:
throw new AssertionError("Invalid state");
}
}
public boolean isEmpty()
{
return this.state == 0;
}
public boolean notEmpty()
{
return this.state != 0;
}
@Override
public boolean equals(Object obj)
{
if (this == obj)
{
return true;
}
if (!(obj instanceof BooleanSet))
{
return false;
}
BooleanSet other = (BooleanSet) obj;
return this.contains(false) == other.contains(false) && this.contains(true) == other.contains(true);
}
@Override
public int hashCode()
{
switch (this.state)
{
case 0:
return 0;
case 1:
return 1237;
case 2:
return 1231;
case 3:
return 2468;
default:
throw new AssertionError("Invalid state");
}
}
@Override
public String toString()
{
return this.makeString("[", ", ", "]");
}
public String makeString()
{
return this.makeString(", ");
}
public String makeString(String separator)
{
return this.makeString("", separator, "");
}
public String makeString(String start, String separator, String end)
{
Appendable stringBuilder = new StringBuilder();
this.appendString(stringBuilder, start, separator, end);
return stringBuilder.toString();
}
public void appendString(Appendable appendable)
{
this.appendString(appendable, ", ");
}
public void appendString(Appendable appendable, String separator)
{
this.appendString(appendable, "", separator, "");
}
public void appendString(Appendable appendable, String start, String separator, String end)
{
try
{
appendable.append(start);
switch (this.state)
{
case 0:
break;
case 1:
appendable.append(String.valueOf(false));
break;
case 2:
appendable.append(String.valueOf(true));
break;
case 3:
appendable.append(String.valueOf(false));
appendable.append(separator);
appendable.append(String.valueOf(true));
break;
default:
throw new AssertionError("Invalid state");
}
appendable.append(end);
}
catch (IOException e)
{
throw new RuntimeException(e);
}
}
public MutableBooleanList toList()
{
return BooleanArrayList.newList(this);
}
public MutableBooleanSet toSet()
{
return BooleanHashSet.newSet(this);
}
public MutableBooleanBag toBag()
{
return BooleanHashBag.newBag(this);
}
public LazyBooleanIterable asLazy()
{
return new LazyBooleanIterableAdapter(this);
}
public void writeExternal(ObjectOutput out) throws IOException
{
out.writeInt(this.size());
switch (this.state)
{
case 0:
return;
case 1:
out.writeBoolean(false);
return;
case 2:
out.writeBoolean(true);
return;
case 3:
out.writeBoolean(false);
out.writeBoolean(true);
return;
default:
throw new AssertionError("Invalid state");
}
}
public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException
{
int size = in.readInt();
for (int i = 0; i < size; i++)
{
this.add(in.readBoolean());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy