command-not-found: Update with new executables
[termux-packages] / packages / dpkg / src-archives.c.patch
... / ...
CommitLineData
1diff -u -r ../dpkg-1.18.2/src/archives.c ./src/archives.c
2--- ../dpkg-1.18.2/src/archives.c 2015-07-13 09:53:37.000000000 -0400
3+++ ./src/archives.c 2015-08-25 17:59:35.594992908 -0400
4@@ -352,8 +352,10 @@
5 namenode->statoverride->uid,
6 namenode->statoverride->gid,
7 namenode->statoverride->mode);
8+#ifndef __ANDROID__
9 if (fchown(fd, st->uid, st->gid))
10 ohshite(_("error setting ownership of '%.255s'"), te->name);
11+#endif
12 if (fchmod(fd, st->mode & ~S_IFMT))
13 ohshite(_("error setting permissions of '%.255s'"), te->name);
14
15@@ -465,11 +467,15 @@
16 return; /* Already handled using the file descriptor. */
17
18 if (te->type == TAR_FILETYPE_SYMLINK) {
19+#ifndef __ANDROID__
20 if (lchown(path, st->uid, st->gid))
21 ohshite(_("error setting ownership of symlink '%.255s'"), path);
22+#endif
23 } else {
24+#ifndef __ANDROID__
25 if (chown(path, st->uid, st->gid))
26 ohshite(_("error setting ownership of '%.255s'"), path);
27+#endif
28 if (chmod(path, st->mode & ~S_IFMT))
29 ohshite(_("error setting permissions of '%.255s'"), path);
30 }
31@@ -1022,14 +1028,19 @@
32 varbuf_end_str(&symlinkfn);
33 if (symlink(symlinkfn.buf,fnametmpvb.buf))
34 ohshite(_("unable to make backup symlink for '%.255s'"), ti->name);
35+#ifndef __ANDROID__
36 if (lchown(fnametmpvb.buf,stab.st_uid,stab.st_gid))
37 ohshite(_("unable to chown backup symlink for '%.255s'"), ti->name);
38+#endif
39 tarobject_set_se_context(fnamevb.buf, fnametmpvb.buf, stab.st_mode);
40 } else {
41 debug(dbg_eachfiledetail, "tarobject nondirectory, 'link' backup");
42+ /* Termux modification: Try with rename(2) for systems not supporting hardlinks. */
43 if (link(fnamevb.buf,fnametmpvb.buf))
44- ohshite(_("unable to make backup link of '%.255s' before installing new version"),
45- ti->name);
46+ if (rename(fnamevb.buf,fnametmpvb.buf)) {
47+ ohshite(_("unable to make backup link of '%.255s' before installing new version"),
48+ ti->name);
49+ }
50 }
51 }
52