aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gdb/ChangeLog8
-rw-r--r--gdb/objfiles.c19
2 files changed, 25 insertions, 2 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog
index d2dbf3a..ce17760 100644
--- a/gdb/ChangeLog
+++ b/gdb/ChangeLog
@@ -1,3 +1,11 @@
+2006-01-06 Fred Fish <fnf@specifix.com>
+
+ * objfiles.c (source.h): Include.
+ (free_objfile): Update comment about clear_symtab_users().
+ (free_objfile): Check all symtabs of objfile being freed and if
+ one of them is the current source symtab, call
+ clear_current_source_symtab_and_line().
+
2006-01-04 Michael Snyder <msnyder@redhat.com>
Checkpoint/Restart for Linux.
diff --git a/gdb/objfiles.c b/gdb/objfiles.c
index 459709a..41aab64 100644
--- a/gdb/objfiles.c
+++ b/gdb/objfiles.c
@@ -45,6 +45,7 @@
#include "breakpoint.h"
#include "block.h"
#include "dictionary.h"
+#include "source.h"
/* Prototypes for local functions */
@@ -432,10 +433,24 @@ free_objfile (struct objfile *objfile)
is unknown, but we play it safe for now and keep each action until
it is shown to be no longer needed. */
- /* I *think* all our callers call clear_symtab_users. If so, no need
- to call this here. */
+ /* Not all our callers call clear_symtab_users (objfile_purge_solibs,
+ for example), so we need to call this here. */
clear_pc_function_cache ();
+ /* Check to see if the current_source_symtab belongs to this objfile,
+ and if so, call clear_current_source_symtab_and_line. */
+
+ {
+ struct symtab_and_line cursal = get_current_source_symtab_and_line ();
+ struct symtab *s;
+
+ ALL_OBJFILE_SYMTABS (objfile, s)
+ {
+ if (s == cursal.symtab)
+ clear_current_source_symtab_and_line ();
+ }
+ }
+
/* The last thing we do is free the objfile struct itself. */
objfile_free_data (objfile);