/*
* JBoss, Home of Professional Open Source
* Copyright 2006, JBoss Inc., and individual contributors as indicated
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.beans.metadata.spi.factory;
import java.util.Map;
import java.util.List;
import org.jboss.beans.info.spi.BeanAccessMode;
import org.jboss.beans.info.spi.BeanInfo;
import org.jboss.beans.metadata.spi.ClassLoaderMetaData;
import org.jboss.beans.metadata.spi.ConstructorMetaData;
import org.jboss.beans.metadata.spi.LifecycleMetaData;
import org.jboss.beans.metadata.spi.ValueMetaData;
import org.jboss.beans.metadata.spi.ParameterMetaData;
import org.jboss.kernel.spi.config.KernelConfigurator;
import org.jboss.joinpoint.spi.MethodJoinpoint;
import org.jboss.joinpoint.spi.JoinpointException;
/**
* SPI contract of bean factory we can create from GenericBeanFactoryMetaData.
* This is the base class to be used for different implementations of the {@link BeanFactory}
* interface.
*
* @author <a href="mailto:ales.justin@jboss.com">Ales Justin</a>
*/
public abstract class AbstractBeanFactory implements BeanFactory
{
/** The configurator */
protected KernelConfigurator configurator;
/** The bean class name */
protected String bean;
/** The access mode */
protected BeanAccessMode accessMode;
/** The classloader */
protected ClassLoaderMetaData classLoader;
/** The constructor metadata */
protected ConstructorMetaData constructor;
/** The properties Map<propertyName, ValueMetaData> */
protected Map<String, ValueMetaData> properties;
/** The create lifecycle method */
protected LifecycleMetaData create;
/** The start lifecycle method */
protected LifecycleMetaData start;
protected AbstractBeanFactory(KernelConfigurator configurator)
{
if (configurator == null)
throw new IllegalArgumentException("Null configurator");
this.configurator = configurator;
}
/**
* Get the configurator.
*
* @return the configurator
*/
protected KernelConfigurator getConfigurator()
{
return configurator;
}
/**
* Get the bean name
*
* @return the bean
*/
public String getBean()
{
return bean;
}
/**
* Set the bean name
*
* @param bean the bean name
*/
public void setBean(String bean)
{
this.bean = bean;
}
/**
* Get the access mode.
*
* @return the access mode
*/
public BeanAccessMode getAccessMode()
{
return accessMode;
}
/**
* Set the access mode.
*
* @param accessMode the access mode.
*/
public void setAccessMode(BeanAccessMode accessMode)
{
this.accessMode = accessMode;
}
/**
* Get the classLoader.
*
* @return the classLoader.
*/
public ClassLoaderMetaData getClassLoader()
{
return classLoader;
}
/**
* Set the classLoader.
*
* @param classLoader the classLoader.
*/
public void setClassLoader(ClassLoaderMetaData classLoader)
{
this.classLoader = classLoader;
}
/**
* Get the constructor metadata
*
* @return the contructor metadata
*/
public ConstructorMetaData getConstructor()
{
return constructor;
}
/**
* Set the constructor metadata
*
* @param constructor the constructor metadata
*/
public void setConstructor(ConstructorMetaData constructor)
{
this.constructor = constructor;
}
/**
* Get the properties
*
* @return the properties Map<propertyName, ValueMetaData>
*/
public Map<String, ValueMetaData> getProperties()
{
return properties;
}
/**
* Set the properties
*
* @param properties the properties Map<propertyName, ValueMetaData>
*/
public void setProperties(Map<String, ValueMetaData> properties)
{
this.properties = properties;
}
/**
* Get the create.
*
* @return the create.
*/
public LifecycleMetaData getCreate()
{
return create;
}
/**
* Set the create.
*
* @param create the create.
*/
public void setCreate(LifecycleMetaData create)
{
this.create = create;
}
/**
* Get the start.
*
* @return the start.
*/
public LifecycleMetaData getStart()
{
return start;
}
/**
* Set the start.
*
* @param start the start.
*/
public void setStart(LifecycleMetaData start)
{
this.start = start;
}
/**
* Invoke a lifecycle method
*
* @param methodName the default method name
* @param lifecycle the lifecycle
* @param info the bean info
* @param cl the classloader
* @param target the target
* @throws Throwable for any error
*/
protected void invokeLifecycle(String methodName, LifecycleMetaData lifecycle, BeanInfo info, ClassLoader cl, Object target) throws Throwable
{
if (lifecycle == null || lifecycle.isIgnored() == false)
{
String method = methodName;
if (lifecycle != null && lifecycle.getMethodName() != null)
method = lifecycle.getMethodName();
List<ParameterMetaData> parameters = null;
if (lifecycle != null)
parameters = lifecycle.getParameters();
MethodJoinpoint joinpoint;
try
{
joinpoint = configurator.getMethodJoinPoint(info, cl, method, parameters, false, true);
}
catch (JoinpointException ignored)
{
return;
}
joinpoint.setTarget(target);
joinpoint.dispatch();
}
}
}