com.github.mictaege.jitter.plugin.ForkMethodProcessor Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jitter-plugin Show documentation
Show all versions of jitter-plugin Show documentation
The jitter-plugin is a Gradle plugin to build and distribute different flavours of an application from a single source base.
The newest version!
package com.github.mictaege.jitter.plugin;
import static com.github.mictaege.jitter.plugin.JitterUtil.active;
import static com.github.mictaege.jitter.plugin.JitterUtil.anyFlavour;
import static com.github.mictaege.jitter.plugin.JitterUtil.log;
import java.util.Optional;
import com.github.mictaege.jitter.api.Fork;
import spoon.processing.AbstractAnnotationProcessor;
import spoon.reflect.declaration.CtMethod;
public class ForkMethodProcessor extends AbstractAnnotationProcessor> {
@Override
public void process(final Fork annotation, final CtMethod> method) {
final String flavour = annotation.ifActive();
if (anyFlavour() && active(flavour)) {
final String altName = annotation.to();
final Optional> altMethod = method.getDeclaringType().getMethodsByName(altName).stream().findFirst();
if (altMethod.isPresent()) {
log().info("Replace method " + method.getDeclaringType().getSimpleName() + "#" + method.getSimpleName() + " with #" + altName);
method.setBody(altMethod.get().getBody());
altMethod.get().delete();
} else {
log().error("The given alternative method " + altName + " could not be found");
}
}
}
}