/* * 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 groovy.lang.Closure; import org.gradle.api.file.FileTree; import org.gradle.api.file.FileTreeElement; import org.gradle.api.internal.ConventionTask; import org.gradle.api.specs.Spec; import org.gradle.api.tasks.util.PatternFilterable; import org.gradle.api.tasks.util.PatternSet; import org.gradle.internal.Factory; import javax.inject.Inject; import java.util.ArrayList; import java.util.List; import java.util.Set; /** * A {@code SourceTask} performs some operation on source files. */ public class SourceTask extends ConventionTask implements PatternFilterable { protected final List<Object> source = new ArrayList<Object>(); private final PatternFilterable patternSet; public SourceTask() { patternSet = getPatternSetFactory().create(); } @Inject protected Factory<PatternSet> getPatternSetFactory() { throw new UnsupportedOperationException(); } /** * Returns the source for this task, after the include and exclude patterns have been applied. Ignores source files which do not exist. * * @return The source. */ @InputFiles @SkipWhenEmpty public FileTree getSource() { ArrayList<Object> copy = new ArrayList<Object>(this.source); FileTree src = getProject().files(copy).getAsFileTree(); return src == null ? getProject().files().getAsFileTree() : src.matching(patternSet); } /** * Sets the source for this task. * * @param source The source. * @since 4.0 */ public void setSource(FileTree source) { setSource((Object) source); } /** * Sets the source for this task. The given source object is evaluated as per {@link org.gradle.api.Project#files(Object...)}. * * @param source The source. */ public void setSource(Object source) { this.source.clear(); this.source.add(source); } /** * Adds some source to this task. The given source objects will be evaluated as per {@link org.gradle.api.Project#files(Object...)}. * * @param sources The source to add * @return this */ public SourceTask source(Object... sources) { for (Object source : sources) { this.source.add(source); } return this; } /** * {@inheritDoc} */ public SourceTask include(String... includes) { patternSet.include(includes); return this; } /** * {@inheritDoc} */ public SourceTask include(Iterable<String> includes) { patternSet.include(includes); return this; } /** * {@inheritDoc} */ public SourceTask include(Spec<FileTreeElement> includeSpec) { patternSet.include(includeSpec); return this; } /** * {@inheritDoc} */ public SourceTask include(Closure includeSpec) { patternSet.include(includeSpec); return this; } /** * {@inheritDoc} */ public SourceTask exclude(String... excludes) { patternSet.exclude(excludes); return this; } /** * {@inheritDoc} */ public SourceTask exclude(Iterable<String> excludes) { patternSet.exclude(excludes); return this; } /** * {@inheritDoc} */ public SourceTask exclude(Spec<FileTreeElement> excludeSpec) { patternSet.exclude(excludeSpec); return this; } /** * {@inheritDoc} */ public SourceTask exclude(Closure excludeSpec) { patternSet.exclude(excludeSpec); return this; } /** * {@inheritDoc} */ @Internal public Set<String> getIncludes() { return patternSet.getIncludes(); } /** * {@inheritDoc} */ public SourceTask setIncludes(Iterable<String> includes) { patternSet.setIncludes(includes); return this; } /** * {@inheritDoc} */ @Internal public Set<String> getExcludes() { return patternSet.getExcludes(); } /** * {@inheritDoc} */ public SourceTask setExcludes(Iterable<String> excludes) { patternSet.setExcludes(excludes); return this; } }