dpkg: Update from 1.17.25 to 1.18.2
[termux-packages] / packages / dpkg / src-archives.c.patch
diff --git a/packages/dpkg/src-archives.c.patch b/packages/dpkg/src-archives.c.patch
new file mode 100644 (file)
index 0000000..9ae0f41
--- /dev/null
@@ -0,0 +1,52 @@
+diff -u -r ../dpkg-1.18.2/src/archives.c ./src/archives.c
+--- ../dpkg-1.18.2/src/archives.c      2015-07-13 09:53:37.000000000 -0400
++++ ./src/archives.c   2015-08-25 17:59:35.594992908 -0400
+@@ -352,8 +352,10 @@
+             namenode->statoverride->uid,
+             namenode->statoverride->gid,
+             namenode->statoverride->mode);
++#ifndef __ANDROID__
+     if (fchown(fd, st->uid, st->gid))
+       ohshite(_("error setting ownership of '%.255s'"), te->name);
++#endif
+     if (fchmod(fd, st->mode & ~S_IFMT))
+       ohshite(_("error setting permissions of '%.255s'"), te->name);
+@@ -465,11 +467,15 @@
+     return; /* Already handled using the file descriptor. */
+   if (te->type == TAR_FILETYPE_SYMLINK) {
++#ifndef __ANDROID__
+     if (lchown(path, st->uid, st->gid))
+       ohshite(_("error setting ownership of symlink '%.255s'"), path);
++#endif
+   } else {
++#ifndef __ANDROID__
+     if (chown(path, st->uid, st->gid))
+       ohshite(_("error setting ownership of '%.255s'"), path);
++#endif
+     if (chmod(path, st->mode & ~S_IFMT))
+       ohshite(_("error setting permissions of '%.255s'"), path);
+   }
+@@ -1022,14 +1028,19 @@
+       varbuf_end_str(&symlinkfn);
+       if (symlink(symlinkfn.buf,fnametmpvb.buf))
+         ohshite(_("unable to make backup symlink for '%.255s'"), ti->name);
++#ifndef __ANDROID__
+       if (lchown(fnametmpvb.buf,stab.st_uid,stab.st_gid))
+         ohshite(_("unable to chown backup symlink for '%.255s'"), ti->name);
++#endif
+       tarobject_set_se_context(fnamevb.buf, fnametmpvb.buf, stab.st_mode);
+     } else {
+       debug(dbg_eachfiledetail, "tarobject nondirectory, 'link' backup");
++      /* Termux modification: Try with rename(2) for systems not supporting hardlinks. */
+       if (link(fnamevb.buf,fnametmpvb.buf))
+-        ohshite(_("unable to make backup link of '%.255s' before installing new version"),
+-                ti->name);
++        if (rename(fnamevb.buf,fnametmpvb.buf)) {
++          ohshite(_("unable to make backup link of '%.255s' before installing new version"),
++                ti->name);
++      }
+     }
+   }