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

org.gradle.api.tasks.incremental.IncrementalTaskInputs Maven / Gradle / Ivy

There is a newer version: 8.11.1
Show newest version
/*
 * Copyright 2013 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.incremental;

import org.gradle.api.Action;
import org.gradle.api.Incubating;
import org.gradle.api.NonExtensible;

/**
 * Provides access to any input files that need to be processed by an incremental task.
 * 

* An incremental task action is one that accepts a single {@link IncrementalTaskInputs} parameter. * The task can then provide an action to execute for all input files that are out of date with respect to the previous execution of the task, * and a separate action for all input files that have been removed since the previous execution. * *

 * class IncrementalReverseTask extends DefaultTask {
 *      {@literal @}InputDirectory
 *      def File inputDir
 *
 *      {@literal @}OutputDirectory
 *      def File outputDir
 *
 *      {@literal @}TaskAction
 *      void execute(IncrementalTaskInputs inputs) {
 *          if (!inputs.incremental)
 *              project.delete(outputDir.listFiles())
 *
 *          inputs.outOfDate { change ->
 *              def targetFile = project.file("$outputDir/${change.file.name}")
 *              targetFile.text = change.file.text.reverse()
 *          }
 *
 *          inputs.removed { change ->
 *              def targetFile = project.file("$outputDir/${change.file.name}")
 *              if (targetFile.exists()) {
 *                  targetFile.delete()
 *              }
 *          }
 *      }
 *  }
 * 
* *

* In the case where Gradle is unable to determine which input files need to be reprocessed, then all of the input files will be reported as {@link #outOfDate}. * Cases where this occurs include: *

    *
  • There is no history available from a previous execution.
  • *
  • An {@link org.gradle.api.tasks.TaskOutputs#upToDateWhen(groovy.lang.Closure)} criteria added to the task returns false.
  • *
  • An {@link org.gradle.api.tasks.Input} property has changed since the previous execution.
  • *
  • One or more output files have changed since the previous execution.
  • *
* * Note that this is a stateful API: *
    *
  • {@link #outOfDate} and {@link #removed} can each only be executed a single time per {@link IncrementalTaskInputs} instance.
  • *
  • {@link #outOfDate} must be executed before {@link #removed} is called.
  • *
*/ @Incubating @NonExtensible public interface IncrementalTaskInputs { /** * Indicates if it was possible for Gradle to determine which exactly input files were out of date compared to a previous execution. * This is not possible in the case of no previous execution, changed input properties, output files, etc. *

* When true: *

    *
  • Any input file that has been added or modified since previous execution will be considered 'out-of-date' and reported to {@link #outOfDate}.
  • *
  • Any input files that has been removed since previous execution will be reported to {@link #removed}.
  • *
*

*

* When false: *

    *
  • Every input file will be considered to be 'out-of-date' and will be reported to {@link #outOfDate}.
  • *
  • No input files will be reported to {@link #removed}.
  • *
*

*/ boolean isIncremental(); /** * Executes the action for all of the input files that are out-of-date since the previous task execution. The action may also be supplied as a {@link groovy.lang.Closure}. *
    *
  • When {@link #isIncremental()} == true, the action will be executed for any added or modified input file.
  • *
  • When {@link #isIncremental()} == false, the action will be executed for every input file for the task.
  • *
*

* This method may only be called a single time for a single {@link IncrementalTaskInputs} instance. *

* @throws IllegalStateException on second and subsequent invocations. */ void outOfDate(Action outOfDateAction); /** * Executes the action for all of the input files that were removed since the previous task execution. The action may also be supplied as a {@link groovy.lang.Closure}. *
    *
  • When {@link #isIncremental()} == true, the action will be executed for any removed input file.
  • *
  • When {@link #isIncremental()} == false, the action will not be executed.
  • *
*

* This method may only be called a single time for a single {@link IncrementalTaskInputs} instance. *

* This method may only be called after {@link #outOfDate} has been called. *

* @throws IllegalStateException if invoked prior to {@link #outOfDate}, or if invoked more than once. */ void removed(Action removedAction); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy