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:
parent
a66789a0c0
commit
48726c8a06
@ -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.
|
||||
|
@ -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 ())
|
||||
|
Loading…
x
Reference in New Issue
Block a user