From 2253ad67101e1423c1912b6e91bb024344d12891 Mon Sep 17 00:00:00 2001 From: cgf Date: Thu, 1 Aug 2002 23:53:07 +0000 Subject: [PATCH] * syscalls.cc (_link): Revert previous change and just always dereference the oldpath. --- winsup/cygwin/ChangeLog | 5 +++++ winsup/cygwin/syscalls.cc | 14 +++++--------- 2 files changed, 10 insertions(+), 9 deletions(-) diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index f5e8e1551c..a9daddbcea 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,5 +1,10 @@ 2002-08-01 Christopher Faylor + * syscalls.cc (_link): Revert previous change and just always + dereference the oldpath. + +2002-08-01 Christopher Faylor + * syscalls.cc (link): Properly deal with a link to a symlink. 2002-08-01 Christopher Faylor diff --git a/winsup/cygwin/syscalls.cc b/winsup/cygwin/syscalls.cc index 84d080cf9a..a9c9d53c50 100644 --- a/winsup/cygwin/syscalls.cc +++ b/winsup/cygwin/syscalls.cc @@ -305,11 +305,10 @@ _read (int fd, void *ptr, size_t len) DWORD wait = cfd->is_nonblocking () ? 0 : INFINITE; /* Could block, so let user know we at least got here. */ - syscall_printf ("read (%d, %p, %d) %sblocking, sigcatchers %d", - fd, ptr, len, wait ? "" : "non", sigcatchers); + syscall_printf ("read (%d, %p, %d) %sblocking, sigcatchers %d", fd, ptr, len, wait ? "" : "non", sigcatchers); if (wait && (!cfd->is_slow () || cfd->get_r_no_interrupt ())) - debug_printf ("no need to call ready_for_read\n"); + debug_printf ("non-interruptible read\n"); else if (!cfd->ready_for_read (fd, wait)) { res = -1; @@ -319,7 +318,7 @@ _read (int fd, void *ptr, size_t len) /* FIXME: This is not thread safe. We need some method to ensure that an fd, closed in another thread, aborts I/O operations. */ - if (!cfd.isopen ()) + if (!cfd.isopen()) return -1; /* Check to see if this is a background read from a "tty", @@ -332,7 +331,7 @@ _read (int fd, void *ptr, size_t len) if (res > bg_eof) { myself->process_state |= PID_TTYIN; - if (!cfd.isopen ()) + if (!cfd.isopen()) return -1; res = cfd->read (ptr, len); myself->process_state &= ~PID_TTYIN; @@ -615,9 +614,8 @@ _link (const char *a, const char *b) { int res = -1; sigframe thisframe (mainthread); + path_conv real_a (a, PC_SYM_FOLLOW | PC_FULL); path_conv real_b (b, PC_SYM_NOFOLLOW | PC_FULL); - path_conv real_a (a, PC_SYM_NOFOLLOW | PC_FULL); - extern BOOL allow_winsymlinks; if (real_a.error) { @@ -648,8 +646,6 @@ _link (const char *a, const char *b) /* Try to make hard link first on Windows NT */ if (wincap.has_hard_links ()) { - if (allow_winsymlinks && real_b.issymlink ()) - strcat (real_a, ".lnk"); if (CreateHardLinkA (real_b, real_a, NULL)) { res = 0; -- 2.11.0