org.gradle.api.file.FileSystemLocationProperty Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-tooling-api Show documentation
Show all versions of gradle-tooling-api Show documentation
Gradle Tooling API - the programmatic API to invoke Gradle
The newest version!
/*
* Copyright 2019 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.file;
import org.gradle.api.provider.Property;
import org.gradle.api.provider.Provider;
import javax.annotation.Nullable;
import java.io.File;
/**
* Represents some element of the file system. A file system element has two parts: its location and its content. A file system element's content, may be the output of a task
* or tasks. This property object keeps track of both the location and the task or tasks that produce the content of the element.
*
* Note: This interface is not intended for implementation by build script or plugin authors.
*
* @param The type of location.
* @since 5.6
*/
public interface FileSystemLocationProperty extends Property {
/**
* Views the location of this file as a {@link File}.
*/
Provider getAsFile();
/**
* Sets the location of this file, using a {@link File} instance. {@link File} instances with relative paths are resolved relative to the project directory of the project
* that owns this property instance.
*/
void set(@Nullable File file);
/**
* Sets the location of this file, using a {@link File} instance. {@link File} instances with relative paths are resolved relative to the project directory of the project
* that owns this property instance.
*
* This method is the same as {@link #set(File)} but allows method chaining.
*
* @return this
* @since 6.0
*/
FileSystemLocationProperty fileValue(@Nullable File file);
/**
* Sets the location of this file, using a {@link File} {@link Provider} instance. {@link File} instances with relative paths are resolved relative to the project directory of the project
* that owns this property instance.
*
* @return this
* @since 6.0
*/
FileSystemLocationProperty fileProvider(Provider provider);
/**
* Returns the location of the file system element, and discards details of the task that produces its content. This allows the location, or a value derived from it, to be used as an input to some other task without implying any dependency on the producing task. This should only be used when the task does, in fact, not use the content of this file system element.
*
* @since 5.6
*/
Provider getLocationOnly();
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy