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

org.apache.maven.plugins.release.AbstractScmReleaseMojo Maven / Gradle / Ivy

Go to download

This plugin is used to release a project with Maven, saving a lot of repetitive, manual work.

There is a newer version: 3.1.1
Show newest version
package org.apache.maven.plugins.release;

/*
 * 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.
 */

import java.util.Map;

import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugin.MojoFailureException;
import org.apache.maven.plugins.annotations.Component;
import org.apache.maven.plugins.annotations.Parameter;
import org.apache.maven.scm.manager.ScmManager;
import org.apache.maven.shared.release.config.ReleaseDescriptor;

/**
 * Abstract Mojo containing SCM parameters 
 *  
 * @author Robert Scholte
 */
// Extra layer since 2.4. Don't use @since doclet, these would be inherited by the subclasses
public abstract class AbstractScmReleaseMojo
    extends AbstractReleaseMojo
{
    /**
     * The SCM username to use.
     */
    @Parameter( property = "username" )
    private String username;

    /**
     * The SCM password to use.
     */
    @Parameter( property = "password" )
    private String password;

    /**
     * The SCM tag to use.
     */
    @Parameter( alias = "releaseLabel", property = "tag" )
    private String tag;

    /**
     * Format to use when generating the tag name if none is specified. Property interpolation is performed on the
     * tag, but in order to ensure that the interpolation occurs during release, you must use @{...}
     * to reference the properties rather than ${...}. The following properties are available:
     * 
    *
  • groupId or project.groupId - The groupId of the root project. *
  • artifactId or project.artifactId - The artifactId of the root project. *
  • version or project.version - The release version of the root project. *
* * @since 2.2.0 */ @Parameter( defaultValue = "@{project.artifactId}-@{project.version}", property = "tagNameFormat" ) private String tagNameFormat; /** * The tag base directory in SVN, you must define it if you don't use the standard svn layout (trunk/tags/branches). * For example, http://svn.apache.org/repos/asf/maven/plugins/tags. The URL is an SVN URL and does not * include the SCM provider and protocol. */ @Parameter( property = "tagBase" ) private String tagBase; /** * The message prefix to use for all SCM changes. * * @since 2.0-beta-5 */ @Parameter( defaultValue = "[maven-release-plugin] ", property = "scmCommentPrefix" ) private String scmCommentPrefix; /** * Implemented with git will or not push changes to the upstream repository. * true by default to preserve backward compatibility. * @since 2.1 */ @Parameter( defaultValue = "true", property = "pushChanges" ) private boolean pushChanges = true; /** * Add a new or overwrite the default implementation per provider. * The key is the scm prefix and the value is the role hint of the * {@link org.apache.maven.scm.provider.ScmProvider}. * * @since 2.0-beta-6 * @see ScmManager#setScmProviderImplementation(String, String) */ @Parameter private Map providerImplementations; /** * The SCM manager. */ @Component private ScmManager scmManager; /** * {@inheritDoc} */ public void execute() throws MojoExecutionException, MojoFailureException { if ( providerImplementations != null ) { for ( Map.Entry providerEntry : providerImplementations.entrySet() ) { getLog().info( "Change the default '" + providerEntry.getKey() + "' provider implementation to '" + providerEntry.getValue() + "'." ); scmManager.setScmProviderImplementation( providerEntry.getKey(), providerEntry.getValue() ); } } } @Override protected ReleaseDescriptor createReleaseDescriptor() { ReleaseDescriptor descriptor = super.createReleaseDescriptor(); descriptor.setScmPassword( password ); descriptor.setScmReleaseLabel( tag ); descriptor.setScmTagNameFormat( tagNameFormat ); descriptor.setScmTagBase( tagBase ); descriptor.setScmUsername( username ); descriptor.setScmCommentPrefix( scmCommentPrefix ); descriptor.setPushChanges( pushChanges ); return descriptor; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy