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

org.gradle.api.plugins.PluginManager Maven / Gradle / Ivy

There is a newer version: 8.11.1
Show newest version
/*
 * Copyright 2014 the original author or authors.
 *
 * 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 org.gradle.api.plugins;

import org.gradle.api.Action;
import org.gradle.api.NonExtensible;
import org.gradle.internal.HasInternalProtocol;

import javax.annotation.Nullable;

/**
 * Facilitates applying plugins and determining which plugins have been applied to a {@link PluginAware} object.
 *
 * @see PluginAware
 * @since 2.3
 */
@HasInternalProtocol
@NonExtensible
public interface PluginManager {

    /**
     * Applies the plugin with the given ID. Does nothing if the plugin has already been applied.
     * 

* Plugins in the {@code "org.gradle"} namespace can be applied directly via name. * That is, the following two lines are equivalent… *

     * pluginManager.apply "org.gradle.java"
     * pluginManager.apply "java"
     * 
* * @param pluginId the ID of the plugin to apply * @since 2.3 */ void apply(String pluginId); /** * Applies the given plugin. Does nothing if the plugin has already been applied. *

* The given class should implement the {@link org.gradle.api.Plugin} interface, and be parameterized for a compatible type of {@code this}. *

* The following two lines are equivalent… *

     * pluginManager.apply org.gradle.api.plugins.JavaPlugin
     * pluginManager.apply "org.gradle.java"
     * 
* * @param type the plugin class to apply * @since 2.3 */ void apply(Class type); /** * Returns the information about the plugin that has been applied with the given ID, or null if no plugin has been applied with the given ID. *

* Plugins in the {@code "org.gradle"} namespace (that is, core Gradle plugins) can be specified by either name (e.g. {@code "java"}) or ID {@code "org.gradle.java"}. * All other plugins must be queried for by their full ID (e.g. {@code "org.company.some-plugin"}). *

* Some Gradle plugins have not yet migrated to fully qualified plugin IDs. * Such plugins can be detected with this method by simply using the unqualified ID (e.g. {@code "some-third-party-plugin"}. * * @param id the plugin ID * @return information about the applied plugin, or {@code null} if no plugin has been applied with the given ID * @since 2.3 */ @Nullable AppliedPlugin findPlugin(String id); /** * Returns {@code true} if a plugin with the given ID has already been applied, otherwise {@code false}. * * @param id the plugin ID. See {@link #findPlugin(String)} for details about this parameter. * @return {@code true} if the plugin has been applied * @since 2.3 */ boolean hasPlugin(String id); /** * Executes the given action when the specified plugin is applied. *

* If a plugin with the specified ID has already been applied, the supplied action will be executed immediately. * Otherwise, the action will executed immediately after a plugin with the specified ID is applied. *

* The given action is always executed after the plugin has been applied. * * @param id the plugin ID. See {@link #findPlugin(String)} for details about this parameter. * @param action the action to execute if/when the plugin is applied * @since 2.3 */ void withPlugin(String id, Action action); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy