Class AnnotationParser
java.lang.Object
org.eclipse.jetty.ee10.annotations.AnnotationParser
AnnotationParser
Use asm to scan classes for annotations. A SAX-style parsing is done. Handlers are registered which will be called back when various types of entity are encountered, eg a class, a method, a field.
Handlers are not called back in any particular order and are assumed to be order-independent.
As a registered Handler will be called back for each annotation discovered on a class, a method, a field, the Handler should test to see if the annotation is one that it is interested in.
For the servlet spec, we are only interested in annotations on classes, methods and fields, so the callbacks for handling finding a class, a method a field are themselves not fully implemented.
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classConvenience base class to provide no-ops for all Handler methods.static classImmutable information gathered by parsing class header.static classImmutable information gathered by parsing a field on a class.static interfaceSignature for all handlers that respond to parsing class files.static classImmutable information gathered by parsing a method on a class.static classASM visitor for a class.static classAn ASM visitor for parsing Fields.static classASM Visitor for parsing a method.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionMap of classnames scanned and the first location from which scan occurred
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic StringConvert internal name to simple namestatic String[]Convert internal names to simple names.voidparse(Set<? extends AnnotationParser.Handler> handlers, Resource r) Parse a resourceprotected voidparseClass(Set<? extends AnnotationParser.Handler> handlers, Resource containingResource, Path classFile) Use ASM on a classprotected voidparseDir(Set<? extends AnnotationParser.Handler> handlers, Resource dirResource) Parse all classes in a directoryprotected voidparseJar(Set<? extends AnnotationParser.Handler> handlers, Resource jarResource) Parse a resource that is a jar file.
- 
Field Details- 
_parsedClassNames
 
- 
- 
Constructor Details- 
AnnotationParserpublic AnnotationParser()
- 
AnnotationParserpublic AnnotationParser(int asmVersion) - Parameters:
- asmVersion- The target asm version or 0 for the internal version.
 
 
- 
- 
Method Details- 
normalize
- 
normalize
- 
parseParse a resource- Parameters:
- handlers- the handlers to look for classes in
- r- the resource to parse
- Throws:
- Exception- if unable to parse
 
- 
parseDirprotected void parseDir(Set<? extends AnnotationParser.Handler> handlers, Resource dirResource) throws Exception Parse all classes in a directory- Parameters:
- handlers- the set of handlers to look for classes in
- dirResource- the resource representing the baseResource being scanned (jar, dir, etc)
- Throws:
- Exception- if unable to parse
 
- 
parseJarprotected void parseJar(Set<? extends AnnotationParser.Handler> handlers, Resource jarResource) throws Exception Parse a resource that is a jar file.- Parameters:
- handlers- the handlers to look for classes in
- jarResource- the jar resource to parse
- Throws:
- Exception- if unable to parse
 
- 
parseClassprotected void parseClass(Set<? extends AnnotationParser.Handler> handlers, Resource containingResource, Path classFile) throws IOException Use ASM on a class- Parameters:
- handlers- the handlers to look for classes in
- containingResource- the dir or jar that the class is contained within, can be null if not known
- classFile- the class file to parse
- Throws:
- IOException- if unable to parse
 
 
-