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

org.gradle.api.provider.Provider Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2017 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.provider;

import org.gradle.api.Incubating;
import org.gradle.api.NonExtensible;
import org.gradle.api.Transformer;
import org.gradle.api.specs.Spec;
import org.gradle.internal.HasInternalProtocol;

import javax.annotation.Nullable;
import java.util.concurrent.Callable;
import java.util.function.BiFunction;

/**
 * A container object that provides a value of a specific type. The value can be retrieved using one of the query methods
 * such as {@link #get()} or {@link #getOrNull()}.
 *
 * 

* A provider may not always have a value available, for example when the value may not yet be known but will be known * at some point in the future. When a value is not available, {@link #isPresent()} returns {@code false} and retrieving * the value will fail with an exception. *

* *

* A provider may not always provide the same value. Although there are no methods on this interface to change the value, * the provider implementation may be mutable or use values from some changing source. A provider may also provide a value * that is mutable and that changes over time. *

* *

* A provider may represent a task output. Such a provider carries information about the task producing its value. When * this provider is attached to an input of another task, Gradle will automatically determine the task dependencies based * on this connection. *

* *

* A typical use of a provider is to pass values from one Gradle model element to another, e.g. from a project extension * to a task, or between tasks. Providers also allow expensive computations to be deferred until their value is actually * needed, usually at task execution time. *

* *

* There are a number of ways to create a {@link Provider} instance. Some common methods: *

* *
    *
  • A number of Gradle types, such as {@link Property}, extend {@link Provider} and can be used directly as a provider.
  • *
  • Calling {@link #map(Transformer)} to create a new provider from an existing provider.
  • *
  • Using the return value of {@link org.gradle.api.tasks.TaskContainer#register(String)}, which is a provider that represents the task instance.
  • *
  • Using the methods on {@link org.gradle.api.file.Directory} and {@link org.gradle.api.file.DirectoryProperty} to produce file providers.
  • *
  • By calling {@link ProviderFactory#provider(Callable)} or {@link org.gradle.api.Project#provider(Callable)} to create a new provider from a {@link Callable}.
  • *
* *

* For a provider whose value can be mutated, see {@link Property} and the methods on {@link org.gradle.api.model.ObjectFactory}. *

* *

* Note: This interface is not intended for implementation by build script or plugin authors. *

* * @param Type of value represented by provider * @since 4.0 */ @HasInternalProtocol @NonExtensible public interface Provider { /** * Returns the value of this provider if it has a value present, otherwise throws {@code java.lang.IllegalStateException}. * * @return the current value of this provider. * @throws IllegalStateException if there is no value present */ T get(); /** * Returns the value of this provider if it has a value present. Returns {@code null} a value is not available. * * @return the value or {@code null} */ @Nullable T getOrNull(); /** * Returns the value of this provider if it has a value present. Returns the given default value if a value is * not available. * * @return the value or the default value. * @since 4.3 */ T getOrElse(T defaultValue); /** * Returns a new {@link Provider} whose value is the value of this provider transformed using the given function. * *

* The resulting provider will be live, so that each time it is queried, it queries the original (this) provider * and applies the transformation to the result. Whenever the original provider has no value, the new provider * will also have no value and the transformation will not be called. *

* *

* When this provider represents a task or the output of a task, the new provider will be considered an output * of the task and will carry dependency information that Gradle can use to automatically attach task dependencies * to tasks that use the new provider for input values. *

* * @param transformer The transformer to apply to values. May return {@code null}, in which case the provider will have no value. * @since 4.3 */ Provider map(Transformer transformer); /** * Returns a new {@link Provider} with the value of this provider if the passed spec is satisfied and no value otherwise. * *

* The resulting provider will be live, so that each time it is queried, it queries the original (this) provider * and applies the spec to the result. Whenever the original provider has no value, the new provider * will also have no value and the spec will not be called. *

* * @param spec The spec to test the value. * @since 8.5 */ @Incubating Provider filter(Spec spec); /** * Returns a new {@link Provider} from the value of this provider transformed using the given function. * *

* While very similar in functionality to the regular {@link #map(Transformer) map} operation, this method * offers a convenient way of connecting together task inputs and outputs. (For a deeper understanding of * the topic see the Lazy Configuration * section of the Gradle manual.)

* *

* Task inputs and outputs often take the form of {@link Provider providers} or {@link Property properties}, * the latter being a special case of provider whose value can be changed at will. An example of using * {@code flatMap} for connecting such properties would be following: *

* *

     * class Producer extends DefaultTask {
     *     {@literal @}OutputFile
     *     abstract RegularFileProperty getOutputFile()
     *
     *     //irrelevant details omitted
     * }
     *
     * class Consumer extends DefaultTask {
     *     {@literal @}InputFile
     *     abstract RegularFileProperty getInputFile()
     *
     *     //irrelevant details omitted
     * }
     *
     * def producer = tasks.register("producer", Producer)
     * def consumer = tasks.register("consumer", Consumer)
     *
     * consumer.configure {
     *     inputFile = producer.flatMap { it.outputFile }
     * }
     * 
* *

* An added benefit of connecting input and output properties like this is that Gradle can automatically * detect task dependencies based on such connections. To make this happen at code level, any task * details associated with this provider (the one on which {@code flatMap} is being called) are ignored. * The new provider will use whatever task details are associated with the return value of the transformation. *

* *

* The new provider returned by {@code flatMap} will be live, so that each time it is queried, it queries * this provider and applies the transformation to the result. Whenever this provider has no value, the new * provider will also have no value and the transformation will not be called. *

* * @param transformer The transformer to apply to values. May return {@code null}, in which case the * provider will have no value. * @since 5.0 */ Provider flatMap(Transformer, ? super T> transformer); /** * Returns {@code true} if there is a value present, otherwise {@code false}. * * @return {@code true} if there is a value present, otherwise {@code false} */ boolean isPresent(); /** * Returns a {@link Provider} whose value is the value of this provider, if present, otherwise the * given default value. * * @param value The default value to use when this provider has no value. * @since 5.6 */ Provider orElse(T value); /** * Returns a {@link Provider} whose value is the value of this provider, if present, otherwise uses the * value from the given provider, if present. * * @param provider The provider whose value should be used when this provider has no value. * @since 5.6 */ Provider orElse(Provider provider); /** * Deprecated. There is no need to use this method. * * @since 6.5 * @deprecated Since version 7.4 this method does nothing. All providers can be used at configuration time without explicit opt-in. * @see the upgrade guide */ @Deprecated Provider forUseAtConfigurationTime(); /** * Returns a provider which value will be computed by combining this provider value with another * provider value using the supplied combiner function. * *

* The resulting provider will be live, so that each time it is queried, it queries both this and the supplied provider * and applies the combiner to the results. Whenever any of the providers has no value, the new provider * will also have no value and the combiner will not be called. *

* *

* If the supplied providers represents a task or the output of a task, the resulting provider * will carry the dependency information. *

* * @param right the second provider to combine with * @param combiner the combiner of values. May return {@code null}, in which case the provider * will have no value. * @param the type of the second provider * @param the type of the result of the combiner * @return a combined provider * @since 6.6 */ Provider zip(Provider right, BiFunction combiner); }