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

io.github.detekt.psi.internal.FullQualifiedNameGuesser.kt Maven / Gradle / Ivy

package io.github.detekt.psi.internal

import org.jetbrains.kotlin.psi.KtFile
import org.jetbrains.kotlin.psi.KtImportDirective
import org.jetbrains.kotlin.utils.addIfNotNull
import kotlin.LazyThreadSafetyMode.NONE

class FullQualifiedNameGuesser internal constructor(
    private val packageName: String?,
    imports: List,
) {

    @Suppress("ClassOrdering")
    constructor(root: KtFile) : this(
        packageName = root.packageDirective?.qualifiedName?.ifBlank { null },
        imports = root.importList?.imports.orEmpty(),
    )

    private val resolvedNames: Map by lazy(NONE) {
        imports
            .asSequence()
            .filterNot { it.isAllUnder }
            .mapNotNull { import ->
                import.importedFqName?.toString()?.let { fqImport ->
                    (import.alias?.name ?: fqImport.substringAfterLast('.')) to fqImport
                }
            }
            .toMap()
    }

    private val starImports: List by lazy(NONE) {
        imports
            .asSequence()
            .filter { it.isAllUnder }
            .mapNotNull { import ->
                import.importedFqName?.toString()
            }
            .toList()
    }

    fun getFullQualifiedName(name: String): Set {
        val resolvedName = findName(name)
        return if (resolvedName != null) {
            setOf(resolvedName)
        } else {
            mutableSetOf()
                .apply {
                    addIfNotNull(defaultImportClasses[name])
                    if (packageName != null) {
                        add("$packageName.$name")
                    }
                    if (name.first().isLowerCase()) {
                        add(name)
                    }
                    starImports.forEach {
                        add("$it.$name")
                    }
                }
        }
    }

    private fun findName(name: String): String? {
        val searchName = name.substringBefore('.')
        val resolvedName = resolvedNames[searchName] ?: return null
        return if (name == searchName) {
            resolvedName
        } else {
            "$resolvedName.${name.substringAfter('.')}"
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy