dwarf2out.c (prefix_of): New function.
authorUlrich Drepper <drepper@gcc.gnu.org>
Thu, 25 Jan 2001 00:18:16 +0000 (00:18 +0000)
committerUlrich Drepper <drepper@gcc.gnu.org>
Thu, 25 Jan 2001 00:18:16 +0000 (00:18 +0000)
* dwarf2out.c (prefix_of): New function.  Determine longest common
prefix of the two arguments.  The units are whole path components.
(output_file_names): When adding a new directory find the one entry
with the longest common prefix already in the list.  Artificially
generate entry if there is none for this prefix.
Fix test to check whether the zeroth directory entry is used.
: ----------------------------------------------------------------------

From-SVN: r39253

gcc/ChangeLog
gcc/dwarf2out.c

index 297208f5101f1af60e56a0bc135775227a58b60f..367b9338d678473cc49094ceabfee7a156fa556f 100644 (file)
@@ -1,3 +1,12 @@
+2001-01-24  Ulrich Drepper  <drepper@redhat.com>
+
+       * dwarf2out.c (prefix_of): New function.  Determine longest common
+       prefix of the two arguments.  The units are whole path components.
+       (output_file_names): When adding a new directory find the one entry
+       with the longest common prefix already in the list.  Artificially
+       generate entry if there is none for this prefix.
+       Fix test to check whether the zeroth directory entry is used.
+
 Wed Jan 24 23:51:55 2001  J"orn Rennecke <amylaar@redhat.com>
 
        * reload1.c (reload_reg_free_for_value_p): New parameter start_regno.
@@ -46,7 +55,7 @@ Wed Jan 24 23:51:55 2001  J"orn Rennecke <amylaar@redhat.com>
        * cpp.texi (-M, -MM): Document -M -include behaviour.
 
 2001-01-24  Roger Collins <roger@ProProject.com>
-         
+
         * config/i386/xm-i386.h: Make __i386__ a boolean macro.
 
 2001-01-24  Will Cohen  <wcohen@redhat.com>
@@ -67,7 +76,7 @@ Wed Jan 24 23:51:55 2001  J"orn Rennecke <amylaar@redhat.com>
 
        * bb-reorder.c (make_reorder_chain_1): Handle case where
        jump edge goes to the same block as the fallthru edge.
+
 2001-01-23  Jim Wilson  <wilson@redhat.com>
 
        * dwarf2out.c (dwarf2out_line): Make last_file_num be unsigned.
@@ -92,7 +101,7 @@ Wed Jan 24 23:51:55 2001  J"orn Rennecke <amylaar@redhat.com>
        (flushrs): Add explicit stop bit at end.
        * config/ia64/lib1funcs.asm (__ia64_restore_stack_nonlocal): Change
        trailing \ to >.
-       
+
 2001-01-23  Chris Demetriou  <cgd@broadcom.com>
 
        * libgcc-std.ver (GCC_3.0): Add __terminate_func_set to list
@@ -172,7 +181,7 @@ Wed Jan 24 23:51:55 2001  J"orn Rennecke <amylaar@redhat.com>
        Use the saved register pointer array as the source of the CFA.
        (throw_helper): Rewrite.  Unwind once rather than twice and keep
        track of saved registers as we go.
+
 2001-01-23  Herman A.J. ten Brugge <Haj.Ten.Brugge@net.HCC.nl>
 
        * c4x-protos.h (c4x_legitimize_reload_address): Remove.
@@ -236,7 +245,7 @@ Mon Jan 22 16:53:06 2001  J"orn Rennecke <amylaar@redhat.com>
        memory.
        (c4x_r11_set_p, c4x_check_laj_p): New functions.
        * c4x-protos.h (c4x_check_laj_p): Add prototype.
-       * c4x.md (in_annul_slot_3): Do not allow auto-increment in last 
+       * c4x.md (in_annul_slot_3): Do not allow auto-increment in last
        anulling slot because of silicon bug.
        (laj, lajv): Call c4x_check_laj_p to check for silicon bug.
 
index 9b0a8c454bec8e6c4e2a2dd519fcc89590df7034..a360a19b455e243b6f4d587dcd215d3bed316211 100644 (file)
@@ -6494,6 +6494,33 @@ file_info_cmp (p1, p2)
     }
 }
 
+/* Compute the maximum prefix of P2 appearing also in P1.  Entire
+   directory names must match.  */
+static int prefix_of PARAMS ((struct dir_info *, struct dir_info *));
+static int
+prefix_of (p1, p2)
+     struct dir_info *p1;
+     struct dir_info *p2;
+{
+  char *s1 = p1->path;
+  char *s2 = p2->path;
+  int len = p1->length < p2->length ? p1->length : p2->length;
+
+  while (*s1 == *s2 && s1 < p1->path + len)
+    ++s1, ++s2;
+
+  if (*s1 == '/' && *s2 == '/')
+    /* The whole of P1 is the prefix.  */
+    return p1->length;
+
+  /* Go back to the last directory component.  */
+  while (s1 > p1->path)
+    if (*--s1 == '/')
+      return s1 - p1->path + 1;
+
+  return 0;
+}
+
 /* Output the directory table and the file name table.  We try to minimize
    the total amount of memory needed.  A heuristic is used to avoid large
    slowdowns with many input files.  */
@@ -6513,7 +6540,7 @@ output_file_names ()
   /* Allocate the various arrays we need.  */
   files = (struct file_info *) alloca (line_file_table.in_use
                                       * sizeof (struct file_info));
-  dirs = (struct dir_info *) alloca (line_file_table.in_use
+  dirs = (struct dir_info *) alloca (line_file_table.in_use * 2
                                     * sizeof (struct dir_info));
 
   /* Sort the file names.  */
@@ -6562,6 +6589,8 @@ output_file_names ()
     else
       {
        int j;
+       int max_idx;
+       int max_len;
 
        /* This is a new directory.  */
        dirs[ndirs].path = files[i].path;
@@ -6573,12 +6602,46 @@ output_file_names ()
        files[i].dir_idx = ndirs;
 
        /* Search for a prefix.  */
-       dirs[ndirs].prefix = -1;
+       max_len = 0;
+       max_idx = 0;
        for (j = 0; j < ndirs; ++j)
-         if (dirs[j].length < dirs[ndirs].length
-             && dirs[j].length != 0
-             && memcmp (dirs[j].path, dirs[ndirs].path, dirs[j].length) == 0)
-           dirs[ndirs].prefix = j;
+         if (dirs[j].length > max_len)
+           {
+             int this_len = prefix_of (&dirs[j], &dirs[ndirs]);
+
+             if (this_len > max_len)
+               {
+                 max_len = this_len;
+                 max_idx = j;
+               }
+           }
+
+       /* Remember the prefix.  If this is a known prefix simply
+          remember the index.  Otherwise we will have to create an
+          artificial entry.  */
+       if (max_len == dirs[max_idx].length)
+         /* This is our prefix.  */
+         dirs[ndirs].prefix = max_idx;
+       else if (max_len > 0)
+         {
+           /* Create an entry without associated file.  Since we have
+              to keep the dirs array sorted (means, entries with paths
+              which come first) we have to move the new entry in the
+              place of the old one.  */
+           dirs[++ndirs] = dirs[max_idx];
+
+           /* We don't have to set .path.  */
+           dirs[max_idx].length = max_len;
+           dirs[max_idx].nbytes = 0;
+           dirs[max_idx].count = 0;
+           dirs[max_idx].dir_idx = ndirs;
+           dirs[max_idx].used = 0;
+           dirs[max_idx].prefix = dirs[ndirs].prefix;
+
+           dirs[ndirs - 1].prefix = dirs[ndirs].prefix = max_idx;
+         }
+       else
+         dirs[ndirs].prefix = -1;
 
        ++ndirs;
       }
@@ -6666,7 +6729,7 @@ output_file_names ()
      confuse these indices with the one for the constructed table
      (even though most of the time they are identical).  */
   idx = 1;
-  idx_offset = dirs[0].path[0] == '/' ? 1 : 0;
+  idx_offset = dirs[0].length > 0 ? 1 : 0;
   for (i = 1 - idx_offset; i < ndirs; ++i)
     if (dirs[i].used != 0)
       {
@@ -7856,7 +7919,7 @@ loc_descriptor_from_tree (loc, addressp)
     case NON_LVALUE_EXPR:
     case SAVE_EXPR:
       return loc_descriptor_from_tree (TREE_OPERAND (loc, 0), addressp);
-      
+
     case COMPONENT_REF:
     case BIT_FIELD_REF:
     case ARRAY_REF: