Limit objdump -S context lines
authorAlan Modra <amodra@gmail.com>
Fri, 24 Jun 2016 01:20:25 +0000 (10:50 +0930)
committerAlan Modra <amodra@gmail.com>
Fri, 24 Jun 2016 13:35:48 +0000 (23:05 +0930)
Showing context lines is confusing in many cases, an obvious example
being loops.

* objdump.c (struct print_file_list): Add "max_printed".
(try_print_file_open): Init new field.
(show_line): Don't show 5 context lines when redisplaying source.

binutils/ChangeLog
binutils/objdump.c

index 201b4668eb74a580add7e3b003c151069357a8ee..757aa988eb2103a77a04b1e58598840355c73e65 100644 (file)
@@ -1,3 +1,9 @@
+2016-06-24  Alan Modra  <amodra@gmail.com>
+
+       * objdump.c (struct print_file_list): Add "max_printed".
+       (try_print_file_open): Init new field.
+       (show_line): Don't show 5 context lines when redisplaying source.
+
 2016-06-22  Nick Clifton  <nickc@redhat.com>
 
        * testsuite/binutils-all/ar.exp: Skip tests for Alpha target.
index 5b848014c7135c65af026e422558ed8f56ca1f3e..174596e252b8aa5610aed01015cc7512d129ca45 100644 (file)
@@ -1135,6 +1135,7 @@ struct print_file_list
   const char **linemap;
   unsigned maxline;
   unsigned last_line;
+  unsigned max_printed;
   int first;
 };
 
@@ -1260,6 +1261,7 @@ try_print_file_open (const char *origname, const char *modname)
 
   p->linemap = index_file (p->map, p->mapsize, &p->maxline);
   p->last_line = 0;
+  p->max_printed = 0;
   p->filename = origname;
   p->modname = modname;
   p->next = print_files;
@@ -1447,10 +1449,17 @@ show_line (bfd *abfd, asection *section, bfd_vma addr_offset)
              l = linenumber - SHOW_PRECEDING_CONTEXT_LINES;
              if (l >= linenumber)
                l = 1;
-             if (p->last_line >= l && p->last_line <= linenumber)
-               l = p->last_line + 1;
+             if (p->max_printed >= l)
+               {
+                 if (p->max_printed < linenumber)
+                   l = p->max_printed + 1;
+                 else
+                   l = linenumber;
+               }
            }
          dump_lines (p, l, linenumber);
+         if (p->max_printed < linenumber)
+           p->max_printed = linenumber;
          p->last_line = linenumber;
          p->first = 0;
        }