2 * Copyright 2005-2010 the original author or authors.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
16 package org.wamblee.inject;
19 import java.util.concurrent.ConcurrentHashMap;
21 import org.wamblee.cdi.CdiInjector;
24 * Cache of {@link CdiInjector}s for efficiency to avoid duplicate analysis of a
27 * @author Erik Brakkee
29 public class InjectorCache {
31 private Map<String, Injector> injectors;
33 private InjectorFactory injectorFactory;
36 * Constructs an empty cache.
41 public InjectorCache(InjectorFactory aInjectorFactory) {
42 injectorFactory = aInjectorFactory;
43 injectors = new ConcurrentHashMap<String, Injector>();
47 * Gets the injector for a given class. This returns a cached injector or
48 * creates a new injector and caches it.
51 * Class to find injector for.
54 public Injector getInjector(Class aClass) {
55 Injector injector = injectors.get(aClass.getName());
56 if (injector == null) {
57 // create and add injector
58 // NOTE: in rare circumstances this will lead to parallel
60 // an injector for the same class. However, only one of them
61 // will be the final one
62 // in the map. There are no side effects of this duplicate
63 // creation of injectors.
64 injector = injectorFactory.create(aClass);
65 injectors.put(aClass.getName(), injector);