org.gradle.api.tasks.SourceSetOutput Maven / Gradle / Ivy
Show all versions of gradle-api Show documentation
/*
* 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.api.file.SourceDirectorySet;
import java.io.File;
import java.util.Map;
/**
* A collection of all output directories (compiled classes, processed resources, etc.) - notice that {@link SourceSetOutput} extends {@link FileCollection}.
*
* Provides output information of the source set. Allows configuring the default output dirs and specify additional output dirs.
*
*
* apply plugin: 'java'
*
* sourceSets {
* main {
* //if you truly want to override the defaults:
* output.resourcesDir = file('out/bin')
* // Compiled Java classes should use this directory
* java.outputDir = file('out/bin')
* }
* }
*
*
* Working with generated resources.
*
* In general, we recommend generating resources into folders different than the regular resourcesDir and classesDir.
* Usually, it makes the build easier to understand and maintain. Also it gives some additional benefits
* because other Gradle plugins can take advantage of the output dirs 'registered' in the SourceSet.output.
* For example: Java plugin will use those dirs in calculating class paths and for jarring the content;
* IDEA and Eclipse plugins will put those folders on relevant classpath.
*
* An example how to work with generated resources:
*
*
* apply plugin: 'java'
*
* def generatedResources = "$buildDir/generated-resources/main"
*
* sourceSets {
* main {
* //let's register an output folder on the main SourceSet:
* output.dir(generatedResources, builtBy: 'generateMyResources')
* //it is now a part of the 'main' classpath and will be a part of the jar
* }
* }
*
* //a task that generates the resources:
* task generateMyResources {
* doLast {
* def generated = new File(generatedResources, "myGeneratedResource.properties")
* generated.text = "message=Stay happy!"
* }
* }
*
* //Java plugin task 'classes' and 'testClasses' will automatically depend on relevant tasks registered with 'builtBy'
*
* //Eclipse/IDEA plugins will automatically depend on 'generateMyResources'
* //because the output dir was registered with 'builtBy' information
* apply plugin: 'idea'; apply plugin: 'eclipse'
*
*
* Find more information in {@link #dir(java.util.Map, Object)} and {@link #getDirs()}
*/
public interface SourceSetOutput extends FileCollection {
/**
* Returns the directory to assemble the compiled classes into.
*
* See example at {@link SourceSetOutput}
*
* @return The classes dir.
* @deprecated Use {@link #getClassesDirs()} or {@link SourceDirectorySet#getOutputDir()}
*/
@Deprecated
File getClassesDir();
/**
* Sets the directory to assemble the compiled classes into.
*
* See example at {@link SourceSetOutput}
*
* @param classesDir the classes dir. Should not be null.
* @deprecated Set the output directory for the particular {@link org.gradle.api.tasks.compile.AbstractCompile} task
* @since 4.0
*/
@Deprecated
void setClassesDir(File classesDir);
/**
* Sets the directory to assemble the compiled classes into.
*
* See example at {@link SourceSetOutput}
*
* @param classesDir the classes dir. Should not be null.
* @deprecated Set the output directory for the particular {@link org.gradle.api.tasks.compile.AbstractCompile} task
*/
@Deprecated
void setClassesDir(Object classesDir);
/**
* Returns the directories containing compiled classes.
*
* @return The classes directories. Never returns null.
* @since 4.0
*/
FileCollection getClassesDirs();
/**
* Source set uses the legacy layout (single classes directory for the entire source set).
* @return true if the source set has a single classes directory
* @since 4.0
*/
boolean isLegacyLayout();
/**
* Returns the output directory for resources
*
* See example at {@link SourceSetOutput}
*
* @return The dir resources are copied to.
*/
File getResourcesDir();
/**
* Sets the output directory for resources
*
* See example at {@link SourceSetOutput}
*
* @param resourcesDir the classes dir. Should not be null.
* @since 4.0
*/
void setResourcesDir(File resourcesDir);
/**
* Sets the output directory for resources
*
* See example at {@link SourceSetOutput}
*
* @param resourcesDir the classes dir. Should not be null.
*/
void setResourcesDir(Object resourcesDir);
/**
* Registers an extra output dir and the builtBy information. Useful for generated resources.
*
* See example at {@link SourceSetOutput}
*
* @param options - use 'builtBy' key to configure the 'builtBy' task of the dir
* @param dir - will be resolved as {@link org.gradle.api.Project#file(Object)}
*/
void dir(Map options, Object dir);
/**
* Registers an extra output dir. Useful for generated resources.
*
* See example at {@link SourceSetOutput}
*
* @param dir - will be resolved as {@link org.gradle.api.Project#file(Object)}
*/
void dir(Object dir);
/**
* Returns all dirs registered with #dir method.
* Each file is resolved as {@link org.gradle.api.Project#file(Object)}
*
* See example at {@link SourceSetOutput}
*
* @return a new instance of registered dirs with resolved files
*/
FileCollection getDirs();
}