Skip to content

Commit

Permalink
Improve addEnclosingTypesToImportedTypes (#6565)
Browse files Browse the repository at this point in the history
  • Loading branch information
mernst committed May 2, 2024
1 parent d62429e commit f5e19d3
Showing 1 changed file with 9 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -555,15 +555,15 @@ private Map<String, TypeElement> getImportedAnnotations() {
// Find compile time constant fields, or values of an enum
putAllNew(result, annosInType(element));
importedConstants.addAll(getImportableMembers(element));
addEnclosingTypesToImportedTypes(element);
addEnclosedTypesToImportedTypes(element);
}

} else {
// Wildcard import of members of a package
PackageElement element = findPackage(imported, importDecl);
if (element != null) {
putAllNew(result, annosInPackage(element));
addEnclosingTypesToImportedTypes(element);
addEnclosedTypesToImportedTypes(element);
}
}
} else {
Expand Down Expand Up @@ -626,10 +626,14 @@ private Map<String, TypeElement> getImportedAnnotations() {
return result;
}

// If a member is imported, then consider every containing class to also be imported.
private void addEnclosingTypesToImportedTypes(Element element) {
/**
* Handle wildcard imports by adding, to {@link #importedTypes}, every enclosed type.
*
* @param element an element for a type or package
*/
private void addEnclosedTypesToImportedTypes(Element element) {
for (Element enclosedEle : element.getEnclosedElements()) {
if (enclosedEle.getKind().isClass()) {
if (enclosedEle.getKind().isClass() || enclosedEle.getKind().isInterface()) {
importedTypes.put(enclosedEle.getSimpleName().toString(), (TypeElement) enclosedEle);
}
}
Expand Down

0 comments on commit f5e19d3

Please sign in to comment.