org.jetbrains.kotlin.js.inline.util.namingUtils.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.js.inline.util
import org.jetbrains.kotlin.js.backend.ast.*
import org.jetbrains.kotlin.js.backend.ast.metadata.staticRef
import org.jetbrains.kotlin.js.inline.context.NamingContext
import org.jetbrains.kotlin.js.inline.util.rewriters.LabelNameRefreshingVisitor
import org.jetbrains.kotlin.js.translate.utils.JsAstUtils
fun aliasArgumentsIfNeeded(
context: NamingContext,
arguments: List,
parameters: List,
source: Any?
) {
require(arguments.size <= parameters.size) { "arguments.size (${arguments.size}) should be less or equal to parameters.size (${parameters.size})" }
val defaultParams = mutableListOf()
for ((arg, param) in arguments.zip(parameters)) {
if (JsAstUtils.isUndefinedExpression(arg)) {
defaultParams += param
continue
}
val paramName = param.name
val replacement = JsScope.declareTemporaryName(paramName.ident).apply {
staticRef = arg
context.newVar(this, arg.deepCopy(), source = source)
}.makeRef()
replacement.source = arg.source
context.replaceName(paramName, replacement)
}
defaultParams += parameters.subList(arguments.size, parameters.size)
for (defaultParam in defaultParams) {
val paramName = defaultParam.name
val freshName = JsScope.declareTemporaryName(paramName.ident)
freshName.copyMetadataFrom(paramName)
context.newVar(freshName, source = source)
context.replaceName(paramName, freshName.makeRef())
}
}
/**
* Makes function local names fresh in context
*/
fun renameLocalNames(
context: NamingContext,
function: JsFunction
) {
for (name in collectDefinedNames(function.body)) {
val temporaryName = JsScope.declareTemporaryName(name.ident).apply { staticRef = name.staticRef }
context.replaceName(name, temporaryName.makeRef())
}
}
fun refreshLabelNames(
node: JsNode,
scope: JsScope
): JsNode {
if (scope !is JsFunctionScope) throw AssertionError("JsFunction is expected to have JsFunctionScope")
val visitor = LabelNameRefreshingVisitor(scope)
return visitor.accept(node)
}