org.gradle.execution.plan.NodeGroup 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 2022 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.plan;
import javax.annotation.Nullable;
import java.util.Collections;
/**
* Represents the reason why a node is included in the work graph. In general, nodes are included in the graph because they are either a "root node" or they are reachable from one or more "root nodes"
* or both. There are two basic kind of "root nodes":
*
* -
* A "requested task", which is a task requested on the command-line. For example given `gradle a b:` then all the tasks that match `a` are treated as a requested task group (with ordinal 0)
* and all the tasks that match `b` are treated as another requested task group (with ordinal 1).
*
* - A finalizer node. Each finalizer is treated as its own node group.
*
*
* A node may be included in more than one group, for example when it is reachable from both a requested task and a finalizer.
*
* The the groups that the node belongs to can affect how the node is scheduled relative to other nodes in the graph.
*/
public abstract class NodeGroup {
public static final NodeGroup DEFAULT_GROUP = new NodeGroup() {
@Override
public String toString() {
return "default group";
}
@Nullable
@Override
public OrdinalGroup asOrdinal() {
return null;
}
@Override
public NodeGroup withOrdinalGroup(OrdinalGroup newOrdinal) {
return newOrdinal;
}
@Override
public boolean isReachableFromEntryPoint() {
return false;
}
};
@Nullable
public abstract OrdinalGroup asOrdinal();
public abstract boolean isReachableFromEntryPoint();
@Nullable
public FinalizerGroup asFinalizer() {
return null;
}
/**
* Returns the sequence of nodes which must complete before the given node can start. The given node must belong to this group.
* The returned sequence is not exhaustive, i.e. it doesn't mean that the given node can start even if all nodes in it are
* completed.
*
* @param node the node to check successors for
*/
public Iterable extends Node> getSuccessorsFor(Node node) {
return Collections.emptyList();
}
/**
* Returns the sequence of nodes which must complete before the given node can start. The given node must belong to this group.
* The returned sequence is not exhaustive, i.e. it doesn't mean that the given node can start even if all nodes in it are
* completed.
*
* The returned sequence is a reverse of the result of {@link #getSuccessorsFor(Node)}.
*
* @param node the node to check successors for
* @see #getSuccessorsFor(Node)
*/
public Iterable extends Node> getSuccessorsInReverseOrderFor(Node node) {
return Collections.emptyList();
}
public Node.DependenciesState checkSuccessorsCompleteFor(Node node) {
return Node.DependenciesState.COMPLETE_AND_SUCCESSFUL;
}
public void addMember(Node node) {
}
public void removeMember(Node node) {
}
public abstract NodeGroup withOrdinalGroup(OrdinalGroup newOrdinal);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy