DEB(1)                                                     DEB(1)

     NAME
          deb - graphical Limbo debugger

     SYNOPSIS
          wm/deb [-f file] [-p pid]

     DESCRIPTION
          Wm/deb displays two windows, the main debugging window and a
          stack window for browsing the data values of the thread cur-
          rently being debugged.

          Debugging is performed using the facilities of the prog
          device bound to the local /prog directory (see prog(3)).
          Debugging of code running on a remote machine can be per-
          formed by binding the remote /prog directory in place of the
          local one. (See bind(1)).

          In order to display source code and set breakpoints accu-
          rately, an up to date symbol file (.sbl) must be available
          as well as the limbo source file (.b).

        Main window
          The main window is comprised of a menu bar, an icon bar and
          three text panels.  One panel, labelled Threads, lists the
          process IDs (PIDs) of the threads being debugged.  Another
          panel, labelled Break, lists the set of breakpoints, each
          given a unique number.  The third and largest panel displays
          the source code of the thread being debugged.

          Breakpoint positions are shown by red text in the source
          code display.  Clicking on a breakpoint number in the Break
          panel results in the source code panel being scrolled or
          updated to show the breakpoint.  Breakpoints are toggled by
          clicking on the statement or sub-expression in the source
          code window and clicking the breakpoint button on the icon
          bar.  A breakpoint can be hit by any of the threads being
          debugged - breakpoints are set on source code, not on indi-
          vidual threads.

          Clicking on a PID in the Threads panel results in the source
          code panel being scrolled or updated to highlight where in
          the code the thread is blocked, broken or halted on a break-
          point.

          A running thread can be halted by clicking the stop button
          on the icon bar.  A thread will also halt when it hits a
          breakpoint.  Once a thread is halted (not blocked or broken)
          its execution can be advanced a step at a time by means of
          the buttons on the icon bar.  The thread can be stepped one
          operation at a time or a statement at a time.  Normally when

     Page 1                       Plan 9            (printed 12/23/24)

     DEB(1)                                                     DEB(1)

          single stepping, function calls are stepped into.  Stepping
          commands allow for stepping over function calls, whereby the
          function is still called but its whole execution is treated
          as a single step.  Stepping out of a function is also pro-
          vided, whereby execution continues unabated until returning
          from the function.  Execution of the halted thread can be
          continued, running until it terminates, breaks or hits
          another breakpoint.

          Any of the threads being debugged can be killed or detached
          from the debugger using buttons on the icon bar.  Detaching
          a halted thread resumes its execution.

          The main window provides a set of menus for viewing source
          files, attaching to other threads, setting debugger options
          and searching for text in the source code window.

        Stack Window
          The stack window is used to inspect the values of local and
          global variables and function arguments.  Items are dis-
          played in a hierarchical manner.  Any item that contains
          other items, such as a variable of an ADT type, can be
          expanded to show the values of the sub-items.  The sub-items
          are displayed by clicking on the expand button on the left
          of the containing item, they can be hidden by pressing the
          button again.  The sub-item list is displayed indented from
          its container as a visual cue to their association.

          The stack window shows the full stack trace of the current
          thread.  The stack trace is displayed as a list of frames,
          the current frame displayed at the top of the window.  Each
          frame is given by the function name and source location of
          the code being executed in the frame.  Each frame has the
          following sub-items:

          locals    Local variables declared in the function of the
                    frame.

          args      The arguments passed to the frame function.

          module    The module global variables in the implementation
                    module of the frame function.

          Clicking on the name of a variable or function argument
          highlights the declaration of that name in the source panel
          of the main debug window.  Clicking on the function name of
          a stack frame causes the main window source panel to display
          the current statement of the frame.

          The debugger has a stack button which simply brings that
          window to the front of the display.

     Page 2                       Plan 9            (printed 12/23/24)

     DEB(1)                                                     DEB(1)

          The options menu has a layout configuration which allows the
          user to have a horizontal scroll bar or to wrap long lines
          (the default); and an option to strip carriage return char-
          acters that precede newlines (for the benefit of those using
          Windows' editors).  The state of the options is saved in the
          file /usr/username/lib/deb if that file can be created. The
          debugger attempts to read this file on startup to set the
          user's preferred options.

     OPTIONS
          -f file   Specifies a source file (.b) to load.  The associ-
                    ated executable file (.dis) is not launched until
                    the continue (run to breakpoint) button is
                    pressed.  This option takes precedence over the -p
                    option.

          -p pid    Attach to the already running thread given by pid.

     PLUMBING
          wm/deb plumbs the address of text selected using button 3 in
          the source display panel, as text of the form

               file-name:line-number

     FILES
          /prog/n/*
          /usr/username/lib/deb

     SOURCE
          /appl/wm/deb.b
          /appl/wm/debdata.b
          /appl/wm/debsrc.b

     SEE ALSO
          limbo(1), prog(3)

     BUGS
          Displaying large arrays in the Stack window can use exces-
          sive amounts of memory.

          When setting breakpoints there is no visual cue for the
          selected statement or operation until the breakpoint is
          actually set.

          It is only possible to debug modules executed by the inter-
          preter.  Code that has been JITed, the compilation execution
          method, yields stack information that does not correspond to
          information in the symbol (.sbl) file.

     Page 3                       Plan 9            (printed 12/23/24)