com.helger.commons.collection.ContainerConversionHelper Maven / Gradle / Ivy
/**
* Copyright (C) 2014-2015 Philip Helger (www.helger.com)
* philip[at]helger[dot]com
*
* 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.helger.commons.collection;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Set;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import javax.annotation.concurrent.Immutable;
import com.helger.commons.ValueEnforcer;
import com.helger.commons.annotation.PresentForCodeCoverage;
import com.helger.commons.annotation.ReturnsImmutableObject;
import com.helger.commons.annotation.ReturnsMutableCopy;
import com.helger.commons.convert.IConverter;
import com.helger.commons.filter.IFilter;
/**
* This utility class helps applying conversions onto collections.
*
* @author Philip Helger
*/
@Immutable
public final class ContainerConversionHelper
{
@PresentForCodeCoverage
private static final ContainerConversionHelper s_aInstance = new ContainerConversionHelper ();
private ContainerConversionHelper ()
{}
@Nonnull
@ReturnsMutableCopy
public static Set newSet (@Nonnull final Iterator extends SRCTYPE> it,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
final Set ret = new HashSet ();
while (it.hasNext ())
ret.add (aConverter.convert (it.next ()));
return ret;
}
@Nonnull
@ReturnsMutableCopy
public static Set newSet (@Nonnull final Iterable extends SRCTYPE> aCont,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
final Set ret = new HashSet ();
for (final SRCTYPE aValue : aCont)
ret.add (aConverter.convert (aValue));
return ret;
}
@Nonnull
@ReturnsMutableCopy
public static Set newSet (@Nonnull final Iterable extends SRCTYPE> aCont,
@Nonnull final IFilter super SRCTYPE> aFilter,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
final Set ret = new HashSet ();
for (final SRCTYPE aIn : aCont)
if (aFilter.matchesFilter (aIn))
ret.add (aConverter.convert (aIn));
return ret;
}
@Nonnull
@ReturnsImmutableObject
public static Set newUnmodifiableSet (@Nonnull final Iterator extends SRCTYPE> it,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
return CollectionHelper.makeUnmodifiable (newSet (it, aConverter));
}
@Nonnull
@ReturnsImmutableObject
public static Set newUnmodifiableSet (@Nonnull final Iterable extends SRCTYPE> aCont,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
return CollectionHelper.makeUnmodifiable (newSet (aCont, aConverter));
}
@Nonnull
@ReturnsImmutableObject
public static Set newUnmodifiableSet (@Nonnull final Iterable extends SRCTYPE> aCont,
@Nonnull final IFilter super SRCTYPE> aFilter,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
return CollectionHelper.makeUnmodifiable (ContainerConversionHelper. newSet (aCont,
aFilter,
aConverter));
}
@Nonnull
@ReturnsMutableCopy
public static Set newOrderedSet (@Nonnull final Iterator extends SRCTYPE> it,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
final Set ret = new LinkedHashSet ();
while (it.hasNext ())
ret.add (aConverter.convert (it.next ()));
return ret;
}
@Nonnull
@ReturnsMutableCopy
public static Set newOrderedSet (@Nonnull final Iterable extends SRCTYPE> aCont,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
final Set ret = new LinkedHashSet ();
for (final SRCTYPE aValue : aCont)
ret.add (aConverter.convert (aValue));
return ret;
}
@Nonnull
@ReturnsMutableCopy
public static Set newOrderedSet (@Nonnull final Iterable extends SRCTYPE> aCont,
@Nonnull final IFilter super SRCTYPE> aFilter,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
final Set ret = new LinkedHashSet ();
for (final SRCTYPE aIn : aCont)
if (aFilter.matchesFilter (aIn))
ret.add (aConverter.convert (aIn));
return ret;
}
@Nonnull
@ReturnsImmutableObject
public static Set newUnmodifiableOrderedSet (@Nonnull final Iterator extends SRCTYPE> it,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
return CollectionHelper.makeUnmodifiable (newOrderedSet (it, aConverter));
}
@Nonnull
@ReturnsImmutableObject
public static Set newUnmodifiableOrderedSet (@Nonnull final Iterable extends SRCTYPE> aCont,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
return CollectionHelper.makeUnmodifiable (newOrderedSet (aCont, aConverter));
}
@Nonnull
@ReturnsImmutableObject
public static Set newUnmodifiableOrderedSet (@Nonnull final Iterable extends SRCTYPE> aCont,
@Nonnull final IFilter super SRCTYPE> aFilter,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
return CollectionHelper.makeUnmodifiable (ContainerConversionHelper. newOrderedSet (aCont,
aFilter,
aConverter));
}
@Nonnull
@ReturnsMutableCopy
public static List newList (@Nullable final Iterable extends SRCTYPE> aCont,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
final List ret = new ArrayList ();
if (aCont != null)
for (final SRCTYPE aIn : aCont)
ret.add (aConverter.convert (aIn));
return ret;
}
@Nonnull
@ReturnsMutableCopy
public static List newList (@Nullable final SRCTYPE [] aCont,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
final List ret = new ArrayList (ArrayHelper.getSize (aCont));
if (aCont != null)
for (final SRCTYPE aIn : aCont)
ret.add (aConverter.convert (aIn));
return ret;
}
@Nonnull
@ReturnsMutableCopy
public static List newList (@Nullable final Iterable extends SRCTYPE> aCont,
@Nonnull final IFilter super SRCTYPE> aFilter,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
final List ret = new ArrayList ();
if (aCont != null)
for (final SRCTYPE aIn : aCont)
if (aFilter.matchesFilter (aIn))
ret.add (aConverter.convert (aIn));
return ret;
}
@Nonnull
@ReturnsImmutableObject
public static List newUnmodifiableList (@Nullable final Iterable extends SRCTYPE> aCont,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
return CollectionHelper.makeUnmodifiable (newList (aCont, aConverter));
}
@Nonnull
@ReturnsImmutableObject
public static List newUnmodifiableList (@Nullable final SRCTYPE [] aCont,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
return CollectionHelper.makeUnmodifiable (newList (aCont, aConverter));
}
@Nonnull
@ReturnsImmutableObject
public static List newUnmodifiableList (@Nullable final Iterable extends SRCTYPE> aCont,
@Nonnull final IFilter super SRCTYPE> aFilter,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
return CollectionHelper.makeUnmodifiable (ContainerConversionHelper. newList (aCont,
aFilter,
aConverter));
}
/**
* Convert the given iterator to a sorted list.
*
* @param
* The type of elements to iterate (source).
* @param
* The type of elements to return (destination).
* @param it
* Input iterator. May not be null
.
* @param aConverter
* The converter to be used. May not be null
.
* @return a non-null {@link ArrayList} based on the results of
* {@link CollectionHelper#getSortedInline(List)}.
*/
@Nonnull
@ReturnsMutableCopy
public static > List getSorted (@Nonnull final Iterator extends SRCTYPE> it,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
ValueEnforcer.notNull (it, "Iterator");
ValueEnforcer.notNull (aConverter, "Converter");
final List ret = new ArrayList ();
while (it.hasNext ())
ret.add (aConverter.convert (it.next ()));
return CollectionHelper.getSortedInline (ret);
}
/**
* Convert the given iterator to a sorted list.
*
* @param
* The type of elements to iterate (source).
* @param
* The type of elements to return (destination).
* @param it
* Input iterator. May not be null
.
* @param aConverter
* The converter to be used. May not be null
.
* @param aComparator
* The comparator to use. May not be null
.
* @return a non-null {@link ArrayList} based on the results of
* {@link CollectionHelper#getSortedInline(List, Comparator)}.
*/
@Nonnull
@ReturnsMutableCopy
public static List getSorted (@Nonnull final Iterator extends SRCTYPE> it,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter,
@Nonnull final Comparator super DSTTYPE> aComparator)
{
ValueEnforcer.notNull (it, "Iterator");
ValueEnforcer.notNull (aConverter, "Converter");
ValueEnforcer.notNull (aComparator, "Comparator");
final List ret = new ArrayList ();
while (it.hasNext ())
ret.add (aConverter.convert (it.next ()));
return CollectionHelper.getSortedInline (ret, aComparator);
}
/**
* Convert the given iterator to a sorted list.
*
* @param
* The type of elements to iterate (source).
* @param
* The type of elements to return (destination).
* @param aCont
* Input container. May not be null
.
* @param aConverter
* The converter to be used. May not be null
.
* @return a non-null {@link ArrayList} based on the results of
* {@link CollectionHelper#getSortedInline(List)}.
*/
@Nonnull
@ReturnsMutableCopy
public static > List getSorted (@Nonnull final Iterable extends SRCTYPE> aCont,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
ValueEnforcer.notNull (aCont, "Container");
ValueEnforcer.notNull (aConverter, "Converter");
final List ret = new ArrayList ();
for (final SRCTYPE aSrc : aCont)
ret.add (aConverter.convert (aSrc));
return CollectionHelper.getSortedInline (ret);
}
/**
* Convert the given iterator to a sorted list.
*
* @param
* The type of elements to iterate (source).
* @param
* The type of elements to return (destination).
* @param aCont
* Input iterator. May not be null
.
* @param aConverter
* The converter to be used. May not be null
.
* @param aComparator
* The comparator to use. May not be null
.
* @return a non-null {@link ArrayList} based on the results of
* {@link CollectionHelper#getSortedInline(List, Comparator)}.
*/
@Nonnull
@ReturnsMutableCopy
public static List getSorted (@Nonnull final Iterable extends SRCTYPE> aCont,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter,
@Nonnull final Comparator super DSTTYPE> aComparator)
{
ValueEnforcer.notNull (aCont, "Container");
ValueEnforcer.notNull (aConverter, "Converter");
ValueEnforcer.notNull (aComparator, "Comparator");
final List ret = new ArrayList ();
for (final SRCTYPE aSrc : aCont)
ret.add (aConverter.convert (aSrc));
return CollectionHelper.getSortedInline (ret, aComparator);
}
@Nonnull
public static Iterator getIterator (@Nonnull final Iterable aCont,
@Nonnull final IConverter super SRCTYPE, ? extends DSTTYPE> aConverter)
{
ValueEnforcer.notNull (aCont, "Container");
ValueEnforcer.notNull (aConverter, "Converter");
return new Iterator ()
{
private final Iterator m_aIT = aCont.iterator ();
public boolean hasNext ()
{
return m_aIT.hasNext ();
}
public DSTTYPE next ()
{
return aConverter.convert (m_aIT.next ());
}
public void remove ()
{
m_aIT.remove ();
}
};
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy