* breakpoint.c (breakpoint_re_set): Avoid setting source symtab
authorJohn Gilmore <gnu@cygnus>
Wed, 2 Sep 1992 02:31:52 +0000 (02:31 +0000)
committerJohn Gilmore <gnu@cygnus>
Wed, 2 Sep 1992 02:31:52 +0000 (02:31 +0000)
(which involves reading in main's symtab) if we have no breakpoints.

gdb/ChangeLog
gdb/breakpoint.c

index 8402d5d24127c6d6c04020fe1149437fa2d670ab..f13f8a6dd7544f024079070b2df410314e9d2918 100644 (file)
@@ -1,3 +1,8 @@
+Tue Sep  1 17:31:45 1992  John Gilmore  (gnu@cygnus.com)
+
+       * breakpoint.c (breakpoint_re_set):  Avoid setting source symtab
+       (which involves reading in main's symtab) if we have no breakpoints.
+
 Mon Aug 31 13:47:45 1992  Fred Fish  (fnf@cygnus.com)
 
        * dwarfread.c (cu_language):  New local variable to record
index 87e8f7c5f08bb962486a5591be90085dc7766cd8..6ae795bb2b8fab3440df5754d9d29f2ca7598e1d 100644 (file)
@@ -2255,9 +2255,16 @@ breakpoint_re_set ()
   static char message1[] = "Error in re-setting breakpoint %d:\n";
   char message[sizeof (message1) + 30 /* slop */];
   
+  /* If we have no current source symtab, and we have any breakpoints,
+     go through the work of making a source context.  */
   if (current_source_symtab == NULL)
     {
-      select_source_symtab (NULL);
+      ALL_BREAKPOINTS (b)
+      {
+       select_source_symtab (NULL);
+       break;                          /* We only care if there are any, and
+                                          don't need to do it N times.  */
+      }
     }
 
   ALL_BREAKPOINTS_SAFE (b, temp)
@@ -2732,7 +2739,6 @@ fixup_breakpoints (low, high, delta)
   CORE_ADDR delta;
 {
   struct breakpoint *b;
-  extern struct breakpoint *breakpoint_chain;
 
   ALL_BREAKPOINTS (b)
     {