]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gdb/doc/observer.texi
2004-05-07 Andrew Cagney <cagney@redhat.com>
[thirdparty/binutils-gdb.git] / gdb / doc / observer.texi
CommitLineData
bcd7e15f
JB
1@c -*-texinfo-*-
2@node GDB Observers
3@appendix @value{GDBN} Currently available observers
4
5@section Implementation rationale
6@cindex observers implementation rationale
7
8An @dfn{observer} is an entity which is interested in being notified
9when GDB reaches certain states, or certain events occur in GDB.
10The entity being observed is called the @dfn{subject}. To receive
11notifications, the observer attaches a callback to the subject.
12One subject can have several observers.
13
14@file{observer.c} implements an internal generic low-level event
6be67e67 15notification mechanism. This generic event notification mechanism is
bcd7e15f
JB
16then re-used to implement the exported high-level notification
17management routines for all possible notifications.
18
19The current implementation of the generic observer provides support
20for contextual data. This contextual data is given to the subject
21when attaching the callback. In return, the subject will provide
22this contextual data back to the observer as a parameter of the
23callback.
24
25Note that the current support for the contextual data is only partial,
26as it lacks a mechanism that would deallocate this data when the
27callback is detached. This is not a problem so far, as this contextual
28data is only used internally to hold a function pointer. Later on, if
29a certain observer needs to provide support for user-level contextual
6be67e67 30data, then the generic notification mechanism will need to be
bcd7e15f
JB
31enhanced to allow the observer to provide a routine to deallocate the
32data when attaching the callback.
33
34The observer implementation is also currently not reentrant.
35In particular, it is therefore not possible to call the attach
36or detach routines during a notification.
37
2b4855ab
AC
38@section Debugging
39Observer notifications can be traced using the command @samp{set debug
40observer 1} (@pxref{Debugging Output, , Optional messages about
41internal happenings, gdb, Debugging with @var{GDBN}}).
42
bcd7e15f
JB
43@section @code{normal_stop} Notifications
44@cindex @code{normal_stop} observer
45@cindex notification about inferior execution stop
46
6be67e67
JB
47@value{GDBN} notifies all @code{normal_stop} observers when the
48inferior execution has just stopped, the associated messages and
49annotations have been printed, and the control is about to be returned
50to the user.
51
52Note that the @code{normal_stop} notification is not emitted when
53the execution stops due to a breakpoint, and this breakpoint has
54a condition that is not met. If the breakpoint has any associated
55commands list, the commands are executed after the notification
56is emitted.
bcd7e15f 57
7a464420 58The following interfaces are available to manage observers:
bcd7e15f 59
7a464420
AC
60@deftypefun extern struct observer *observer_attach_@var{event} (observer_@var{event}_ftype *@var{f})
61Using the function @var{f}, create an observer that is notified when
62ever @var{event} occures, return the observer.
bcd7e15f
JB
63@end deftypefun
64
7a464420 65@deftypefun extern void observer_detach_@var{event} (struct observer *@var{observer});
bcd7e15f 66Remove @var{observer} from the list of observers to be notified when
7a464420 67@var{event} occurs.
bcd7e15f
JB
68@end deftypefun
69
7a464420
AC
70@deftypefun extern void observer_notify_@var{event} (void);
71Send a notification to all @var{event} observers.
bcd7e15f
JB
72@end deftypefun
73
7a464420 74The following observable events are defined:
bcd7e15f 75
7a464420
AC
76@c note: all events must take at least one parameter.
77
78@deftypefun void normal_stop (struct bpstats *@var{bs})
79The inferior has stopped for real.
80@end deftypefun
79346bcb
OF
81
82@deftypefun void target_changed (struct target_ops *@var{target})
67ab9a76 83The target's register contents have changed.
79346bcb 84@end deftypefun