* child_info.h (~child_info_spawn): Check moreinfo->myself_pinfo for
NULL before closing. * spawn.cc (spawn_guts): Don't close moreinfo->myself_pinfo explicitely in case of failing CloseProcess. * fhandler.cc (fhandler_base::open_): Return EISDIR when trying to create a directory. * path.cc (path_conv::check): If input path had a trailing dir separator, tack it on to the native path if directory doesn't exist.
This commit is contained in:
parent
e3bf57046b
commit
8a889eff57
@ -1,3 +1,15 @@
|
||||
2008-03-05 Corinna Vinschen <corinna@vinschen.de>
|
||||
|
||||
* child_info.h (~child_info_spawn): Check moreinfo->myself_pinfo for
|
||||
NULL before closing.
|
||||
* spawn.cc (spawn_guts): Don't close moreinfo->myself_pinfo explicitely
|
||||
in case of failing CloseProcess.
|
||||
|
||||
* fhandler.cc (fhandler_base::open_): Return EISDIR when trying to
|
||||
create a directory.
|
||||
* path.cc (path_conv::check): If input path had a trailing dir
|
||||
separator, tack it on to the native path if directory doesn't exist.
|
||||
|
||||
2008-03-02 Christopher Faylor <me+cygwin@cgf.cx>
|
||||
|
||||
* cygtls.cc (_cygtls::init_exception_handler): Semi-revert to making
|
||||
|
@ -125,7 +125,7 @@ public:
|
||||
cfree (*e);
|
||||
cfree (moreinfo->envp);
|
||||
}
|
||||
if (type != _PROC_SPAWN)
|
||||
if (type != _PROC_SPAWN && moreinfo->myself_pinfo)
|
||||
CloseHandle (moreinfo->myself_pinfo);
|
||||
cfree (moreinfo);
|
||||
}
|
||||
|
@ -590,7 +590,13 @@ fhandler_base::open (int flags, mode_t mode)
|
||||
create_disposition, create_options, NULL, 0);
|
||||
if (!NT_SUCCESS (status))
|
||||
{
|
||||
__seterrno_from_nt_status (status);
|
||||
/* Trying to open a directory should return EISDIR, not ENOENT. */
|
||||
PUNICODE_STRING upath = pc.get_nt_native_path ();
|
||||
if (status == STATUS_OBJECT_NAME_INVALID
|
||||
&& upath->Buffer[upath->Length / sizeof (WCHAR) - 1] == '\\')
|
||||
set_errno (EISDIR);
|
||||
else
|
||||
__seterrno_from_nt_status (status);
|
||||
if (!nohandle ())
|
||||
goto done;
|
||||
}
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* path.cc: path support.
|
||||
/* path.cc: path support.
|
||||
|
||||
Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
|
||||
2006, 2007 Red Hat, Inc.
|
||||
@ -1101,6 +1101,8 @@ out:
|
||||
}
|
||||
else if (!need_directory || error)
|
||||
/* nothing to do */;
|
||||
else if (fileattr == INVALID_FILE_ATTRIBUTES)
|
||||
strcat (path, "\\"); /* Reattach trailing dirsep in native path. */
|
||||
else if (fileattr & FILE_ATTRIBUTE_DIRECTORY)
|
||||
path_flags &= ~PATH_SYMLINK;
|
||||
else
|
||||
|
@ -599,8 +599,6 @@ loop:
|
||||
myself->exec_sendsig = NULL;
|
||||
}
|
||||
res = -1;
|
||||
if (moreinfo->myself_pinfo)
|
||||
CloseHandle (moreinfo->myself_pinfo);
|
||||
goto out;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user