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

org.apache.maven.plugin.AbstractMojo Maven / Gradle / Ivy

There is a newer version: 5.17.0
Show newest version
package org.apache.maven.plugin;

/*
 * 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 org.apache.maven.plugin.logging.Log;
import org.apache.maven.plugin.logging.SystemStreamLog;

import java.util.Map;

/**
 * Abstract class to provide most of the infrastructure required to implement a Mojo except for
 * the execute method.
 * 
* The implementation should have a goal annotation in the class-level javadoc annotation: *
 * /**
 *  * @goal goalName
 *  */
 * 
* * There are also a number of class-level javadoc annotations which can be used to control how and when the * Mojo is executed: *
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
Descriptor ElementAnnotationRequired?Notes
goal@goal <goalName>YesThe name for the Mojo that users will reference from the command line to execute the Mojo directly, * or inside a POM in order to provide Mojo-specific configuration.
implementationnone (detected)YesThe Mojo's fully-qualified class name (or script path in the case of non-Java Mojos).
languagenone (detected)No. Default: javaThe implementation language for this Mojo (Java, beanshell, etc.).
configurator@configurator <roleHint>NoThe configurator type to use when injecting parameter values into this Mojo. The value is normally * deduced from the Mojo's implementation language, but can be specified to allow a custom * ComponentConfigurator implementation to be used. *
* NOTE: This will only be used in very special cases, using a highly controlled vocabulary of possible * values. (Elements like this are why it's a good idea to use the descriptor tools.) *
phase@phase <phaseName>NoBinds this Mojo to a particular phase of the standard build lifecycle, if specified. *
* NOTE: This is only required if this Mojo is to participate in the standard build process. *
execute@execute [phase=<phaseName>|goal=<goalName>] [lifecycle=<lifecycleId>]NoWhen this goal is invoked, it will first invoke a parallel lifecycle, ending at the given phase. * If a goal is provided instead of a phase, that goal will be executed in isolation. * The execution of either will not affect the current project, but instead make available the * ${executedProject} expression if required. An alternate lifecycle can also be provided: * for more information see the documentation on the * build lifecycle. *
requiresDependencyResolution@requiresDependencyResolution <requiredScope>NoFlags this Mojo as requiring the dependencies in the specified scope (or an implied scope) to be * resolved before it can execute. *
* NOTE: Currently supports compile, runtime, and test scopes. *
descriptionnone (detected)NoThe description of this Mojo's functionality. Using the toolset, this will be the class-level * Javadoc description provided. *
* NOTE: While this is not a required part of the Mojo specification, it SHOULD be provided to * enable future tool support for browsing, etc. and for clarity. *
parametersN/ANoSpecifications for the parameters which this Mojo uses will be provided in parameter sub-elements * in this section. *
* NOTE: Parameters are discussed in more detail below. *
* * @see Guide to Developing Java Plugins * @see Guide to Configuring Plug-ins * @see Mojo API Specification * * @author Brett Porter * @author jdcasey * @author Vincent Siveton * @version $Id: AbstractMojo.java 612012 2008-01-15 04:17:35Z vsiveton $ */ public abstract class AbstractMojo implements Mojo, ContextEnabled { /** Instance logger */ private Log log; /** Plugin container context */ private Map pluginContext; /** * @see org.apache.maven.plugin.Mojo#setLog(org.apache.maven.plugin.logging.Log) */ public void setLog( Log log ) { this.log = log; } /** * Returns the logger that has been injected into this mojo. If no logger has been setup yet, a SystemStreamLog * logger will be created and returned. *

* Note: * The logger returned by this method must not be cached in an instance field during the construction of the mojo. * This would cause the mojo to use a wrongly configured default logger when being run by Maven. The proper logger * gets injected by the Plexus container after the mojo has been constructed. Therefore, simply call this * method directly whenever you need the logger, it is fast enough and needs no caching. * * @see org.apache.maven.plugin.Mojo#getLog() */ public Log getLog() { if ( log == null ) { log = new SystemStreamLog(); } return log; } /** * @see org.apache.maven.plugin.ContextEnabled#getPluginContext() */ public Map getPluginContext() { return pluginContext; } /** * @see org.apache.maven.plugin.ContextEnabled#setPluginContext(java.util.Map) */ public void setPluginContext( Map pluginContext ) { this.pluginContext = pluginContext; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy