4
0
mirror of git://sourceware.org/git/newlib-cygwin.git synced 2025-01-18 12:29:32 +08:00

* syscalls.cc (rename): Handle a special case of trying to rename a

mount point.
This commit is contained in:
Corinna Vinschen 2008-03-12 18:46:10 +00:00
parent a66789a0c0
commit 48726c8a06
2 changed files with 18 additions and 5 deletions

View File

@ -1,3 +1,8 @@
2008-03-12 Corinna Vinschen <corinna@vinschen.de>
* syscalls.cc (rename): Handle a special case of trying to rename a
mount point.
2008-03-12 Corinna Vinschen <corinna@vinschen.de>
* environ.h: Fix comment.

View File

@ -1573,13 +1573,21 @@ rename (const char *oldpath, const char *newpath)
/* First check if oldpath and newpath only differ by case. If so, it's
just a request to change the case of the filename. By simply setting
the file attributes to INVALID_FILE_ATTRIBUTES (which translates to
"file doesn't exist"), all later tests are skipped. */
if (newpc.exists ()
&& equal_path
&& !RtlEqualUnicodeString (oldpc.get_nt_native_path (),
"file doesn't exist"), all later tests are skipped.
If not, it's a request to change the case of the name of a mount
point. If we don't catch this here, the underlying directory would
be deleted, if it happens to be empty. */
if (newpc.exists () && equal_path)
{
if (RtlEqualUnicodeString (oldpc.get_nt_native_path (),
newpc.get_nt_native_path (),
FALSE))
newpc.file_attributes (INVALID_FILE_ATTRIBUTES);
{
set_errno (EACCES);
goto out;
}
newpc.file_attributes (INVALID_FILE_ATTRIBUTES);
}
else if (oldpc.isdir ())
{
if (newpc.exists () && !newpc.isdir ())