Package org.eclipse.jetty.annotations
Class AnnotationParser
- java.lang.Object
- 
- org.eclipse.jetty.annotations.AnnotationParser
 
- 
- Direct Known Subclasses:
- AnnotationParser
 
 public class AnnotationParser extends java.lang.ObjectAnnotationParserUse 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 Classes Modifier and Type Class Description static classAnnotationParser.AbstractHandlerConvenience base class to provide no-ops for all Handler methods.classAnnotationParser.ClassInfoImmutable information gathered by parsing class header.classAnnotationParser.FieldInfoImmutable information gathered by parsing a field on a class.static interfaceAnnotationParser.HandlerSignature for all handlers that respond to parsing class files.classAnnotationParser.MethodInfoImmutable information gathered by parsing a method on a class.classAnnotationParser.MyClassVisitorASM visitor for a class.classAnnotationParser.MyFieldVisitorAn ASM visitor for parsing Fields.classAnnotationParser.MyMethodVisitorASM Visitor for parsing a method.
 - 
Field SummaryFields Modifier and Type Field Description protected java.util.Map<java.lang.String,Resource>_parsedClassNamesMap of classnames scanned and the first location from which scan occurred
 - 
Constructor SummaryConstructors Constructor Description AnnotationParser()AnnotationParser(int javaPlatform)AnnotationParser(int javaPlatform, int asmVersion)
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidaddParsedClass(java.lang.String classname, Resource location)Add a class as having been parsed.java.util.List<java.lang.String>getParsedLocations(java.lang.String classname)Deprecated.List of duplicate locations no longer storedbooleanisValidClassFileName(java.lang.String name)Check that the given path represents a valid class file name.booleanisValidClassFilePath(java.lang.String path)Check that the given path does not contain hidden directoriesstatic java.lang.Stringnormalize(java.lang.String name)Convert internal name to simple namestatic java.lang.String[]normalize(java.lang.String[] list)Convert internal names to simple names.voidparse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.lang.Class<?> clazz, boolean visitSuperClasses)Parse the given class, optionally walking its inheritance hierarchyvoidparse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.lang.ClassLoader loader, boolean visitParents, boolean nullInclusive)Deprecated.voidparse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.lang.String className)Parse a given classvoidparse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.lang.String[] classNames)Parse the given classesvoidparse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.net.URI uri)Parse a particular urivoidparse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.net.URI[] uris)Parse classes in the supplied uris.voidparse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.util.List<java.lang.String> classNames)Parse the given classesvoidparse(java.util.Set<? extends AnnotationParser.Handler> handlers, Resource r)Parse a resourceprotected voidparseDir(java.util.Set<? extends AnnotationParser.Handler> handlers, Resource root)Parse all classes in a directoryprotected voidparseJar(java.util.Set<? extends AnnotationParser.Handler> handlers, Resource jarResource)Parse a resource that is a jar file.protected voidparseJarEntry(java.util.Set<? extends AnnotationParser.Handler> handlers, Resource jar, MultiReleaseJarFile.VersionedJarEntry entry)Parse a single entry in a jar filevoidresetParsedClasses()Remove any parsed class names.protected voidscanClass(java.util.Set<? extends AnnotationParser.Handler> handlers, Resource containingResource, java.io.InputStream is)Use ASM on a class
 
- 
- 
- 
Field Detail- 
_parsedClassNamesprotected java.util.Map<java.lang.String,Resource> _parsedClassNames Map of classnames scanned and the first location from which scan occurred
 
- 
 - 
Method Detail- 
normalizepublic static java.lang.String normalize(java.lang.String name) Convert internal name to simple name- Parameters:
- name- the internal name
- Returns:
- the simple name
 
 - 
normalizepublic static java.lang.String[] normalize(java.lang.String[] list) Convert internal names to simple names.- Parameters:
- list- the list of internal names
- Returns:
- the list of simple names
 
 - 
addParsedClasspublic void addParsedClass(java.lang.String classname, Resource location)Add a class as having been parsed.- Parameters:
- classname- the name of the class
- location- the fully qualified location of the class
 
 - 
getParsedLocations@Deprecated public java.util.List<java.lang.String> getParsedLocations(java.lang.String classname) Deprecated.List of duplicate locations no longer storedGet the locations of the given classname. There may be more than one location if there are duplicates of the same class.- Parameters:
- classname- the name of the class
- Returns:
- an immutable list of locations
 
 - 
parsepublic void parse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.lang.String className) throws java.lang.Exception Parse a given class- Parameters:
- handlers- the set of handlers to find class
- className- the class name to parse
- Throws:
- java.lang.Exception- if unable to parse
 
 - 
parsepublic void parse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.lang.Class<?> clazz, boolean visitSuperClasses) throws java.lang.Exception Parse the given class, optionally walking its inheritance hierarchy- Parameters:
- handlers- the handlers to look for class in
- clazz- the class to look for
- visitSuperClasses- if true, also visit super classes for parse
- Throws:
- java.lang.Exception- if unable to parse class
 
 - 
parsepublic void parse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.lang.String[] classNames) throws java.lang.Exception Parse the given classes- Parameters:
- handlers- the set of handlers to look for class in
- classNames- the class name
- Throws:
- java.lang.Exception- if unable to parse
 
 - 
parsepublic void parse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.util.List<java.lang.String> classNames) throws java.lang.Exception Parse the given classes- Parameters:
- handlers- the set of handlers to look for class in
- classNames- the class names
- Throws:
- java.lang.Exception- if unable to parse
 
 - 
parseDirprotected void parseDir(java.util.Set<? extends AnnotationParser.Handler> handlers, Resource root) throws java.lang.Exception Parse all classes in a directory- Parameters:
- handlers- the set of handlers to look for classes in
- root- the resource directory to look for classes
- Throws:
- java.lang.Exception- if unable to parse
 
 - 
parse@Deprecated public void parse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.lang.ClassLoader loader, boolean visitParents, boolean nullInclusive) throws java.lang.Exception Deprecated.Parse classes in the supplied classloader. Only class files in jar files will be scanned.- Parameters:
- handlers- the handlers to look for classes in
- loader- the classloader for the classes
- visitParents- if true, visit parent classloaders too
- nullInclusive- if true, an empty pattern means all names match, if false, none match
- Throws:
- java.lang.Exception- if unable to parse
 
 - 
parsepublic void parse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.net.URI[] uris) throws java.lang.Exception Parse classes in the supplied uris.- Parameters:
- handlers- the handlers to look for classes in
- uris- the uris for the jars
- Throws:
- java.lang.Exception- if unable to parse
 
 - 
parsepublic void parse(java.util.Set<? extends AnnotationParser.Handler> handlers, java.net.URI uri) throws java.lang.Exception Parse a particular uri- Parameters:
- handlers- the handlers to look for classes in
- uri- the uri for the jar
- Throws:
- java.lang.Exception- if unable to parse
 
 - 
parsepublic void parse(java.util.Set<? extends AnnotationParser.Handler> handlers, Resource r) throws java.lang.Exception Parse a resource- Parameters:
- handlers- the handlers to look for classes in
- r- the resource to parse
- Throws:
- java.lang.Exception- if unable to parse
 
 - 
parseJarprotected void parseJar(java.util.Set<? extends AnnotationParser.Handler> handlers, Resource jarResource) throws java.lang.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:
- java.lang.Exception- if unable to parse
 
 - 
parseJarEntryprotected void parseJarEntry(java.util.Set<? extends AnnotationParser.Handler> handlers, Resource jar, MultiReleaseJarFile.VersionedJarEntry entry) throws java.lang.Exception Parse a single entry in a jar file- Parameters:
- handlers- the handlers to look for classes in
- entry- the entry in the potentially MultiRelease jar resource to parse
- jar- the jar file
- Throws:
- java.lang.Exception- if unable to parse
 
 - 
scanClassprotected void scanClass(java.util.Set<? extends AnnotationParser.Handler> handlers, Resource containingResource, java.io.InputStream is) throws java.io.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
- is- the input stream to parse
- Throws:
- java.io.IOException- if unable to parse
 
 - 
resetParsedClassespublic void resetParsedClasses() Remove any parsed class names.
 - 
isValidClassFileNamepublic boolean isValidClassFileName(java.lang.String name) Check that the given path represents a valid class file name. The check is fairly cursory, checking that:- the name ends with .class
- it isn't a dot file or in a hidden directory
- the name of the class at least begins with a valid identifier for a class name
 - Parameters:
- name- the class file name
- Returns:
- whether the class file name is valid
 
 - 
isValidClassFilePathpublic boolean isValidClassFilePath(java.lang.String path) Check that the given path does not contain hidden directories- Parameters:
- path- the class file path
- Returns:
- whether the class file path is valid
 
 
- 
 
-