SimpleMetadataReaderFactory is capable of resolving inner class names with dot syntax now (analogous to ClassUtils.forName)
Issue: SPR-12390
This commit is contained in:
parent
807864fa9a
commit
725ad0df50
|
@ -86,6 +86,16 @@ public class ConfigurationClassPostProcessorTests {
|
||||||
assertSame(foo, bar.foo);
|
assertSame(foo, bar.foo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void configurationIntrospectionOfInnerClassesWorksWithDotNameSyntax() {
|
||||||
|
beanFactory.registerBeanDefinition("config", new RootBeanDefinition(getClass().getName() + ".SingletonBeanConfig"));
|
||||||
|
ConfigurationClassPostProcessor pp = new ConfigurationClassPostProcessor();
|
||||||
|
pp.postProcessBeanFactory(beanFactory);
|
||||||
|
Foo foo = beanFactory.getBean("foo", Foo.class);
|
||||||
|
Bar bar = beanFactory.getBean("bar", Bar.class);
|
||||||
|
assertSame(foo, bar.foo);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests the fix for SPR-5655, a special workaround that prefers reflection
|
* Tests the fix for SPR-5655, a special workaround that prefers reflection
|
||||||
* over ASM if a bean class is already loaded.
|
* over ASM if a bean class is already loaded.
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2012 the original author or authors.
|
* Copyright 2002-2014 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -74,7 +74,23 @@ public class SimpleMetadataReaderFactory implements MetadataReaderFactory {
|
||||||
public MetadataReader getMetadataReader(String className) throws IOException {
|
public MetadataReader getMetadataReader(String className) throws IOException {
|
||||||
String resourcePath = ResourceLoader.CLASSPATH_URL_PREFIX +
|
String resourcePath = ResourceLoader.CLASSPATH_URL_PREFIX +
|
||||||
ClassUtils.convertClassNameToResourcePath(className) + ClassUtils.CLASS_FILE_SUFFIX;
|
ClassUtils.convertClassNameToResourcePath(className) + ClassUtils.CLASS_FILE_SUFFIX;
|
||||||
return getMetadataReader(this.resourceLoader.getResource(resourcePath));
|
Resource resource = this.resourceLoader.getResource(resourcePath);
|
||||||
|
if (!resource.exists()) {
|
||||||
|
// Maybe an inner class name using the dot name syntax? Need to use the dollar syntax here...
|
||||||
|
// ClassUtils.forName has an equivalent check for resolution into Class references later on.
|
||||||
|
int lastDotIndex = className.lastIndexOf('.');
|
||||||
|
if (lastDotIndex != -1) {
|
||||||
|
String innerClassName =
|
||||||
|
className.substring(0, lastDotIndex) + '$' + className.substring(lastDotIndex + 1);
|
||||||
|
String innerClassResourcePath = ResourceLoader.CLASSPATH_URL_PREFIX +
|
||||||
|
ClassUtils.convertClassNameToResourcePath(innerClassName) + ClassUtils.CLASS_FILE_SUFFIX;
|
||||||
|
Resource innerClassResource = this.resourceLoader.getResource(innerClassResourcePath);
|
||||||
|
if (innerClassResource.exists()) {
|
||||||
|
resource = innerClassResource;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return getMetadataReader(resource);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in New Issue