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

org.mentacontainer.ConfigurableFactory Maven / Gradle / Ivy

Go to download

A IOC container as simple and pragmatic as it can get with programmatic configuration through a Fluent API.

There is a newer version: 1.2.6
Show newest version
package org.mentacontainer;

/**
 * An IoC factory that knows how to create instances and 
 * can be configured by accepting values for its constructor
 * and properties (setters). It can also be intercepted right
 * after it creates an instance and right before it releases an instance
 * through the Interceptor interface.
 * 
 * It also supports constructor and property values that are dependencies, in other words, they come from the container itself.
 * 
 * @author [email protected]
 * @see Interceptor
 */
public interface ConfigurableFactory extends Factory {
	
	/**
	 * Add a constructor parameter to be used when the bean is instantiated. It can be called more than once to
	 * use constructors with more than one argument.
	 * 
	 * @param value A parameter value to be used by a constructor.
	 * @return The factory itself. (Fluent API)
	 */
	public ConfigurableFactory addInitValue(Object value);
	
	/**
	 * Add a constructor parameter that is a primitive to be used when the bean is instantiated. It can be called more than once to
	 * use constructors with more than one argument.
*
* Note: This method is seldom necessary and should be used if and only if you have a constructor that mixes Wrappers and primitives, like below:
*
	 * public AObject(int x, Integer i, Boolean b, boolean f) { ... }
	 * 
* * @param value A parameter value to be used by a constructor. Must be a primitive that will be autoboxed. * @return The factory itself. (Fluent API) */ public ConfigurableFactory addInitPrimitive(Object value); /** * Add a constructor parameter that is a dependency, in other words, it gets its value from the container. * When the object is created the dependency will be obtained from the container. * * @param key The key used to get an instance from the container * @return The factory itself. (Fluent API) */ public ConfigurableFactory addConstructorDependency(Object key); /** * In case you want to force the use of a zero argument constructor and avoid any ambiguity when choosing the constructor to use. * * This method is seldom necessary and should be used in the rare cases that the container cannot correctly determine the constructor you * want to use due to auto-wiring. * * @return The factory itself. (Fluent API) */ public ConfigurableFactory useZeroArgumentConstructor(); /** * Add a property to be injected through a setter when the factory instantiates an object. * * @param name The property name. * @param value The property value. * @return The factory itself. (Fluent API) */ public ConfigurableFactory addPropertyValue(String name, Object value); /** * Add a setter property that is a dependency, in other words, its value will be obtained from the container. * * The property name and the dependency name are the same. If they are different you can use the other version of addPropertyDependency that accepts both values. * * @param property The dependency name which is equal to the property name. * @return The factory itself. (Fluent API) */ public ConfigurableFactory addPropertyDependency(String property); /** * Add a setter property that is a dependency, in other words, its value will be obtained from the container. * * The property name and the dependency name are different. * * @param property The property that will be injected by the container. * @param key The dependency name, in other words, the key used to get a bean from the container. * @return The factory itself. (Fluent API) */ public ConfigurableFactory addPropertyDependency(String property, Object key); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy