This is the mail archive of the gdb-patches@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Re: [RFA][patch 1/9] Yet another respin of the patch with initial Python support


On Mon, Aug 04, 2008 at 10:48:46PM +0300, Eli Zaretskii wrote:
>    When executing the @code{python} command, Python exceptions
>    uncaught within the Python code are translated to calls to
>    @value{GDBN} error-reporting mechanism.  If the command that called
>    @code{python} does not handle the error, @value{GDBN} will
>    terminate it and print an error message containing the Python
>    exception name, the associated value, and the Python call stack
>    backtrace at the point where the exception was raised.  Example:

I think we've almost got it.  The only problem I see with the above
text is that it's focused on user commands, both "python" and others.
This fits with the "Canned Sequences of Commands" usage which is what
the first patch implements, but if we can say it more generally it may
continue to be true as more patches go in.  Here's some other
scenarios I heard mentioned in conversation today:

- Tab completion.  Python code might be invoked when the user hits Tab
in the middle of an expression.

- "gdb --python", which Tom has implemented on the branch - no CLI
interpreter involved, GDB just executes a Python script.

- If Python code is used to discover some information about a stack
frame, it might be invoked every time the program stops.

So that gives me a paragraph like this, which I think is accurate.
Does this look OK to you?

  When executing Python code, uncaught Python exceptions are translated
  to calls to the @value{GDBN} error-reporting mechanism.  If
  @value{GDBN} does not handle the error, it will terminate the current
  command and print an error message containing the Python exception
  name, the associated value, and the Python call stack backtrace at the
  point where the exception was raised.  Example:

-- 
Daniel Jacobowitz
CodeSourcery


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]