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

org.jetbrains.kotlin.cli.jvm.index.JvmDependenciesIndex.kt Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2010-2016 JetBrains s.r.o.
 *
 * 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
 *
 * http://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.jetbrains.kotlin.cli.jvm.index

import com.intellij.openapi.vfs.VirtualFile
import org.jetbrains.kotlin.name.ClassId
import org.jetbrains.kotlin.name.FqName
import java.util.*

interface JvmDependenciesIndex {
    val indexedRoots: Sequence

    /**
     * Searches the index for all packages which may contain a class called [classId], and invokes [findClassGivenDirectory] with the
     * [VirtualFile] directory and [JavaRoot] of each package that may contain the class. The function returns the list of classes that were
     * found and created by [findClassGivenDirectory].
     *
     * [findClassGivenDirectory] must check whether the class with this [classId] exists in the given package.
     *
     * [findClasses] may return multiple results for the same [classId] because a [JvmDependenciesIndex] is currently shared between all
     * modules and thus takes a global view on the project. A project may have two libraries which contain a class with the same name. When
     * we have two independent modules which each depend on one library, there is no classpath issue as the libraries do not overlap. In
     * such a case, the global index must provide virtual files for both classes.
     *
     * The [JvmDependenciesIndex] implementation may choose to find only the first result instead of all results if it's operated under a
     * single-module view. This avoids the possible negative performance impact of looking for multiple results.
     */
    fun  findClasses(
        classId: ClassId,
        acceptedRootTypes: Set = JavaRoot.SourceAndBinary,
        findClassGivenDirectory: (VirtualFile, JavaRoot.RootType) -> T?
    ): Collection

    fun traverseDirectoriesInPackage(
        packageFqName: FqName,
        acceptedRootTypes: Set = JavaRoot.SourceAndBinary,
        continueSearch: (VirtualFile, JavaRoot.RootType) -> Boolean
    )
}

data class JavaRoot(val file: VirtualFile, val type: RootType, val prefixFqName: FqName? = null) {
    enum class RootType {
        SOURCE,
        BINARY,
        BINARY_SIG
    }

    companion object RootTypes {
        val OnlyBinary: Set = EnumSet.of(RootType.BINARY, RootType.BINARY_SIG)
        val OnlySource: Set = EnumSet.of(RootType.SOURCE)
        val SourceAndBinary: Set = EnumSet.of(RootType.BINARY, RootType.BINARY_SIG, RootType.SOURCE)
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy