2003-07-18 Andrew Cagney <cagney@redhat.com>
[deliverable/binutils-gdb.git] / gdb / gdb-events.c
index 3a4f497d1287b8fea81ffffe63555be4822b3bd8..63ee3bc400bd271cbda60d8590f552ee388a96a1 100644 (file)
@@ -1,23 +1,24 @@
 /* User Interface Events.
-   Copyright 1999 Free Software Foundation, Inc.
+
+   Copyright 1999, 2001, 2002 Free Software Foundation, Inc.
 
    Contributed by Cygnus Solutions.
 
-This file is part of GDB.
+   This file is part of GDB.
 
-This program is free software; you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation; either version 2 of the License, or
-(at your option) any later version.
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 2 of the License, or
+   (at your option) any later version.
 
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
 
-You should have received a copy of the GNU General Public License
-along with this program; if not, write to the Free Software
-Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
+   You should have received a copy of the GNU General Public License
+   along with this program; if not, write to the Free Software
+   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
 
 /* Work in progress */
 
@@ -38,9 +39,6 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
 #include "gdb-events.h"
 #include "gdbcmd.h"
 
-#undef XMALLOC
-#define XMALLOC(TYPE) ((TYPE*) xmalloc (sizeof (TYPE)))
-
 #if WITH_GDB_EVENTS
 static struct gdb_events null_event_hooks;
 static struct gdb_events queue_event_hooks;
@@ -81,6 +79,76 @@ breakpoint_modify_event (int b)
   current_event_hooks->breakpoint_modify (b);
 }
 
+void
+tracepoint_create_event (int number)
+{
+  if (gdb_events_debug)
+    fprintf_unfiltered (gdb_stdlog, "tracepoint_create_event\n");
+  if (!current_event_hooks->tracepoint_create)
+    return;
+  current_event_hooks->tracepoint_create (number);
+}
+
+void
+tracepoint_delete_event (int number)
+{
+  if (gdb_events_debug)
+    fprintf_unfiltered (gdb_stdlog, "tracepoint_delete_event\n");
+  if (!current_event_hooks->tracepoint_delete)
+    return;
+  current_event_hooks->tracepoint_delete (number);
+}
+
+void
+tracepoint_modify_event (int number)
+{
+  if (gdb_events_debug)
+    fprintf_unfiltered (gdb_stdlog, "tracepoint_modify_event\n");
+  if (!current_event_hooks->tracepoint_modify)
+    return;
+  current_event_hooks->tracepoint_modify (number);
+}
+
+void
+architecture_changed_event (void)
+{
+  if (gdb_events_debug)
+    fprintf_unfiltered (gdb_stdlog, "architecture_changed_event\n");
+  if (!current_event_hooks->architecture_changed)
+    return;
+  current_event_hooks->architecture_changed ();
+}
+
+void
+target_changed_event (void)
+{
+  if (gdb_events_debug)
+    fprintf_unfiltered (gdb_stdlog, "target_changed_event\n");
+  if (!current_event_hooks->target_changed)
+    return;
+  current_event_hooks->target_changed ();
+}
+
+void
+selected_frame_level_changed_event (int level)
+{
+  if (gdb_events_debug)
+    fprintf_unfiltered (gdb_stdlog, "selected_frame_level_changed_event\n");
+  if (!current_event_hooks->selected_frame_level_changed)
+    return;
+  current_event_hooks->selected_frame_level_changed (level);
+}
+
+void
+selected_thread_changed_event (int thread_num)
+{
+  if (gdb_events_debug)
+    fprintf_unfiltered (gdb_stdlog, "selected_thread_changed_event\n");
+  if (!current_event_hooks->selected_thread_changed)
+    return;
+  current_event_hooks->selected_thread_changed (thread_num);
+}
+
 #endif
 
 #if WITH_GDB_EVENTS
@@ -96,13 +164,28 @@ set_gdb_event_hooks (struct gdb_events *vector)
 }
 #endif
 
+#if WITH_GDB_EVENTS
+void
+clear_gdb_event_hooks (void)
+{
+  set_gdb_event_hooks (&null_event_hooks);
+}
+#endif
+
 enum gdb_event
-  {
-    breakpoint_create,
-    breakpoint_delete,
-    breakpoint_modify,
-    nr_gdb_events
-  };
+{
+  breakpoint_create,
+  breakpoint_delete,
+  breakpoint_modify,
+  tracepoint_create,
+  tracepoint_delete,
+  tracepoint_modify,
+  architecture_changed,
+  target_changed,
+  selected_frame_level_changed,
+  selected_thread_changed,
+  nr_gdb_events
+};
 
 struct breakpoint_create
   {
@@ -119,15 +202,45 @@ struct breakpoint_modify
     int b;
   };
 
+struct tracepoint_create
+  {
+    int number;
+  };
+
+struct tracepoint_delete
+  {
+    int number;
+  };
+
+struct tracepoint_modify
+  {
+    int number;
+  };
+
+struct selected_frame_level_changed
+  {
+    int level;
+  };
+
+struct selected_thread_changed
+  {
+    int thread_num;
+  };
+
 struct event
   {
     enum gdb_event type;
     struct event *next;
     union
       {
-        struct breakpoint_create breakpoint_create;
-        struct breakpoint_delete breakpoint_delete;
-        struct breakpoint_modify breakpoint_modify;
+       struct breakpoint_create breakpoint_create;
+       struct breakpoint_delete breakpoint_delete;
+       struct breakpoint_modify breakpoint_modify;
+       struct tracepoint_create tracepoint_create;
+       struct tracepoint_delete tracepoint_delete;
+       struct tracepoint_modify tracepoint_modify;
+       struct selected_frame_level_changed selected_frame_level_changed;
+       struct selected_thread_changed selected_thread_changed;
       }
     data;
   };
@@ -171,6 +284,67 @@ queue_breakpoint_modify (int b)
   append (event);
 }
 
+static void
+queue_tracepoint_create (int number)
+{
+  struct event *event = XMALLOC (struct event);
+  event->type = tracepoint_create;
+  event->data.tracepoint_create.number = number;
+  append (event);
+}
+
+static void
+queue_tracepoint_delete (int number)
+{
+  struct event *event = XMALLOC (struct event);
+  event->type = tracepoint_delete;
+  event->data.tracepoint_delete.number = number;
+  append (event);
+}
+
+static void
+queue_tracepoint_modify (int number)
+{
+  struct event *event = XMALLOC (struct event);
+  event->type = tracepoint_modify;
+  event->data.tracepoint_modify.number = number;
+  append (event);
+}
+
+static void
+queue_architecture_changed (void)
+{
+  struct event *event = XMALLOC (struct event);
+  event->type = architecture_changed;
+  append (event);
+}
+
+static void
+queue_target_changed (void)
+{
+  struct event *event = XMALLOC (struct event);
+  event->type = target_changed;
+  append (event);
+}
+
+static void
+queue_selected_frame_level_changed (int level)
+{
+  struct event *event = XMALLOC (struct event);
+  event->type = selected_frame_level_changed;
+  event->data.selected_frame_level_changed.level = level;
+  append (event);
+}
+
+static void
+queue_selected_thread_changed (int thread_num)
+{
+  struct event *event = XMALLOC (struct event);
+  event->type = selected_thread_changed;
+  event->data.selected_thread_changed.thread_num = thread_num;
+  append (event);
+}
+
 void
 gdb_events_deliver (struct gdb_events *vector)
 {
@@ -179,7 +353,7 @@ gdb_events_deliver (struct gdb_events *vector)
     {
       struct event *event = delivering_events;
       delivering_events = event->next;
-      free (event);
+      xfree (event);
     }
   /* Process any pending events.  Because one of the deliveries could
      bail out we move everything off of the pending queue onto an
@@ -191,22 +365,48 @@ gdb_events_deliver (struct gdb_events *vector)
     {
       struct event *event = delivering_events;
       switch (event->type)
-        {
-        case breakpoint_create:
-          vector->breakpoint_create
-            (event->data.breakpoint_create.b);
-          break;
-        case breakpoint_delete:
-          vector->breakpoint_delete
-            (event->data.breakpoint_delete.b);
-          break;
-        case breakpoint_modify:
-          vector->breakpoint_modify
-            (event->data.breakpoint_modify.b);
-          break;
-        }
+       {
+       case breakpoint_create:
+         vector->breakpoint_create
+           (event->data.breakpoint_create.b);
+         break;
+       case breakpoint_delete:
+         vector->breakpoint_delete
+           (event->data.breakpoint_delete.b);
+         break;
+       case breakpoint_modify:
+         vector->breakpoint_modify
+           (event->data.breakpoint_modify.b);
+         break;
+       case tracepoint_create:
+         vector->tracepoint_create
+           (event->data.tracepoint_create.number);
+         break;
+       case tracepoint_delete:
+         vector->tracepoint_delete
+           (event->data.tracepoint_delete.number);
+         break;
+       case tracepoint_modify:
+         vector->tracepoint_modify
+           (event->data.tracepoint_modify.number);
+         break;
+       case architecture_changed:
+         vector->architecture_changed ();
+         break;
+       case target_changed:
+         vector->target_changed ();
+         break;
+       case selected_frame_level_changed:
+         vector->selected_frame_level_changed
+           (event->data.selected_frame_level_changed.level);
+         break;
+       case selected_thread_changed:
+         vector->selected_thread_changed
+           (event->data.selected_thread_changed.thread_num);
+         break;
+       }
       delivering_events = event->next;
-      free (event);
+      xfree (event);
     }
 }
 
@@ -214,16 +414,31 @@ void _initialize_gdb_events (void);
 void
 _initialize_gdb_events (void)
 {
+  struct cmd_list_element *c;
 #if WITH_GDB_EVENTS
   queue_event_hooks.breakpoint_create = queue_breakpoint_create;
   queue_event_hooks.breakpoint_delete = queue_breakpoint_delete;
   queue_event_hooks.breakpoint_modify = queue_breakpoint_modify;
+  queue_event_hooks.tracepoint_create = queue_tracepoint_create;
+  queue_event_hooks.tracepoint_delete = queue_tracepoint_delete;
+  queue_event_hooks.tracepoint_modify = queue_tracepoint_modify;
+  queue_event_hooks.architecture_changed = queue_architecture_changed;
+  queue_event_hooks.target_changed = queue_target_changed;
+  queue_event_hooks.selected_frame_level_changed = queue_selected_frame_level_changed;
+  queue_event_hooks.selected_thread_changed = queue_selected_thread_changed;
 #endif
-  add_show_from_set (add_set_cmd ("eventdebug",
-                                  class_maintenance,
-                                  var_zinteger,
-                                  (char *)&gdb_events_debug,
-                                  "Set event debugging.\n\
-When non-zero, event/notify debugging is enabled.", &setlist),
-                     &showlist);
+
+  c = add_set_cmd ("eventdebug", class_maintenance, var_zinteger,
+                  (char *) (&gdb_events_debug), "Set event debugging.\n\
+When non-zero, event/notify debugging is enabled.", &setlist);
+  deprecate_cmd (c, "set debug event");
+  deprecate_cmd (add_show_from_set (c, &showlist), "show debug event");
+
+  add_show_from_set (add_set_cmd ("event",
+                                 class_maintenance,
+                                 var_zinteger,
+                                 (char *) (&gdb_events_debug),
+                                 "Set event debugging.\n\
+When non-zero, event/notify debugging is enabled.", &setdebuglist),
+                    &showdebuglist);
 }
This page took 0.035857 seconds and 4 git commands to generate.