class Byebug::FrameCommand

Move to specific frames in the backtrace.

Public Class Methods

description() click to toggle source
# File lib/byebug/commands/frame.rb, line 21
    def self.description
      <<-DESCRIPTION
        f[rame][ frame-number]

        #{short_description}

        If a frame number has been specified, to moves to that frame. Otherwise
        it moves to the newest frame.

        A negative number indicates position from the other end, so "frame -1"
        moves to the oldest frame, and "frame 0" moves to the newest frame.

        Without an argument, the command prints the current stack frame. Since
        the current position is redisplayed, it may trigger a resyncronization
        if there is a front end also watching over things.

        Use the "bt" command to find out where you want to go.
      DESCRIPTION
    end
regexp() click to toggle source
# File lib/byebug/commands/frame.rb, line 17
def self.regexp
  /^\s* f(?:rame)? (?:\s+(\S+))? \s*$/x
end
short_description() click to toggle source
# File lib/byebug/commands/frame.rb, line 41
def self.short_description
  "Moves to a frame in the call stack"
end

Public Instance Methods

execute() click to toggle source
# File lib/byebug/commands/frame.rb, line 45
def execute
  return print(pr("frame.line", context.frame.to_hash)) unless @match[1]

  pos, err = get_int(@match[1], "Frame")
  return errmsg(err) unless pos

  switch_to_frame(pos)

  ListCommand.new(processor).execute if Setting[:autolist]
end