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

org.jetbrains.kotlin.resolve.scopes.synthetic.FunInterfaceConstructorsSyntheticScope.kt Maven / Gradle / Ivy

There is a newer version: 2.0.0
Show newest version
/*
 * Copyright 2010-2020 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.resolve.scopes.synthetic

import org.jetbrains.kotlin.descriptors.*
import org.jetbrains.kotlin.incremental.components.LookupLocation
import org.jetbrains.kotlin.incremental.components.LookupTracker
import org.jetbrains.kotlin.incremental.record
import org.jetbrains.kotlin.resolve.sam.*
import org.jetbrains.kotlin.resolve.scopes.SyntheticScope
import org.jetbrains.kotlin.resolve.scopes.SyntheticScopes
import org.jetbrains.kotlin.storage.StorageManager
import org.jetbrains.kotlin.util.collectionUtils.filterIsInstanceMapNotNull

class FunInterfaceConstructorsScopeProvider(
    storageManager: StorageManager,
    lookupTracker: LookupTracker,
    samResolver: SamConversionResolver,
    samConversionOracle: SamConversionOracle
) : SyntheticScopes {
    override val scopes: Collection = listOf(
        FunInterfaceConstructorsSyntheticScope(storageManager, lookupTracker, samResolver, samConversionOracle)
    )
}

class FunInterfaceConstructorsSyntheticScope(
    storageManager: StorageManager,
    private val lookupTracker: LookupTracker,
    private val samResolver: SamConversionResolver,
    private val samConversionOracle: SamConversionOracle
) : SyntheticScope.Default() {

    private val samConstructorForClassifier =
        storageManager.createMemoizedFunction { classifier ->
            createSamConstructorFunction(classifier.containingDeclaration, classifier, samResolver, samConversionOracle)
        }

    override fun getSyntheticConstructors(
        contributedClassifier: ClassifierDescriptor,
        location: LookupLocation
    ): Collection {
        recordSamLookupsToClassifier(contributedClassifier, location)

        return listOfNotNull(getSamConstructor(contributedClassifier))
    }

    override fun getSyntheticConstructors(classifierDescriptors: Collection): Collection =
        classifierDescriptors.filterIsInstanceMapNotNull { getSamConstructor(it) }

    private fun getSamConstructor(classifier: ClassifierDescriptor): SamConstructorDescriptor? {
        if (classifier is TypeAliasDescriptor) {
            return getTypeAliasSamConstructor(classifier)
        }

        val classDescriptor = checkIfClassifierApplicable(classifier) ?: return null
        return samConstructorForClassifier(classDescriptor)
    }

    private fun getTypeAliasSamConstructor(classifier: TypeAliasDescriptor): SamConstructorDescriptor? {
        val classDescriptor = checkIfClassifierApplicable(classifier.classDescriptor ?: return null) ?: return null

        return createTypeAliasSamConstructorFunction(
            classifier, samConstructorForClassifier(classDescriptor), samResolver, samConversionOracle
        )
    }

    private fun checkIfClassifierApplicable(classifier: ClassifierDescriptor): ClassDescriptor? {
        if (classifier !is ClassDescriptor) return null
        if (!classifier.isFun) return null
        if (getSingleAbstractMethodOrNull(classifier) == null) return null

        return classifier
    }

    private fun recordSamLookupsToClassifier(classifier: ClassifierDescriptor, location: LookupLocation) {
        if (classifier !is ClassDescriptor || !classifier.isFun) return
        lookupTracker.record(location, classifier, SAM_LOOKUP_NAME)
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy