simplification, use getAllMembers() in processor

Signed-off-by: Gavin King <gavin@hibernate.org>
This commit is contained in:
Gavin King 2024-04-02 10:48:37 +02:00 committed by Christian Beikov
parent a12a2cad80
commit 08d5da7844
1 changed files with 5 additions and 17 deletions

View File

@ -379,8 +379,8 @@ public class AnnotationMetaEntity extends AnnotationMeta {
final List<ExecutableElement> lifecycleMethods = new ArrayList<>();
if ( repository ) {
final List<ExecutableElement> methodsOfClass = new ArrayList<>();
addMethods( element, methodsOfClass );
final List<ExecutableElement> methodsOfClass =
methodsIn( context.getElementUtils().getAllMembers(element) );
for ( ExecutableElement method: methodsOfClass ) {
if ( containsAnnotation( method, HQL, SQL, JD_QUERY, FIND, JD_FIND ) ) {
queryMethods.add( method );
@ -396,8 +396,9 @@ public class AnnotationMetaEntity extends AnnotationMeta {
queryMethods.add( method );
}
}
else if ( !isSessionGetter(method)
&& !method.getModifiers().contains(Modifier.DEFAULT) ) {
else if ( method.getEnclosingElement().getKind().isInterface()
&& !method.isDefault()
&& !isSessionGetter(method) ) {
final String companionClassName = element.getQualifiedName().toString() + '$';
if ( context.getElementUtils().getTypeElement(companionClassName) == null ) {
message( method, "repository method cannot be implemented",
@ -498,19 +499,6 @@ public class AnnotationMetaEntity extends AnnotationMeta {
return result;
}
private void addMethods(TypeElement element, List<ExecutableElement> methodsOfClass) {
//TODO just use Elements.getAllMembers(element) here!
for ( TypeMirror typeMirror : element.getInterfaces() ) {
final DeclaredType declaredType = (DeclaredType) typeMirror;
final TypeElement typeElement = (TypeElement) declaredType.asElement();
addMethods( typeElement, methodsOfClass );
}
for ( ExecutableElement method : methodsIn( element.getEnclosedElements() ) ) {
methodsOfClass.removeIf( m -> context.getElementUtils().overrides(method, m, element) );
methodsOfClass.add( method );
}
}
private void addDefaultConstructor() {
final String sessionVariableName = getSessionVariableName(sessionType);
putMember("_", new DefaultConstructor(