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

org.jboss.weld.metadata.cache.MetaAnnotationStore Maven / Gradle / Ivy

/*
 * JBoss, Home of Professional Open Source
 * Copyright 2008, 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.metadata.cache;

import com.google.common.base.Function;
import com.google.common.collect.ComputationException;
import com.google.common.collect.MapMaker;
import org.jboss.weld.bootstrap.api.Service;
import org.jboss.weld.exceptions.DefinitionException;
import org.jboss.weld.exceptions.DeploymentException;
import org.jboss.weld.exceptions.WeldException;
import org.jboss.weld.resources.ClassTransformer;

import java.lang.annotation.Annotation;
import java.util.concurrent.ConcurrentMap;

import static org.jboss.weld.util.reflection.Reflections.cast;

/**
 * Metadata singleton for holding EJB metadata, scope models etc.
 *
 * @author Pete Muir
 */
public class MetaAnnotationStore implements Service {

    private abstract static class AbstractMetaAnnotationFunction> implements Function, M> {

        private final ClassTransformer classTransformer;

        private AbstractMetaAnnotationFunction(ClassTransformer classTransformer) {
            this.classTransformer = classTransformer;
        }

        public ClassTransformer getClassTransformer() {
            return classTransformer;
        }

    }

    private static class StereotypeFunction extends AbstractMetaAnnotationFunction> {

        public StereotypeFunction(ClassTransformer classTransformer) {
            super(classTransformer);
        }

        public StereotypeModel apply(Class from) {
            return new StereotypeModel(from, getClassTransformer());
        }

    }

    private static class ScopeFunction extends AbstractMetaAnnotationFunction> {

        public ScopeFunction(ClassTransformer classTransformer) {
            super(classTransformer);
        }

        public ScopeModel apply(Class from) {
            return new ScopeModel(from, getClassTransformer());
        }

    }

    private static class QualifierFunction extends AbstractMetaAnnotationFunction> {

        public QualifierFunction(ClassTransformer classTransformer) {
            super(classTransformer);
        }

        public QualifierModel apply(Class from) {
            return new QualifierModel(from, getClassTransformer());
        }

    }

    private static class InterceptorBindingFunction extends AbstractMetaAnnotationFunction> {

        public InterceptorBindingFunction(ClassTransformer classTransformer) {
            super(classTransformer);
        }

        public InterceptorBindingModel apply(Class from) {
            return new InterceptorBindingModel(from, getClassTransformer());
        }

    }

    // The stereotype models
    private ConcurrentMap, StereotypeModel> stereotypes;
    // The scope models
    private ConcurrentMap, ScopeModel> scopes;
    // The binding type models
    private ConcurrentMap, QualifierModel> qualifiers;
    // the interceptor bindings
    private ConcurrentMap, InterceptorBindingModel> interceptorBindings;

    public MetaAnnotationStore(ClassTransformer classTransformer) {
        MapMaker mapMaker = new MapMaker();
        this.stereotypes = mapMaker.makeComputingMap(new StereotypeFunction(classTransformer));
        this.scopes = mapMaker.makeComputingMap(new ScopeFunction(classTransformer));
        this.qualifiers = mapMaker.makeComputingMap(new QualifierFunction(classTransformer));
        this.interceptorBindings = mapMaker.makeComputingMap(new InterceptorBindingFunction(classTransformer));
    }

    /**
     * removes all data for an annotation class. This should be called after an
     * annotation has been modified through the SPI
     */
    public void clearAnnotationData(Class annotationClass) {
        stereotypes.remove(annotationClass);
        scopes.remove(annotationClass);
        qualifiers.remove(annotationClass);
        interceptorBindings.remove(annotationClass);
    }

    /**
     * Gets a stereotype model
     * 

* Adds the model if it is not present. * * @param The type * @param stereotype The stereotype * @return The stereotype model */ public StereotypeModel getStereotype(final Class stereotype) { return cast(stereotypes.get(stereotype)); } /** * Gets a scope model *

* Adds the model if it is not present. * * @param The type * @param scope The scope type * @return The scope type model */ public ScopeModel getScopeModel(final Class scope) { return cast(scopes.get(scope)); } /** * Gets a binding type model. *

* Adds the model if it is not present. * * @param The type * @param bindingType The binding type * @return The binding type model */ public QualifierModel getBindingTypeModel(final Class bindingType) { return cast(qualifiers.get(bindingType)); } /** * Gets a string representation * * @return A string representation */ @Override public String toString() { StringBuilder buffer = new StringBuilder(); buffer.append("Metadata cache\n"); buffer.append("Registered binding type models: ").append(qualifiers.size()).append("\n"); buffer.append("Registered scope type models: ").append(scopes.size()).append("\n"); buffer.append("Registered stereotype models: ").append(stereotypes.size()).append("\n"); buffer.append("Registered interceptor binding models: ").append(interceptorBindings.size()).append("\n"); return buffer.toString(); } public void cleanup() { this.qualifiers.clear(); this.scopes.clear(); this.stereotypes.clear(); this.interceptorBindings.clear(); } public InterceptorBindingModel getInterceptorBindingModel(final Class interceptorBinding) { // Unwrap Definition/Deployment exceptions wrapped in a ComputationException // TODO: generalize this and move to a higher level (MBG) try { return cast(interceptorBindings.get(interceptorBinding)); } catch (ComputationException e) { if (e.getCause() instanceof DeploymentException || e.getCause() instanceof DefinitionException) { throw (WeldException) e.getCause(); } else { throw e; } } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy