diff options
Diffstat (limited to 'gdb/inferior.c')
-rw-r--r-- | gdb/inferior.c | 43 |
1 files changed, 27 insertions, 16 deletions
diff --git a/gdb/inferior.c b/gdb/inferior.c index 0667bfa..f1991c9 100644 --- a/gdb/inferior.c +++ b/gdb/inferior.c @@ -133,6 +133,8 @@ add_inferior_silent (int pid) inferior_alloc_data (inf); + observer_notify_inferior_added (inf); + if (pid != 0) inferior_appeared (inf, pid); @@ -194,7 +196,7 @@ delete_threads_of_inferior (int pid) /* If SILENT then be quiet -- don't announce a inferior death, or the exit of its threads. */ -static void +void delete_inferior_1 (struct inferior *todel, int silent) { struct inferior *inf, *infprev; @@ -219,6 +221,8 @@ delete_inferior_1 (struct inferior *todel, int silent) else inferior_list = inf->next; + observer_notify_inferior_removed (inf); + free_inferior (inf); } @@ -265,7 +269,7 @@ exit_inferior_1 (struct inferior *inftoex, int silent) /* Notify the observers before removing the inferior from the list, so that the observers have a chance to look it up. */ - observer_notify_inferior_exit (inf->pid); + observer_notify_inferior_exit (inf); inf->pid = 0; if (inf->vfork_parent != NULL) @@ -315,7 +319,7 @@ inferior_appeared (struct inferior *inf, int pid) { inf->pid = pid; - observer_notify_inferior_appeared (pid); + observer_notify_inferior_appeared (inf); } void @@ -738,6 +742,24 @@ remove_inferior_command (char *args, int from_tty) delete_inferior_1 (inf, 1); } +struct inferior * +add_inferior_with_spaces (void) +{ + struct address_space *aspace; + struct program_space *pspace; + struct inferior *inf; + + /* If all inferiors share an address space on this system, this + doesn't really return a new address space; otherwise, it + really does. */ + aspace = maybe_new_address_space (); + pspace = add_program_space (aspace); + inf = add_inferior (0); + inf->pspace = pspace; + inf->aspace = pspace->aspace; + + return inf; +} /* add-inferior [-copies N] [-exec FILENAME] */ @@ -782,18 +804,7 @@ add_inferior_command (char *args, int from_tty) for (i = 0; i < copies; ++i) { - struct address_space *aspace; - struct program_space *pspace; - struct inferior *inf; - - /* If all inferiors share an address space on this system, this - doesn't really return a new address space; otherwise, it - really does. */ - aspace = maybe_new_address_space (); - pspace = add_program_space (aspace); - inf = add_inferior (0); - inf->pspace = pspace; - inf->aspace = pspace->aspace; + struct inferior *inf = add_inferior_with_spaces (); printf_filtered (_("Added inferior %d\n"), inf->num); @@ -801,7 +812,7 @@ add_inferior_command (char *args, int from_tty) { /* Switch over temporarily, while reading executable and symbols.q */ - set_current_program_space (pspace); + set_current_program_space (inf->pspace); set_current_inferior (inf); switch_to_thread (null_ptid); |