com.igormaznitsa.jbbp.plugin.mvn.AbstractJBBPMojo Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jbbp-maven-plugin Show documentation
Show all versions of jbbp-maven-plugin Show documentation
Generator of sources from JBBP scripts
The newest version!
package com.igormaznitsa.jbbp.plugin.mvn;
import com.igormaznitsa.jbbp.plugin.common.converters.Target;
import com.igormaznitsa.meta.annotation.MustNotContainNull;
import com.igormaznitsa.meta.common.utils.Assertions;
import java.io.File;
import java.util.HashSet;
import java.util.Set;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import org.apache.maven.plugin.AbstractMojo;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugin.MojoFailureException;
import org.apache.maven.plugins.annotations.Parameter;
import org.apache.maven.project.MavenProject;
import org.codehaus.plexus.compiler.util.scan.InclusionScanException;
import org.codehaus.plexus.compiler.util.scan.SimpleSourceInclusionScanner;
import org.codehaus.plexus.compiler.util.scan.SourceInclusionScanner;
import org.codehaus.plexus.compiler.util.scan.mapping.SuffixMapping;
public abstract class AbstractJBBPMojo extends AbstractMojo {
/**
* Provides an explicit list of all the JBBP scripts that should be included
* in the generate phase of the plug-in.
*
* A set of Ant-like inclusion patterns used to select files from the source
* directory for processing. By default, the pattern
* **/*.jbbp
is used to select JBBP script files.
*
*/
@Parameter(alias = "includes")
protected final Set includes = new HashSet();
/**
* A set of Ant-like exclusion patterns used to prevent certain files from
* being processed. By default, this set is empty such that no files are
* excluded.
*/
@Parameter(alias = "excludes")
protected final Set excludes = new HashSet();
/**
* Current maven project.
*/
@Parameter(property = "project", required = true, readonly = true)
protected MavenProject project;
/**
* Specifies whether sources are added to the {@code compile} or {@code test}
* scope.
*/
@Parameter(alias = "generateTestSources", defaultValue = "false")
protected boolean generateTestSources;
/**
* Package to override package name extracted from script file name, it will be
* common for all processed classes.
*/
@Parameter(alias = "packageName")
protected String packageName;
/**
* Target for translation.
*
* @see Target
*/
@Parameter(alias = "target", defaultValue = "JAVA")
protected String target;
/**
* Flag to skip processing of the plug-in.
*/
@Parameter(alias = "skip", defaultValue = "false")
protected boolean skip;
/**
* Destination directory for generated Java classes, the default value is
* "${project.build.directory}/generated-sources/jbbp"
*/
@Parameter(alias = "output", defaultValue = "${project.build.directory}/generated-sources/jbbp")
protected File output;
/**
* Flag to make plugin verbose.
*/
@Parameter(alias = "verbose", defaultValue = "false")
protected boolean verbose;
/**
* Source directory for JBBP scripts, the default value is
* "${project.basedir}/src/jbbp"
*/
@Parameter(alias = "source", defaultValue = "${project.basedir}/src/jbbp")
protected File source;
@Nullable
public String getTarget() {
return this.target;
}
public void setTarget(@Nullable final String value) {
this.target = value;
}
@MustNotContainNull
@Nonnull
public Set getExcludes() {
return this.excludes;
}
@Nullable
public String getPackageName() {
return this.packageName;
}
public void setPackageName(@Nullable final String text) {
this.packageName = text;
}
@MustNotContainNull
@Nonnull
public Set getIncludes() {
return this.includes;
}
@Nonnull
public File getSource() {
return this.source;
}
public void setSource(@Nonnull final File file) {
this.source = Assertions.assertNotNull("Source must not be null", file);
}
public boolean getSkip() {
return this.skip;
}
public void setSkip(final boolean value) {
this.skip = value;
}
@Nonnull
public File getOutput() {
return this.output;
}
public void setOutput(@Nullable final File file) {
this.output = file;
}
public boolean getVerbose() {
return this.verbose;
}
public void setVerbose(final boolean flag) {
this.verbose = flag;
}
public boolean getGenerateTestSources() {
return this.generateTestSources;
}
public void setGenerateTestSources(final boolean flag) {
this.generateTestSources = flag;
}
protected void registerSourceRoot(@Nonnull final File outputDir) {
if (this.generateTestSources) {
getLog().debug("Registering TEST source root : " + outputDir.getPath());
this.project.addTestCompileSourceRoot(outputDir.getPath());
} else {
getLog().debug("Registering source root : " + outputDir.getPath());
this.project.addCompileSourceRoot(outputDir.getPath());
}
}
@Nonnull
public Set findSources(@Nonnull final File targetDirectory) throws MojoExecutionException {
try {
final SourceInclusionScanner scanner =
new SimpleSourceInclusionScanner(this.includes, this.excludes);
scanner.addSourceMapping(new SuffixMapping("JBBP", "jbbp"));
return scanner.getIncludedSources(this.source, targetDirectory);
} catch (InclusionScanException ex) {
throw new MojoExecutionException("Error during sources scanning", ex);
}
}
public void logInfo(@Nullable final String text, final boolean onlyIfVerbose) {
if (text != null) {
if (this.verbose) {
getLog().info(text);
} else {
if (!onlyIfVerbose) {
getLog().info(text);
}
}
}
}
public boolean checkSetNonEmptyWithLogging(@Nonnull final Set files) {
boolean result = true;
if (files.isEmpty()) {
getLog().warn("There is not any detected JBBP script");
result = false;
}
return result;
}
@Override
public final void execute() throws MojoExecutionException, MojoFailureException {
if (this.skip) {
logInfo("Skip processing", false);
return;
}
if (this.includes.isEmpty()) {
this.includes.add("**/*.jbbp");
}
executeMojo();
}
@Nonnull
public Target findTarget() throws MojoExecutionException {
final Target theTarget;
try {
return Target.valueOf(this.target);
} catch (IllegalArgumentException ex) {
throw new MojoExecutionException("Unsupported target : " + this.target, ex);
}
}
protected abstract void executeMojo() throws MojoExecutionException, MojoFailureException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy