All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.javagimmicks.collections8.builder.CollectionBuilder Maven / Gradle / Ivy

There is a newer version: 0.99-alpha1
Show newest version
package net.sf.javagimmicks.collections8.builder;

import java.util.Arrays;
import java.util.Collection;
import java.util.Comparator;
import java.util.HashSet;
import java.util.Set;
import java.util.TreeSet;
import java.util.function.Supplier;

/**
 * A builder class for building {@link Collection}s and {@link Set}s using a
 * fluent API with one chained call.
 * 
 * @param 
 *           the type of elements the resulting {@link Collection} can carry
 * @param 
 *           the type of the produced {@link Collection}
 */
public class CollectionBuilder> implements Supplier
{
   protected final T _internalCollection;

   /**
    * Wraps a new {@link CollectionBuilder} around the given {@link Collection}
    * 
    * @param internalCollection
    *           the {@link Collection} to wrap a new {@link CollectionBuilder}
    *           around
    * @param 
    *           the type of elements the resulting {@link Collection} can carry
    * @param 
    *           the type of the produced {@link Collection}
    * @return the resulting {@link CollectionBuilder}
    */
   public static > CollectionBuilder create(final T internalCollection)
   {
      return new CollectionBuilder(internalCollection);
   }

   /**
    * Creates a new {@link CollectionBuilder} for building a new {@link HashSet}
    * 
    * @param 
    *           the type of elements the resulting {@link HashSet} can carry
    * @return the resulting {@link CollectionBuilder}
    */
   public static  CollectionBuilder> createHashSet()
   {
      return create(new HashSet());
   }

   /**
    * Creates a new {@link CollectionBuilder} for building a new {@link TreeSet}
    * 
    * @param 
    *           the type of elements the resulting {@link TreeSet} can carry
    * 
    * @return the resulting {@link CollectionBuilder}
    */
   public static  CollectionBuilder> createTreeSet()
   {
      return create(new TreeSet());
   }

   /**
    * Creates a new {@link CollectionBuilder} for building a new {@link TreeSet}
    * based on a given {@link Comparator}
    * 
    * @param comparator
    *           the {@link Comparator} to use in the underlying {@link TreeSet}
    * @param 
    *           the type of elements the resulting {@link TreeSet} can carry
    * @return the resulting {@link CollectionBuilder}
    */
   public static  CollectionBuilder> createTreeSet(final Comparator comparator)
   {
      return create(new TreeSet(comparator));
   }

   /**
    * Creates a new {@link CollectionBuilder} around a given internal
    * {@link Collection}
    * 
    * @param internalCollection
    *           the {@link Collection} to wrap around
    */
   public CollectionBuilder(final T internalCollection)
   {
      _internalCollection = internalCollection;
   }

   /**
    * Calls {@link Collection#add(Object)} on the underlying {@link Collection}
    * and returns itself
    * 
    * @param e
    *           the element to add
    * @return the {@link CollectionBuilder} itself
    * @see Collection#add(Object)
    */
   public CollectionBuilder add(final E e)
   {
      _internalCollection.add(e);
      return this;
   }

   /**
    * Calls {@link Collection#addAll(Collection)} on the underlying
    * {@link Collection} and returns itself
    * 
    * @param c
    *           the {@link Collection} whose elements should be added
    * @return the {@link CollectionBuilder} itself
    * @see Collection#addAll(Collection)
    */
   public CollectionBuilder addAll(final Collection c)
   {
      _internalCollection.addAll(c);
      return this;
   }

   /**
    * Adds any number of elements given as a variable argument list to the
    * underlying {@link Collection} and returns itself
    * 
    * @param elements
    *           the list of elements to add
    * @return the {@link CollectionBuilder} itself
    * @see #addAll(Collection)
    */
   @SuppressWarnings("unchecked")
   public CollectionBuilder addAll(final E... elements)
   {
      return addAll(Arrays.asList(elements));
   }

   /**
    * Calls {@link Collection#remove(Object)} on the underlying
    * {@link Collection} and returns itself
    * 
    * @param o
    *           the element to remove from the underlying {@link Collection}
    * @return the {@link CollectionBuilder} itself
    * @see Collection#remove(Object)
    */
   public CollectionBuilder remove(final Object o)
   {
      _internalCollection.remove(o);
      return this;
   }

   /**
    * Calls {@link Collection#removeAll(Collection)} on the underlying
    * {@link Collection} and returns itself
    * 
    * @param c
    *           the {@link Collection} of elements to remove from the underlying
    *           {@link Collection}
    * @return the {@link CollectionBuilder} itself
    * @see Collection#removeAll(Collection)
    */
   public CollectionBuilder removeAll(final Collection c)
   {
      _internalCollection.removeAll(c);
      return this;
   }

   /**
    * Removes any number of elements given as a variable argument list from the
    * underlying {@link Collection} and returns itself
    * 
    * @param elements
    *           the list of elements to remove
    * @return the {@link CollectionBuilder} itself
    * @see #removeAll(Collection)
    */
   @SuppressWarnings("unchecked")
   public CollectionBuilder removeAll(final E... elements)
   {
      return removeAll(Arrays.asList(elements));
   }

   /**
    * Calls {@link Collection#retainAll(Collection)} on the underlying
    * {@link Collection} and returns itself
    * 
    * @param c
    *           the {@link Collection} of elements to retain in the underlying
    *           {@link Collection}
    * @return the {@link CollectionBuilder} itself
    * @see Collection#retainAll(Collection)
    */
   public CollectionBuilder retainAll(final Collection c)
   {
      _internalCollection.retainAll(c);
      return this;
   }

   /**
    * Retains any number of elements given as a variable argument list in the
    * underlying {@link Collection} and returns itself
    * 
    * @param elements
    *           the list of elements to retain
    * @return the {@link CollectionBuilder} itself
    * @see #retainAll(Collection)
    */
   @SuppressWarnings("unchecked")
   public CollectionBuilder retainAll(final E... elements)
   {
      return retainAll(Arrays.asList(elements));
   }

   /**
    * Calls {@link Collection#clear()} on the underlying {@link Collection} and
    * returns itself
    * 
    * @return the {@link CollectionBuilder} itself
    * @see Collection#clear()
    */
   public CollectionBuilder clear()
   {
      _internalCollection.clear();
      return this;
   }

   /**
    * Returns the underlying {@link Collection}
    * 
    * @return the underlying {@link Collection}
    */
   @Override
   public T get()
   {
      return _internalCollection;
   }

   @Override
   public String toString()
   {
      return _internalCollection.toString();
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy