On Friday 08 February 2013 07:08:14 Torsten Bögershausen wrote: > On 07.02.13 20:35, Junio C Hamano wrote: > > Ramsay Jones <ramsay@xxxxxxxxxxxxxxxxxxx> writes: > > > >> Torsten Bögershausen wrote: > >>> t0070 and t1301 fail when running the test suite under cygwin. > >>> Skip the failing tests by unsetting POSIXPERM. > >> t1301 does not fail for me. (WIN XP (SP3) on NTFS) > > Others run Cygwin with vfat or some other filesystem, and some of > > them do not cope will with POSIXPERM, perhaps? > > > > Not having POSIXPERM by default for Cygwin may be a saner default > > than having one, if we have to pick one. > > > > It may be debatable to have this default as platform attribute, > > though. > > > Yes, 1301 passes on cygwin 1.5, but not on 1.7. > And it breaks on VFAT, for all kind of OS. > > Thanks for comments, I'll put more investigations on my todo stack. > /Torsten It turns out that cygwin 1.7 handles the read only attribute different then cygwin 1.5. Under cygwin 1.5 the "read only" attribute is synchronized with the "user write" bit from the permissions. tb@PC /cygdrive/c/temp/pt $ echo x >x $ chmod 444 x $ attrib x A R C:\temp\pt\x Cygwin 1.7 does not do the synchronization, which means that some files seem to be writable when do_stat() is used, but the permissions are r--r--r-- We can improve Git to work for cygwin 1.7, a suggestion for a patch may look like this: -- >8 -- Subject: [PATCH] Make core.sharedRepository work under cygwin 1.7 When core.sharedRepository is used, set_shared_perm() in path.c needs lstat() to return the correct POSIX permissions. The default for cygwin is core.ignoreCygwinFSTricks = false, which means that a simplified and fast implementation of lstat() is used. Especially the file permission bits are wrong in cygwin_lstat_fn(): The read-only attribute of a file is used to calculate the permissions, resulting in either rw-r--r-- or r--r--r-- Use a compile switch IGNORECYGWINFSTRICKS to disable the usage of cygwin_lstat_fn() only in path.c Signed-off-by: Torsten Bögershausen <tboegi@xxxxxx> --- compat/cygwin.h | 2 ++ path.c | 2 ++ 2 files changed, 4 insertions(+) diff --git a/compat/cygwin.h b/compat/cygwin.h index a3229f5..984efbe 100644 --- a/compat/cygwin.h +++ b/compat/cygwin.h @@ -5,5 +5,7 @@ typedef int (*stat_fn_t)(const char*, struct stat*); extern stat_fn_t cygwin_stat_fn; extern stat_fn_t cygwin_lstat_fn; +#ifndef IGNORECYGWINFSTRICKS #define stat(path, buf) (*cygwin_stat_fn)(path, buf) #define lstat(path, buf) (*cygwin_lstat_fn)(path, buf) +#endif diff --git a/path.c b/path.c index d3d3f8b..0acfabf 100644 --- a/path.c +++ b/path.c @@ -10,6 +10,8 @@ * * which is what it's designed for. */ +#define IGNORECYGWINFSTRICKS + #include "cache.h" #include "strbuf.h" #include "string-list.h" -- 1.8.2.341.g543621f -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html