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

org.hibernate.validator.parameternameprovider.ParanamerParameterNameProvider Maven / Gradle / Ivy

Go to download

JSR 349's RI, Hibernate Validator version ${hibernate-validator.version} and its dependencies repackaged as OSGi bundle

There is a newer version: 2.5.0-b06
Show newest version
/*
 * JBoss, Home of Professional Open Source
 * Copyright 2013, Red Hat, Inc. and/or its affiliates, 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.parameternameprovider;

import java.lang.reflect.Constructor;
import java.lang.reflect.Method;
import java.util.Arrays;
import java.util.List;
import javax.validation.ParameterNameProvider;

import com.thoughtworks.paranamer.AdaptiveParanamer;
import com.thoughtworks.paranamer.CachingParanamer;
import com.thoughtworks.paranamer.Paranamer;

import org.hibernate.validator.internal.engine.DefaultParameterNameProvider;

/**
 * A {@link ParameterNameProvider} implementation backed by the ParaNamer
 * library.
 * 

* The {@link Paranamer} implementation to use can be passed when creating a {@code ParanamerParameterNameProvider}. By * default a {@link AdaptiveParanamer} will be used which is wrapped into a {@link CachingParanamer}. If no parameter * names can be obtained from the configured {@code Paranamer}, the default parameter name provider will be used as * fall back. *

* The ParaNamer library must be present on the classpath when using this parameter name provider. * * @author Gunnar Morling * @see ParaNamer web site */ public class ParanamerParameterNameProvider implements ParameterNameProvider { private final ParameterNameProvider fallBackProvider; private final Paranamer paranamer; public ParanamerParameterNameProvider() { this( null ); } public ParanamerParameterNameProvider(Paranamer paranamer) { this.paranamer = paranamer != null ? paranamer : new CachingParanamer( new AdaptiveParanamer() ); fallBackProvider = new DefaultParameterNameProvider(); } @Override public List getParameterNames(Constructor constructor) { String[] parameterNames; //there are no guarantees regarding thread-safety synchronized ( paranamer ) { parameterNames = paranamer.lookupParameterNames( constructor, false ); } //either null or an empty array is returned if no names could be retrieved if ( parameterNames != null && parameterNames.length == constructor.getParameterTypes().length ) { return Arrays.asList( parameterNames ); } return fallBackProvider.getParameterNames( constructor ); } @Override public List getParameterNames(Method method) { String[] parameterNames; synchronized ( paranamer ) { parameterNames = paranamer.lookupParameterNames( method, false ); } if ( parameterNames != null && parameterNames.length == method.getParameterTypes().length ) { return Arrays.asList( parameterNames ); } return fallBackProvider.getParameterNames( method ); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy