com.autonomousapps.model.declaration.Declaration.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dependency-analysis-gradle-plugin Show documentation
Show all versions of dependency-analysis-gradle-plugin Show documentation
Analyzes dependency usage in Android and JVM projects
// Copyright (c) 2024. Tony Robalik.
// SPDX-License-Identifier: Apache-2.0
package com.autonomousapps.model.declaration
import com.autonomousapps.internal.unsafeLazy
import com.autonomousapps.model.GradleVariantIdentification
import com.squareup.moshi.JsonClass
/**
* A dependency's declaration is the configuration that it's declared on (by user or plugin). A dependency may actually
* be declared on more than one configuration, and that would not be an error.
*
* Declarations must be associated with a well-known [bucket] such as **implementation**, **api**, etc. That is,
* analysis on ad hoc configurations is unsupported.
*
* Declarations are also always associated with a [variant]. For JVM projects (Java, Kotlin, etc.), this is a fancy way
* of referring to the _source set_ (main, test). For Android projects, it is the combination of source set and
* _variant_ (e.g., debug, release, buildTypeFlavor).
*/
@JsonClass(generateAdapter = false)
internal data class Declaration(
val identifier: String,
val version: String? = null,
val configurationName: String,
val gradleVariantIdentification: GradleVariantIdentification
) {
val bucket: Bucket by unsafeLazy { Bucket.of(configurationName) }
fun gav(): String = if (version != null) "$identifier:$version" else identifier
fun variant(supportedSourceSets: Set, hasCustomSourceSets: Boolean): Variant? {
return Variant.of(configurationName, supportedSourceSets, hasCustomSourceSets)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy