io.crysknife.generator.ObservesGenerator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of crysknife-processor Show documentation
Show all versions of crysknife-processor Show documentation
apt processor for crysknife-annotations project
The newest version!
/*
* Copyright © 2020 Treblereel
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/
package io.crysknife.generator;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.function.BiConsumer;
import jakarta.enterprise.event.Observes;
import javax.lang.model.element.ExecutableElement;
import javax.lang.model.element.Modifier;
import javax.lang.model.element.VariableElement;
import javax.lang.model.type.TypeMirror;
import com.google.auto.common.MoreElements;
import io.crysknife.client.internal.AbstractEventHandler;
import io.crysknife.client.internal.event.EventManager;
import io.crysknife.definition.MethodDefinition;
import io.crysknife.exception.GenerationException;
import io.crysknife.generator.api.ClassMetaInfo;
import io.crysknife.generator.api.Generator;
import io.crysknife.generator.api.IOCGenerator;
import io.crysknife.generator.api.WiringElementType;
import io.crysknife.generator.context.IOCContext;
import io.crysknife.generator.helpers.FreemarkerTemplateGenerator;
import io.crysknife.generator.helpers.MethodCallGenerator;
import io.crysknife.logger.TreeLogger;
import io.crysknife.util.TypeUtils;
import jsinterop.base.Js;
/**
* @author Dmitrii Tikhomirov Created by treblereel 4/5/19
*/
@Generator(priority = 1000)
public class ObservesGenerator extends IOCGenerator {
private final FreemarkerTemplateGenerator freemarkerTemplateSubscribeGenerator =
new FreemarkerTemplateGenerator("observes/subscribe.ftlh");
private final FreemarkerTemplateGenerator freemarkerTemplateConsumereGenerator =
new FreemarkerTemplateGenerator("observes/consumer.ftlh");
private final FreemarkerTemplateGenerator freemarkerTemplateOnDestroyGenerator =
new FreemarkerTemplateGenerator("observes/onDestroy.ftlh");
private final MethodCallGenerator methodCallGenerator = new MethodCallGenerator(iocContext);
public ObservesGenerator(TreeLogger logger, IOCContext iocContext) {
super(logger, iocContext);
}
@Override
public void register() {
iocContext.register(Observes.class, WiringElementType.PARAMETER, this);
}
public void generate(ClassMetaInfo classMetaInfo, MethodDefinition methodDefinition) {
validate(methodDefinition);
classMetaInfo.addImport(AbstractEventHandler.class);
classMetaInfo.addImport(BiConsumer.class);
classMetaInfo.addImport(EventManager.class);
classMetaInfo.addImport(Js.class);
boolean isDependent = TypeUtils.isDependent(methodDefinition.getBeanDefinition());
VariableElement parameter = methodDefinition.getExecutableElement().getParameters().get(0);
String consumer = getConsumer(methodDefinition.getExecutableElement(), parameter);
String target =
iocContext.getGenerationContext().getTypes().erasure(parameter.asType()).toString();
addConsumerField(classMetaInfo, methodDefinition, target, consumer);
addToOnDestroy(classMetaInfo, target, consumer);
doInitInstance(classMetaInfo, target, consumer, isDependent);
}
private void validate(MethodDefinition methodDefinition) {
ExecutableElement method = methodDefinition.getExecutableElement();
if (method.getParameters().size() > 1) {
throw new GenerationException("Method annotated with @Observes must contain only one param "
+ method.getEnclosingElement() + " " + method);
}
if (method.getModifiers().contains(Modifier.STATIC)) {
throw new GenerationException("Method annotated with @Observes must be non-static "
+ method.getEnclosingElement() + " " + method);
}
}
private String getConsumer(ExecutableElement beanDefinition, VariableElement parameter) {
TypeMirror parameterTypeMirror =
iocContext.getGenerationContext().getTypes().erasure(parameter.asType());
String consumer = parameter.getEnclosingElement().getSimpleName().toString() + "_"
+ parameterTypeMirror.toString().replaceAll("\\.", "_") + "_"
+ MoreElements.asType(beanDefinition.getEnclosingElement()).getQualifiedName().toString()
.replaceAll("\\.", "_");
return consumer;
}
private void addConsumerField(ClassMetaInfo classMetaInfo, MethodDefinition methodDefinition,
String target, String consumer) {
String bean = iocContext.getGenerationContext().getTypes()
.erasure(methodDefinition.getExecutableElement().getEnclosingElement().asType()).toString();
Map root = new HashMap<>();
root.put("target", target);
root.put("bean", bean);
root.put("consumer", consumer);
String call = methodCallGenerator.generate(methodDefinition.getBeanDefinition().getType(),
methodDefinition.getExecutableElement(), List.of("event"));
root.put("call", call);
String source = freemarkerTemplateConsumereGenerator.toSource(root);
classMetaInfo.addToBody(() -> source);
}
private void addToOnDestroy(ClassMetaInfo classMetaInfo, String target, String consumer) {
Map root = new HashMap<>();
root.put("target", target);
root.put("subscriber", consumer);
String source = freemarkerTemplateOnDestroyGenerator.toSource(root);
classMetaInfo.addToOnDestroy(() -> source);
}
private void doInitInstance(ClassMetaInfo classMetaInfo, String target, String consumer,
boolean isDependent) {
Map root = new HashMap<>();
root.put("target", target);
root.put("consumer", consumer);
root.put("isDependent", isDependent);
String source = freemarkerTemplateSubscribeGenerator.toSource(root);
if (!isDependent) {
classMetaInfo.addToFactoryConstructor(() -> source);
}
classMetaInfo.addToDoInitInstance(() -> source);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy