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

org.gradle.api.file.Directory Maven / Gradle / Ivy

There is a newer version: 8.6
Show 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.file;

import org.gradle.api.Incubating;
import org.gradle.api.provider.Provider;

import java.io.File;

/**
 * Represents a directory at some fixed location on the file system.
 * 

* Note: This interface is not intended for implementation by build script or plugin authors. An instance of this class can be created * using the {@link #dir(String)} method or using various methods on {@link ProjectLayout} such as {@link ProjectLayout#getProjectDirectory()}. * * @since 4.1 */ public interface Directory extends FileSystemLocation { /** * Returns the location of this directory, as an absolute {@link File}. * * @since 4.2 */ @Override File getAsFile(); /** * Returns a {@link FileTree} that allows the files and directories contained in this directory to be queried. */ FileTree getAsFileTree(); /** * Returns a {@link Directory} whose location is the given path, resolved relative to this directory. * * @param path The path. Can be absolute. * @return The directory. */ Directory dir(String path); /** * Returns a {@link Provider} whose value is a {@link Directory} whose location is the given path resolved relative to this directory. * *

The return value is live and the provided {@code path} is queried each time the return value is queried. * * @param path The path provider. Can have value that is an absolute path. * @return The provider. */ Provider dir(Provider path); /** * Returns a {@link RegularFile} whose location is the given path, resolved relative to this directory. * * @param path The path. Can be absolute. * @return The file. */ RegularFile file(String path); /** * Returns a {@link Provider} whose value is a {@link RegularFile} whose location is the given path resolved relative to this directory. * *

The return value is live and the provided {@code path} is queried each time the return value is queried. * * @param path The path provider. Can have value that is an absolute path. * @return The file. */ Provider file(Provider path); /** * Returns a {@link FileCollection} containing the given files, * whose locations are the given paths resolved relative to this directory, * as defined by {@link org.gradle.api.Project#files(Object...)}. * * This method can also be used to create an empty collection, but the collection may not be mutated later. * * @param paths The paths to the files. May be empty. * @return The file collection. * @since 6.0 */ @Incubating FileCollection files(Object... paths); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy