From c27a29813a634f283a405df1165f0010bb10eb74 Mon Sep 17 00:00:00 2001 From: Christopher Faylor Date: Sun, 7 Oct 2001 21:16:36 +0000 Subject: [PATCH] * path.cc (normalize_posix_path): Don't eat a '.' after a '\\' since it has special meaning on NT. * syscalls.cc (access): Use stat_worker. --- winsup/cygwin/ChangeLog | 7 +++++++ winsup/cygwin/path.cc | 14 +++++++++++++- winsup/cygwin/syscalls.cc | 4 ++-- 3 files changed, 22 insertions(+), 3 deletions(-) diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 665ae95b4..05a7f3016 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,10 @@ +Sun Oct 7 17:16:05 2001 Christopher Faylor + + * path.cc (normalize_posix_path): Don't eat a '.' after a '\\' since it + has special meaning on NT. + + * syscalls.cc (access): Use stat_worker. + Fri Oct 5 21:01:14 2001 Christopher Faylor * fhandler.cc (fhandler_base::fork_fixup): Protect dup'ed handle and diff --git a/winsup/cygwin/path.cc b/winsup/cygwin/path.cc index 1688f086e..5e00f3541 100644 --- a/winsup/cygwin/path.cc +++ b/winsup/cygwin/path.cc @@ -209,6 +209,12 @@ normalize_posix_path (const char *src, char *dst) *dst++ = '/'; src = src_start + 1; } + else if (src[0] == '.' && isslash (src[1])) + { + *dst++ = '.'; + *dst++ = '/'; + src += 2; + } } else *dst = '\0'; @@ -934,7 +940,13 @@ normalize_win32_path (const char *src, char *dst) if (beg_src_slash && isdirsep (src[1])) { *dst++ = '\\'; - ++src; + src++; + if (src[1] == '.' && isdirsep (src[2])) + { + *dst++ = '\\'; + *dst++ = '.'; + src += 2; + } } else if (strchr (src, ':') == NULL && *src != '/') { diff --git a/winsup/cygwin/syscalls.cc b/winsup/cygwin/syscalls.cc index d41cb2b10..ebdd7674b 100644 --- a/winsup/cygwin/syscalls.cc +++ b/winsup/cygwin/syscalls.cc @@ -1074,7 +1074,7 @@ access (const char *fn, int flags) { sigframe thisframe (mainthread); // flags were incorrectly specified - if (flags & ~ (F_OK|R_OK|W_OK|X_OK)) + if (flags & ~(F_OK|R_OK|W_OK|X_OK)) { set_errno (EINVAL); return -1; @@ -1084,7 +1084,7 @@ access (const char *fn, int flags) return acl_access (fn, flags); struct stat st; - int r = stat (fn, &st); + int r = stat_worker (fn, &st, 0); if (r) return -1; r = -1;