diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2005-12-21 13:01:27 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2005-12-21 13:01:27 +0000 |
commit | 0786c42a9ce31bfbd48b8887e509dab09a6974a0 (patch) | |
tree | dc5f22d6c5d75ffb31f3961fc97ba55b06de0303 | |
parent | 94692f408c6c668d09527a6cac6a88be747a2943 (diff) | |
download | newlib-0786c42a9ce31bfbd48b8887e509dab09a6974a0.zip newlib-0786c42a9ce31bfbd48b8887e509dab09a6974a0.tar.gz newlib-0786c42a9ce31bfbd48b8887e509dab09a6974a0.tar.bz2 |
* fhandler_disk_file.cc (fhandler_base::fstat_helper): Fix inode number
debug output.
(fhandler_disk_file::fchown): Always set sensible permission values
when creating the ACL for symlinks.
-rw-r--r-- | winsup/cygwin/ChangeLog | 7 | ||||
-rw-r--r-- | winsup/cygwin/fhandler_disk_file.cc | 24 |
2 files changed, 26 insertions, 5 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index aa6cd5a..256788d 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,10 @@ +2005-12-21 Corinna Vinschen <corinna@vinschen.de> + + * fhandler_disk_file.cc (fhandler_base::fstat_helper): Fix inode number + debug output. + (fhandler_disk_file::fchown): Always set sensible permission values + when creating the ACL for symlinks. + 2005-12-20 Corinna Vinschen <corinna@vinschen.de> * winsup.h (flush_file_buffers): Define as inline function. diff --git a/winsup/cygwin/fhandler_disk_file.cc b/winsup/cygwin/fhandler_disk_file.cc index 5b684e5..d8fc42b 100644 --- a/winsup/cygwin/fhandler_disk_file.cc +++ b/winsup/cygwin/fhandler_disk_file.cc @@ -452,9 +452,9 @@ fhandler_base::fstat_helper (struct __stat64 *buf, } done: - syscall_printf ("0 = fstat (, %p) st_atime=%x st_size=%D, st_mode=%p, st_ino=%d, sizeof=%d", + syscall_printf ("0 = fstat (, %p) st_atime=%x st_size=%D, st_mode=%p, st_ino=%D, sizeof=%d", buf, buf->st_atime, buf->st_size, buf->st_mode, - (int) buf->st_ino, sizeof (*buf)); + buf->st_ino, sizeof (*buf)); return 0; } @@ -562,9 +562,23 @@ fhandler_disk_file::fchown (__uid32_t uid, __gid32_t gid) attrib |= S_IFDIR; int res = get_file_attribute (pc.has_acls (), get_io_handle (), pc, &attrib); if (!res) - res = set_file_attribute (pc.has_acls (), get_io_handle (), pc, - uid, gid, attrib); - + { + /* Typical Windows default ACLs can contain permissions for one + group, while being owned by another user/group. The permission + bits returned above are pretty much useless then. Creating a + new ACL with these useless permissions results in a potentially + broken symlink. So what we do here is to set the underlying + permissions of symlinks to a sensible value which allows the + world to read the symlink and only the new owner to change it. + As for the execute permissions... they *seem* to be not + necessary, but for the sake of comleteness and to avoid + struggling with yet another Windows weirdness, the execute bits + are added as well. */ + if (pc.issymlink ()) + attrib = S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH; + res = set_file_attribute (pc.has_acls (), get_io_handle (), pc, + uid, gid, attrib); + } if (oret) close (); |