Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
  /*
  * JBoss, Home of Professional Open Source
  * Copyright 2010, Red Hat Middleware LLC, and individual contributors
  * by the @authors tag. See the copyright.txt in the distribution for a
  * full listing of individual contributors.
  *
  * 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 org.hibernate.validator.internal.util;
 
 import java.util.List;
 import java.util.Map;
 import java.util.Set;
Provides some methods for simplified collection instantiation.

Author(s):
Gunnar Morling
Kevin Pollet <kevin.pollet@serli.com> (C) 2011 SERLI
Hardy Ferentschik
 
 public final class CollectionHelper {
 
 	private CollectionHelper() {
 	}
 
 	public static <K, V> HashMap<K, V> newHashMap() {
 		return new HashMap<K, V>();
 	}
 
 	public static <K, V> HashMap<K, V> newHashMap(int size) {
 		return new HashMap<K, V>( size );
 	}
 
 	public static <K, V> ConcurrentHashMap<K, V> newConcurrentHashMap() {
 		return new ConcurrentHashMap<K, V>();
 	}
 
 	public static <T> HashSet<T> newHashSet() {
 		return new HashSet<T>();
 	}
 
 	public static <T> HashSet<T> newHashSet(int size) {
 		return new HashSet<T>( size );
 	}
 
 	public static <T> HashSet<T> newHashSet(Collection<? extends T> c) {
 		return new HashSet<T>( c );
 	}
 
 	public static <T> HashSet<T> newHashSet(Collection<? extends T> s1Collection<? extends T> s2) {
 		HashSet<T> set = newHashSets1 );
 		set.addAlls2 );
 		return set;
 	}
 
 	public static <T> HashSet<T> newHashSet(Iterable<? extends T> iterable) {
 		HashSet<T> set = newHashSet();
 		for ( T t : iterable ) {
 			set.addt );
 		}
 		return set;
 	}
 
 	public static <T> ArrayList<T> newArrayList() {
 		return new ArrayList<T>();
 	}
 
 	public static <T> ArrayList<T> newArrayList(int size) {
 		return new ArrayList<T>( size );
 	}
 
 	public static <T> ArrayList<T> newArrayList(Iterable<T>... iterables) {
 		ArrayList<T> resultList = newArrayList();
 		for ( Iterable<T> oneIterable : iterables ) {
 			for ( T oneElement : oneIterable ) {
 				resultList.addoneElement );
 			}
 		}
 		return resultList;
 	}
 
 	public static <T> Set<T> asSet(T... ts) {
 		return new HashSet<T>( Arrays.asListts ) );
	}

Creates a map containing the given list's values partitioned by the given partitioner.

Parameters:
<K> The key type of the resulting map.
<V> The element type of the list to be partitioned.
list The list to be partitioned.
partitioner The partitioner to be used for determining the partitions.
Returns:
A map containing the given list's values partitioned by the given partitioner.
	public static <K, V> Map<K, List<V>> partition(List<V> listPartitioner<K, V> partitioner) {
		if ( list == null ) {
			return Collections.emptyMap();
		}
		Map<K, List<V>> theValue = newHashMap();
		for ( V v : list ) {
key = partitioner.getPartitionv );
			List<V> partition = theValue.getkey );
			if ( partition == null ) {
				partition = newArrayList();
				theValue.putkeypartition );
			}
			partition.addv );
		}
		return theValue;
	}

Creates a map containing the given set's values partitioned by the given partitioner.

Parameters:
<K> The key type of the resulting map.
<V> The element type of the set to be partitioned.
set The set to be partitioned.
partitioner The partitioner to be used for determining the partitions.
Returns:
A map containing the given set's values partitioned by the given partitioner.
	public static <K, V> Map<K, Set<V>> partition(Set<V> setPartitioner<K, V> partitioner) {
		if ( set == null ) {
			return Collections.emptyMap();
		}
		Map<K, Set<V>> theValue = newHashMap();
		for ( V v : set ) {
key = partitioner.getPartitionv );
			Set<V> partition = theValue.getkey );
			if ( partition == null ) {
				partition = newHashSet();
				theValue.putkeypartition );
			}
			partition.addv );
		}
		return theValue;
	}
	public interface Partitioner<K, V> {
getPartition(V v);
	}
New to GrepCode? Check out our FAQ X