org.openrewrite.gradle.marker.GradleProject Maven / Gradle / Ivy
Show all versions of rewrite-gradle Show documentation
/*
* 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 org.openrewrite.internal.lang.Nullable;
import org.openrewrite.marker.Marker;
import org.openrewrite.maven.tree.MavenRepository;
import java.io.Serializable;
import java.util.*;
/**
* Contains metadata about a Gradle Project. Queried from Gradle itself when the OpenRewrite build plugin runs.
* Not automatically available on LSTs that aren't parsed through a Gradle plugin, so tests won't automatically have
* access to this metadata.
*/
@SuppressWarnings("unused")
@Value
public class GradleProject implements Marker, Serializable {
@With
UUID id;
@With
String name;
@With
String path;
@With
List plugins;
@With
List mavenRepositories;
@With
List mavenPluginRepositories;
Map nameToConfiguration;
public List getMavenPluginRepositories() {
return mavenPluginRepositories == null ? Collections.emptyList() : mavenPluginRepositories;
}
@Nullable
public GradleDependencyConfiguration getConfiguration(String name) {
return nameToConfiguration.get(name);
}
public List getConfigurations() {
return new ArrayList<>(nameToConfiguration.values());
}
/**
* List the configurations which extend from the given configuration.
* Assuming a hierarchy like:
*
* implementation
* |> compileClasspath
* |> runtimeClasspath
* |> testImplementation
* |> testCompileClasspath
* |> testRuntimeClasspath
*
*
* When querying "implementation" with transitive is false this function will return [compileClasspath, runtimeClasspath, testImplementation].
* When transitive is true this function will also return [testCompileClasspath, testRuntimeClasspath].
*/
public List configurationsExtendingFrom(
GradleDependencyConfiguration parentConfiguration,
boolean transitive
) {
List result = new ArrayList<>();
for (GradleDependencyConfiguration configuration : nameToConfiguration.values()) {
if (configuration == parentConfiguration) {
continue;
}
for (GradleDependencyConfiguration extendsFrom : configuration.getExtendsFrom()) {
if (extendsFrom == parentConfiguration) {
result.add(configuration);
if (transitive) {
result.addAll(configurationsExtendingFrom(configuration, true));
}
}
}
}
return result;
}
public GradleProject withNameToConfiguration(Map nameToConfiguration) {
Map configurations = new HashMap<>(nameToConfiguration);
for (GradleDependencyConfiguration gdc : configurations.values()) {
List extendsFromList = new ArrayList<>(gdc.getExtendsFrom());
boolean changed = false;
for (int i = 0; i < extendsFromList.size(); i++) {
GradleDependencyConfiguration extendsFrom = extendsFromList.get(i);
if (configurations.get(extendsFrom.getName()) != extendsFrom) {
extendsFromList.set(i, configurations.get(extendsFrom.getName()));
changed = true;
}
}
if (changed) {
configurations.put(gdc.getName(), gdc.withExtendsFrom(extendsFromList));
}
}
return new GradleProject(
id,
name,
path,
plugins,
mavenRepositories,
mavenPluginRepositories,
configurations
);
}
}