mirror of
https://github.com/zaaarf/geb-processor.git
synced 2024-11-22 21:34:53 +01:00
fix: can't access the ProcessingEnv before init()
This commit is contained in:
parent
f5cf9ae236
commit
bee16a300d
1 changed files with 29 additions and 18 deletions
|
@ -9,6 +9,7 @@ import ftbsc.geb.exceptions.BadListenerArgumentsException;
|
||||||
import ftbsc.geb.exceptions.MissingInterfaceException;
|
import ftbsc.geb.exceptions.MissingInterfaceException;
|
||||||
|
|
||||||
import javax.annotation.processing.AbstractProcessor;
|
import javax.annotation.processing.AbstractProcessor;
|
||||||
|
import javax.annotation.processing.ProcessingEnvironment;
|
||||||
import javax.annotation.processing.RoundEnvironment;
|
import javax.annotation.processing.RoundEnvironment;
|
||||||
import javax.annotation.processing.SupportedAnnotationTypes;
|
import javax.annotation.processing.SupportedAnnotationTypes;
|
||||||
import javax.lang.model.element.*;
|
import javax.lang.model.element.*;
|
||||||
|
@ -40,6 +41,34 @@ public class GEBProcessor extends AbstractProcessor {
|
||||||
*/
|
*/
|
||||||
private final Set<String> generatedClasses = new HashSet<>();
|
private final Set<String> generatedClasses = new HashSet<>();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A {@link TypeMirror} representing the {@link IListener} interface.
|
||||||
|
*/
|
||||||
|
private TypeMirror listenerInterface;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A {@link TypeMirror} representing the {@link IEvent} interface.
|
||||||
|
*/
|
||||||
|
private TypeMirror eventInterface;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A {@link TypeMirror} representing the {@link IEventDispatcher} interface.
|
||||||
|
*/
|
||||||
|
private TypeMirror dispatcherInterface;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Initializes the processor with the given environment.
|
||||||
|
* Also takes carae of initializing the TypeMirror "constants" for later use.
|
||||||
|
* @param env the environment
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public synchronized void init(ProcessingEnvironment env) {
|
||||||
|
super.init(env);
|
||||||
|
listenerInterface = env.getElementUtils().getTypeElement("ftbsc.geb.api.IListener").asType();
|
||||||
|
eventInterface = env.getElementUtils().getTypeElement("ftbsc.geb.api.IEvent").asType();
|
||||||
|
dispatcherInterface = env.getElementUtils().getTypeElement("ftbsc.geb.api.IEventDispatcher").asType();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The starting point of the processor.
|
* The starting point of the processor.
|
||||||
* It calls {@link #processListener(Element)} on all elements annotated with
|
* It calls {@link #processListener(Element)} on all elements annotated with
|
||||||
|
@ -66,24 +95,6 @@ public class GEBProcessor extends AbstractProcessor {
|
||||||
return claimed;
|
return claimed;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* A {@link TypeMirror} representing the {@link IListener} interface.
|
|
||||||
*/
|
|
||||||
private final TypeMirror listenerInterface = this.processingEnv.getElementUtils()
|
|
||||||
.getTypeElement("ftbsc.geb.api.IListener").asType();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A {@link TypeMirror} representing the {@link IEvent} interface.
|
|
||||||
*/
|
|
||||||
private final TypeMirror eventInterface = this.processingEnv.getElementUtils()
|
|
||||||
.getTypeElement("ftbsc.geb.api.IEvent").asType();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A {@link TypeMirror} representing the {@link IEventDispatcher} interface.
|
|
||||||
*/
|
|
||||||
private final TypeMirror dispatcherInterface = this.processingEnv.getElementUtils()
|
|
||||||
.getTypeElement("ftbsc.geb.api.IEventDispatcher").asType();
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Verifies that the annotated method is valid and, if it is, adds it to
|
* Verifies that the annotated method is valid and, if it is, adds it to
|
||||||
* the list. See the annotation's javadoc for details on what's considered
|
* the list. See the annotation's javadoc for details on what's considered
|
||||||
|
|
Loading…
Reference in a new issue