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

org.gradle.api.tasks.TaskInputs Maven / Gradle / Ivy

There is a newer version: 8.11.1
Show newest version
/*
 * Copyright 2010 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.tasks;

import org.gradle.api.file.FileCollection;
import org.gradle.internal.HasInternalProtocol;

import javax.annotation.Nullable;
import java.util.Map;

/**
 * 

A {@code TaskInputs} represents the inputs for a task.

* *

You can obtain a {@code TaskInputs} instance using {@link org.gradle.api.Task#getInputs()}.

*/ @HasInternalProtocol public interface TaskInputs { /** * Returns true if this task has declared the inputs that it consumes. * * @return true if this task has declared any inputs. */ boolean getHasInputs(); /** * Returns the input files of this task. * * @return The input files. Returns an empty collection if this task has no input files. */ FileCollection getFiles(); /** * Registers some input files for this task. * * @param paths The input files. The given paths are evaluated as per {@link org.gradle.api.Project#files(Object...)}. * @return a property builder to further configure the property. */ TaskInputFilePropertyBuilder files(Object... paths); /** * Registers some input file for this task. * * @param path The input file. The given path is evaluated as per {@link org.gradle.api.Project#file(Object)}. * @return a property builder to further configure the property. */ TaskInputFilePropertyBuilder file(Object path); /** * Registers an input directory hierarchy. All files found under the given directory are treated as input files for * this task. * *

An input directory hierarchy ignores empty directories by default. See {@link TaskInputFilePropertyBuilder#ignoreEmptyDirectories()}.

* * @param dirPath The directory. The path is evaluated as per {@link org.gradle.api.Project#file(Object)}. * @return a property builder to further configure the property. */ TaskInputFilePropertyBuilder dir(Object dirPath); /** * Returns a map of input properties for this task. * * The returned map is unmodifiable, and does not reflect further changes to the task's properties. * Trying to modify the map will result in an {@link UnsupportedOperationException} being thrown. * * @return The properties. */ Map getProperties(); /** *

Registers an input property for this task. This value is persisted when the task executes, and is compared * against the property value for later invocations of the task, to determine if the task is up-to-date.

* *

The given value must be a simple value, like a String or Integer, or serializable. For complex values, * Gradle compares the serialized forms for detecting changes and the {@code equals()} method is ignored. * *

If the value is not known when registering the input, a {@link org.gradle.api.provider.Provider} can be * passed instead. Gradle will then resolve the provider at the latest possible time in order to determine the actual * property value.

* * @param name The name of the property. Must not be null. * @param value The value for the property. Can be null. */ TaskInputPropertyBuilder property(String name, @Nullable Object value); /** * Registers a set of input properties for this task. See {@link #property(String, Object)} for details. * *

Note: do not use the return value to chain calls. * Instead always use call via {@link org.gradle.api.Task#getInputs()}.

* * @param properties The properties. */ TaskInputs properties(Map properties); /** * Returns true if this task has declared that it accepts source files. * * @return true if this task has source files, false if not. */ boolean getHasSourceFiles(); /** * Returns the set of source files for this task. These are the subset of input files which the task actually does work on. * A task is skipped if it has declared it accepts source files, and this collection is empty. * * @return The set of source files for this task. */ FileCollection getSourceFiles(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy