org.gradle.api.tasks.AbstractExecTask Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of gradle-api Show documentation
Show all versions of gradle-api Show documentation
Gradle 6.9.1 API redistribution.
/*
* 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.Incubating;
import org.gradle.api.internal.ConventionTask;
import org.gradle.api.model.ObjectFactory;
import org.gradle.api.provider.Property;
import org.gradle.api.provider.Provider;
import org.gradle.process.CommandLineArgumentProvider;
import org.gradle.process.ExecResult;
import org.gradle.process.ExecSpec;
import org.gradle.process.ProcessForkOptions;
import org.gradle.process.internal.DefaultExecSpec;
import org.gradle.process.internal.ExecAction;
import org.gradle.process.internal.ExecActionFactory;
import javax.annotation.Nullable;
import javax.inject.Inject;
import java.io.File;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.List;
import java.util.Map;
/**
* {@code AbstractExecTask} is the base class for all exec tasks.
*
* @param The concrete type of the class.
*/
public abstract class AbstractExecTask extends ConventionTask implements ExecSpec {
private final Class taskType;
private final Property execResult;
private final DefaultExecSpec execSpec;
public AbstractExecTask(Class taskType) {
execSpec = getObjectFactory().newInstance(DefaultExecSpec.class);
execResult = getObjectFactory().property(ExecResult.class);
this.taskType = taskType;
}
@Inject
protected ObjectFactory getObjectFactory() {
throw new UnsupportedOperationException();
}
@Inject
protected ExecActionFactory getExecActionFactory() {
throw new UnsupportedOperationException();
}
@TaskAction
protected void exec() {
ExecAction execAction = getExecActionFactory().newExecAction();
execSpec.copyTo(execAction);
execResult.set(execAction.execute());
}
/**
* {@inheritDoc}
*/
@Override
public T commandLine(Object... arguments) {
execSpec.commandLine(arguments);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Override
public T commandLine(Iterable> args) {
execSpec.commandLine(args);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Override
public T args(Object... args) {
execSpec.args(args);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Override
public T args(Iterable> args) {
execSpec.args(args);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Override
public T setArgs(List arguments) {
execSpec.setArgs(arguments);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Override
public T setArgs(@Nullable Iterable> arguments) {
execSpec.setArgs(arguments);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Nullable
@Optional
@Input
@Override
public List getArgs() {
return execSpec.getArgs();
}
/**
* {@inheritDoc}
*/
@Nested
@Override
public List getArgumentProviders() {
return execSpec.getArgumentProviders();
}
/**
* {@inheritDoc}
*/
@Internal
@Override
public List getCommandLine() {
return execSpec.getCommandLine();
}
/**
* {@inheritDoc}
*/
@Override
public void setCommandLine(List args) {
execSpec.setCommandLine(args);
}
/**
* {@inheritDoc}
*/
@Override
public void setCommandLine(Iterable> args) {
execSpec.setCommandLine(args);
}
/**
* {@inheritDoc}
*/
@Override
public void setCommandLine(Object... args) {
execSpec.setCommandLine(args);
}
/**
* {@inheritDoc}
*/
@Nullable
@Optional
@Input
@Override
public String getExecutable() {
return execSpec.getExecutable();
}
/**
* {@inheritDoc}
*/
@Override
public void setExecutable(@Nullable String executable) {
execSpec.setExecutable(executable);
}
/**
* {@inheritDoc}
*/
@Override
public void setExecutable(Object executable) {
execSpec.setExecutable(executable);
}
/**
* {@inheritDoc}
*/
@Override
public T executable(Object executable) {
execSpec.executable(executable);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Override
@Internal
// TODO:LPTR Should be a content-less @InputDirectory
public File getWorkingDir() {
return execSpec.getWorkingDir();
}
/**
* {@inheritDoc}
*/
@Override
public void setWorkingDir(File dir) {
execSpec.setWorkingDir(dir);
}
/**
* {@inheritDoc}
*/
@Override
public void setWorkingDir(Object dir) {
execSpec.setWorkingDir(dir);
}
/**
* {@inheritDoc}
*/
@Override
public T workingDir(Object dir) {
execSpec.workingDir(dir);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Internal
@Override
public Map getEnvironment() {
return execSpec.getEnvironment();
}
/**
* {@inheritDoc}
*/
@Override
public void setEnvironment(Map environmentVariables) {
execSpec.setEnvironment(environmentVariables);
}
/**
* {@inheritDoc}
*/
@Override
public T environment(String name, Object value) {
execSpec.environment(name, value);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Override
public T environment(Map environmentVariables) {
execSpec.environment(environmentVariables);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Override
public T copyTo(ProcessForkOptions target) {
execSpec.copyTo(target);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Override
public T setStandardInput(InputStream inputStream) {
execSpec.setStandardInput(inputStream);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Internal
@Override
public InputStream getStandardInput() {
return execSpec.getStandardInput();
}
/**
* {@inheritDoc}
*/
@Override
public T setStandardOutput(OutputStream outputStream) {
execSpec.setStandardOutput(outputStream);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Internal
@Override
public OutputStream getStandardOutput() {
return execSpec.getStandardOutput();
}
/**
* {@inheritDoc}
*/
@Override
public T setErrorOutput(OutputStream outputStream) {
execSpec.setErrorOutput(outputStream);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Internal
@Override
public OutputStream getErrorOutput() {
return execSpec.getErrorOutput();
}
/**
* {@inheritDoc}
*/
@Override
public T setIgnoreExitValue(boolean ignoreExitValue) {
execSpec.setIgnoreExitValue(ignoreExitValue);
return taskType.cast(this);
}
/**
* {@inheritDoc}
*/
@Input
@Override
public boolean isIgnoreExitValue() {
return execSpec.isIgnoreExitValue();
}
/**
* Returns the result for the command run by this task. Returns {@code null} if this task has not been executed yet.
*
* @return The result. Returns {@code null} if this task has not been executed yet.
* @see #getExecutionResult() for the preferred way of accessing this property.
*/
@Internal
@Nullable
public ExecResult getExecResult() {
// TODO: Once getExecutionResult is stable, make this deprecated
// DeprecationLogger.deprecateMethod(AbstractExecTask.class, "getExecResult()").replaceWith("AbstractExecTask.getExecutionResult()").undocumented().nagUser();
return execResult.getOrNull();
}
/**
* Returns the result for the command run by this task. The provider has no value if this task has not been executed yet.
*
* @return A provider of the result.
* @since 6.1
*/
@Internal
@Incubating
public Provider getExecutionResult() {
return execResult;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy