All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.codehaus.mojo.license.UpdateFileHeaderMojo Maven / Gradle / Ivy

The newest version!
package org.codehaus.mojo.license;

/*
 * #%L
 * License Maven Plugin
 * %%
 * Copyright (C) 2008 - 2012 CodeLutin, Codehaus, Tony Chemit
 * %%
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation, either version 3 of the
 * License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Lesser Public License for more details.
 *
 * You should have received a copy of the GNU General Lesser Public
 * License along with this program.  If not, see
 * .
 * #L%
 */

import javax.inject.Inject;

import java.util.Map;

import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
import org.codehaus.mojo.license.header.transformer.FileHeaderTransformer;

/**
 * The goal to update (or add) the header on project source files.
 * 

* This goal replace the {@code update-header} goal which can not deal with * Copyright. *

* This goal use a specific project file descriptor {@code project.xml} to * describe all files to update for a whole project. * * @author tchemit [email protected] * @since 1.0 */ @Mojo(name = "update-file-header", threadSafe = true) public class UpdateFileHeaderMojo extends AbstractFileHeaderMojo { // ---------------------------------------------------------------------- // Mojo Parameters // ---------------------------------------------------------------------- /** * A flag to fail the build if {@link #dryRun} flag is on and some files with * no header are detected. *

* Note: If {@link #dryRun} flag is not set, there is no effect. * * @since 1.2 */ @Parameter(property = "license.failOnMissingHeader", defaultValue = "false") private boolean failOnMissingHeader; /** * A flag to fail the build if {@link #dryRun} flag is on and some files with headers * to update. *

* Note: If {@link #dryRun} flag is not set, there is no effect. * * @since 1.2 */ @Parameter(property = "license.failOnNotUptodateHeader", defaultValue = "false") private boolean failOnNotUptodateHeader; /** * A flag to skip the goal. * * @since 1.0 */ @Parameter(property = "license.skipUpdateLicense", defaultValue = "false") private boolean skipUpdateLicense; /** * A flag to test plugin but modify no file. * * @since 1.0 */ @Parameter(property = "dryRun", defaultValue = "false") private boolean dryRun; @Inject public UpdateFileHeaderMojo(Map transformers) { super(transformers); } // ---------------------------------------------------------------------- // AbstractLicenceMojo Implementation // ---------------------------------------------------------------------- @Override public boolean isSkip() { return skipUpdateLicense; } // ---------------------------------------------------------------------- // AbstractFileHeaderMojo Implementation // ---------------------------------------------------------------------- @Override protected boolean isDryRun() { return dryRun; } @Override protected boolean isFailOnMissingHeader() { return failOnMissingHeader; } @Override protected boolean isFailOnNotUptodateHeader() { return failOnNotUptodateHeader; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy