Creating a Launching Debugger


The following is a brief example of using the launching debugger to start a target JVM process and connect to it for debugging purposes.



import org.scaladebugger.api.debuggers.LaunchingDebugger
import org.scaladebugger.api.utils.JDITools

 * Launches a target JVM process and connects to it using the
 * launching debugger.
object LaunchingDebuggerExample extends App {
  // Get the executing class name (remove $ from object class name)
  val klass = SomeLaunchingMainClass.getClass
  val className = klass.getName.replaceAllLiterally("$", "")

  // Add our main class to the classpath used to launch the class
  val classpath = JDITools.jvmClassPath
  val jvmOptions = Seq("-classpath", classpath)

  val launchingDebugger = LaunchingDebugger(
    className = className,
    jvmOptions = jvmOptions,
    suspend = true // Wait to start the main class until after connected

  launchingDebugger.start { s =>
    println("Launched and connected to JVM: " + s.uniqueId)

    // Shuts down the launched target JVM and our debugger

  // Keep the sample program running while our debugger is running
  while (launchingDebugger.isRunning) Thread.sleep(1)


 * Sample main class that does nothing.
object SomeLaunchingMainClass {
  def main(args: Array[String]): Unit = {
    // Does nothing