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

org.powermock.reflect.internal.primitivesupport.PrimitiveWrapper Maven / Gradle / Ivy

/*
 * Copyright 2008 the original author or authors.
 *
 * 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.powermock.reflect.internal.primitivesupport;

import java.util.HashMap;
import java.util.Map;

/**
 * The purpose of the Primitive Wrapper is to provide methods that deals with
 * translating wrapper types to its related primitive type.
 */
public class PrimitiveWrapper {
	private static final Map, Class> primitiveWrapper = new HashMap, Class>();

	static {
		primitiveWrapper.put(Integer.class, int.class);
		primitiveWrapper.put(Long.class, long.class);
		primitiveWrapper.put(Float.class, float.class);
		primitiveWrapper.put(Double.class, double.class);
		primitiveWrapper.put(Boolean.class, boolean.class);
		primitiveWrapper.put(Byte.class, byte.class);
		primitiveWrapper.put(Short.class, short.class);
		primitiveWrapper.put(Character.class, char.class);
	}

	/**
	 * Convert all wrapper types in {@code types} to their primitive
	 * counter parts.
	 * 
	 * @param types
	 *            The array of types that should be converted.
	 * @return A new array where all wrapped types have been converted to their
	 *         primitive counter part.
	 */
	public static Class[] toPrimitiveType(Class[] types) {
		if (types == null) {
			throw new IllegalArgumentException("types cannot be null");
		}

		Class[] convertedTypes = new Class[types.length];
		for (int i = 0; i < types.length; i++) {
			final Class originalType = types[i];
			Class primitiveType = primitiveWrapper.get(originalType);
			if (primitiveType == null) {
				convertedTypes[i] = originalType;
			} else {
				convertedTypes[i] = primitiveType;
			}
		}
		return convertedTypes;
	}

	/**
	 * Get the primitive counter part from a wrapped type. For example:
	 * 

* * {@code getPrimitiveFromWrapperType(Integer.class)} will return * {@code int.class}. * * * @param wrapperType * The wrapper type to convert to its primitive counter part. * @return The primitive counter part or {@code null} if the class did * not have a primitive counter part. * */ public static Class getPrimitiveFromWrapperType(Class wrapperType) { return primitiveWrapper.get(wrapperType); } /** * Returns {@code true} if {@code type} has a primitive * counter-part. E.g. if {@code type} if {@code Integer} then this * method will return {@code true}. * * @param type * The type to check whether or not it has a primitive * counter-part. * @return {@code true} if this type has a primitive counter-part. */ public static boolean hasPrimitiveCounterPart(Class type) { return primitiveWrapper.containsKey(type); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy