Browse Source

Support @Name meta-annotations with Kotlin binding

Update `ValueObjectBinder` Kotlin support to meta-annotations of
`@Named`.

See gh-24379
pull/24453/head
Phillip Webb 5 years ago
parent
commit
14816a6b6c
  1. 8
      spring-boot-project/spring-boot/src/main/java/org/springframework/boot/context/properties/bind/ValueObjectBinder.java

8
spring-boot-project/spring-boot/src/main/java/org/springframework/boot/context/properties/bind/ValueObjectBinder.java

@ -190,6 +190,8 @@ class ValueObjectBinder implements DataObjectBinder { @@ -190,6 +190,8 @@ class ValueObjectBinder implements DataObjectBinder {
*/
private static final class KotlinValueObject<T> extends ValueObject<T> {
private static final Annotation[] ANNOTATION_ARRAY = new Annotation[0];
private final List<ConstructorParameter> constructorParameters;
private KotlinValueObject(Constructor<T> primaryConstructor, KFunction<T> kotlinConstructor,
@ -206,15 +208,15 @@ class ValueObjectBinder implements DataObjectBinder { @@ -206,15 +208,15 @@ class ValueObjectBinder implements DataObjectBinder {
String name = getParameterName(parameter);
ResolvableType parameterType = ResolvableType
.forType(ReflectJvmMapping.getJavaType(parameter.getType()), type);
Annotation[] annotations = parameter.getAnnotations().toArray(new Annotation[0]);
Annotation[] annotations = parameter.getAnnotations().toArray(ANNOTATION_ARRAY);
result.add(new ConstructorParameter(name, parameterType, annotations));
}
return Collections.unmodifiableList(result);
}
private String getParameterName(KParameter parameter) {
return parameter.getAnnotations().stream().filter(Name.class::isInstance).findFirst().map(Name.class::cast)
.map(Name::value).orElse(parameter.getName());
return MergedAnnotations.from(parameter, parameter.getAnnotations().toArray(ANNOTATION_ARRAY))
.get(Name.class).getValue(MergedAnnotation.VALUE, String.class).orElseGet(parameter::getName);
}
@Override

Loading…
Cancel
Save