org.apache.camel.maven.packaging.AbstractGenerateMojo Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of camel-package-maven-plugin Show documentation
Show all versions of camel-package-maven-plugin Show documentation
Maven plugin to help package Camel components and plugins
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 org.apache.camel.maven.packaging;
import java.io.File;
import java.io.IOError;
import java.io.IOException;
import java.io.Writer;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
import java.nio.file.attribute.BasicFileAttributes;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import java.util.zip.ZipFile;
import org.apache.camel.tooling.util.ReflectionHelper;
import org.apache.maven.artifact.Artifact;
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.apache.maven.project.MavenProjectHelper;
import org.codehaus.plexus.build.BuildContext;
public abstract class AbstractGenerateMojo extends AbstractMojo {
private static final String INCREMENTAL_DATA = "";
private final MavenProjectHelper projectHelper;
private final BuildContext buildContext;
@Parameter(property = "project", required = true, readonly = true)
protected MavenProject project;
@Parameter(defaultValue = "${showStaleFiles}")
private boolean showStaleFiles;
@Parameter(defaultValue = "false")
private boolean skip;
protected AbstractGenerateMojo(MavenProjectHelper projectHelper, BuildContext buildContext) {
this.projectHelper = projectHelper;
this.buildContext = buildContext;
}
@Override
public void execute() throws MojoExecutionException, MojoFailureException {
if (skip) {
getLog().info("Skipping execution");
return;
}
try {
if (!isUpToDate(project)) {
doExecute();
writeIncrementalInfo(project);
}
} catch (Exception e) {
throw new MojoFailureException("Error generating data " + e, e);
}
}
protected abstract void doExecute() throws MojoFailureException, MojoExecutionException;
protected void invoke(Class extends AbstractGeneratorMojo> mojoClass)
throws MojoExecutionException, MojoFailureException {
invoke(mojoClass, null);
}
protected void invoke(Class extends AbstractGeneratorMojo> mojoClass, Map parameters)
throws MojoExecutionException, MojoFailureException {
try {
AbstractGeneratorMojo mojo = mojoClass.getDeclaredConstructor(MavenProjectHelper.class, BuildContext.class)
.newInstance(projectHelper, buildContext);
mojo.setLog(getLog());
mojo.setPluginContext(getPluginContext());
// set options using reflections
if (parameters != null && !parameters.isEmpty()) {
ReflectionHelper.doWithFields(mojoClass, field -> {
for (Map.Entry entry : parameters.entrySet()) {
if (field.getName().equals(entry.getKey())) {
ReflectionHelper.setField(field, mojo, entry.getValue());
}
}
});
}
mojo.execute(project);
} catch (MojoExecutionException | MojoFailureException e) {
throw e;
} catch (Exception e) {
throw new MojoFailureException("Unable to create mojo", e);
}
}
private void writeIncrementalInfo(MavenProject project) throws MojoExecutionException {
try {
Path cacheData = getIncrementalDataPath(project);
Files.createDirectories(cacheData.getParent());
try (Writer w = Files.newBufferedWriter(cacheData)) {
w.append(INCREMENTAL_DATA);
}
} catch (IOException e) {
throw new MojoExecutionException("Error checking manifest uptodate status", e);
}
}
private boolean isUpToDate(MavenProject project) throws MojoExecutionException {
try {
Path cacheData = getIncrementalDataPath(project);
final String prvdata = getPreviousRunData(cacheData);
if (INCREMENTAL_DATA.equals(prvdata)) {
long lastmod = Files.getLastModifiedTime(cacheData).toMillis();
Set stale = Stream.concat(Stream.concat(
project.getCompileSourceRoots().stream().map(File::new),
Stream.of(new File(project.getBuild().getOutputDirectory()))),
project.getArtifacts().stream().map(Artifact::getFile))
.flatMap(f -> newer(lastmod, f)).collect(Collectors.toSet());
if (!stale.isEmpty()) {
getLog().info("Stale files detected, re-generating.");
if (showStaleFiles) {
getLog().info("Stale files: " + String.join(", ", stale));
} else if (getLog().isDebugEnabled()) {
getLog().debug("Stale files: " + String.join(", ", stale));
}
} else {
// everything is in order, skip
getLog().info("Skipping generation, everything is up to date.");
return true;
}
} else {
if (prvdata == null) {
getLog().info("No previous run data found, generating files.");
} else {
getLog().info("Configuration changed, re-generating files.");
}
}
} catch (IOException e) {
throw new MojoExecutionException("Error checking uptodate status", e);
}
return false;
}
private String getPreviousRunData(Path cacheData) throws IOException {
if (Files.isRegularFile(cacheData)) {
return Files.readString(cacheData, StandardCharsets.UTF_8);
} else {
return null;
}
}
private Path getIncrementalDataPath(MavenProject project) {
return Paths.get(project.getBuild().getDirectory(), "camel-package-maven-plugin",
"org.apache.camel_camel-package-maven-plugin_info_xx");
}
private static long isRecentlyModifiedFile(Path p) {
try {
BasicFileAttributes fileAttributes = Files.readAttributes(p, BasicFileAttributes.class);
// if it's a directory, we don't care
if (fileAttributes.isDirectory()) {
return 0;
}
return fileAttributes.lastModifiedTime().toMillis();
} catch (IOException e) {
return 0;
}
}
private static Stream newer(long lastmod, File file) {
try {
if (!file.exists()) {
return Stream.empty();
}
BasicFileAttributes fileAttributes = Files.readAttributes(file.toPath(), BasicFileAttributes.class);
if (fileAttributes.isDirectory()) {
return Files.walk(file.toPath()).filter(p -> isRecentlyModifiedFile(p) > lastmod)
.map(Path::toString);
} else if (fileAttributes.isRegularFile()) {
if (fileAttributes.lastModifiedTime().toMillis() > lastmod) {
if (file.getName().endsWith(".jar")) {
try (ZipFile zf = new ZipFile(file)) {
return zf.stream().filter(ze -> !ze.isDirectory())
.filter(ze -> ze.getLastModifiedTime().toMillis() > lastmod)
.map(ze -> file + "!" + ze.getName()).toList().stream();
} catch (IOException e) {
throw new IOException("Error reading zip file: " + file, e);
}
} else {
return Stream.of(file.toString());
}
} else {
return Stream.empty();
}
} else {
return Stream.empty();
}
} catch (IOException e) {
throw new IOError(e);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy