Actually do a chmod if -U, but only try chmod'ing the lower 0777 bits.

This is needed to make things executable, where appropriate.
This commit is contained in:
tv 2001-11-12 19:08:31 +00:00
parent 5da3f37a1c
commit aff1bdffff

View File

@ -1,4 +1,4 @@
/* $NetBSD: xinstall.c,v 1.57 2001/10/29 02:57:21 lukem Exp $ */ /* $NetBSD: xinstall.c,v 1.58 2001/11/12 19:08:31 tv Exp $ */
/* /*
* Copyright (c) 1987, 1993 * Copyright (c) 1987, 1993
@ -43,7 +43,7 @@ __COPYRIGHT("@(#) Copyright (c) 1987, 1993\n\
#if 0 #if 0
static char sccsid[] = "@(#)xinstall.c 8.1 (Berkeley) 7/21/93"; static char sccsid[] = "@(#)xinstall.c 8.1 (Berkeley) 7/21/93";
#else #else
__RCSID("$NetBSD: xinstall.c,v 1.57 2001/10/29 02:57:21 lukem Exp $"); __RCSID("$NetBSD: xinstall.c,v 1.58 2001/11/12 19:08:31 tv Exp $");
#endif #endif
#endif /* not lint */ #endif /* not lint */
@ -503,7 +503,9 @@ install(char *from_name, char *to_name, u_int flags)
(void)unlink(to_name); (void)unlink(to_name);
errx(1, "%s: chown/chgrp: %s", to_name, strerror(serrno)); errx(1, "%s: chown/chgrp: %s", to_name, strerror(serrno));
} }
if (!dounpriv && fchmod(to_fd, mode) == -1) { if (dounpriv)
mode &= S_IRWXU|S_IRWXG|S_IRWXO;
if (fchmod(to_fd, mode) == -1) {
serrno = errno; serrno = errno;
(void)unlink(to_name); (void)unlink(to_name);
errx(1, "%s: chmod: %s", to_name, strerror(serrno)); errx(1, "%s: chmod: %s", to_name, strerror(serrno));