All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.scaladebugger.api.lowlevel.steps.StepManager.scala Maven / Gradle / Ivy

package org.scaladebugger.api.lowlevel.steps
import acyclic.file

import com.sun.jdi.ThreadReference
import com.sun.jdi.request.{EventRequestManager, StepRequest}
import org.scaladebugger.api.lowlevel.requests.Implicits._
import org.scaladebugger.api.lowlevel.requests.JDIRequestArgument
import org.scaladebugger.api.lowlevel.requests.filters.CountFilter
import org.scaladebugger.api.lowlevel.requests.properties.{EnabledProperty, SuspendPolicyProperty}
import org.scaladebugger.api.utils.MultiMap

import scala.util.Try

/**
 * Represents the manager for step requests.
 */
trait StepManager {
  /**
   * Creates a new step request to step into the next called method (in other
   * words, enter the next frame created by a function on the current line or
   * continue forward) for the next line location.
   *
   * Removes any existing step requests for the specified thread.
   *
   * @note Includes a default count filter of 1. This can be overridden by
   *       providing a CountFilter(count = ???) as an extra argument.
   *
   * @param threadReference The thread where the step will occur
   * @param extraArguments The additional arguments to provide to the request
   *
   * @return Success(id) if successful, otherwise Failure
   */
  def createStepIntoLineRequest(
    threadReference: ThreadReference,
    extraArguments: JDIRequestArgument*
  ): Try[String] = createStepRequest(
    threadReference,
    StepRequest.STEP_LINE,
    StepRequest.STEP_INTO,
    extraArguments: _*
  )

  /**
   * Creates a new step request to step only into caller frames (in other
   * words, exit the current frame of execution) for the next line location.
   *
   * Removes any existing step requests for the specified thread.
   *
   * @note Includes a default count filter of 1. This can be overridden by
   *       providing a CountFilter(count = ???) as an extra argument.
   *
   * @param threadReference The thread where the step will occur
   * @param extraArguments The additional arguments to provide to the request
   *
   * @return Success(id) if successful, otherwise Failure
   */
  def createStepOutLineRequest(
    threadReference: ThreadReference,
    extraArguments: JDIRequestArgument*
  ): Try[String] = createStepRequest(
    threadReference,
    StepRequest.STEP_LINE,
    StepRequest.STEP_OUT,
    extraArguments: _*
  )

  /**
   * Creates a new step request to step only into caller frames or the current
   * frame (in other words, ignore any frames created by executing lines) for
   * the next line location.
   *
   * Removes any existing step requests for the specified thread.
   *
   * @note Includes a default count filter of 1. This can be overridden by
   *       providing a CountFilter(count = ???) as an extra argument.
   *
   * @param threadReference The thread where the step will occur
   * @param extraArguments The additional arguments to provide to the request
   *
   * @return Success(id) if successful, otherwise Failure
   */
  def createStepOverLineRequest(
    threadReference: ThreadReference,
    extraArguments: JDIRequestArgument*
  ): Try[String] = createStepRequest(
    threadReference,
    StepRequest.STEP_LINE,
    StepRequest.STEP_OVER,
    extraArguments: _*
  )

  /**
   * Creates a new step request to step into the next called method (in other
   * words, enter the next frame created by a function on the current line or
   * continue forward) for the next possible location.
   *
   * Removes any existing step requests for the specified thread.
   *
   * @note Includes a default count filter of 1. This can be overridden by
   *       providing a CountFilter(count = ???) as an extra argument.
   *
   * @param threadReference The thread where the step will occur
   * @param extraArguments The additional arguments to provide to the request
   *
   * @return Success(id) if successful, otherwise Failure
   */
  def createStepIntoMinRequest(
    threadReference: ThreadReference,
    extraArguments: JDIRequestArgument*
  ): Try[String] = createStepRequest(
    threadReference,
    StepRequest.STEP_MIN,
    StepRequest.STEP_INTO,
    extraArguments: _*
  )

  /**
   * Creates a new step request to step only into caller frames (in other
   * words, exit the current frame of execution) for the next possible location.
   *
   * Removes any existing step requests for the specified thread.
   *
   * @note Includes a default count filter of 1. This can be overridden by
   *       providing a CountFilter(count = ???) as an extra argument.
   *
   * @param threadReference The thread where the step will occur
   * @param extraArguments The additional arguments to provide to the request
   *
   * @return Success(id) if successful, otherwise Failure
   */
  def createStepOutMinRequest(
    threadReference: ThreadReference,
    extraArguments: JDIRequestArgument*
  ): Try[String] = createStepRequest(
    threadReference,
    StepRequest.STEP_MIN,
    StepRequest.STEP_OUT,
    extraArguments: _*
  )

  /**
   * Creates a new step request to step only into caller frames or the current
   * frame (in other words, ignore any frames created by executing lines) for
   * the next possible location.
   *
   * Removes any existing step requests for the specified thread.
   *
   * @note Includes a default count filter of 1. This can be overridden by
   *       providing a CountFilter(count = ???) as an extra argument.
   *
   * @param threadReference The thread where the step will occur
   * @param extraArguments The additional arguments to provide to the request
   *
   * @return Success(id) if successful, otherwise Failure
   */
  def createStepOverMinRequest(
    threadReference: ThreadReference,
    extraArguments: JDIRequestArgument*
  ): Try[String] = createStepRequest(
    threadReference,
    StepRequest.STEP_MIN,
    StepRequest.STEP_OVER,
    extraArguments: _*
  )

  /**
   * Retrieves the list of steps contained by this manager.
   *
   * @return The collection of steps in the form of thread reference
   */
  def stepRequestList: Seq[StepRequestInfo]

  /**
   * Retrieves the list of steps contained by this manager.
   *
   * @return The collection of steps by id
   */
  def stepRequestListById: Seq[String]

  /**
   * Creates and enables a step request for the given thread using the provided
   * size (next valid location or next location on a new line) and depth (into,
   * over, or out of the current frame).
   *
   * Removes any existing step requests for the specified thread.
   *
   * @note Includes a default count filter of 1. This can be overridden by
   *       providing a CountFilter(count = ???) as an extra argument.
   *
   * @param requestId The id of the request used for lookup and removal
   * @param threadReference The thread with which to perform the step
   * @param size The size of the step request (LINE/MIN)
   * @param depth The depth of the step request (INTO/OVER/OUT)
   * @param extraArguments Any additional arguments to provide to the request
   *
   * @return Success(id) if successful, otherwise Failure
   */
  def createStepRequestWithId(
    requestId: String,
    threadReference: ThreadReference,
    size: Int,
    depth: Int,
    extraArguments: JDIRequestArgument*
  ): Try[String] = createStepRequestWithId(
    requestId = requestId,
    removeExistingRequests = true,
    threadReference = threadReference,
    size = size,
    depth = depth,
    extraArguments: _*
  )

  /**
   * Creates and enables a step request for the given thread using the provided
   * size (next valid location or next location on a new line) and depth (into,
   * over, or out of the current frame).
   *
   * @note Includes a default count filter of 1. This can be overridden by
   *       providing a CountFilter(count = ???) as an extra argument.
   *
   * @param requestId The id of the request used for lookup and removal
   * @param removeExistingRequests If true, will first remove any existing
   *                               step requests for the specified thread
   * @param threadReference The thread with which to perform the step
   * @param size The size of the step request (LINE/MIN)
   * @param depth The depth of the step request (INTO/OVER/OUT)
   * @param extraArguments Any additional arguments to provide to the request
   *
   * @return Success(id) if successful, otherwise Failure
   */
  def createStepRequestWithId(
    requestId: String,
    removeExistingRequests: Boolean,
    threadReference: ThreadReference,
    size: Int,
    depth: Int,
    extraArguments: JDIRequestArgument*
  ): Try[String]

  /**
   * Creates and enables a step request for the given thread using the provided
   * size (next valid location or next location on a new line) and depth (into,
   * over, or out of the current frame).
   *
   * Removes any existing step requests for the specified thread.
   *
   * @note Includes a default count filter of 1. This can be overridden by
   *       providing a CountFilter(count = ???) as an extra argument.
   *
   * @param threadReference The thread with which to perform the step
   * @param size The size of the step request (LINE/MIN)
   * @param depth The depth of the step request (INTO/OVER/OUT)
   * @param extraArguments Any additional arguments to provide to the request
   *
   * @return Success(id) if successful, otherwise Failure
   */
  def createStepRequest(
    threadReference: ThreadReference,
    size: Int,
    depth: Int,
    extraArguments: JDIRequestArgument*
  ): Try[String] = createStepRequestWithId(
    newRequestId(),
    threadReference,
    size,
    depth,
    extraArguments: _*
  )

  /**
   * Creates a step request based on the specified information.
   *
   * @param stepRequestInfo The information used to create the step request
   *
   * @return Success(id) if successful, otherwise Failure
   */
  def createStepRequestFromInfo(
    stepRequestInfo: StepRequestInfo
  ): Try[String] = createStepRequestWithId(
    stepRequestInfo.requestId,
    stepRequestInfo.removeExistingRequests,
    stepRequestInfo.threadReference,
    stepRequestInfo.size,
    stepRequestInfo.depth,
    stepRequestInfo.extraArguments: _*
  )

  /**
   * Determines whether or not there is a step request for the specified thread.
   *
   * @param threadReference The thread with which the step request is associated
   *
   * @return True if a step request for the thread exists, otherwise false
   */
  def hasStepRequest(threadReference: ThreadReference): Boolean

  /**
   * Determines whether or not the step request with the specified id exists.
   *
   * @param requestId The id of the request
   *
   * @return True if a step request with the id exists, otherwise false
   */
  def hasStepRequestWithId(requestId: String): Boolean

  /**
   * Returns the collection of step requests for the specified thread.
   *
   * @param threadReference The thread with which the step is associated
   *
   * @return Some collection of steps for the specified thread if it exists,
   *         otherwise None
   */
  def getStepRequest(threadReference: ThreadReference): Option[Seq[StepRequest]]

  /**
   * Returns the collection of steps with the specified id.
   *
   * @param requestId The id of the request
   *
   * @return Some step request if the id exists, otherwise None
   */
  def getStepRequestWithId(requestId: String): Option[StepRequest]

  /**
   * Returns the arguments for a step request with the specified id.
   *
   * @param requestId The id of the request
   *
   * @return Some step arguments if found, otherwise None
   */
  def getStepRequestInfoWithId(requestId: String): Option[StepRequestInfo]

  /**
   * Removes the step requests for the specified thread.
   *
   * @param threadReference The thread with which the step is associated
   *
   * @return True if successfully removed the step request, otherwise false
   */
  def removeStepRequest(threadReference: ThreadReference): Boolean

  /**
   * Removes the step request with the specified id.
   *
   * @param requestId The id of the request
   *
   * @return True if successfully removed the step request, otherwise false
   */
  def removeStepRequestWithId(requestId: String): Boolean

  /**
   * Generates an id for a new request.
   *
   * @return The id as a string
   */
  protected def newRequestId(): String = java.util.UUID.randomUUID().toString
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy