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

ch.sourcepond.maven.plugin.jenkins.process.cmd.Token Maven / Gradle / Ivy

Go to download

The Jenkins Maven Plugin allows to use the Jenkins CLI (command line interface) from within a Maven build. It allows the execution of any command supported by the CLI, see https://wiki.jenkins-ci.org/display/JENKINS/Jenkins+CLI for further information. Therefore, it downloads the current jenkins-cli.jar from ${project.ciManagement.url}/jnlpJars/jenkins-cli.jar and uses that artifact for interacting with the Jenkins server. The architecture of the Jenkins Maven Plugin follows the UNIX philosophy "do one thing and do it well": it does not provide any logic for specific tasks, for instance creating job configuration files. This can be done with another, more appropriate plugin and its result can then be specified as stdin to the Jenkins Maven Plugin.

There is a newer version: 1.2.0
Show newest version
/*Copyright (C) 2015 Roland Hauser, 

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 ch.sourcepond.maven.plugin.jenkins.process.cmd;

import java.util.List;

import org.apache.maven.plugin.MojoExecutionException;

import ch.sourcepond.maven.plugin.jenkins.config.Config;

/**
 *
 */
abstract class Token implements CommandToken {
	private CommandToken next;

	/**
	 * @param pNext
	 */
	Token(final CommandToken pNext) {
		next = pNext;
	}

	/**
	 * Determines whether this token should be visited.
	 * 
	 * @param pConfig
	 *            {@link Config} instance which contains all necessary
	 *            information, must not be {@code null}.
	 * @return {@code true} if this token should be visited, {@code false}
	 *         otherwise
	 */
	protected boolean isVisitNecessary(final Config pConfig) {
		return true;
	}

	/**
	 * @param pConfig
	 * @param pTokens
	 * @throws MojoExecutionException
	 */
	protected abstract void doVisitToken(List pTokens, Config pConfig);

	/**
	 * @param pTokens
	 * @param pConfig
	 * @throws MojoExecutionException
	 */
	@Override
	public final void visitToken(final List pTokens,
			final Config pConfig) {
		assert pTokens != null : "pTokens is null";
		assert pConfig != null : " pConfig is null";

		if (isVisitNecessary(pConfig)) {
			doVisitToken(pTokens, pConfig);
		}
		if (next != null) {
			next.visitToken(pTokens, pConfig);
		}
	}

	/**
	 * @param pTokens
	 * @param pName
	 * @param pValue
	 */
	protected final void addParameter(final List pTokens,
			final String pName, final Object pValue) {
		assert pName != null : "pName is null";
		assert pValue != null : "pValue is null";
		pTokens.add(pName);
		pTokens.add(pValue.toString());
	}

	/**
	 * @param pTokens
	 * @param pName
	 * @param pValue
	 */
	protected final void addSingleParameter(final List pTokens,
			final String pName, final Object pValue) {
		assert pName != null : "pName is null";
		assert pValue != null : "pValue is null";
		pTokens.add(pName + "=" + pValue.toString());
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy