Browse Source

Plugable ExtensionStorage in ExtensionAnnotationProcessor (via processor options and system properties)

pull/87/head
Decebal Suiu 9 years ago
parent
commit
494d0fed21
  1. 42
      pf4j/src/main/java/ro/fortsoft/pf4j/processor/ExtensionAnnotationProcessor.java

42
pf4j/src/main/java/ro/fortsoft/pf4j/processor/ExtensionAnnotationProcessor.java

@ -28,6 +28,7 @@ import javax.lang.model.type.DeclaredType;
import javax.lang.model.type.TypeKind; import javax.lang.model.type.TypeKind;
import javax.lang.model.type.TypeMirror; import javax.lang.model.type.TypeMirror;
import javax.tools.Diagnostic; import javax.tools.Diagnostic;
import java.lang.reflect.Constructor;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.HashSet; import java.util.HashSet;
@ -41,6 +42,8 @@ import java.util.TreeSet;
*/ */
public class ExtensionAnnotationProcessor extends AbstractProcessor { public class ExtensionAnnotationProcessor extends AbstractProcessor {
private static final String STORAGE_CLASS_NAME = "pf4j.storageClassName";
private Map<String, Set<String>> extensions = new HashMap<>(); // the key is the extension point private Map<String, Set<String>> extensions = new HashMap<>(); // the key is the extension point
private Map<String, Set<String>> oldExtensions = new HashMap<>(); // the key is the extension point private Map<String, Set<String>> oldExtensions = new HashMap<>(); // the key is the extension point
@ -50,8 +53,7 @@ public class ExtensionAnnotationProcessor extends AbstractProcessor {
public synchronized void init(ProcessingEnvironment processingEnv) { public synchronized void init(ProcessingEnvironment processingEnv) {
super.init(processingEnv); super.init(processingEnv);
storage = new LegacyExtensionStorage(this); storage = createStorage();
// storage = new ServiceProviderExtensionStorage(this);
} }
@Override @Override
@ -67,6 +69,14 @@ public class ExtensionAnnotationProcessor extends AbstractProcessor {
return annotationTypes; return annotationTypes;
} }
@Override
public Set<String> getSupportedOptions() {
Set<String> options = new HashSet<>();
options.add(STORAGE_CLASS_NAME);
return options;
}
@Override @Override
public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) { public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) {
if (roundEnv.processingOver()) { if (roundEnv.processingOver()) {
@ -194,5 +204,33 @@ public class ExtensionAnnotationProcessor extends AbstractProcessor {
return processingEnv.getElementUtils().getTypeElement(ExtensionPoint.class.getName()).asType(); return processingEnv.getElementUtils().getTypeElement(ExtensionPoint.class.getName()).asType();
} }
private ExtensionStorage createStorage() {
ExtensionStorage storage = null;
// search in processing options
String storageClassName = processingEnv.getOptions().get(STORAGE_CLASS_NAME);
if (storageClassName == null) {
// search in system properties
storageClassName = System.getProperty(STORAGE_CLASS_NAME);
}
if (storageClassName != null) {
// use reflection to create the storage instance
try {
Class storageClass = getClass().getClassLoader().loadClass(storageClassName);
Constructor constructor = storageClass.getConstructor(ExtensionAnnotationProcessor.class);
storage = (ExtensionStorage) constructor.newInstance(this);
} catch (Exception e) {
error(e.getMessage());
}
}
if (storage == null) {
// default storage
storage = new LegacyExtensionStorage(this);
}
return storage;
} }
}

Loading…
Cancel
Save