diff options
author | John Gilmore <gnu@cygnus> | 1992-10-01 10:00:47 +0000 |
---|---|---|
committer | John Gilmore <gnu@cygnus> | 1992-10-01 10:00:47 +0000 |
commit | 35a15d60028e53c9a7296d99bde6211240348946 (patch) | |
tree | af798c394433803fdd904d4d5d440a63a9e64fcd /gdb/doc | |
parent | fe6745b544392b5a8d00cc1fd4fd4db560717491 (diff) | |
download | gdb-35a15d60028e53c9a7296d99bde6211240348946.zip gdb-35a15d60028e53c9a7296d99bde6211240348946.tar.gz gdb-35a15d60028e53c9a7296d99bde6211240348946.tar.bz2 |
Add `command hooks' and a hook for inferior program stopping.
Diffstat (limited to 'gdb/doc')
-rw-r--r-- | gdb/doc/gdb.texinfo | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/gdb/doc/gdb.texinfo b/gdb/doc/gdb.texinfo index fd9bf1c..d183dbd 100644 --- a/gdb/doc/gdb.texinfo +++ b/gdb/doc/gdb.texinfo @@ -7001,6 +7001,7 @@ for execution as a unit: user-defined commands and command files. @menu * Define:: User-Defined Commands +* Hooks:: User-Defined Command Hooks * Command Files:: Command Files * Output:: Commands for Controlled Output @end menu @@ -7058,6 +7059,47 @@ without asking when used inside a user-defined command. Many _GDBN__ commands that normally print messages to say what they are doing omit the messages when used in a user-defined command. +@node Hooks +@section User-Defined Command Hooks +@cindex command files + +You may define @emph{hooks}, which are a special kind of user-defined +command. Whenever you run the command @samp{foo}, if the user-defined +command @samp{hook-foo} exists, it is executed (with no arguments) +before that command. + +In addition, a pseudo-command, @samp{stop} exists. Hooking this command +will cause your hook to be executed every time execution stops in the +inferior program, before breakpoint commands are run, displays are +printed, or the stack frame is printed. + +For example, to cause @code{SIGALRM} signals to be ignored while +single-stepping, but cause them to be resumed during normal execution, +you could do: + +@example +define hook-stop +handle SIGALRM nopass +end + +define hook-run +handle SIGALRM pass +end + +define hook-continue +handle SIGLARM pass +end +@end example + +Any single-word command in GDB can be hooked. Aliases for other commands +cannot be hooked (you should hook the basic command name, e.g. @code{backtrace} +rather than @code{bt}). If an error occurs during the execution of your +hook, execution of GDB commands stops and you are returned to the GDB +prompt (before the command that you actually typed had a chance to run). + +If you try to define a hook which doesn't match any known command, you +will get a warning from the @code{define} command. + @node Command Files @section Command Files |