org.gradle.api.internal.TaskInternal 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.internal;
import org.gradle.api.Action;
import org.gradle.api.Task;
import org.gradle.api.internal.project.taskfactory.TaskIdentity;
import org.gradle.api.internal.tasks.InputChangesAwareTaskAction;
import org.gradle.api.internal.tasks.TaskRequiredServices;
import org.gradle.api.internal.tasks.TaskStateInternal;
import org.gradle.api.internal.tasks.properties.ServiceReferenceSpec;
import org.gradle.api.specs.Spec;
import org.gradle.api.tasks.Internal;
import org.gradle.api.tasks.TaskDependency;
import org.gradle.internal.Factory;
import org.gradle.internal.logging.StandardOutputCapture;
import org.gradle.internal.resources.ResourceLock;
import org.gradle.util.Configurable;
import org.gradle.util.Path;
import java.io.File;
import java.util.List;
import java.util.Optional;
import java.util.Set;
public interface TaskInternal extends Task, Configurable {
/**
* A more efficient version of {@link #getActions()}, which circumvents the
* validating change listener that normally prevents users from changing tasks
* once they start executing.
*/
@Internal
List getTaskActions();
@Internal
boolean hasTaskActions();
@Internal
Spec super TaskInternal> getOnlyIf();
/**
* Return the reason for not to track state.
*
* Gradle considers the task as untracked if the reason is present.
* When not tracking state, a reason must be present. Hence the {@code Optional} represents the state of enablement, too.
*
* @see org.gradle.api.tasks.UntrackedTask
*/
@Internal
Optional getReasonNotToTrackState();
@Internal
boolean isCompatibleWithConfigurationCache();
@Internal
Optional getReasonTaskIsIncompatibleWithConfigurationCache();
@Internal
StandardOutputCapture getStandardOutputCapture();
@Override
TaskInputsInternal getInputs();
@Override
TaskOutputsInternal getOutputs();
@Override
TaskStateInternal getState();
@Internal
boolean getImpliesSubProjects();
void setImpliesSubProjects(boolean impliesSubProjects);
/**
* The returned factory is expected to return the same file each time.
*
* The getTemporaryDir() method creates the directory which can be problematic. Use this to delay that creation.
*/
@Internal
Factory getTemporaryDirFactory();
void prependParallelSafeAction(Action super Task> action);
void appendParallelSafeAction(Action super Task> action);
@Internal
boolean isHasCustomActions();
@Internal
Path getIdentityPath();
@Internal
TaskIdentity> getTaskIdentity();
@Internal
TaskRequiredServices getRequiredServices();
void acceptServiceReferences(Set serviceReferences);
/**
* Gets the shared resources required by this task.
*/
@Internal
List extends ResourceLock> getSharedResources();
/**
* "Lifecycle dependencies" are dependencies of this task declared via an explicit {@link Task#dependsOn(Object...)} call,
* as opposed to the recommended approach of connecting producer tasks' outputs to consumer tasks' inputs.
* @return the dependencies of this task declared via an explicit {@link Task#dependsOn(Object...)}
*/
@Internal
TaskDependency getLifecycleDependencies();
}