diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2006-07-19 08:20:26 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2006-07-19 08:20:26 +0000 |
commit | ef4954b62d5297362d99c433076ed719fc9355bb (patch) | |
tree | 281aded0f97ab6dcccb1ae0b643a572156523141 /winsup | |
parent | 3438293a0b90b4f827ca7bb0817753b615adef38 (diff) | |
download | cygnal-ef4954b62d5297362d99c433076ed719fc9355bb.tar.gz cygnal-ef4954b62d5297362d99c433076ed719fc9355bb.tar.bz2 cygnal-ef4954b62d5297362d99c433076ed719fc9355bb.zip |
* path.cc (symlink_worker): Return EEXIST if newpath exists.
Diffstat (limited to 'winsup')
-rw-r--r-- | winsup/cygwin/ChangeLog | 4 | ||||
-rw-r--r-- | winsup/cygwin/path.cc | 3 |
2 files changed, 6 insertions, 1 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index cb1a29a9a..777e1af99 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,7 @@ +2006-07-19 Corinna Vinschen <corinna@vinschen.de> + + * path.cc (symlink_worker): Return EEXIST if newpath exists. + 2006-07-18 Christopher Faylor <cgf@timesys.com> * 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 116691670..f857f168e 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; |