summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
ac6ce98)
Gnu cp behaves the same way.
* Set the default value of --modify-window to 2 on Cygwin. (Max Bowsher)
* Set the default value of --modify-window to 2 on Cygwin. (Max Bowsher)
+ * Ignore errors from chmod when -p/-a/--preserve-perms is not set.
+ (Dave Dykstra)
+
BUG FIXES:
* Fix "forward name lookup failed" errors on AIX 4.3.3. (John
BUG FIXES:
* Fix "forward name lookup failed" errors on AIX 4.3.3. (John
extern int dry_run;
extern int read_only;
extern int list_only;
extern int dry_run;
extern int read_only;
extern int list_only;
+extern int preserve_perms;
#define CHECK_RO if (read_only || list_only) {errno = EROFS; return -1;}
#define CHECK_RO if (read_only || list_only) {errno = EROFS; return -1;}
#if HAVE_CHMOD
int do_chmod(const char *path, mode_t mode)
{
#if HAVE_CHMOD
int do_chmod(const char *path, mode_t mode)
{
if (dry_run) return 0;
CHECK_RO
if (dry_run) return 0;
CHECK_RO
- return chmod(path, mode);
+ code = chmod(path, mode);
+ if ((code != 0) && preserve_perms)
+ return code;
+ return 0;
{
int fd = mkstemp(template);
if (fd == -1) return -1;
{
int fd = mkstemp(template);
if (fd == -1) return -1;
- if (fchmod(fd, perms) != 0) {
+ if ((fchmod(fd, perms) != 0) && preserve_perms) {
close(fd);
unlink(template);
return -1;
close(fd);
unlink(template);
return -1;