Accessing Script Documentation#

The LLDB API is contained in a python module named lldb. A useful resource when writing Python extensions is the lldb Python classes reference guide.

The documentation is also accessible in an interactive debugger session with the following command:

(lldb) script help(lldb)
   Help on package lldb:

   NAME
      lldb - The lldb module contains the public APIs for Python binding.

   FILE
      /System/Library/PrivateFrameworks/LLDB.framework/Versions/A/Resources/Python/lldb/__init__.py

   DESCRIPTION
...

You can also get help using a module class name. The full API that is exposed for that class will be displayed in a man page style window. Below we want to get help on the lldb.SBFrame class:

(lldb) script help(lldb.SBFrame)
   Help on class SBFrame in module lldb:

   class SBFrame(builtins.object)
    |  SBFrame(*args)
    |  
    |  Represents one of the stack frames associated with a thread.
    |  
    |  SBThread contains SBFrame(s). For example (from test/lldbutil.py), ::
    |  
    |      def print_stacktrace(thread, string_buffer = False):
    |          '''Prints a simple stack trace of this thread.'''
...

Or you can get help using any python object, here we use the lldb.process object which is a global variable in the lldb module which represents the currently selected process:

(lldb) script help(lldb.process)
   Help on SBProcess in module lldb object:

   class SBProcess(builtins.object)
    |  SBProcess(*args)
    |  
    |  Represents the process associated with the target program.
    |  
    |  SBProcess supports thread iteration. For example (from test/lldbutil.py), ::
    |  
    |      # ==================================================
    |      # Utility functions related to Threads and Processes
    |      # ==================================================
...