 
                        
        
                        
        org.jboss.weld.injection.VirtualMethodInjectionPoint Maven / Gradle / Ivy
                 Go to download
                
        
                    Show more of this group  Show more artifacts with this name
Show all versions of weld-servlet-shaded Show documentation
                Show all versions of weld-servlet-shaded Show documentation
This jar bundles all the bits of Weld and CDI required for running in a Servlet container.
                
             The newest version!
        
        /*
 * JBoss, Home of Professional Open Source
 * Copyright 2014, Red Hat, Inc., 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.jboss.weld.injection;
import static org.jboss.weld.util.reflection.Reflections.isPackagePrivate;
import static org.jboss.weld.util.reflection.Reflections.isPrivate;
import java.lang.annotation.Annotation;
import java.lang.reflect.Method;
import java.util.Collections;
import java.util.Map;
import java.util.Objects;
import java.util.Set;
import jakarta.enterprise.inject.spi.Bean;
import org.jboss.weld.annotated.enhanced.EnhancedAnnotatedMethod;
import org.jboss.weld.bean.AbstractClassBean;
import org.jboss.weld.bean.AbstractProducerBean;
import org.jboss.weld.manager.BeanManagerImpl;
import org.jboss.weld.util.collections.ImmutableMap;
import org.jboss.weld.util.reflection.Reflections;
/**
 * {@link MethodInjectionPoint} that invokes virtual methods.
 *
 * @author Jozef Hartinger
 *
 * @param 
 * @param 
 */
class VirtualMethodInjectionPoint extends StaticMethodInjectionPoint {
    private volatile Map, Method> methods;
    VirtualMethodInjectionPoint(MethodInjectionPointType methodInjectionPointType, EnhancedAnnotatedMethod enhancedMethod,
            Bean> declaringBean,
            Class> declaringComponentClass, Set> specialParameterMarkers,
            InjectionPointFactory factory,
            BeanManagerImpl manager) {
        super(methodInjectionPointType, enhancedMethod, declaringBean, declaringComponentClass, specialParameterMarkers,
                factory, manager);
        this.methods = Collections., Method> singletonMap(getAnnotated().getJavaMember().getDeclaringClass(),
                accessibleMethod);
    }
    @Override
    protected Method getMethod(Object receiver) throws NoSuchMethodException {
        final Map, Method> methods = this.methods;
        Method method = this.methods.get(receiver.getClass());
        if (method == null) {
            // the same method may be written to the map twice, but that is ok
            // lookupMethod is very slow
            Method delegate = getAnnotated().getJavaMember();
            if ((hasDecorators() || MethodInjectionPointType.INITIALIZER.equals(type))
                    && (isPrivate(delegate) || isPackagePrivate(delegate.getModifiers())
                            && !Objects.equals(delegate.getDeclaringClass().getPackage(), receiver.getClass().getPackage()))) {
                // Initializer methods and decorated beans - overriding does not apply to private methods and package-private methods where the subclass is in a different package
                method = accessibleMethod;
            } else {
                method = Reflections.lookupMethod(receiver.getClass(), delegate.getName(), delegate.getParameterTypes());
                Reflections.ensureAccessible(method, receiver);
            }
            final Map, Method> newMethods = ImmutableMap., Method> builder().putAll(methods)
                    .put(receiver.getClass(), method).build();
            this.methods = newMethods;
        }
        return method;
    }
    private boolean hasDecorators() {
        if (getBean() instanceof AbstractClassBean) {
            return ((AbstractClassBean>) getBean()).hasDecorators();
        }
        if (getBean() instanceof AbstractProducerBean) {
            return ((AbstractProducerBean, ?, ?>) getBean()).getDeclaringBean().hasDecorators();
        }
        return false;
    }
}
           © 2015 - 2025 Weber Informatics LLC | Privacy Policy