/*
 * Copyright (c) 2008 Harold Cooper. All rights reserved.
 * Licensed under the MIT License.
 * See LICENSE file in the project root for full license information.
 */

package org.pcollections;

import java.io.Serializable;
import java.util.AbstractSet;
import java.util.Collection;
import java.util.Iterator;

A map-backed persistent set.

If the backing map is thread-safe, then this implementation is thread-safe (assuming Java's AbstractSet is thread-safe), although its iterators may not be.

Author:harold
Type parameters:
  • <E> –
/** * A map-backed persistent set. * * <p>If the backing map is thread-safe, then this implementation is thread-safe (assuming Java's * AbstractSet is thread-safe), although its iterators may not be. * * @author harold * @param <E> */
public final class MapPSet<E> extends AbstractSet<E> implements PSet<E>, Serializable { private static final long serialVersionUID = 1L; //// STATIC FACTORY METHODS ////
Params:
  • map –
Type parameters:
  • <E> –
Returns:a PSet with the elements of map.keySet(), backed by map
/** * @param <E> * @param map * @return a PSet with the elements of map.keySet(), backed by map */
@SuppressWarnings("unchecked") public static <E> MapPSet<E> from(final PMap<E, ?> map) { return new MapPSet<E>((PMap<E, Object>) map); }
Params:
  • map –
  • e –
Type parameters:
  • <E> –
Returns:from(map).plus(e)
/** * @param <E> * @param map * @param e * @return from(map).plus(e) */
public static <E> MapPSet<E> from(final PMap<E, ?> map, E e) { return from(map).plus(e); }
Params:
  • map –
  • list –
Type parameters:
  • <E> –
Returns:from(map).plusAll(list)
/** * @param <E> * @param map * @param list * @return from(map).plusAll(list) */
public static <E> MapPSet<E> from(final PMap<E, ?> map, final Collection<? extends E> list) { return from(map).plusAll(list); } //// PRIVATE CONSTRUCTORS //// private final PMap<E, Object> map; // not instantiable (or subclassable): private MapPSet(final PMap<E, Object> map) { this.map = map; } //// REQUIRED METHODS FROM AbstractSet //// @Override public Iterator<E> iterator() { return map.keySet().iterator(); } @Override public int size() { return map.size(); } //// OVERRIDDEN METHODS OF AbstractSet //// @Override public boolean contains(final Object e) { return map.containsKey(e); } //// IMPLEMENTED METHODS OF PSet //// private static enum In { IN } public MapPSet<E> plus(final E e) { if (contains(e)) return this; return new MapPSet<E>(map.plus(e, In.IN)); } public MapPSet<E> minus(final Object e) { if (!contains(e)) return this; return new MapPSet<E>(map.minus(e)); } public MapPSet<E> plusAll(final Collection<? extends E> list) { PMap<E, Object> map = this.map; for (E e : list) map = map.plus(e, In.IN); return from(map); } public MapPSet<E> minusAll(final Collection<?> list) { PMap<E, Object> map = this.map.minusAll(list); return from(map); } }