/* * Copyright 2009 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.Describable; import org.gradle.api.Named; import org.gradle.api.provider.Provider; import org.gradle.api.tasks.util.PatternFilterable; import org.gradle.model.internal.core.UnmanagedStruct; import java.io.File; import java.util.Set; /** * <p>A {@code SourceDirectorySet} represents a set of source files composed from a set of source directories, along * with associated include and exclude patterns.</p> * * <p>{@code SourceDirectorySet} extends {@link FileTree}. The contents of the file tree represent the source files of this set, arranged in a hierarchy. The file tree is live and reflects changes to the source directories and their contents.</p> */ @UnmanagedStruct public interface SourceDirectorySet extends FileTree, PatternFilterable, Named, Describable { /** * A concise name for the source directory set (typically used to identify it in a collection). */ String getName(); /** * Adds the given source directory to this set. The given directory does not need to exist. Directories that do not exist are ignored. * * @param srcPath The source directory. This is evaluated as per {@link org.gradle.api.Project#files(Object...)} * @return this */ SourceDirectorySet srcDir(Object srcPath); /** * Adds the given source directories to this set. The given directories to not need to exist. Directories that do no exist are ignored. * * @param srcPaths The source directories. These are evaluated as per {@link org.gradle.api.Project#files(Object...)} * @return this */ SourceDirectorySet srcDirs(Object... srcPaths); /** * Returns the source directories that make up this set. Does not filter source directories that do not exist. * * @return The source directories. Returns an empty set when this set contains no source directories. */ Set<File> getSrcDirs(); /** * Sets the source directories for this set. * * @param srcPaths The source directories. These are evaluated as per {@link org.gradle.api.Project#files(Object...)} * @return this */ SourceDirectorySet setSrcDirs(Iterable<?> srcPaths); /** * Adds the given source to this set. * * @param source The source to add. * @return this */ SourceDirectorySet source(SourceDirectorySet source); /** * Returns the source directories that make up this set, represented as a {@link FileCollection}. Does not filter source directories that do not exist. * Generally, it is preferable to use this method instead of {@link #getSrcDirs()}, as this method does not require the source directories to be calculated when it is called. Instead, the source directories are calculated when queried. The return value of this method also maintains dependency information. * * <p>The returned collection is live and reflects changes to this source directory set. */ FileCollection getSourceDirectories(); /** * Returns the source directory trees that make up this set. Does not filter source directories that do not exist. * * @return The source directory trees. Returns an empty set when this set contains no source directories. */ Set<DirectoryTree> getSrcDirTrees(); /** * Returns the filter used to select the source from the source directories. These filter patterns are applied after * the include and exclude patterns of this source directory set. Generally, the filter patterns are used to * restrict the contents to certain types of files, eg {@code *.java}. * * @return The filter patterns. */ PatternFilterable getFilter(); /** * Returns the directory to put the output for these sources. * * @return The output directory for this set of sources. * @since 4.0 */ File getOutputDir(); /** * Sets the provider that gives the directory to assemble the compiled classes into. * @param provider provides output directory for this source directory set * @since 4.0 */ void setOutputDir(Provider<File> provider); /** * Sets the directory to assemble the compiled classes into. * * @param outputDir output directory for this source directory set * @since 4.0 */ void setOutputDir(File outputDir); }