* gdb-events.sh (context_hook): Removed comment.
(context_changed): Add new event.
* gdb-events.c: Regenerate.
* gdb-events.h: Regenerate.
+2002-08-08 Keith Seitz <keiths@redhat.com>
+
+ * infrun.c (handle_inferior_event): Add context_changed_event.
+ * gdb-events.sh (context_hook): Removed comment.
+ (context_changed): Add new event.
+ * gdb-events.c: Regenerate.
+ * gdb-events.h: Regenerate.
+
2002-07-25 Keith Seitz <keiths@redhat.com>
* stack.c (frame_command): If the frame level changed, issue
* cli/cli-interp.c: New file. Almost entirely from Apple's
sources. Collected and moved here.
- * mi/mi-interp.c: Ditto.
- * mi/mi-events.c: Ditto.
- * mi/mi.h: New file.
* Makefile.in: Add new files.
Update dependencies on interps.h.
* defs.h (selected_frame_level_changed_hook): Add declaration.
* top.c (catcher): If the caught command changes the uiout on us,
try to do something sane, like using the current interpreter's
uiout.
- * mi/mi-main.c (captured_execute_command): Use catch_exception
- instead of catch_errors.
- (mi_execute_command_wrapper): Remove. Using catch_errors now.
- (mi_input): Make global.
- (mi_load_progress): Ditto.
- Use interpreter functions instead of interpreter_p.
- (mi_command_loop): Moved to mi-interp.c
- (mi0_command_loop): Ditto.
- (mi1_command_loop): Ditto.
- (mi_init_ui): Remove.
- (_initialize_mi_main): Remove. No longer needed.
From Jim Ingham <jingham@apple.com>:
* event-loop.c (start_event_loop): Poll the interpreter's event loop
current_event_hooks->selected_frame_level_changed (level);
}
+void
+context_changed_event (int num)
+{
+ if (gdb_events_debug)
+ fprintf_unfiltered (gdb_stdlog, "context_changed_event\n");
+ if (!current_event_hooks->context_changed)
+ return;
+ current_event_hooks->context_changed (num);
+}
+
#endif
#if WITH_GDB_EVENTS
architecture_changed,
register_update,
selected_frame_level_changed,
+ context_changed,
nr_gdb_events
};
int level;
};
+struct context_changed
+ {
+ int num;
+ };
+
struct event
{
enum gdb_event type;
struct tracepoint_modify tracepoint_modify;
struct register_update register_update;
struct selected_frame_level_changed selected_frame_level_changed;
+ struct context_changed context_changed;
}
data;
};
append (event);
}
+static void
+queue_context_changed (int num)
+{
+ struct event *event = XMALLOC (struct event);
+ event->type = context_changed;
+ event->data.context_changed.num = num;
+ append (event);
+}
+
void
gdb_events_deliver (struct gdb_events *vector)
{
vector->selected_frame_level_changed
(event->data.selected_frame_level_changed.level);
break;
+ case context_changed:
+ vector->context_changed
+ (event->data.context_changed.num);
+ break;
}
delivering_events = event->next;
xfree (event);
queue_event_hooks.architecture_changed = queue_architecture_changed;
queue_event_hooks.register_update = queue_register_update;
queue_event_hooks.selected_frame_level_changed = queue_selected_frame_level_changed;
+ queue_event_hooks.context_changed = queue_context_changed;
#endif
c = add_set_cmd ("eventdebug", class_maintenance, var_zinteger,
typedef void (gdb_events_architecture_changed_ftype) (void);
typedef void (gdb_events_register_update_ftype) (int regno);
typedef void (gdb_events_selected_frame_level_changed_ftype) (int level);
+typedef void (gdb_events_context_changed_ftype) (int num);
/* gdb-events: object. */
gdb_events_architecture_changed_ftype *architecture_changed;
gdb_events_register_update_ftype *register_update;
gdb_events_selected_frame_level_changed_ftype *selected_frame_level_changed;
+ gdb_events_context_changed_ftype *context_changed;
};
extern void architecture_changed_event (void);
extern void register_update_event (int regno);
extern void selected_frame_level_changed_event (int level);
+extern void context_changed_event (int num);
/* When GDB_EVENTS are not being used, completly disable them. */
#define architecture_changed_event() 0
#define register_update_event(regno) 0
#define selected_frame_level_changed_event(level) 0
+#define context_changed_event(num) 0
#endif
/* Install custom gdb-events hooks. */
f:void:architecture_changed:void
f:void:register_update:int regno:regno
f:void:selected_frame_level_changed:int level:level
+f:void:context_changed:int num:num
#*:void:annotate_starting_hook:void
#*:void:annotate_stopped_hook:void
#*:void:annotate_signalled_hook:void
#*:char *:readline_hook:char *prompt:prompt
#*:void:readline_end_hook:void
#*:void:memory_changed_hook:CORE_ADDR addr, int len:addr, len
-#*:void:context_hook:int num:num
#*:int:target_wait_hook:int pid, struct target_waitstatus *status:pid, status
#*:void:call_command_hook:struct cmd_list_element *c, char *cmd, int from_tty:c, cmd, from_tty
#*:NORETURN void:error_hook:void:: ATTR_NORETURN
context_switch (ecs);
+ context_changed_event (pid_to_thread_id (ecs->ptid));
if (context_hook)
context_hook (pid_to_thread_id (ecs->ptid));