org.jetbrains.kotlin.resolve.lazy.FileScopeProvider.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kotlin-compiler-embeddable Show documentation
Show all versions of kotlin-compiler-embeddable Show documentation
the Kotlin compiler embeddable
/*
* 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.resolve.lazy
import com.intellij.openapi.util.Key
import org.jetbrains.kotlin.container.DefaultImplementation
import org.jetbrains.kotlin.psi.KtFile
import org.jetbrains.kotlin.psi.UserDataProperty
import org.jetbrains.kotlin.resolve.BindingTrace
import org.jetbrains.kotlin.resolve.bindingContextUtil.recordScope
import org.jetbrains.kotlin.resolve.scopes.LexicalScope
import org.jetbrains.kotlin.storage.StorageManager
@DefaultImplementation(FileScopeProviderImpl::class)
interface FileScopeProvider {
fun getFileResolutionScope(file: KtFile): LexicalScope = getFileScopes(file).lexicalScope
fun getImportResolver(file: KtFile): ImportForceResolver = getFileScopes(file).importForceResolver
fun getFileScopes(file: KtFile): FileScopes
object ThrowException : FileScopeProvider {
override fun getFileScopes(file: KtFile) = throw UnsupportedOperationException("Should not be called")
}
}
class FileScopeProviderImpl(
private val fileScopeFactory: FileScopeFactory,
private val bindingTrace: BindingTrace,
private val storageManager: StorageManager
) : FileScopeProvider {
private val cache = storageManager.createMemoizedFunction { file ->
val scopes = (file.originalFile as KtFile?)?.fileScopesCustomizer?.createFileScopes(fileScopeFactory)
?: fileScopeFactory.createScopesForFile(file)
bindingTrace.recordScope(scopes.lexicalScope, file)
scopes
}
override fun getFileScopes(file: KtFile) = cache(file)
}
interface FileScopesCustomizer {
fun createFileScopes(fileScopeFactory: FileScopeFactory): FileScopes
}
var KtFile.fileScopesCustomizer: FileScopesCustomizer? by UserDataProperty(Key.create("FILE_SCOPES_CUSTOMIZER"))