org.picocontainer.injectors.SetterInjection Maven / Gradle / Ivy
The newest version!
/*****************************************************************************
* 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.injectors;
import org.picocontainer.Characteristics;
import org.picocontainer.ComponentAdapter;
import org.picocontainer.ComponentMonitor;
import org.picocontainer.LifecycleStrategy;
import org.picocontainer.Parameter;
import org.picocontainer.PicoCompositionException;
import org.picocontainer.behaviors.AbstractBehaviorFactory;
import java.util.Properties;
/**
* A {@link org.picocontainer.InjectionFactory} for JavaBeans.
* The factory creates {@link SetterInjector}.
*
* @author Jörg Schaible
*/
@SuppressWarnings("serial")
public class SetterInjection extends AbstractInjectionFactory {
private final String prefix;
private String notThisOneThough;
private boolean optional;
public SetterInjection(String prefix) {
this.prefix = prefix;
}
public SetterInjection() {
this("set");
}
/**
* Specify a prefix and an exclusion
* @param prefix the prefix like 'set'
* @param notThisOneThough to exclude, like 'setMetaClass' for Groovy
*/
public SetterInjection(String prefix, String notThisOneThough) {
this(prefix);
this.notThisOneThough = notThisOneThough;
}
/**
* Create a {@link SetterInjector}.
*
* @param monitor
* @param lifecycleStrategy
* @param componentProperties
* @param componentKey The component's key
* @param componentImplementation The class of the bean.
* @param parameters Any parameters for the setters. If null the adapter
* solves the dependencies for all setters internally. Otherwise
* the number parameters must match the number of the setter.
* @return Returns a new {@link SetterInjector}.
* @throws PicoCompositionException if dependencies cannot be solved
*/
public ComponentAdapter createComponentAdapter(ComponentMonitor monitor, LifecycleStrategy lifecycleStrategy, Properties componentProperties, Object componentKey, Class componentImplementation, Parameter... parameters)
throws PicoCompositionException {
boolean useNames = AbstractBehaviorFactory.arePropertiesPresent(componentProperties, Characteristics.USE_NAMES, true);
return wrapLifeCycle(monitor.newInjector(new SetterInjector(componentKey, componentImplementation, parameters, monitor, prefix, notThisOneThough != null ? notThisOneThough : "", optional, useNames)), lifecycleStrategy);
}
public SetterInjection withInjectionOptional() {
optional = true;
return this;
}
}