org.springframework.beans
Class BeanMetadataAttributeAccessor

java.lang.Object
  extended by org.springframework.core.AttributeAccessorSupport
      extended by org.springframework.beans.BeanMetadataAttributeAccessor
All Implemented Interfaces:
java.io.Serializable, BeanMetadataElement, AttributeAccessor
Direct Known Subclasses:
AbstractBeanDefinition, AutowireCandidateQualifier, PropertyValue

public class BeanMetadataAttributeAccessor
extends AttributeAccessorSupport
implements BeanMetadataElement

Extension of AttributeAccessorSupport, holding attributes as BeanMetadataAttribute objects in order to keep track of the definition source.

Since:
2.5
Author:
Juergen Hoeller
See Also:
Serialized Form

Field Summary
private  java.lang.Object source
           
 
Constructor Summary
BeanMetadataAttributeAccessor()
           
 
Method Summary
 void addMetadataAttribute(BeanMetadataAttribute attribute)
          Add the given BeanMetadataAttribute to this accessor's set of attributes.
 java.lang.Object getAttribute(java.lang.String name)
          Get the value of the attribute identified by name.
 BeanMetadataAttribute getMetadataAttribute(java.lang.String name)
          Look up the given BeanMetadataAttribute in this accessor's set of attributes.
 java.lang.Object getSource()
          Return the configuration source Object for this metadata element (may be null).
 java.lang.Object removeAttribute(java.lang.String name)
          Remove the attribute identified by name and return its value.
 void setAttribute(java.lang.String name, java.lang.Object value)
          Set the attribute defined by name to the supplied value.
 void setSource(java.lang.Object source)
          Set the configuration source Object for this metadata element.
 
Methods inherited from class org.springframework.core.AttributeAccessorSupport
attributeNames, copyAttributesFrom, equals, hasAttribute, hashCode
 
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

source

private java.lang.Object source
Constructor Detail

BeanMetadataAttributeAccessor

public BeanMetadataAttributeAccessor()
Method Detail

setSource

public void setSource(java.lang.Object source)
Set the configuration source Object for this metadata element.

The exact type of the object will depend on the configuration mechanism used.


getSource

public java.lang.Object getSource()
Description copied from interface: BeanMetadataElement
Return the configuration source Object for this metadata element (may be null).

Specified by:
getSource in interface BeanMetadataElement

addMetadataAttribute

public void addMetadataAttribute(BeanMetadataAttribute attribute)
Add the given BeanMetadataAttribute to this accessor's set of attributes.

Parameters:
attribute - the BeanMetadataAttribute object to register

getMetadataAttribute

public BeanMetadataAttribute getMetadataAttribute(java.lang.String name)
Look up the given BeanMetadataAttribute in this accessor's set of attributes.

Parameters:
name - the name of the attribute
Returns:
the corresponding BeanMetadataAttribute object, or null if no such attribute defined

setAttribute

public void setAttribute(java.lang.String name,
                         java.lang.Object value)
Description copied from interface: AttributeAccessor
Set the attribute defined by name to the supplied value. If value is null, the attribute is removed.

In general, users should take care to prevent overlaps with other metadata attributes by using fully-qualified names, perhaps using class or package names as prefix.

Specified by:
setAttribute in interface AttributeAccessor
Overrides:
setAttribute in class AttributeAccessorSupport
Parameters:
name - the unique attribute key
value - the attribute value to be attached

getAttribute

public java.lang.Object getAttribute(java.lang.String name)
Description copied from interface: AttributeAccessor
Get the value of the attribute identified by name. Return null if the attribute doesn't exist.

Specified by:
getAttribute in interface AttributeAccessor
Overrides:
getAttribute in class AttributeAccessorSupport
Parameters:
name - the unique attribute key
Returns:
the current value of the attribute, if any

removeAttribute

public java.lang.Object removeAttribute(java.lang.String name)
Description copied from interface: AttributeAccessor
Remove the attribute identified by name and return its value. Return null if no attribute under name is found.

Specified by:
removeAttribute in interface AttributeAccessor
Overrides:
removeAttribute in class AttributeAccessorSupport
Parameters:
name - the unique attribute key
Returns:
the last value of the attribute, if any