Skip to content

Commit

Permalink
Exclude implicit vararg arrays from diagram
Browse files Browse the repository at this point in the history
  • Loading branch information
bnorm committed Mar 30, 2023
1 parent be90be5 commit 32a2ad8
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import org.jetbrains.kotlin.ir.expressions.IrFunctionExpression
import org.jetbrains.kotlin.ir.expressions.IrStatementOrigin
import org.jetbrains.kotlin.ir.expressions.IrTypeOperator
import org.jetbrains.kotlin.ir.expressions.IrTypeOperatorCall
import org.jetbrains.kotlin.ir.expressions.IrVararg
import org.jetbrains.kotlin.ir.expressions.IrWhen
import org.jetbrains.kotlin.ir.util.dumpKotlinLike
import org.jetbrains.kotlin.ir.visitors.IrElementVisitor
Expand Down Expand Up @@ -123,6 +124,11 @@ fun buildTree(expression: IrExpression): Node? {
}
}

override fun visitVararg(expression: IrVararg, data: Node) {
// Skip processing of vararg array
expression.acceptChildren(this, data)
}

override fun visitConst(expression: IrConst<*>, data: Node) {
// Do not include constants
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
/*
* Copyright (C) 2023 Brian Norman
*
* 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 com.bnorm.power

import kotlin.test.Test

class VarargTest {
@Test
fun `implicit array of vararg parameters is excluded from diagram`() {
assertMessage(
"""
fun main() {
var i = 0
assert(listOf("a", "b", "c") == listOf(i++, i++, i++))
}""",
"""
Assertion failed
assert(listOf("a", "b", "c") == listOf(i++, i++, i++))
| | | | | |
| | | | | 2
| | | | 1
| | | 0
| | [0, 1, 2]
| false
[a, b, c]
""".trimIndent()
)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ fun executeAssertion(
listOf(SourceFile.kotlin("main.kt", source, trimIndent = false)),
*plugins,
)
assertEquals(KotlinCompilation.ExitCode.OK, result.exitCode)
assertEquals(KotlinCompilation.ExitCode.OK, result.exitCode, result.messages)

val kClazz = result.classLoader.loadClass("MainKt")
val main = kClazz.declaredMethods.single { it.name == "main" && it.parameterCount == 0 }
Expand Down

0 comments on commit 32a2ad8

Please sign in to comment.