From 535a6f760a71a327bb8b4441fc8850b55ea3893a Mon Sep 17 00:00:00 2001 From: corinna Date: Wed, 19 Jul 2006 08:20:26 +0000 Subject: [PATCH] * path.cc (symlink_worker): Return EEXIST if newpath exists. --- winsup/cygwin/ChangeLog | 4 ++++ winsup/cygwin/path.cc | 3 ++- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index cb1a29a9a5..777e1af994 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,7 @@ +2006-07-19 Corinna Vinschen + + * path.cc (symlink_worker): Return EEXIST if newpath exists. + 2006-07-18 Christopher Faylor * tty.cc (tty_list::terminate): Don't enter the busy loop if we don't diff --git a/winsup/cygwin/path.cc b/winsup/cygwin/path.cc index 116691670a..f857f168e5 100644 --- a/winsup/cygwin/path.cc +++ b/winsup/cygwin/path.cc @@ -2757,7 +2757,8 @@ symlink_worker (const char *oldpath, const char *newpath, bool use_winsym, syscall_printf ("symlink (%s, %s)", oldpath, win32_path.get_win32 ()); - if (win32_path.is_auto_device ()) + if ((!isdevice && win32_path.exists ()) + || win32_path.is_auto_device ()) { set_errno (EEXIST); goto done; -- 2.11.0