org.openrewrite.gradle.marker.GradleDependencyConfiguration Maven / Gradle / Ivy
/*
* 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
*
* https://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.openrewrite.gradle.marker;
import lombok.Value;
import lombok.With;
import lombok.experimental.NonFinal;
import org.jspecify.annotations.Nullable;
import org.openrewrite.internal.StringUtils;
import org.openrewrite.maven.tree.Dependency;
import org.openrewrite.maven.tree.ResolvedDependency;
import java.io.Serializable;
import java.util.*;
import static java.util.Collections.emptyList;
@SuppressWarnings("unused")
@Value
@With
public class GradleDependencyConfiguration implements Serializable {
/**
* The name of the dependency configuration. Unique within a given project.
*/
String name;
@Nullable
String description;
boolean isTransitive;
boolean isCanBeResolved;
boolean isCanBeConsumed;
/**
* The list of zero or more configurations this configuration extends from.
* The extended configuration's dependencies are all requested as part of this configuration, but different versions
* may be resolved.
*/
@NonFinal
List extendsFrom;
List requested;
/**
* The list of direct dependencies resolved for this configuration.
*/
List directResolved;
public List getDirectResolved() {
return directResolved == null ? emptyList() : directResolved;
}
/**
* The list of all dependencies resolved for this configuration, including transitive dependencies.
*/
public List getResolved() {
List resolved = new ArrayList<>(getDirectResolved());
Set alreadyResolved = new LinkedHashSet<>();
return resolveTransitiveDependencies(resolved, alreadyResolved);
}
/**
* The type of exception thrown when attempting to resolve this configuration. null if no exception was thrown.
*/
@Nullable
String exceptionType;
/**
* The message of the exception thrown when attempting to resolve this configuration. null if no exception was thrown.
*/
@Nullable
String message;
/**
* List the configurations which are extended by the given configuration.
* Assuming a hierarchy like:
*
* implementation
* |> compileClasspath
* |> runtimeClasspath
* |> testImplementation
* |> testCompileClasspath
* |> testRuntimeClasspath
*
*
* When querying "testCompileClasspath" this function will return [testImplementation, implementation].
*/
public List allExtendsFrom() {
Set result = new LinkedHashSet<>();
for (GradleDependencyConfiguration parentConfiguration : getExtendsFrom()) {
result.add(parentConfiguration);
result.addAll(parentConfiguration.allExtendsFrom());
}
return new ArrayList<>(result);
}
public @Nullable Dependency findRequestedDependency(String groupId, String artifactId) {
for (Dependency d : requested) {
if (StringUtils.matchesGlob(d.getGav().getGroupId(), groupId) &&
StringUtils.matchesGlob(d.getGav().getArtifactId(), artifactId)) {
return d;
}
}
return null;
}
public @Nullable ResolvedDependency findResolvedDependency(String groupId, String artifactId) {
for (ResolvedDependency d : directResolved) {
ResolvedDependency dependency = d.findDependency(groupId, artifactId);
if (dependency != null) {
return dependency;
}
}
return null;
}
public void unsafeSetExtendsFrom(List extendsFrom) {
this.extendsFrom = extendsFrom;
}
private static List resolveTransitiveDependencies(List resolved, Set alreadyResolved) {
for (ResolvedDependency dependency : resolved) {
if (alreadyResolved.add(dependency)) {
alreadyResolved.addAll(resolveTransitiveDependencies(dependency.getDependencies(), alreadyResolved));
}
}
return new ArrayList<>(alreadyResolved);
}
}