Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*****************************************************************************
* Copyright (c) PicoContainer Organization. All rights reserved. *
* ------------------------------------------------------------------------- *
* The software in this package is published under the terms of the BSD *
* style license a copy of which has been included with this distribution in *
* the LICENSE.txt file. *
* *
* Idea by Rachel Davies, Original code by Aslak Hellesoy and Paul Hammant *
*****************************************************************************/
package org.picocontainer.behaviors;
import org.picocontainer.ComponentAdapter;
import org.picocontainer.Parameter;
import org.picocontainer.PicoCompositionException;
import org.picocontainer.Characteristics;
import org.picocontainer.ComponentMonitor;
import org.picocontainer.LifecycleStrategy;
import org.picocontainer.references.ThreadLocalMapObjectReference;
import java.io.Serializable;
import java.util.Properties;
import java.util.HashMap;
import java.util.Map;
import java.util.Collections;
//import java.util.concurrent.ConcurrentHashMap;
/**
* @author Paul Hammant
*/
@SuppressWarnings("serial")
public class Storing extends AbstractBehaviorFactory {
private final StoreThreadLocal mapThreadLocalObjectReference = new StoreThreadLocal();
public ComponentAdapter createComponentAdapter(ComponentMonitor componentMonitor, LifecycleStrategy lifecycleStrategy, Properties componentProperties, final Object componentKey, Class componentImplementation, Parameter... parameters)
throws PicoCompositionException {
if (removePropertiesIfPresent(componentProperties, Characteristics.NO_CACHE)) {
return super.createComponentAdapter(componentMonitor,
lifecycleStrategy,
componentProperties,
componentKey,
componentImplementation,
parameters);
}
removePropertiesIfPresent(componentProperties, Characteristics.CACHE);
return componentMonitor.newBehavior(new Stored(super.createComponentAdapter(componentMonitor, lifecycleStrategy,
componentProperties, componentKey, componentImplementation, parameters),
new ThreadLocalMapObjectReference(mapThreadLocalObjectReference, componentKey)));
}
public ComponentAdapter addComponentAdapter(ComponentMonitor componentMonitor,
LifecycleStrategy lifecycleStrategy,
Properties componentProperties,
final ComponentAdapter adapter) {
if (removePropertiesIfPresent(componentProperties, Characteristics.NO_CACHE)) {
return super.addComponentAdapter(componentMonitor, lifecycleStrategy, componentProperties, adapter);
}
removePropertiesIfPresent(componentProperties, Characteristics.CACHE);
return componentMonitor.newBehavior(new Stored(super.addComponentAdapter(componentMonitor, lifecycleStrategy, componentProperties, adapter),
new ThreadLocalMapObjectReference(mapThreadLocalObjectReference, adapter.getComponentKey())));
}
public StoreWrapper getCacheForThread() {
StoreWrapper wrappedMap = new StoreWrapper();
wrappedMap.wrapped = (Map)mapThreadLocalObjectReference.get();
return wrappedMap;
}
public void putCacheForThread(StoreWrapper wrappedMap) {
mapThreadLocalObjectReference.set(wrappedMap.wrapped);
}
public StoreWrapper resetCacheForThread() {
Map map = new HashMap();
mapThreadLocalObjectReference.set(map);
StoreWrapper storeWrapper = new StoreWrapper();
storeWrapper.wrapped = map;
return storeWrapper;
}
public void invalidateCacheForThread() {
mapThreadLocalObjectReference.set(Collections.unmodifiableMap(Collections.emptyMap()));
}
public int getCacheSize() {
return ((Map)mapThreadLocalObjectReference.get()).size();
}
public static class StoreThreadLocal extends ThreadLocal