1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
|
import scala.tools.partest.BytecodeTest
import scala.tools.asm
import scala.tools.asm.util._
import scala.collection.JavaConverters._
object Test extends BytecodeTest {
val nullChecks = Set(asm.Opcodes.NEW)
def show: Unit = {
def test(methodName: String) {
val classNode = loadClassNode("Foo")
val methodNode = getMethod(classNode, "b")
val ops = methodNode.instructions.iterator.asScala.map(_.getOpcode).toList
assert(!ops.contains(asm.Opcodes.NEW), ops)// should be allocation free if the closure is eliminated
}
test("b")
}
}
class Foo {
@inline final def a(x: Int => Int) = x(1)
final def b {
val delta = 0
a(x => delta + 1)
}
}
|