org.jetbrains.kotlin.analysis.project.structure.ktModuleUtils.kt Maven / Gradle / Ivy
/*
* Copyright 2010-2021 JetBrains s.r.o. and Kotlin Programming Language contributors.
* Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file.
*/
package org.jetbrains.kotlin.analysis.project.structure
import org.jetbrains.kotlin.utils.topologicalSort
/**
* A list of all modules that the current module can depend on with regular dependency.
*
* @see KtModule.directRegularDependencies
*/
public inline fun KtModule.directRegularDependenciesOfType(): Sequence =
directRegularDependencies.asSequence().filterIsInstance()
/**
* A list of all modules that the current module can depend on with friend dependency.
*
* @see KtModule.directFriendDependencies
*/
public inline fun KtModule.directFriendDependenciesOfType(): Sequence =
directFriendDependencies.asSequence().filterIsInstance()
/**
* A list of all modules that the current module can depend on with refinement dependency.
*
* @see KtModule.directDependsOnDependencies
*/
public inline fun KtModule.directDependsOnDependenciesOfType(): Sequence =
directDependsOnDependencies.asSequence().filterIsInstance()
/**
* A list of all other modules that the current module can depend on.
*
* @see KtModule.directRegularDependencies
* @see KtModule.directDependsOnDependencies
* @see KtModule.directFriendDependencies
*/
public fun KtModule.allDirectDependencies(): Sequence =
sequence {
yieldAll(directRegularDependencies)
yieldAll(directDependsOnDependencies)
yieldAll(directFriendDependencies)
}
/**
* A list of all other modules of type [M] that the current module can depend on.
*
* @see KtModule.directRegularDependencies
* @see KtModule.directDependsOnDependencies
* @see KtModule.directFriendDependencies
*/
public inline fun KtModule.allDirectDependenciesOfType(): Sequence =
allDirectDependencies().filterIsInstance()
/**
* Computes the transitive `dependsOn` dependencies of [directDependsOnDependencies]. [computeTransitiveDependsOnDependencies] is the
* default computation strategy to provide [KtModule.transitiveDependsOnDependencies].
*
* The algorithm is a depth-first search-based topological sort. `dependsOn` dependencies cannot be cyclical and thus form a DAG, which
* allows the application of a topological sort.
*/
public fun computeTransitiveDependsOnDependencies(directDependsOnDependencies: List): List =
topologicalSort(directDependsOnDependencies) { this.directDependsOnDependencies }
/**
* Specifies how references to non-local declarations in the dangling files should be resolved.
*/
public enum class DanglingFileResolutionMode {
/** Resolve first to declarations in the dangling file, and delegate to the original file or module only when needed. */
PREFER_SELF,
/** * Resolve only to declarations in the original file or module. Ignore all non-local declarations in the dangling file copy. */
IGNORE_SELF
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy