tty on open unless the open is for stdin/stdout/stderr.
* tty.cc (tty_list::connect): Set ENXIO when can't find a tty.
+2011-10-10 Christopher Faylor <me.cygwin2011@cgf.cx>
+
+ * syscalls.cc (open): Add temporary kludge to avoid assigning the
+ controlling tty on open unless the open is for stdin/stdout/stderr.
+ * tty.cc (tty_list::connect): Set ENXIO when can't find a tty.
+
2011-10-10 Corinna Vinschen <corinna@vinschen.de>
* fhandler.h (fhandler_process::closedir): Declare.
if (fd >= 0)
{
+ /* This is a temporary kludge until all utilities can catch up with
+ a change in behavior that implements linux functionality: opening
+ a tty should not automatically cause it to become the controlling
+ tty for the process. */
+ if (fd > 2)
+ flags |= O_NOCTTY;
if (!(fh = build_fh_name (unix_path,
(flags & (O_NOFOLLOW | O_EXCL))
? PC_SYM_NOFOLLOW : PC_SYM_FOLLOW,
if (!ttys[ttynum].exists ())
{
termios_printf ("tty %d was not allocated", ttynum);
+ set_errno (ENXIO);
return -1;
}