public interface ProcessingEnvironment
Third parties may wish to provide value-add wrappers around the
 facility objects from this interface, for example a Filer
 extension that allows multiple processors to coordinate writing out
 a single source file.  To enable this, for processors running in a
 context where their side effects via the API could be visible to
 each other, the tool infrastructure must provide corresponding
 facility objects that are .equals, Filers that are
 .equals, and so on.  In addition, the tool invocation must
 be able to be configured such that from the perspective of the
 running annotation processors, at least the chosen subset of helper
 classes are viewed as being loaded by the same class loader.
 (Since the facility objects manage shared state, the implementation
 of a wrapper class must know whether or not the same base facility
 object has been wrapped before.)
| Modifier and Type | Method and Description | 
|---|---|
| Elements | getElementUtils()Returns an implementation of some utility methods for
 operating on elements | 
| Filer | getFiler()Returns the filer used to create new source, class, or auxiliary
 files. | 
| Locale | getLocale()Returns the current locale or  nullif no locale is in
 effect. | 
| Messager | getMessager()Returns the messager used to report errors, warnings, and other
 notices. | 
| Map<String,String> | getOptions()Returns the processor-specific options passed to the annotation
 processing tool. | 
| SourceVersion | getSourceVersion() | 
| Types | getTypeUtils()Returns an implementation of some utility methods for
 operating on types. | 
Map<String,String> getOptions()
null.
 See documentation of the particular tool infrastructure
 being used for details on how to pass in processor-specific
 options.  For example, a command-line implementation may
 distinguish processor-specific options by prefixing them with a
 known string like "-A"; other tool implementations may
 follow different conventions or provide alternative mechanisms.
 A given implementation may also provide implementation-specific
 ways of finding options passed to the tool in addition to the
 processor-specific options.
Messager getMessager()
Filer getFiler()
Elements getElementUtils()
Types getTypeUtils()
SourceVersion getSourceVersion()
Processor.getSupportedSourceVersion() Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2025, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.