org.gradle.execution.DefaultTaskSelector 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.execution;
import org.gradle.api.Project;
import org.gradle.api.Task;
import org.gradle.api.initialization.IncludedBuild;
import org.gradle.api.internal.GradleInternal;
import org.gradle.api.internal.project.ProjectInternal;
import org.gradle.api.logging.Logger;
import org.gradle.api.logging.Logging;
import org.gradle.api.specs.Spec;
import org.gradle.execution.taskpath.ResolvedTaskPath;
import org.gradle.execution.taskpath.TaskPathResolver;
import org.gradle.util.internal.NameMatcher;
import javax.annotation.Nullable;
import java.io.File;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
public class DefaultTaskSelector extends TaskSelector {
private static final Logger LOGGER = Logging.getLogger(DefaultTaskSelector.class);
private final TaskNameResolver taskNameResolver;
private final GradleInternal gradle;
private final ProjectConfigurer configurer;
private final TaskPathResolver taskPathResolver = new TaskPathResolver();
public DefaultTaskSelector(GradleInternal gradle, TaskNameResolver taskNameResolver, ProjectConfigurer configurer) {
this.taskNameResolver = taskNameResolver;
this.gradle = gradle;
this.configurer = configurer;
}
public TaskSelection getSelection(String path) {
return getSelection(path, gradle.getDefaultProject());
}
public Spec getFilter(String path) {
final ResolvedTaskPath taskPath = taskPathResolver.resolvePath(path, gradle.getDefaultProject());
if (!taskPath.isQualified()) {
ProjectInternal targetProject = taskPath.getProject();
configurer.configure(targetProject);
if (taskNameResolver.tryFindUnqualifiedTaskCheaply(taskPath.getTaskName(), taskPath.getProject())) {
// An exact match in the target project - can just filter tasks by path to avoid configuring sub-projects at this point
return new TaskPathSpec(targetProject, taskPath.getTaskName());
}
}
final Set selectedTasks = getSelection(path, gradle.getDefaultProject()).getTasks();
return new Spec() {
@Override
public boolean isSatisfiedBy(Task element) {
return !selectedTasks.contains(element);
}
};
}
public TaskSelection getSelection(@Nullable String projectPath, @Nullable File root, String path) {
if (root != null) {
ensureNotFromIncludedBuild(root);
}
ProjectInternal project = projectPath != null
? gradle.getRootProject().findProject(projectPath)
: gradle.getDefaultProject();
return getSelection(path, project);
}
private void ensureNotFromIncludedBuild(File root) {
Set includedRoots = new HashSet();
for (IncludedBuild includedBuild : gradle.getIncludedBuilds()) {
includedRoots.add(includedBuild.getProjectDir());
}
if (includedRoots.contains(root)) {
throw new TaskSelectionException("Can't launch tasks from included builds");
}
}
private TaskSelection getSelection(String path, ProjectInternal project) {
ResolvedTaskPath taskPath = taskPathResolver.resolvePath(path, project);
ProjectInternal targetProject = taskPath.getProject();
if (taskPath.isQualified()) {
configurer.configure(targetProject);
} else {
configurer.configureHierarchy(targetProject);
}
TaskSelectionResult tasks = taskNameResolver.selectWithName(taskPath.getTaskName(), taskPath.getProject(), !taskPath.isQualified());
if (tasks != null) {
LOGGER.info("Task name matched '{}'", taskPath.getTaskName());
return new TaskSelection(taskPath.getProject().getPath(), path, tasks);
} else {
Map tasksByName = taskNameResolver.selectAll(taskPath.getProject(), !taskPath.isQualified());
NameMatcher matcher = new NameMatcher();
String actualName = matcher.find(taskPath.getTaskName(), tasksByName.keySet());
if (actualName != null) {
LOGGER.info("Abbreviated task name '{}' matched '{}'", taskPath.getTaskName(), actualName);
return new TaskSelection(taskPath.getProject().getPath(), taskPath.getPrefix() + actualName, tasksByName.get(actualName));
}
throw new TaskSelectionException(matcher.formatErrorMessage("task", taskPath.getProject()));
}
}
private static class TaskPathSpec implements Spec {
private final ProjectInternal targetProject;
private final String taskName;
public TaskPathSpec(ProjectInternal targetProject, String taskName) {
this.targetProject = targetProject;
this.taskName = taskName;
}
@Override
public boolean isSatisfiedBy(Task element) {
if (!element.getName().equals(taskName)) {
return true;
}
for (Project current = element.getProject(); current != null; current = current.getParent()) {
if (current.equals(targetProject)) {
return false;
}
}
return true;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy