[IR] Reorder parameters in IrFactory#createTypeParameter
This is to prepare for IrFactory auto-generation (KT-59308).
This commit is contained in:
committed by
Space Team
parent
b1f7b5e982
commit
2b4a08524d
+24
-12
@@ -440,10 +440,14 @@ class Fir2IrClassifierStorage(
|
||||
symbolFactory = { IrTypeParameterPublicSymbolImpl(signature) }
|
||||
) { symbol ->
|
||||
irFactory.createTypeParameter(
|
||||
startOffset, endOffset, origin, symbol,
|
||||
name, if (index < 0) 0 else index,
|
||||
isReified,
|
||||
variance
|
||||
startOffset = startOffset,
|
||||
endOffset = endOffset,
|
||||
origin = origin,
|
||||
name = name,
|
||||
symbol = symbol,
|
||||
variance = variance,
|
||||
index = if (index < 0) 0 else index,
|
||||
isReified = isReified,
|
||||
)
|
||||
}
|
||||
} else {
|
||||
@@ -452,19 +456,27 @@ class Fir2IrClassifierStorage(
|
||||
symbolFactory = { IrTypeParameterPublicSymbolImpl(signature) }
|
||||
) { symbol ->
|
||||
irFactory.createTypeParameter(
|
||||
startOffset, endOffset, origin, symbol,
|
||||
name, if (index < 0) 0 else index,
|
||||
isReified,
|
||||
variance
|
||||
startOffset = startOffset,
|
||||
endOffset = endOffset,
|
||||
origin = origin,
|
||||
name = name,
|
||||
symbol = symbol,
|
||||
variance = variance,
|
||||
index = if (index < 0) 0 else index,
|
||||
isReified = isReified,
|
||||
)
|
||||
}
|
||||
|
||||
}
|
||||
} ?: irFactory.createTypeParameter(
|
||||
startOffset, endOffset, origin, IrTypeParameterSymbolImpl(),
|
||||
name, if (index < 0) 0 else index,
|
||||
isReified,
|
||||
variance
|
||||
startOffset = startOffset,
|
||||
endOffset = endOffset,
|
||||
origin = origin,
|
||||
name = name,
|
||||
symbol = IrTypeParameterSymbolImpl(),
|
||||
variance = variance,
|
||||
index = if (index < 0) 0 else index,
|
||||
isReified = isReified,
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -458,8 +458,14 @@ class IrBuiltInsOverFir(
|
||||
|
||||
checkNotNullSymbol = run {
|
||||
val typeParameter: IrTypeParameter = irFactory.createTypeParameter(
|
||||
UNDEFINED_OFFSET, UNDEFINED_OFFSET, BUILTIN_OPERATOR, IrTypeParameterSymbolImpl(), Name.identifier("T0"), 0, true,
|
||||
Variance.INVARIANT
|
||||
startOffset = UNDEFINED_OFFSET,
|
||||
endOffset = UNDEFINED_OFFSET,
|
||||
origin = BUILTIN_OPERATOR,
|
||||
name = Name.identifier("T0"),
|
||||
symbol = IrTypeParameterSymbolImpl(),
|
||||
variance = Variance.INVARIANT,
|
||||
index = 0,
|
||||
isReified = true
|
||||
).apply {
|
||||
superTypes = listOf(anyType)
|
||||
}
|
||||
|
||||
+16
-2
@@ -219,7 +219,14 @@ class IrDescriptorBasedFunctionFactory(
|
||||
|
||||
val pSymbol = descriptorFactory.typeParameterDescriptor(index) {
|
||||
irFactory.createTypeParameter(
|
||||
offset, offset, classOrigin, it, pName, index++, false, Variance.IN_VARIANCE
|
||||
startOffset = offset,
|
||||
endOffset = offset,
|
||||
origin = classOrigin,
|
||||
name = pName,
|
||||
symbol = it,
|
||||
variance = Variance.IN_VARIANCE,
|
||||
index = index++,
|
||||
isReified = false
|
||||
)
|
||||
}
|
||||
val pDeclaration = pSymbol.owner
|
||||
@@ -231,7 +238,14 @@ class IrDescriptorBasedFunctionFactory(
|
||||
|
||||
val rSymbol = descriptorFactory.typeParameterDescriptor(index) {
|
||||
irFactory.createTypeParameter(
|
||||
offset, offset, classOrigin, it, Name.identifier("R"), index, false, Variance.OUT_VARIANCE
|
||||
startOffset = offset,
|
||||
endOffset = offset,
|
||||
origin = classOrigin,
|
||||
name = Name.identifier("R"),
|
||||
symbol = it,
|
||||
variance = Variance.OUT_VARIANCE,
|
||||
index = index,
|
||||
isReified = false
|
||||
)
|
||||
}
|
||||
val rDeclaration = rSymbol.owner
|
||||
|
||||
+8
-3
@@ -321,9 +321,14 @@ fun IrFunction.addValueParameter(name: Name, type: IrType, origin: IrDeclaration
|
||||
internal fun IrFactory.buildTypeParameter(builder: IrTypeParameterBuilder, parent: IrDeclarationParent): IrTypeParameter =
|
||||
with(builder) {
|
||||
createTypeParameter(
|
||||
startOffset, endOffset, origin,
|
||||
IrTypeParameterSymbolImpl(),
|
||||
name, index, isReified, variance
|
||||
startOffset = startOffset,
|
||||
endOffset = endOffset,
|
||||
origin = origin,
|
||||
name = name,
|
||||
symbol = IrTypeParameterSymbolImpl(),
|
||||
variance = variance,
|
||||
index = index,
|
||||
isReified = isReified,
|
||||
).also {
|
||||
it.superTypes = superTypes
|
||||
it.parent = parent
|
||||
|
||||
@@ -183,11 +183,11 @@ interface IrFactory {
|
||||
startOffset: Int,
|
||||
endOffset: Int,
|
||||
origin: IrDeclarationOrigin,
|
||||
symbol: IrTypeParameterSymbol,
|
||||
name: Name,
|
||||
symbol: IrTypeParameterSymbol,
|
||||
variance: Variance,
|
||||
index: Int,
|
||||
isReified: Boolean,
|
||||
variance: Variance,
|
||||
): IrTypeParameter
|
||||
|
||||
fun createValueParameter(
|
||||
|
||||
@@ -224,11 +224,11 @@ abstract class AbstractIrFactoryImpl : IrFactory {
|
||||
startOffset: Int,
|
||||
endOffset: Int,
|
||||
origin: IrDeclarationOrigin,
|
||||
symbol: IrTypeParameterSymbol,
|
||||
name: Name,
|
||||
symbol: IrTypeParameterSymbol,
|
||||
variance: Variance,
|
||||
index: Int,
|
||||
isReified: Boolean,
|
||||
variance: Variance,
|
||||
): IrTypeParameter =
|
||||
IrTypeParameterImpl(startOffset, endOffset, origin, symbol, name, index, isReified, variance, factory = this)
|
||||
|
||||
|
||||
+5
-5
@@ -346,21 +346,21 @@ class IrFactoryImplForJsIC(override val stageController: StageController) : Abst
|
||||
startOffset: Int,
|
||||
endOffset: Int,
|
||||
origin: IrDeclarationOrigin,
|
||||
symbol: IrTypeParameterSymbol,
|
||||
name: Name,
|
||||
symbol: IrTypeParameterSymbol,
|
||||
variance: Variance,
|
||||
index: Int,
|
||||
isReified: Boolean,
|
||||
variance: Variance
|
||||
isReified: Boolean
|
||||
): IrTypeParameter {
|
||||
return super.createTypeParameter(
|
||||
startOffset,
|
||||
endOffset,
|
||||
origin,
|
||||
symbol,
|
||||
name,
|
||||
symbol,
|
||||
variance,
|
||||
index,
|
||||
isReified,
|
||||
variance,
|
||||
).register()
|
||||
}
|
||||
|
||||
|
||||
@@ -185,13 +185,13 @@ class LazyIrFactory(
|
||||
startOffset: Int,
|
||||
endOffset: Int,
|
||||
origin: IrDeclarationOrigin,
|
||||
symbol: IrTypeParameterSymbol,
|
||||
name: Name,
|
||||
symbol: IrTypeParameterSymbol,
|
||||
variance: Variance,
|
||||
index: Int,
|
||||
isReified: Boolean,
|
||||
variance: Variance
|
||||
isReified: Boolean
|
||||
): IrTypeParameter = if (symbol.isBound)
|
||||
symbol.owner
|
||||
else
|
||||
delegate.createTypeParameter(startOffset, endOffset, origin, symbol, name, index, isReified, variance)
|
||||
delegate.createTypeParameter(startOffset, endOffset, origin, name, symbol, variance, index, isReified)
|
||||
}
|
||||
@@ -342,13 +342,14 @@ open class DeepCopyIrTreeWithSymbols(
|
||||
|
||||
private fun copyTypeParameter(declaration: IrTypeParameter): IrTypeParameter =
|
||||
declaration.factory.createTypeParameter(
|
||||
declaration.startOffset, declaration.endOffset,
|
||||
mapDeclarationOrigin(declaration.origin),
|
||||
symbolRemapper.getDeclaredTypeParameter(declaration.symbol),
|
||||
symbolRenamer.getTypeParameterName(declaration.symbol),
|
||||
declaration.index,
|
||||
declaration.isReified,
|
||||
declaration.variance
|
||||
startOffset = declaration.startOffset,
|
||||
endOffset = declaration.endOffset,
|
||||
origin = mapDeclarationOrigin(declaration.origin),
|
||||
name = symbolRenamer.getTypeParameterName(declaration.symbol),
|
||||
symbol = symbolRemapper.getDeclaredTypeParameter(declaration.symbol),
|
||||
variance = declaration.variance,
|
||||
index = declaration.index,
|
||||
isReified = declaration.isReified,
|
||||
).apply {
|
||||
transformAnnotations(declaration)
|
||||
}
|
||||
|
||||
@@ -988,8 +988,14 @@ open class SymbolTable(
|
||||
descriptor: TypeParameterDescriptor,
|
||||
typeParameterFactory: (IrTypeParameterSymbol) -> IrTypeParameter = {
|
||||
irFactory.createTypeParameter(
|
||||
startOffset, endOffset, origin, it, nameProvider.nameForDeclaration(descriptor),
|
||||
it.descriptor.index, it.descriptor.isReified, it.descriptor.variance
|
||||
startOffset = startOffset,
|
||||
endOffset = endOffset,
|
||||
origin = origin,
|
||||
name = nameProvider.nameForDeclaration(descriptor),
|
||||
symbol = it,
|
||||
variance = it.descriptor.variance,
|
||||
index = it.descriptor.index,
|
||||
isReified = it.descriptor.isReified
|
||||
)
|
||||
}
|
||||
): IrTypeParameter =
|
||||
@@ -1015,8 +1021,14 @@ open class SymbolTable(
|
||||
descriptor: TypeParameterDescriptor,
|
||||
typeParameterFactory: (IrTypeParameterSymbol) -> IrTypeParameter = {
|
||||
irFactory.createTypeParameter(
|
||||
startOffset, endOffset, origin, it, nameProvider.nameForDeclaration(descriptor),
|
||||
it.descriptor.index, it.descriptor.isReified, it.descriptor.variance
|
||||
startOffset = startOffset,
|
||||
endOffset = endOffset,
|
||||
origin = origin,
|
||||
name = nameProvider.nameForDeclaration(descriptor),
|
||||
symbol = it,
|
||||
variance = it.descriptor.variance,
|
||||
index = it.descriptor.index,
|
||||
isReified = it.descriptor.isReified
|
||||
)
|
||||
}
|
||||
): IrTypeParameter =
|
||||
|
||||
+8
-8
@@ -283,14 +283,14 @@ class IrDeclarationDeserializer(
|
||||
|
||||
val factory = { symbol: IrTypeParameterSymbol ->
|
||||
irFactory.createTypeParameter(
|
||||
coordinates.startOffset,
|
||||
coordinates.endOffset,
|
||||
deserializeIrDeclarationOrigin(proto.base.originName),
|
||||
symbol,
|
||||
name,
|
||||
index,
|
||||
flags.isReified,
|
||||
flags.variance
|
||||
startOffset = coordinates.startOffset,
|
||||
endOffset = coordinates.endOffset,
|
||||
origin = deserializeIrDeclarationOrigin(proto.base.originName),
|
||||
name = name,
|
||||
symbol = symbol,
|
||||
variance = flags.variance,
|
||||
index = index,
|
||||
isReified = flags.isReified
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
+8
-3
@@ -18,7 +18,6 @@ import org.jetbrains.kotlin.backend.common.extensions.IrPluginContext
|
||||
import org.jetbrains.kotlin.backend.common.ir.addDispatchReceiver
|
||||
import org.jetbrains.kotlin.backend.common.lower.ConstructorDelegationKind
|
||||
import org.jetbrains.kotlin.backend.common.lower.DeclarationIrBuilder
|
||||
import org.jetbrains.kotlin.backend.common.lower.callsSuper
|
||||
import org.jetbrains.kotlin.backend.common.lower.delegationKind
|
||||
import org.jetbrains.kotlin.descriptors.*
|
||||
import org.jetbrains.kotlin.ir.IrStatement
|
||||
@@ -346,8 +345,14 @@ private val IrClassifierSymbol.isFragment: Boolean
|
||||
private fun TranslationPluginContext.declareTypeParameterStub(typeParameterDescriptor: TypeParameterDescriptor): IrTypeParameter {
|
||||
val symbol = IrTypeParameterSymbolImpl(typeParameterDescriptor)
|
||||
return irFactory.createTypeParameter(
|
||||
UNDEFINED_OFFSET, UNDEFINED_OFFSET, IrDeclarationOrigin.DEFINED, symbol, typeParameterDescriptor.name,
|
||||
typeParameterDescriptor.index, typeParameterDescriptor.isReified, typeParameterDescriptor.variance
|
||||
startOffset = UNDEFINED_OFFSET,
|
||||
endOffset = UNDEFINED_OFFSET,
|
||||
origin = IrDeclarationOrigin.DEFINED,
|
||||
name = typeParameterDescriptor.name,
|
||||
symbol = symbol,
|
||||
variance = typeParameterDescriptor.variance,
|
||||
index = typeParameterDescriptor.index,
|
||||
isReified = typeParameterDescriptor.isReified,
|
||||
)
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user