teknoraver / rpms / rpm

Forked from rpms/rpm 5 months ago
Clone

Blame rpm-4.4.2.1-debuginfo-names.patch

Panu Matilainen 61cb76
From roland@redhat.com Sun Aug 12 15:45:49 2007
Panu Matilainen 61cb76
Date: Sun, 12 Aug 2007 05:45:16 -0700 (PDT)
Panu Matilainen 61cb76
From: Roland McGrath <roland@redhat.com>
Panu Matilainen 61cb76
To: Panu Matilainen <pmatilai@redhat.com>
Panu Matilainen 61cb76
Cc: Paul Nasrat <pnasrat@redhat.com>
Panu Matilainen 61cb76
Subject: Re: debugedit.c goof
Panu Matilainen 61cb76
Panu Matilainen 61cb76
> No need, already applied upstream HEAD, 4.4.x branch and rawhide build 
Panu Matilainen 61cb76
> with the fix triggered.
Panu Matilainen 61cb76
Panu Matilainen 61cb76
Too quick!  I have another fix. ;-)
Panu Matilainen 61cb76
Panu Matilainen 61cb76
This one is less trivial, and not tested.  It should make it put names in
Panu Matilainen 61cb76
the -l file when they match the edit replace directory name as well as the
Panu Matilainen 61cb76
edit match directory name, the point being that it emits the same names
Panu Matilainen 61cb76
when run twice in a row.
Panu Matilainen 61cb76
Panu Matilainen 61cb76
Thanks,
Panu Matilainen 61cb76
Roland
Panu Matilainen 61cb76
Panu Matilainen 61cb76
Panu Matilainen 61cb76
diff -r fb1ee4c438c9 tools/debugedit.c
Panu Matilainen 61cb76
--- a/tools/debugedit.c	Sun Aug 12 15:27:46 2007 +0300
Panu Matilainen 61cb76
+++ b/tools/debugedit.c	Sun Aug 12 05:42:13 2007 -0700
Panu Matilainen 61cb76
@@ -567,23 +567,22 @@ edit_dwarf2_line (DSO *dso, uint_32 off,
Panu Matilainen 61cb76
 	  memcpy (s + comp_dir_len + 1 + dir_len + 1, file, file_len + 1);
Panu Matilainen 61cb76
 	}
Panu Matilainen 61cb76
       canonicalize_path (s, s);
Panu Matilainen 61cb76
-      if (base_dir == NULL ||
Panu Matilainen 61cb76
-	  has_prefix (s, base_dir))
Panu Matilainen 61cb76
-	{
Panu Matilainen 61cb76
-	  char *p;
Panu Matilainen 61cb76
-	  size_t size;
Panu Matilainen 61cb76
-	  ssize_t ret;
Panu Matilainen 61cb76
-	  if (base_dir)
Panu Matilainen 61cb76
+      if (list_file_fd != -1)
Panu Matilainen 61cb76
+	{
Panu Matilainen 61cb76
+	  char *p = NULL;
Panu Matilainen 61cb76
+	  if (base_dir == NULL)
Panu Matilainen 61cb76
+	    p = s;
Panu Matilainen 61cb76
+	  else if (has_prefix (s, base_dir))
Panu Matilainen 61cb76
 	    p = s + strlen (base_dir);
Panu Matilainen 61cb76
-	  else
Panu Matilainen 61cb76
-	    p = s;
Panu Matilainen 61cb76
-	  
Panu Matilainen 61cb76
-	  if (list_file_fd != -1)
Panu Matilainen 61cb76
+	  else if (has_prefix (s, dest_dir))
Panu Matilainen 61cb76
+	    p = s + strlen (dest_dir);
Panu Matilainen 61cb76
+
Panu Matilainen 61cb76
+	  if (p)
Panu Matilainen 61cb76
 	    {
Panu Matilainen 61cb76
-	      size = strlen (p) + 1;
Panu Matilainen 61cb76
+	      size_t size = strlen (p) + 1;
Panu Matilainen 61cb76
 	      while (size > 0)
Panu Matilainen 61cb76
 		{
Panu Matilainen 61cb76
-		  ret = write (list_file_fd, p, size);
Panu Matilainen 61cb76
+		  ssize_t ret = write (list_file_fd, p, size);
Panu Matilainen 61cb76
 		  if (ret == -1)
Panu Matilainen 61cb76
 		    break;
Panu Matilainen 61cb76
 		  size -= ret;