net.nicoulaj.maven.plugins.checksum.mojo.FilesMojo Maven / Gradle / Ivy
/*
* checksum-maven-plugin - http://checksum-maven-plugin.nicoulaj.net
* Copyright © 2010-2021 checksum-maven-plugin contributors
*
* 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 net.nicoulaj.maven.plugins.checksum.mojo;
import org.apache.maven.model.FileSet;
import org.apache.maven.plugins.annotations.LifecyclePhase;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
import org.apache.maven.shared.utils.io.DirectoryScanner;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
/**
* Compute specified files checksum digests and store them in individual files
* and/or a summary file.
*
* The files are not filtered.
*
* Optionally attaches the checksum files as additional project artifacts (with no classifier)
*
* @author Julien Nicoulaud
* @since 1.0
* @version $Id: $Id
*/
@Mojo(
name = FilesMojo.NAME,
defaultPhase = LifecyclePhase.VERIFY,
requiresProject = true,
inheritByDefault = false,
threadSafe = true )
public class FilesMojo
extends AbstractChecksumMojo
{
/**
* The mojo name.
*/
public static final String NAME = "files";
/**
* The default file inclusion pattern.
*
* @see #getFilesToProcess()
*/
protected static final String[] DEFAULT_INCLUDES = { "**/**" };
/**
* The list of files to process.
*
* Use the following syntax:
*
<fileSets>
* <fileSet>
* <directory>...</directory>
* <includes>
* <include>...</include>
* </includes>
* <excludes>
* <exclude>...</exclude>
* </excludes>
* </fileSet>
* </fileSets>
*
* @since 1.1
*/
@Parameter( required = true )
protected List fileSets;
/**
* Indicates whether the build will store checksums in separate files (one file per algorithm per artifact).
*
* @since 1.0
*/
@Parameter( defaultValue = "true" )
protected boolean individualFiles;
/**
* The directory where output files will be stored. Leave unset to have each file next to the source file.
*
* @since 1.0
*/
@Parameter
protected String individualFilesOutputDirectory;
/**
* Indicates whether the build will store checksums to a single CSV summary file.
*
* @since 1.0
*/
@Parameter( defaultValue = "true" )
protected boolean csvSummary;
/**
* The name of the summary file created if the option is activated.
*
* @see #csvSummary
* @since 1.0
*/
@Parameter( defaultValue = "checksums.csv" )
protected String csvSummaryFile;
/**
* Indicates whether the build will store checksums to a single XML summary file.
*
* @since 1.0
*/
@Parameter( defaultValue = "false" )
protected boolean xmlSummary;
/**
* The name of the summary file created if the option is activated.
*
* @see #xmlSummary
* @since 1.0
*/
@Parameter( defaultValue = "checksums.xml" )
protected String xmlSummaryFile;
/**
* Indicates whether the build will store checksums to a single shasum summary file.
*
* @since 1.3
*/
@Parameter( defaultValue = "false" )
protected boolean shasumSummary;
/**
* The name of the summary file created if the option is activated.
*
* @see #shasumSummary
* @since 1.3
*/
@Parameter( defaultValue = "checksums.sha" )
protected String shasumSummaryFile;
/**
* Fail if no file found to calculate checksum.
*
* @since 1.7
*/
@Parameter( defaultValue = "true" )
protected boolean failIfNoFiles;
/**
* Constructor.
*/
public FilesMojo() {
super(true, true, true);
}
/**
* {@inheritDoc}
*
* Build the list of files from which digests should be generated.
*/
@Override
protected List getFilesToProcess()
{
final List filesToProcess = new ArrayList<>();
for ( final FileSet fileSet : fileSets )
{
final DirectoryScanner scanner = new DirectoryScanner();
final String fileSetDirectory = (new File( fileSet.getDirectory() ) ).getPath();
scanner.setBasedir( fileSetDirectory );
String[] includes;
if ( fileSet.getIncludes() != null && !fileSet.getIncludes().isEmpty() )
{
final List fileSetIncludes = fileSet.getIncludes();
includes = fileSetIncludes.toArray( new String[0] );
}
else
{
includes = DEFAULT_INCLUDES;
}
scanner.setIncludes( includes );
if ( fileSet.getExcludes() != null && !fileSet.getExcludes().isEmpty() )
{
final List fileSetExcludes = fileSet.getExcludes();
scanner.setExcludes( fileSetExcludes.toArray( new String[0] ) );
}
scanner.addDefaultExcludes();
scanner.scan();
for ( String filePath : scanner.getIncludedFiles() )
{
filesToProcess.add( new ChecksumFile( (new File( fileSetDirectory ) ).getPath(), new File( fileSetDirectory, filePath ), null, null ) );
}
}
return filesToProcess;
}
/** {@inheritDoc} */
@Override
protected boolean isIndividualFiles()
{
return individualFiles;
}
/** {@inheritDoc} */
@Override
protected String getIndividualFilesOutputDirectory()
{
return individualFilesOutputDirectory;
}
/** {@inheritDoc} */
@Override
protected boolean isCsvSummary()
{
return csvSummary;
}
/** {@inheritDoc} */
@Override
protected String getCsvSummaryFile()
{
return csvSummaryFile;
}
/** {@inheritDoc} */
@Override
protected boolean isXmlSummary()
{
return xmlSummary;
}
/** {@inheritDoc} */
@Override
protected String getXmlSummaryFile()
{
return xmlSummaryFile;
}
/** {@inheritDoc} */
@Override
protected boolean isShasumSummary()
{
return shasumSummary;
}
/** {@inheritDoc} */
@Override
protected String getShasumSummaryFile()
{
return shasumSummaryFile;
}
/** {@inheritDoc} */
@Override
protected boolean isFailIfNoFiles(){
return failIfNoFiles;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy