Class JavaVisitorContext
java.lang.Object
io.micronaut.annotation.processing.visitor.JavaVisitorContext
- All Implemented Interfaces:
- ConversionServiceProvider,- ConvertibleValues<Object>,- MutableConvertibleValues<Object>,- ValueResolver<CharSequence>,- BeanElementVisitorContext,- VisitorContext,- ClassWriterOutputVisitor,- Iterable<Map.Entry<String,- Object>> 
@Internal
public final class JavaVisitorContext
extends Object
implements VisitorContext, BeanElementVisitorContext
The visitor context when visiting Java code.
- Since:
- 1.0
- Author:
- James Kleeh
- 
Nested Class SummaryNested classes/interfaces inherited from interface io.micronaut.inject.visitor.VisitorContextVisitorContext.Language
- 
Field SummaryFields inherited from interface io.micronaut.core.convert.value.ConvertibleValuesEMPTYFields inherited from interface io.micronaut.inject.visitor.VisitorContextMICRONAUT_BASE_OPTION_NAME, MICRONAUT_PROCESSING_GROUP, MICRONAUT_PROCESSING_MODULE, MICRONAUT_PROCESSING_PROJECT_DIR
- 
Constructor SummaryConstructorsConstructorDescriptionJavaVisitorContext(ProcessingEnvironment processingEnv, Messager messager, Elements elements, AnnotationUtils annotationUtils, Types types, ModelUtils modelUtils, GenericUtils genericUtils, Filer filer, MutableConvertibleValues<Object> visitorAttributes, TypeElementVisitor.VisitorKind visitorKind) Deprecated, for removal: This API element is subject to removal in a future version.No longer neededJavaVisitorContext(ProcessingEnvironment processingEnv, Messager messager, Elements elements, Types types, ModelUtils modelUtils, Filer filer, MutableConvertibleValues<Object> visitorAttributes, TypeElementVisitor.VisitorKind visitorKind) Deprecated, for removal: This API element is subject to removal in a future version.No longer neededJavaVisitorContext(ProcessingEnvironment processingEnv, Messager messager, Elements elements, Types types, ModelUtils modelUtils, Filer filer, MutableConvertibleValues<Object> visitorAttributes, TypeElementVisitor.VisitorKind visitorKind, Set<String> postponedTypes) The default constructor.
- 
Method SummaryModifier and TypeMethodDescriptionaddAssociatedBean(Element originatingElement, ClassElement type) voidaddGeneratedResource(@NonNull String resource) Some TypeElementVisitors generate classpath resources that other visitors might be interested in.clear()Clear all values.voidAllows failing compilation for a given element with the given message.voidfinish()Finish writing and flush any service entries to disk.<T> Optional<T>get(CharSequence name, ArgumentConversionContext<T> conversionContext) Resolve the given property for the given name.Gets the annotation metadata builder.Deprecated, for removal: This API element is subject to removal in a future version.No longer usedgetClassElement(String name) This method will look up another class element by name.getClassElement(String name, ElementAnnotationMetadataFactory annotationMetadataFactory) This method will look up another class element by name.getClassElements(@NonNull String aPackage, @NonNull String... stereotypes) Find all the classes within the given package and having the given annotation.Obtain a set of resources from the user classpath.Gets the element annotation metadata factory.Gets the element factory for this visitor context.The elements.Provide a collection of generated classpath resources that other TypeElement visitors might want to consume.Deprecated, for removal: This API element is subject to removal in a future version.No longer usedThe messager.The model utils.Java visitor context options fromjavacarguments andSystem.getProperties()getTypes()The types.voidAllows printing informational messages.voidAllows printing informational messages.booleannames()put(CharSequence key, @Nullable Object value) Insert a value for the given key and value.remove(CharSequence key) Remove a value for the given key.voidsetVisitUnresolvedInterfaces(boolean visitUnresolvedInterfaces) values()visitClass(String classname, Element originatingElement) Visits a new class and returns the output stream with which should be written the bytes of the class to be generated.visitClass(String classname, Element... originatingElements) Visits a new class and returns the output stream with which should be written the bytes of the class to be generated.visitGeneratedFile(String path) Visit a file that will be located within the generated source directory.visitGeneratedFile(String path, Element... originatingElements) Visit a file that will be generated within the generated 'sources' directory.visitGeneratedSourceFile(String packageName, String fileNameWithoutExtension, Element... originatingElements) Visit a source file that will be generated within the generated 'sources' directory.visitMetaInfFile(String path, Element... originatingElements) Visit a file within the META-INF directory.voidvisitServiceDescriptor(String type, String classname) Allows adding a class that will be written to theMETA-INF/servicesfile under the given type and class name.voidvisitServiceDescriptor(String type, String classname, Element originatingElement) Allows adding a class that will be written to theMETA-INF/servicesfile under the given type and class name.voidPrint warning message.voidAllows printing a warning for the given message and element.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface io.micronaut.inject.writer.ClassWriterOutputVisitorgetServiceEntries, visitClass, visitMetaInfFile, visitServiceDescriptor, visitServiceDescriptorMethods inherited from interface io.micronaut.core.convert.value.ConvertibleValuesasMap, asMap, asProperties, contains, forEach, getConversionService, getValue, getValueType, isEmpty, iterator, subMap, subMap, subMapMethods inherited from interface java.lang.IterableforEach, spliteratorMethods inherited from interface io.micronaut.core.convert.value.MutableConvertibleValuesputAll, putAllMethods inherited from interface io.micronaut.core.value.ValueResolverget, get, getMethods inherited from interface io.micronaut.inject.visitor.VisitorContextgetClassElement, getClassesOutputPath, getConfiguration, getProjectDir, getRequiredClassElement
- 
Constructor Details- 
JavaVisitorContext@Deprecated(forRemoval=true, since="4.3.0") public JavaVisitorContext(ProcessingEnvironment processingEnv, Messager messager, Elements elements, AnnotationUtils annotationUtils, Types types, ModelUtils modelUtils, GenericUtils genericUtils, Filer filer, MutableConvertibleValues<Object> visitorAttributes, TypeElementVisitor.VisitorKind visitorKind) Deprecated, for removal: This API element is subject to removal in a future version.No longer neededThe default constructor.- Parameters:
- processingEnv- The processing environment
- messager- The messager
- elements- The elements
- annotationUtils- The annotation utils
- types- Type types
- modelUtils- The model utils
- genericUtils- The generic type utils
- filer- The filer
- visitorAttributes- The attributes
- visitorKind- The visitor kind
 
- 
JavaVisitorContext@Deprecated(forRemoval=true, since="4.7.0") public JavaVisitorContext(ProcessingEnvironment processingEnv, Messager messager, Elements elements, Types types, ModelUtils modelUtils, Filer filer, MutableConvertibleValues<Object> visitorAttributes, TypeElementVisitor.VisitorKind visitorKind) Deprecated, for removal: This API element is subject to removal in a future version.No longer neededThe default constructor.- Parameters:
- processingEnv- The processing environment
- messager- The messager
- elements- The elements
- types- Type types
- modelUtils- The model utils
- filer- The filer
- visitorAttributes- The attributes
- visitorKind- The visitor kind
 
- 
JavaVisitorContextpublic JavaVisitorContext(ProcessingEnvironment processingEnv, Messager messager, Elements elements, Types types, ModelUtils modelUtils, Filer filer, MutableConvertibleValues<Object> visitorAttributes, TypeElementVisitor.VisitorKind visitorKind, Set<String> postponedTypes) The default constructor.- Parameters:
- processingEnv- The processing environment
- messager- The messager
- elements- The elements
- types- Type types
- modelUtils- The model utils
- filer- The filer
- visitorAttributes- The attributes
- visitorKind- The visitor kind
- postponedTypes- The postponed types
 
 
- 
- 
Method Details- 
getLanguage- Specified by:
- getLanguagein interface- VisitorContext
- Returns:
- The visitor context's language.
 
- 
getVisitorKind- Returns:
- The visitor kind
 
- 
getProcessingEnv- Returns:
- The processing environment
 
- 
isVisitUnresolvedInterfacespublic boolean isVisitUnresolvedInterfaces()- Returns:
- True if the unresolved interfaces should be visited
- Since:
- 4.9
 
- 
setVisitUnresolvedInterfacespublic void setVisitUnresolvedInterfaces(boolean visitUnresolvedInterfaces) - Parameters:
- visitUnresolvedInterfaces- True to visit unresolved interfaces
- Since:
- 4.9
 
- 
getClasspathResourcesDescription copied from interface:VisitorContextObtain a set of resources from the user classpath.- Specified by:
- getClasspathResourcesin interface- VisitorContext
- Parameters:
- path- The path
- Returns:
- An iterable of resources
 
- 
getClassElementDescription copied from interface:VisitorContextThis method will look up another class element by name. If it cannot be found an empty optional will be returned.- Specified by:
- getClassElementin interface- VisitorContext
- Parameters:
- name- The name
- Returns:
- The class element
 
- 
getClassElementpublic Optional<ClassElement> getClassElement(String name, ElementAnnotationMetadataFactory annotationMetadataFactory) Description copied from interface:VisitorContextThis method will look up another class element by name. If it cannot be found an empty optional will be returned.- Specified by:
- getClassElementin interface- VisitorContext
- Parameters:
- name- The name
- annotationMetadataFactory- The element annotation metadata factory
- Returns:
- The class element
 
- 
getClassElements@NonNull public @NonNull ClassElement[] getClassElements(@NonNull @NonNull String aPackage, @NonNull @NonNull String... stereotypes) Description copied from interface:VisitorContextFind all the classes within the given package and having the given annotation.- Specified by:
- getClassElementsin interface- VisitorContext
- Parameters:
- aPackage- The package
- stereotypes- The stereotypes
- Returns:
- The class elements
 
- 
getElementFactoryDescription copied from interface:VisitorContextGets the element factory for this visitor context.- Specified by:
- getElementFactoryin interface- VisitorContext
- Returns:
- The element factory
 
- 
getElementAnnotationMetadataFactoryDescription copied from interface:VisitorContextGets the element annotation metadata factory.- Specified by:
- getElementAnnotationMetadataFactoryin interface- VisitorContext
- Returns:
- The element annotation metadata factory
 
- 
getExpressionCompilationContextFactory@NonNull public @NonNull ExpressionCompilationContextFactory getExpressionCompilationContextFactory()- Specified by:
- getExpressionCompilationContextFactoryin interface- VisitorContext
- Returns:
- The expression compilation context factory.
 
- 
getAnnotationMetadataBuilderDescription copied from interface:VisitorContextGets the annotation metadata builder.- Specified by:
- getAnnotationMetadataBuilderin interface- VisitorContext
- Returns:
- The annotation metadata builder
 
- 
infoDescription copied from interface:VisitorContextAllows printing informational messages.- Specified by:
- infoin interface- VisitorContext
- Parameters:
- message- The message
- element- The element
 
- 
infoDescription copied from interface:VisitorContextAllows printing informational messages.- Specified by:
- infoin interface- VisitorContext
- Parameters:
- message- The message
 
- 
failDescription copied from interface:VisitorContextAllows failing compilation for a given element with the given message.- Specified by:
- failin interface- VisitorContext
- Parameters:
- message- The message
- element- The element
 
- 
warnDescription copied from interface:VisitorContextAllows printing a warning for the given message and element.- Specified by:
- warnin interface- VisitorContext
- Parameters:
- message- The message
- element- The element
 
- 
warnPrint warning message.- Parameters:
- message- The message
- element- The element
- Since:
- 4.0.0
 
- 
visitClasspublic OutputStream visitClass(String classname, @Nullable Element originatingElement) throws IOException Description copied from interface:ClassWriterOutputVisitorVisits a new class and returns the output stream with which should be written the bytes of the class to be generated.- Specified by:
- visitClassin interface- ClassWriterOutputVisitor
- Parameters:
- classname- the fully qualified classname
- originatingElement- The originating element
- Returns:
- the output stream to write to
- Throws:
- IOException- if an error occurs creating the output stream
 
- 
visitClassDescription copied from interface:ClassWriterOutputVisitorVisits a new class and returns the output stream with which should be written the bytes of the class to be generated.Note that this method should only be called from a TypeElementVisitor.VisitorKind.AGGREGATINGvisitor from within theTypeElementVisitor.finish(io.micronaut.inject.visitor.VisitorContext)method. If the file- Specified by:
- visitClassin interface- ClassWriterOutputVisitor
- Parameters:
- classname- the fully qualified classname
- originatingElements- The originating elements
- Returns:
- the output stream to write to
- Throws:
- IOException- if an error occurs creating the output stream
 
- 
visitServiceDescriptorDescription copied from interface:ClassWriterOutputVisitorAllows adding a class that will be written to theMETA-INF/servicesfile under the given type and class name.- Specified by:
- visitServiceDescriptorin interface- ClassWriterOutputVisitor
- Parameters:
- type- the fully qualified service name
- classname- the fully qualified classname
 
- 
visitServiceDescriptorDescription copied from interface:ClassWriterOutputVisitorAllows adding a class that will be written to theMETA-INF/servicesfile under the given type and class name.- Specified by:
- visitServiceDescriptorin interface- ClassWriterOutputVisitor
- Parameters:
- type- the fully qualified service name
- classname- the fully qualified classname
- originatingElement- The originating element
 
- 
visitMetaInfFileDescription copied from interface:VisitorContextVisit a file within the META-INF directory.- Specified by:
- visitMetaInfFilein interface- ClassWriterOutputVisitor
- Specified by:
- visitMetaInfFilein interface- VisitorContext
- Parameters:
- path- The path to the file
- originatingElements- The originating elements
- Returns:
- An optional file it was possible to create it
 
- 
visitGeneratedFileDescription copied from interface:VisitorContextVisit a file that will be located within the generated source directory.- Specified by:
- visitGeneratedFilein interface- ClassWriterOutputVisitor
- Specified by:
- visitGeneratedFilein interface- VisitorContext
- Parameters:
- path- The path to the file
- Returns:
- An optional file it was possible to create it
 
- 
visitGeneratedFileDescription copied from interface:ClassWriterOutputVisitorVisit a file that will be generated within the generated 'sources' directory.- Specified by:
- visitGeneratedFilein interface- ClassWriterOutputVisitor
- Parameters:
- path- The path
- originatingElements- the originating elements
- Returns:
- The file if it was possible to create it
 
- 
visitGeneratedSourceFilepublic Optional<GeneratedFile> visitGeneratedSourceFile(String packageName, String fileNameWithoutExtension, Element... originatingElements) Description copied from interface:ClassWriterOutputVisitorVisit a source file that will be generated within the generated 'sources' directory.- Specified by:
- visitGeneratedSourceFilein interface- ClassWriterOutputVisitor
- Parameters:
- packageName- The package for the source file
- fileNameWithoutExtension- the name of the source file, without extension (determined automatically)
- originatingElements- the originating elements
- Returns:
- The file if it was possible to create it
 
- 
finishpublic void finish()Description copied from interface:ClassWriterOutputVisitorFinish writing and flush any service entries to disk.- Specified by:
- finishin interface- ClassWriterOutputVisitor
 
- 
getMessagerThe messager.- Returns:
- The messager
 
- 
getModelUtilsThe model utils.- Returns:
- The model utils
 
- 
getElementsThe elements.- Returns:
- The elements
 
- 
getAnnotationUtilsDeprecated, for removal: This API element is subject to removal in a future version.No longer usedThe annotation utils.- Returns:
- The annotation utils
 
- 
getTypesThe types.- Returns:
- The types
 
- 
getGenericUtilsDeprecated, for removal: This API element is subject to removal in a future version.No longer usedThe generic utils object.- Returns:
- The generic utils
 
- 
getNativeElementsHelper- Returns:
- The elements helper
 
- 
getOptionsJava visitor context options fromjavacarguments andSystem.getProperties()System properties has priority over arguments. - Specified by:
- getOptionsin interface- VisitorContext
- Returns:
- Java visitor context options for all visitors
- See Also:
 
- 
putDescription copied from interface:MutableConvertibleValuesInsert a value for the given key and value.- Specified by:
- putin interface- MutableConvertibleValues<Object>
- Parameters:
- key- The key
- value- The value
- Returns:
- This values instance
 
- 
removeDescription copied from interface:MutableConvertibleValuesRemove a value for the given key.- Specified by:
- removein interface- MutableConvertibleValues<Object>
- Parameters:
- key- The key
- Returns:
- This values instance
 
- 
clearDescription copied from interface:MutableConvertibleValuesClear all values.- Specified by:
- clearin interface- MutableConvertibleValues<Object>
- Returns:
- This values instance
 
- 
names- Specified by:
- namesin interface- ConvertibleValues<Object>
- Returns:
- The names of the values
 
- 
values- Specified by:
- valuesin interface- ConvertibleValues<Object>
- Returns:
- The values
 
- 
getDescription copied from interface:ValueResolverResolve the given property for the given name.- Specified by:
- getin interface- ValueResolver<CharSequence>
- Type Parameters:
- T- The concrete type
- Parameters:
- name- The name
- conversionContext- The conversion context
- Returns:
- An optional containing the property value if it exists and is able to be converted
 
- 
getGeneratedResourcesDescription copied from interface:VisitorContextProvide a collection of generated classpath resources that other TypeElement visitors might want to consume. The generated resources are intended to be strings paths relative to the classpath root.- Specified by:
- getGeneratedResourcesin interface- VisitorContext
- Returns:
- a possibly empty collection of resource paths
 
- 
addGeneratedResourceDescription copied from interface:VisitorContextSome TypeElementVisitors generate classpath resources that other visitors might be interested in. The generated resources are intended to be strings paths relative to the classpath root- Specified by:
- addGeneratedResourcein interface- VisitorContext
- Parameters:
- resource- the relative path to add
 
- 
getBeanElementBuilders- Returns:
- Gets the produced bean definition builders.
 
- 
addAssociatedBean- Specified by:
- addAssociatedBeanin interface- BeanElementVisitorContext
 
 
-