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

* fhandler_disk_file.cc (fhandler_base::fstat_helper): Check

for executable suffixes here in case we're on a file system
	not supporting permission.
	* path.cc (path_conv::check): Drop check for executable suffixes.
This commit is contained in:
Corinna Vinschen 2008-10-09 14:23:09 +00:00
parent 3059d18288
commit 079db16bf7
3 changed files with 19 additions and 11 deletions

View File

@ -1,3 +1,10 @@
2008-10-09 Corinna Vinschen <corinna@vinschen.de>
* fhandler_disk_file.cc (fhandler_base::fstat_helper): Check
for executable suffixes here in case we're on a file system
not supporting permission.
* path.cc (path_conv::check): Drop check for executable suffixes.
2008-10-09 Corinna Vinschen <corinna@vinschen.de>
* fhandler_floppy.cc (fhandler_dev_floppy::raw_read): Keep track of

View File

@ -609,6 +609,18 @@ fhandler_base::fstat_helper (struct __stat64 *buf,
else
{
buf->st_mode |= S_IFREG;
/* Check suffix for executable file. */
if (pc.exec_state () == dont_know_if_executable)
{
PUNICODE_STRING path = pc.get_nt_native_path ();
if (RtlEqualUnicodePathSuffix (path, L".exe", TRUE)
|| RtlEqualUnicodePathSuffix (path, L".bat", TRUE)
|| RtlEqualUnicodePathSuffix (path, L".com", TRUE))
pc.set_exec ();
}
/* No known sufix, check file header. This catches binaries and
shebang scripts. */
if (pc.exec_state () == dont_know_if_executable)
{
UNICODE_STRING same;

View File

@ -1248,17 +1248,6 @@ out:
if (saw_symlinks)
set_has_symlinks ();
if (!error && !isdir () && !(path_flags & PATH_ALL_EXEC)
&& !fs.has_acls () && !fs.is_nfs ())
{
const char *p = strchr (path, '\0') - 4;
if (p >= path &&
(ascii_strcasematch (".exe", p) ||
ascii_strcasematch (".bat", p) ||
ascii_strcasematch (".com", p)))
path_flags |= PATH_EXEC;
}
if (!(opt & PC_POSIX))
normalized_path_size = 0;
else