* fhandler_disk_file.cc (fhandler_base::fstat_fs): Use created
handle regardless of nohandle state. Clean up afterwards.
This commit is contained in:
parent
6653af6cc2
commit
88506c6752
@ -1,3 +1,8 @@
|
|||||||
|
2004-03-23 Corinna Vinschen <corinna@vinschen.de>
|
||||||
|
|
||||||
|
* fhandler_disk_file.cc (fhandler_base::fstat_fs): Use created
|
||||||
|
handle regardless of nohandle state. Clean up afterwards.
|
||||||
|
|
||||||
2004-03-23 Gerd Spalink <Gerd.Spalink@t-online.de>
|
2004-03-23 Gerd Spalink <Gerd.Spalink@t-online.de>
|
||||||
|
|
||||||
* autoload.cc: Load eight more functions for waveIn support.
|
* autoload.cc: Load eight more functions for waveIn support.
|
||||||
|
@ -201,13 +201,21 @@ fhandler_base::fstat_fs (struct __stat64 *buf)
|
|||||||
oret = open_fs (open_flags, 0);
|
oret = open_fs (open_flags, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!oret || get_nohandle ())
|
if (oret)
|
||||||
res = fstat_by_name (buf);
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
|
/* We now have a valid handle, regardless of the "nohandle" state.
|
||||||
|
Since fhandler_base::open only calls CloseHandle if !get_nohandle,
|
||||||
|
we have to set it to false before calling close_fs and restore
|
||||||
|
the state afterwards. */
|
||||||
res = fstat_by_handle (buf);
|
res = fstat_by_handle (buf);
|
||||||
|
bool nohandle = get_nohandle ();
|
||||||
|
set_nohandle (false);
|
||||||
close_fs ();
|
close_fs ();
|
||||||
|
set_nohandle (nohandle);
|
||||||
|
set_io_handle (NULL);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
res = fstat_by_name (buf);
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user