}
}
break;
case ANNOTATION_TYPE:
AnnotationMirror stereotypeAnnotationMirror = AnnotationProcessingUtils
.findAnnotationMirror(procEnv, e,
"javax.enterprise.inject.Stereotype");
if (stereotypeAnnotationMirror == null) {
procEnv.getMessager()
.printMessage(
Diagnostic.Kind.ERROR,
"Annotation targets other than stereotyped annotation, enum, interface, class, constructor, field and methods are not supported",
e, annotation);
break;
}
Set<Element> stereotypeAnnotatedElements = (Set<Element>) roundEnv
.getElementsAnnotatedWith((TypeElement) e);
for (Element stereotypeAnnotatedElement : stereotypeAnnotatedElements) {
// Always add the element to the map, otherwise it won't be
// validated
elements.put(stereotypeAnnotatedElement,
new HashSet<Element>());
switch (stereotypeAnnotatedElement.getKind()) {
case CONSTRUCTOR:
case FIELD:
case METHOD:
for (Element classMemberElement : procEnv
.getElementUtils()
.getAllMembers(
(TypeElement) stereotypeAnnotatedElement
.getEnclosingElement())) {
if (AnnotationProcessingUtils.findAnnotationMirror(
procEnv, classMemberElement,
referencedAnnotationTypeElement) != null) {
elements.get(stereotypeAnnotatedElement).add(
classMemberElement);
}
}
break;
case INTERFACE:
case CLASS:
// Maybe add here support for subtype checking, so that
// abstract classes or interfaces must not explicitly
// fullfill a
// referencing constraint, but also a subtype can do
case ENUM:
for (Element classMemberElement : procEnv
.getElementUtils()
.getAllMembers(
(TypeElement) stereotypeAnnotatedElement)) {
if (AnnotationProcessingUtils.findAnnotationMirror(
procEnv, classMemberElement,
referencedAnnotationTypeElement) != null) {
elements.get(stereotypeAnnotatedElement).add(
classMemberElement);
}
}
break;
default:
procEnv.getMessager().printMessage(
Diagnostic.Kind.ERROR,
"Feature not yet implemented",
stereotypeAnnotatedElement, annotation);
break;
}
}
break;
default:
procEnv.getMessager()
.printMessage(
Diagnostic.Kind.ERROR,
"Annotation targets other than stereotyped annotation, enum, interface, class, constructor, field and methods are not supported",
e, annotation);
break;
}
break;
case ELEMENT:
if (AnnotationProcessingUtils.findAnnotationMirror(procEnv, e,
referencedAnnotationTypeElement) != null) {
elements.put(e, new HashSet<Element>(Arrays.asList(e)));
}
break;
}
OUTER: for (Map.Entry<Element, Set<Element>> elementEntry : elements
.entrySet()) {
for (Element lookupElement : elementEntry.getValue()) {
AnnotationMirror referencedAnnotationMirror = AnnotationProcessingUtils
.findAnnotationMirror(procEnv, lookupElement,
referencedAnnotationTypeElement);
Object memberName = null;
// Should never be null here