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

infra.beans.factory.support.ChildBeanDefinition Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2017 - 2024 the original author or authors.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program 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 General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program. If not, see [https://www.gnu.org/licenses/]
 */

package infra.beans.factory.support;

import infra.beans.PropertyValues;
import infra.beans.factory.BeanDefinitionValidationException;
import infra.beans.factory.config.BeanDefinition;
import infra.beans.factory.config.ConstructorArgumentValues;
import infra.lang.Nullable;
import infra.util.ObjectUtils;

/**
 * Bean definition for beans which inherit settings from their parent.
 * Child bean definitions have a fixed dependency on a parent bean definition.
 *
 * 

A child bean definition will inherit constructor argument values, * property values and method overrides from the parent, with the option * to add new values. If init method, destroy method and/or static factory * method are specified, they will override the corresponding parent settings. * The remaining settings will always be taken from the child definition: * depends on, autowire mode, dependency check, singleton, lazy init. * *

NOTE: the preferred way to register bean * definitions programmatically is the {@link BeanDefinition} class, * which allows to dynamically define parent dependencies through the * {@link BeanDefinition#setParentName} method. This effectively * supersedes the ChildBeanDefinition class for most use cases. * * @author Rod Johnson * @author Juergen Hoeller * @author Harry Yang * @see BeanDefinition * @since 4.0 2022/3/7 10:52 */ @SuppressWarnings("serial") public class ChildBeanDefinition extends AbstractBeanDefinition { @Nullable private String parentName; /** * Create a new ChildBeanDefinition for the given parent, to be * configured through its bean properties and configuration methods. * * @param parentName the name of the parent bean * @see #setBeanClass * @see #setScope * @see #setConstructorArgumentValues * @see #setPropertyValues */ public ChildBeanDefinition(String parentName) { super(); this.parentName = parentName; } /** * Create a new ChildBeanDefinition for the given parent. * * @param parentName the name of the parent bean * @param pvs the additional property values of the child */ public ChildBeanDefinition(String parentName, PropertyValues pvs) { super(null, pvs); this.parentName = parentName; } /** * Create a new ChildBeanDefinition for the given parent. * * @param parentName the name of the parent bean * @param cargs the constructor argument values to apply * @param pvs the additional property values of the child */ public ChildBeanDefinition( String parentName, ConstructorArgumentValues cargs, PropertyValues pvs) { super(cargs, pvs); this.parentName = parentName; } /** * Create a new ChildBeanDefinition for the given parent, * providing constructor arguments and property values. * * @param parentName the name of the parent bean * @param beanClass the class of the bean to instantiate * @param cargs the constructor argument values to apply * @param pvs the property values to apply */ public ChildBeanDefinition( String parentName, Class beanClass, ConstructorArgumentValues cargs, PropertyValues pvs) { super(cargs, pvs); this.parentName = parentName; setBeanClass(beanClass); } /** * Create a new ChildBeanDefinition for the given parent, * providing constructor arguments and property values. * Takes a bean class name to avoid eager loading of the bean class. * * @param parentName the name of the parent bean * @param beanClassName the name of the class to instantiate * @param cargs the constructor argument values to apply * @param pvs the property values to apply */ public ChildBeanDefinition( String parentName, String beanClassName, ConstructorArgumentValues cargs, PropertyValues pvs) { super(cargs, pvs); this.parentName = parentName; setBeanClassName(beanClassName); } /** * Create a new ChildBeanDefinition as deep copy of the given * bean definition. * * @param original the original bean definition to copy from */ public ChildBeanDefinition(ChildBeanDefinition original) { super(original); } @Override public void setParentName(@Nullable String parentName) { this.parentName = parentName; } @Override @Nullable public String getParentName() { return this.parentName; } @Override public void validate() throws BeanDefinitionValidationException { super.validate(); if (this.parentName == null) { throw new BeanDefinitionValidationException("'parentName' must be set in ChildBeanDefinition"); } } @Override public AbstractBeanDefinition cloneBeanDefinition() { return new ChildBeanDefinition(this); } @Override public boolean equals(@Nullable Object other) { if (this == other) { return true; } if (!(other instanceof ChildBeanDefinition that)) { return false; } return (ObjectUtils.nullSafeEquals(this.parentName, that.parentName) && super.equals(other)); } @Override public int hashCode() { return ObjectUtils.nullSafeHashCode(this.parentName) * 29 + super.hashCode(); } @Override public String toString() { return "Child bean with parent '" + this.parentName + "': " + super.toString(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy