/******************************************************************************* * * Copyright (c) 2004-2009 Oracle Corporation. * * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * * Tom Huybrechts * * *******************************************************************************/ package hudson.tools; import hudson.ExtensionList; import hudson.ExtensionPoint; import hudson.slaves.NodeSpecific; import hudson.model.Hudson; import hudson.model.Node; import hudson.model.TaskListener; import java.io.File; import java.io.IOException; /** * This Hudson-wide extension points can participate in determining the actual * node-specific path of the {@link ToolInstallation} for the given * {@link Node}. * * <p> This extension point is useful when there's a deterministic rule of where * tools are installed. One can program such a logic and contribute a * {@link ToolLocationTranslator}. Compared to manually specifying * {@link ToolLocationNodeProperty}, duplicated configurations can be avoided * this way. * * <p> Entry point to the translation process is * * @author Kohsuke Kawaguchi * @since 1.299 * @see ToolInstallation#translateFor(Node, TaskListener) */ public abstract class ToolLocationTranslator implements ExtensionPoint { /** * Called for each {@link ToolInstallation#translateFor(Node, TaskListener)} * invocations (which normally means it's invoked for each * {@link NodeSpecific#forNode(Node, TaskListener)}) to translate the tool * location into the node specific location. * * <p> If this implementation is capable of determining the location, return * the path in the absolute file name. (This method doesn't return * {@link File} so that it can handle path names of a different OS. * * <p> Otherwise return null to let other {@link ToolLocationTranslator}s a * chance to do translations on their own. */ public abstract String getToolHome(Node node, ToolInstallation installation, TaskListener log) throws IOException, InterruptedException; /** * Returns all the registered {@link ToolLocationTranslator}s. */ public static ExtensionList<ToolLocationTranslator> all() { return Hudson.getInstance().getExtensionList(ToolLocationTranslator.class); } }