1
0
Fork 0
mirror of git://git.code.sf.net/p/zsh/code synced 2025-01-22 00:21:27 +01:00

History file-handling improvments.

This commit is contained in:
Wayne Davison 2008-03-06 17:23:00 +00:00
parent 9fb0f8dea2
commit 697d170928
2 changed files with 33 additions and 8 deletions

View file

@ -1,3 +1,14 @@
2008-03-06 Wayne Davison <wayned@users.sourceforge.net>
* 24693: Src/utils.c: provide better errors when skipping
history-file saving due to ownership. Allow root to do the
save anyway if zsh can chown a file descriptor. Fixed the
propagation of the errno from a failed open() of the history
file (zsh used to complain about an invalid file descriptor).
* unposted: Src/Zle/zle_utils.c: fixed 2 compiler warnings
about comparing signed and unsigned.
2008-03-04 Peter Stephenson <pws@csr.com> 2008-03-04 Peter Stephenson <pws@csr.com>
* unposted: Completion/Unix/Command/_perforce: ignore range * unposted: Completion/Unix/Command/_perforce: ignore range

View file

@ -2192,13 +2192,13 @@ savehistfile(char *fn, int err, int writeflags)
} }
errno = 0; errno = 0;
if (writeflags & HFILE_APPEND) { if (writeflags & HFILE_APPEND) {
int fd = open(unmeta(fn), O_CREAT | O_WRONLY | O_APPEND | O_NOCTTY, 0600);
tmpfile = NULL; tmpfile = NULL;
out = fdopen(open(unmeta(fn), out = fd >= 0 ? fdopen(fd, "a") : NULL;
O_CREAT | O_WRONLY | O_APPEND | O_NOCTTY, 0600), "a");
} else if (!isset(HISTSAVEBYCOPY)) { } else if (!isset(HISTSAVEBYCOPY)) {
int fd = open(unmeta(fn), O_CREAT | O_WRONLY | O_TRUNC | O_NOCTTY, 0600);
tmpfile = NULL; tmpfile = NULL;
out = fdopen(open(unmeta(fn), out = fd >= 0 ? fdopen(fd, "w") : NULL;
O_CREAT | O_WRONLY | O_TRUNC | O_NOCTTY, 0600), "w");
} else { } else {
tmpfile = bicat(unmeta(fn), ".new"); tmpfile = bicat(unmeta(fn), ".new");
if (unlink(tmpfile) < 0 && errno != ENOENT) if (unlink(tmpfile) < 0 && errno != ENOENT)
@ -2206,13 +2206,27 @@ savehistfile(char *fn, int err, int writeflags)
else { else {
struct stat sb; struct stat sb;
int old_exists = stat(unmeta(fn), &sb) == 0; int old_exists = stat(unmeta(fn), &sb) == 0;
uid_t euid = geteuid();
if (old_exists && sb.st_uid != geteuid()) { if (old_exists
#if defined HAVE_FCHMOD && defined HAVE_FCHOWN
&& euid
#endif
&& sb.st_uid != euid) {
free(tmpfile); free(tmpfile);
tmpfile = NULL; /* Avoid an error about HISTFILE.new */ if (err) {
if (isset(APPENDHISTORY) || isset(INCAPPENDHISTORY)
|| isset(SHAREHISTORY))
zerr("rewriting %s would change its ownership -- skipped", fn);
else
zerr("rewriting %s would change its ownership -- history not saved", fn);
err = 0; /* Don't report a generic error below. */
}
out = NULL; out = NULL;
} else } else {
out = fdopen(open(tmpfile, O_CREAT | O_WRONLY | O_EXCL, 0600), "w"); int fd = open(tmpfile, O_CREAT | O_WRONLY | O_EXCL, 0600);
out = fd >= 0 ? fdopen(fd, "w") : NULL;
}
#ifdef HAVE_FCHMOD #ifdef HAVE_FCHMOD
if (old_exists && out) { if (old_exists && out) {