From 079db16bf7ae41fa9a09640296bb2f3031971d08 Mon Sep 17 00:00:00 2001 From: Corinna Vinschen Date: Thu, 9 Oct 2008 14:23:09 +0000 Subject: * 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. --- winsup/cygwin/fhandler_disk_file.cc | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'winsup/cygwin/fhandler_disk_file.cc') diff --git a/winsup/cygwin/fhandler_disk_file.cc b/winsup/cygwin/fhandler_disk_file.cc index aa945f588..e3c9aaf93 100644 --- a/winsup/cygwin/fhandler_disk_file.cc +++ b/winsup/cygwin/fhandler_disk_file.cc @@ -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; -- cgit v1.2.3