Class Jsr330ScopeMetadataResolver
- All Implemented Interfaces:
ScopeMetadataResolver
ScopeMetadataResolver implementation that follows JSR-330 scoping rules:
defaulting to prototype scope unless Singleton is present.
This scope resolver can be used with ClassPathBeanDefinitionScanner and
AnnotatedBeanDefinitionReader for standard JSR-330 compliance. However,
in practice, you will typically use Spring's rich default scoping instead - or extend
this resolver with custom scoping annotations that point to extended Spring scopes.
- Since:
- 3.0
- Author:
- Juergen Hoeller
- See Also:
-
registerScope(java.lang.Class<?>, java.lang.String)resolveScopeName(java.lang.String)ClassPathBeanDefinitionScanner.setScopeMetadataResolver(org.springframework.context.annotation.ScopeMetadataResolver)AnnotatedBeanDefinitionReader.setScopeMetadataResolver(org.springframework.context.annotation.ScopeMetadataResolver)
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionfinal voidregisterScope(Class<?> annotationType, String scopeName) Register an extended JSR-330 scope annotation, mapping it onto a specific Spring scope by name.final voidregisterScope(String annotationType, String scopeName) Register an extended JSR-330 scope annotation, mapping it onto a specific Spring scope by name.resolveScopeMetadata(BeanDefinition definition) Resolve theScopeMetadataappropriate to the supplied beandefinition.protected StringresolveScopeName(String annotationType) Resolve the given annotation type into a named Spring scope.
-
Constructor Details
-
Jsr330ScopeMetadataResolver
public Jsr330ScopeMetadataResolver()
-
-
Method Details
-
registerScope
Register an extended JSR-330 scope annotation, mapping it onto a specific Spring scope by name.- Parameters:
annotationType- the JSR-330 annotation type as a ClassscopeName- the Spring scope name
-
registerScope
Register an extended JSR-330 scope annotation, mapping it onto a specific Spring scope by name.- Parameters:
annotationType- the JSR-330 annotation type by namescopeName- the Spring scope name
-
resolveScopeName
Resolve the given annotation type into a named Spring scope.The default implementation simply checks against registered scopes. Can be overridden for custom mapping rules, e.g. naming conventions.
- Parameters:
annotationType- the JSR-330 annotation type- Returns:
- the Spring scope name
-
resolveScopeMetadata
Description copied from interface:ScopeMetadataResolverResolve theScopeMetadataappropriate to the supplied beandefinition.Implementations can of course use any strategy they like to determine the scope metadata, but some implementations that spring immediately to mind might be to use source level annotations present on
the classof the supplieddefinition, or to use metadata present in theAttributeAccessor.attributeNames()of the supplieddefinition.- Specified by:
resolveScopeMetadatain interfaceScopeMetadataResolver- Parameters:
definition- the target bean definition- Returns:
- the relevant scope metadata; never
null
-