| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 
 | import scala.tools.partest.{BytecodeTest, ASMConverters}
import scala.tools.nsc.util.JavaClassPath
import java.io.InputStream
import scala.tools.asm
import asm.ClassReader
import asm.tree.{ClassNode, InsnList}
import scala.collection.JavaConverters._
object Test extends BytecodeTest {
  import ASMConverters._
  def show: Unit = {
    val instrBaseSeqs = Seq("ScalaClient_1", "JavaClient_1") map (name => instructionsFromMethod(getMethod(loadClassNode(name), "foo")))
    val instrSeqs = instrBaseSeqs map (_ filter isInvoke)
    cmpInstructions(instrSeqs(0), instrSeqs(1))
  }
  def cmpInstructions(isa: List[Instruction], isb: List[Instruction]) = {
    if (isa == isb) println("bytecode identical")
    else diffInstructions(isa, isb)
  }
  def isInvoke(node: Instruction): Boolean = {
    val opcode = node.opcode
    (opcode == "INVOKEVIRTUAL") || (opcode == "INVOKEINTERFACE")
  }
}
 |