summaryrefslogtreecommitdiff
path: root/test/files/jvm/constant-optimization/Test.scala
diff options
context:
space:
mode:
authorJames Iry <jamesiry@gmail.com>2013-03-15 08:28:35 -0700
committerJames Iry <jamesiry@gmail.com>2013-03-15 08:28:35 -0700
commit25aabc80c9f07bc75ad5b24d48b14f0911544eca (patch)
tree732f708f4438fea75079c11bece36a38ec0198f0 /test/files/jvm/constant-optimization/Test.scala
parent482bef8079e2a2fecc2b8f77eb7c6da648125e3c (diff)
parent3a17ff00067f8f11288b1ddc778e193bed3ea017 (diff)
downloadscala-25aabc80c9f07bc75ad5b24d48b14f0911544eca.tar.gz
scala-25aabc80c9f07bc75ad5b24d48b14f0911544eca.tar.bz2
scala-25aabc80c9f07bc75ad5b24d48b14f0911544eca.zip
Merge pull request #2214 from JamesIry/master_constant_optimization
Analyze constants to remove unnecessary branches
Diffstat (limited to 'test/files/jvm/constant-optimization/Test.scala')
-rw-r--r--test/files/jvm/constant-optimization/Test.scala27
1 files changed, 27 insertions, 0 deletions
diff --git a/test/files/jvm/constant-optimization/Test.scala b/test/files/jvm/constant-optimization/Test.scala
new file mode 100644
index 0000000000..283aa6f47a
--- /dev/null
+++ b/test/files/jvm/constant-optimization/Test.scala
@@ -0,0 +1,27 @@
+
+import scala.tools.partest.BytecodeTest
+import scala.tools.asm
+import asm.tree.InsnList
+import scala.collection.JavaConverters._
+
+object Test extends BytecodeTest {
+ val comparisons = Set(asm.Opcodes.IF_ACMPEQ, asm.Opcodes.IF_ACMPNE, asm.Opcodes.IF_ICMPEQ, asm.Opcodes.IF_ICMPGE, asm.Opcodes.IF_ICMPGT, asm.Opcodes.IF_ICMPLE,
+ asm.Opcodes.IF_ICMPLT, asm.Opcodes.IF_ICMPNE, asm.Opcodes.IFEQ, asm.Opcodes.IFGE, asm.Opcodes.IFGT, asm.Opcodes.IFLE, asm.Opcodes.IFLT,
+ asm.Opcodes.IFNE, asm.Opcodes.IFNONNULL, asm.Opcodes.IFNULL)
+
+ def show: Unit = {
+ val classNode = loadClassNode("Foo_1")
+ val methodNode = getMethod(classNode, "foo")
+ // after optimization there should be no comparisons left
+ val expected = 0
+
+ val got = countComparisons(methodNode.instructions)
+ assert(got == expected, s"expected $expected but got $got comparisons")
+ }
+
+ def countComparisons(insnList: InsnList): Int = {
+ def isComparison(node: asm.tree.AbstractInsnNode): Boolean =
+ (comparisons contains node.getOpcode)
+ insnList.iterator.asScala count isComparison
+ }
+} \ No newline at end of file