From cc1f1dd4736e86035e4e685339747d8431c34e41 Mon Sep 17 00:00:00 2001 From: Tamas Vajk Date: Fri, 4 Oct 2024 13:35:30 +0200 Subject: [PATCH 1/2] KE2: Extract some expr/stmt kinds --- .../src/main/kotlin/KotlinFileExtractor.kt | 69 --- .../src/main/kotlin/entities/Expression.kt | 447 +++++++++++------- 2 files changed, 272 insertions(+), 244 deletions(-) diff --git a/java/kotlin-extractor2/src/main/kotlin/KotlinFileExtractor.kt b/java/kotlin-extractor2/src/main/kotlin/KotlinFileExtractor.kt index 4004f6f040ce..821ef4bf0269 100644 --- a/java/kotlin-extractor2/src/main/kotlin/KotlinFileExtractor.kt +++ b/java/kotlin-extractor2/src/main/kotlin/KotlinFileExtractor.kt @@ -2542,75 +2542,6 @@ OLD: KE1 tw.writeHasLocation(it, locId) } - private fun extractStatement( - s: IrStatement, - callable: Label, - parent: Label, - idx: Int - ) { - with("statement", s) { - when (s) { - is IrExpression -> { - extractExpressionStmt(s, callable, parent, idx) - } - is IrVariable -> { - extractVariable(s, callable, parent, idx) - } - is IrClass -> { - extractLocalTypeDeclStmt(s, callable, parent, idx) - } - is IrFunction -> { - if (s.isLocalFunction()) { - val compilerGeneratedKindOverride = - if (s.origin == IrDeclarationOrigin.ADAPTER_FOR_CALLABLE_REFERENCE) { - CompilerGeneratedKinds.DECLARING_CLASSES_OF_ADAPTER_FUNCTIONS - } else { - null - } - val classId = - extractGeneratedClass( - s, - listOf(pluginContext.irBuiltIns.anyType), - compilerGeneratedKindOverride = compilerGeneratedKindOverride - ) - extractLocalTypeDeclStmt(classId, s, callable, parent, idx) - val ids = getLocallyVisibleFunctionLabels(s) - tw.writeKtLocalFunction(ids.function) - } else { - logger.errorElement("Expected to find local function", s) - } - } - is IrLocalDelegatedProperty -> { - val blockId = tw.getFreshIdLabel() - val locId = tw.getLocation(s) - tw.writeStmts_block(blockId, parent, idx, callable) - tw.writeHasLocation(blockId, locId) - extractVariable(s.delegate, callable, blockId, 0) - - val propId = tw.getFreshIdLabel() - tw.writeKtProperties(propId, s.name.asString()) - tw.writeHasLocation(propId, locId) - tw.writeKtPropertyDelegates(propId, useVariable(s.delegate)) - - // Getter: - extractStatement(s.getter, callable, blockId, 1) - val getterLabel = getLocallyVisibleFunctionLabels(s.getter).function - tw.writeKtPropertyGetters(propId, getterLabel) - - val setter = s.setter - if (setter != null) { - extractStatement(setter, callable, blockId, 2) - val setterLabel = getLocallyVisibleFunctionLabels(setter).function - tw.writeKtPropertySetters(propId, setterLabel) - } - } - else -> { - logger.errorElement("Unrecognised IrStatement: " + s.javaClass, s) - } - } - } - } - /** * Returns true iff `c` is a call to the function `fName` in the `kotlin.internal.ir` package. * This is used to find calls to builtin functions, which need to be handled specially as they diff --git a/java/kotlin-extractor2/src/main/kotlin/entities/Expression.kt b/java/kotlin-extractor2/src/main/kotlin/entities/Expression.kt index 7f26ca82b356..ce7da53e61eb 100644 --- a/java/kotlin-extractor2/src/main/kotlin/entities/Expression.kt +++ b/java/kotlin-extractor2/src/main/kotlin/entities/Expression.kt @@ -89,27 +89,26 @@ OLD: KE1 tw.writeHasLocation(it, locId) } -/* -OLD: KE1 - private fun extractExpressionStmt( - e: IrExpression, - callable: Label, - parent: Label, - idx: Int - ) { - extractExpression(e, callable, StmtParent(parent, idx)) - } +context(KaSession) +private fun KotlinFileExtractor.extractExpressionStmt( + e: KtExpression, + callable: Label, + parent: Label, + idx: Int +) { + extractExpression(e, callable, StmtParent(parent, idx)) +} - fun extractExpressionExpr( - e: IrExpression, - callable: Label, - parent: Label, - idx: Int, - enclosingStmt: Label - ) { - extractExpression(e, callable, ExprParent(parent, idx, enclosingStmt)) - } -*/ +context(KaSession) +fun KotlinFileExtractor.extractExpressionExpr( + e: KtExpression, + callable: Label, + parent: Label, + idx: Int, + enclosingStmt: Label +) { + extractExpression(e, callable, ExprParent(parent, idx, enclosingStmt)) +} private fun KotlinFileExtractor.extractExprContext( id: Label, @@ -219,6 +218,11 @@ private fun KotlinFileExtractor.extractExpression( ) { with("expression", e) { when (e) { + is KtLabeledExpression -> { + // TODO: we could handle this here, or in each child that might have a label + // We're handling it in the children with the below + extractExpression(e.baseExpression!!, callable, parent) + } /* OLD: KE1 is IrDelegatingConstructorCall -> { @@ -278,27 +282,31 @@ private fun KotlinFileExtractor.extractExpression( // todo: type arguments at index -2, -3, ... } - is IrThrow -> { - val stmtParent = parent.stmt(e, callable) - val id = tw.getFreshIdLabel() - val locId = tw.getLocation(e) - tw.writeStmts_throwstmt(id, stmtParent.parent, stmtParent.idx, callable) - tw.writeHasLocation(id, locId) - extractExpressionExpr(e.value, callable, id, 0, id) - } - is IrBreak -> { - val stmtParent = parent.stmt(e, callable) - val id = tw.getFreshIdLabel() - tw.writeStmts_breakstmt(id, stmtParent.parent, stmtParent.idx, callable) - extractBreakContinue(e, id) - } - is IrContinue -> { - val stmtParent = parent.stmt(e, callable) - val id = tw.getFreshIdLabel() - tw.writeStmts_continuestmt(id, stmtParent.parent, stmtParent.idx, callable) - extractBreakContinue(e, id) - } */ + is KtThrowExpression -> { + val stmtParent = parent.stmt(e, callable) + val id = tw.getFreshIdLabel() + val locId = tw.getLocation(e) + tw.writeStmts_throwstmt(id, stmtParent.parent, stmtParent.idx, callable) + tw.writeHasLocation(id, locId) + val thrown = e.thrownExpression!! + extractExpressionExpr(thrown, callable, id, 0, id) + } + + is KtBreakExpression -> { + val stmtParent = parent.stmt(e, callable) + val id = tw.getFreshIdLabel() + tw.writeStmts_breakstmt(id, stmtParent.parent, stmtParent.idx, callable) + extractBreakContinue(e, id) + } + + is KtContinueExpression -> { + val stmtParent = parent.stmt(e, callable) + val id = tw.getFreshIdLabel() + tw.writeStmts_continuestmt(id, stmtParent.parent, stmtParent.idx, callable) + extractBreakContinue(e, id) + } + is KtReturnExpression -> { val stmtParent = parent.stmt(e, callable) val id = tw.getFreshIdLabel() @@ -311,57 +319,65 @@ private fun KotlinFileExtractor.extractExpression( } // TODO: e.getLabeledExpression() } - /* - OLD: KE1 - is IrTry -> { - val stmtParent = parent.stmt(e, callable) - val id = tw.getFreshIdLabel() - val locId = tw.getLocation(e) - tw.writeStmts_trystmt(id, stmtParent.parent, stmtParent.idx, callable) - tw.writeHasLocation(id, locId) - extractExpressionStmt(e.tryResult, callable, id, -1) - val finallyStmt = e.finallyExpression - if (finallyStmt != null) { - extractExpressionStmt(finallyStmt, callable, id, -2) - } - for ((catchIdx, catchClause) in e.catches.withIndex()) { - val catchId = tw.getFreshIdLabel() - tw.writeStmts_catchclause(catchId, id, catchIdx, callable) - val catchLocId = tw.getLocation(catchClause) - tw.writeHasLocation(catchId, catchLocId) - extractTypeAccessRecursive( - catchClause.catchParameter.type, - tw.getLocation(catchClause.catchParameter), - catchId, - -1, - callable, - catchId - ) - extractVariableExpr( - catchClause.catchParameter, - callable, - catchId, - 0, - catchId - ) - extractExpressionStmt(catchClause.result, callable, catchId, 1) - } - } - is IrContainerExpression -> { - if ( - !tryExtractArrayUpdate(e, callable, parent) && - !tryExtractForLoop(e, callable, parent) - ) { + is KtTryExpression -> { + val stmtParent = parent.stmt(e, callable) + val id = tw.getFreshIdLabel() + val locId = tw.getLocation(e) + tw.writeStmts_trystmt(id, stmtParent.parent, stmtParent.idx, callable) + tw.writeHasLocation(id, locId) + extractExpressionStmt(e.tryBlock, callable, id, -1) + val finallyStmt = e.finallyBlock?.finalExpression + if (finallyStmt != null) { + extractExpressionStmt(finallyStmt, callable, id, -2) + } + for ((catchIdx, catchClause) in e.catchClauses.withIndex()) { + val catchId = tw.getFreshIdLabel() + tw.writeStmts_catchclause(catchId, id, catchIdx, callable) + val catchLocId = tw.getLocation(catchClause) + tw.writeHasLocation(catchId, catchLocId) + /* + OLD: KE1 + extractTypeAccessRecursive( + catchClause.catchParameter.type, + tw.getLocation(catchClause.catchParameter), + catchId, + -1, + callable, + catchId + ) + extractVariableExpr( + catchClause.catchParameter, + callable, + catchId, + 0, + catchId + ) + */ + extractExpressionStmt(catchClause.catchBody!!, callable, catchId, 1) + } + } - extractBlock(e, e.statements, parent, callable) - } - } - is IrWhileLoop -> { - extractLoopWithCondition(e, parent, callable) - } - is IrDoWhileLoop -> { - extractLoopWithCondition(e, parent, callable) - } + is KtBlockExpression -> { + /* + OLD: KE1 + if ( + !tryExtractArrayUpdate(e, callable, parent) && + !tryExtractForLoop(e, callable, parent) + ) { + extractBlock(e, e.statements, parent, callable) + } + */ + extractBlock(e, e.statements, parent, callable) + } + + is KtWhileExpression -> { + extractLoopWithCondition(e, parent, callable) + } + + is KtDoWhileExpression -> { + extractLoopWithCondition(e, parent, callable) + } + /* is IrInstanceInitializerCall -> { val irConstructor = declarationStack.peek().first as? IrConstructor if (irConstructor == null) { @@ -934,32 +950,108 @@ private fun KotlinFileExtractor.extractExpression( } } -/* -OLD: KE1 - private fun extractBlock( - e: IrContainerExpression, - statements: List, - parent: StmtExprParent, - callable: Label - ) { - val stmtParent = parent.stmt(e, callable) - extractBlock(e, statements, stmtParent.parent, stmtParent.idx, callable) - } +context(KaSession) +private fun KotlinFileExtractor.extractBlock( + e: KtBlockExpression, + statements: List, + parent: StmtExprParent, + callable: Label +) { + val stmtParent = parent.stmt(e, callable) + extractBlock(e, statements, stmtParent.parent, stmtParent.idx, callable) +} - private fun extractBlock( - e: IrElement, - statements: List, - parent: Label, - idx: Int, - callable: Label - ) { - val id = tw.getFreshIdLabel() - val locId = tw.getLocation(e) - tw.writeStmts_block(id, parent, idx, callable) - tw.writeHasLocation(id, locId) - statements.forEachIndexed { i, s -> extractStatement(s, callable, id, i) } +context(KaSession) +private fun KotlinFileExtractor.extractBlock( + e: KtBlockExpression, + statements: List, + parent: Label, + idx: Int, + callable: Label +) { + val id = tw.getFreshIdLabel() + val locId = tw.getLocation(e) + tw.writeStmts_block(id, parent, idx, callable) + tw.writeHasLocation(id, locId) + statements.forEachIndexed { i, s -> extractStatement(s, callable, id, i) } +} + +context(KaSession) +private fun KotlinFileExtractor.extractStatement( + s: KtExpression, + callable: Label, + parent: Label, + idx: Int +) { + with("statement", s) { + when (s) { + is KtStatementExpression -> { + extractExpressionStmt(s, callable, parent, idx) + } + /* + OLD: KE1 + is IrVariable -> { + extractVariable(s, callable, parent, idx) + } + is IrClass -> { + extractLocalTypeDeclStmt(s, callable, parent, idx) + } + is IrFunction -> { + if (s.isLocalFunction()) { + val compilerGeneratedKindOverride = + if (s.origin == IrDeclarationOrigin.ADAPTER_FOR_CALLABLE_REFERENCE) { + CompilerGeneratedKinds.DECLARING_CLASSES_OF_ADAPTER_FUNCTIONS + } else { + null + } + val classId = + extractGeneratedClass( + s, + listOf(pluginContext.irBuiltIns.anyType), + compilerGeneratedKindOverride = compilerGeneratedKindOverride + ) + extractLocalTypeDeclStmt(classId, s, callable, parent, idx) + val ids = getLocallyVisibleFunctionLabels(s) + tw.writeKtLocalFunction(ids.function) + } else { + logger.errorElement("Expected to find local function", s) + } + } + is IrLocalDelegatedProperty -> { + val blockId = tw.getFreshIdLabel() + val locId = tw.getLocation(s) + tw.writeStmts_block(blockId, parent, idx, callable) + tw.writeHasLocation(blockId, locId) + extractVariable(s.delegate, callable, blockId, 0) + + val propId = tw.getFreshIdLabel() + tw.writeKtProperties(propId, s.name.asString()) + tw.writeHasLocation(propId, locId) + tw.writeKtPropertyDelegates(propId, useVariable(s.delegate)) + + // Getter: + extractStatement(s.getter, callable, blockId, 1) + val getterLabel = getLocallyVisibleFunctionLabels(s.getter).function + tw.writeKtPropertyGetters(propId, getterLabel) + + val setter = s.setter + if (setter != null) { + extractStatement(setter, callable, blockId, 2) + val setterLabel = getLocallyVisibleFunctionLabels(setter).function + tw.writeKtPropertySetters(propId, setterLabel) + } + } + + */ + else -> { + logger.errorElement("Unhandled statement: " + s.javaClass, s) + } + } } +} +/* +OLD: KE1 private inline fun getBoundSymbolOwner( symbol: IrBindableSymbol, e: IrExpression @@ -1165,65 +1257,70 @@ OLD: KE1 callable, enclosingStmt ) +*/ +context(KaSession) +private fun KotlinFileExtractor.extractLoop( + loop: KtLoopExpression, + bodyIdx: Int?, + stmtExprParent: StmtExprParent, + callable: Label, + getId: (Label, Int) -> Label +): Label { + val stmtParent = stmtExprParent.stmt(loop, callable) + val locId = tw.getLocation(loop) + + val idx: Int + val parent: Label + + val label = (loop.parent as? KtLabeledExpression)?.getLabelName() + if (label != null) { + val labeledStmt = tw.getFreshIdLabel() + tw.writeStmts_labeledstmt(labeledStmt, stmtParent.parent, stmtParent.idx, callable) + tw.writeHasLocation(labeledStmt, locId) + + tw.writeNamestrings(label, "", labeledStmt) + idx = 0 + parent = labeledStmt + } else { + idx = stmtParent.idx + parent = stmtParent.parent + } - private fun extractLoop( - loop: IrLoop, - bodyIdx: Int?, - stmtExprParent: StmtExprParent, - callable: Label, - getId: (Label, Int) -> Label - ): Label { - val stmtParent = stmtExprParent.stmt(loop, callable) - val locId = tw.getLocation(loop) - - val idx: Int - val parent: Label - - val label = loop.label - if (label != null) { - val labeledStmt = tw.getFreshIdLabel() - tw.writeStmts_labeledstmt(labeledStmt, stmtParent.parent, stmtParent.idx, callable) - tw.writeHasLocation(labeledStmt, locId) - - tw.writeNamestrings(label, "", labeledStmt) - idx = 0 - parent = labeledStmt - } else { - idx = stmtParent.idx - parent = stmtParent.parent - } - - val id = getId(parent, idx) - tw.writeHasLocation(id, locId) - - val body = loop.body - if (body != null && bodyIdx != null) { - extractExpressionStmt(body, callable, id, bodyIdx) - } + val id = getId(parent, idx) + tw.writeHasLocation(id, locId) - return id + val body = loop.body + if (body != null && bodyIdx != null) { + extractExpressionStmt(body, callable, id, bodyIdx) } - private fun extractLoopWithCondition( - loop: IrLoop, - stmtExprParent: StmtExprParent, - callable: Label - ) { - val id = - extractLoop(loop, 1, stmtExprParent, callable) { parent, idx -> - if (loop is IrWhileLoop) { - tw.getFreshIdLabel().also { - tw.writeStmts_whilestmt(it, parent, idx, callable) - } - } else { - tw.getFreshIdLabel().also { - tw.writeStmts_dostmt(it, parent, idx, callable) - } + return id +} + +context(KaSession) +private fun KotlinFileExtractor.extractLoopWithCondition( + loop: KtWhileExpressionBase, + stmtExprParent: StmtExprParent, + callable: Label +) { + val id = + extractLoop(loop, 1, stmtExprParent, callable) { parent, idx -> + if (loop is KtWhileExpression) { + tw.getFreshIdLabel().also { + tw.writeStmts_whilestmt(it, parent, idx, callable) + } + } else { + tw.getFreshIdLabel().also { + tw.writeStmts_dostmt(it, parent, idx, callable) } } - extractExpressionExpr(loop.condition, callable, id, 0, id) - } + } + val condition = loop.condition!! + extractExpressionExpr(condition, callable, id, 0, id) +} +/* +OLD: KE1 private fun exprIdOrFresh(id: Label?) = id?.cast() ?: tw.getFreshIdLabel() @@ -2217,15 +2314,15 @@ private fun KotlinFileExtractor.extractConstant( } } } + */ - private fun extractBreakContinue(e: IrBreakContinue, id: Label) { - with("break/continue", e) { - val locId = tw.getLocation(e) - tw.writeHasLocation(id, locId) - val label = e.label - if (label != null) { - tw.writeNamestrings(label, "", id) - } - } +private fun KotlinFileExtractor.extractBreakContinue(e: KtExpressionWithLabel, id: Label) { + with("break/continue", e) { + val locId = tw.getLocation(e) + tw.writeHasLocation(id, locId) + val label = e.getLabelName() + if (label != null) { + tw.writeNamestrings(label, "", id) } - */ \ No newline at end of file + } +} \ No newline at end of file From aa5fa12b4fb15e78d76613884f12d0b56ec5aad8 Mon Sep 17 00:00:00 2001 From: Tamas Vajk Date: Fri, 4 Oct 2024 16:38:09 +0200 Subject: [PATCH 2/2] Add TODO comment --- java/kotlin-extractor2/src/main/kotlin/entities/Expression.kt | 2 ++ 1 file changed, 2 insertions(+) diff --git a/java/kotlin-extractor2/src/main/kotlin/entities/Expression.kt b/java/kotlin-extractor2/src/main/kotlin/entities/Expression.kt index ce7da53e61eb..243d52cd7f18 100644 --- a/java/kotlin-extractor2/src/main/kotlin/entities/Expression.kt +++ b/java/kotlin-extractor2/src/main/kotlin/entities/Expression.kt @@ -319,6 +319,7 @@ private fun KotlinFileExtractor.extractExpression( } // TODO: e.getLabeledExpression() } + is KtTryExpression -> { val stmtParent = parent.stmt(e, callable) val id = tw.getFreshIdLabel() @@ -1272,6 +1273,7 @@ private fun KotlinFileExtractor.extractLoop( val idx: Int val parent: Label + // TODO: the below can be removed if KtLabeledExpression is handled in extractExpression. val label = (loop.parent as? KtLabeledExpression)?.getLabelName() if (label != null) { val labeledStmt = tw.getFreshIdLabel()