All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.openrewrite.gradle.marker.GradleProject Maven / Gradle / Ivy

There is a newer version: 8.42.0
Show newest version
/*
 * 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 com.fasterxml.jackson.annotation.JsonCreator; import lombok.AllArgsConstructor; import lombok.Value; import lombok.With; import org.jspecify.annotations.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 @AllArgsConstructor(onConstructor_ = { @JsonCreator }) public class GradleProject implements Marker, Serializable { @With UUID id; @With @Nullable String group; @With String name; @With @Nullable String version; @With String path; @With List plugins; @With List mavenRepositories; @With List mavenPluginRepositories; Map nameToConfiguration; // Backwards compatibility to ease convoluted release process with rewrite-gradle-tooling-model public GradleProject( UUID id, String name, String path, List plugins, List mavenRepositories, List mavenPluginRepositories, Map nameToConfiguration ) { this(id, "", name, "", path, plugins, mavenRepositories, mavenPluginRepositories, nameToConfiguration); } public List getMavenPluginRepositories() { return mavenPluginRepositories == null ? Collections.emptyList() : mavenPluginRepositories; } public @Nullable 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, group, name, version, path, plugins, mavenRepositories, mavenPluginRepositories, configurations ); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy