diff options
author | Christopher Faylor <me@cgf.cx> | 2012-04-13 02:30:51 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2012-04-13 02:30:51 +0000 |
commit | 3bfa9d984ba833fc4e439c2c3b706213880a8b37 (patch) | |
tree | ee1c8696de6e151b6eb54c6611afeb354dccc81f /winsup | |
parent | 416b2d8719a91411f65e5d85cef9a74ea4045e79 (diff) | |
download | newlib-3bfa9d984ba833fc4e439c2c3b706213880a8b37.zip newlib-3bfa9d984ba833fc4e439c2c3b706213880a8b37.tar.gz newlib-3bfa9d984ba833fc4e439c2c3b706213880a8b37.tar.bz2 |
* devices.in (exists_console): Allow /dev/con{sole,in,out} to be referenced
they exist.
* devices.cc: Regenerate.
* fhandler_console.cc (fhandler_console::set_unit): Ditto.
Diffstat (limited to 'winsup')
-rw-r--r-- | winsup/cygwin/ChangeLog | 7 | ||||
-rw-r--r-- | winsup/cygwin/devices.cc | 6 | ||||
-rw-r--r-- | winsup/cygwin/devices.in | 6 | ||||
-rw-r--r-- | winsup/cygwin/fhandler_console.cc | 7 |
4 files changed, 15 insertions, 11 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 5e444b5..be7da92 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,10 @@ +2012-04-12 Christopher Faylor <me.cygwin2012@cgf.cx> + + * devices.in (exists_console): Allow /dev/con{sole,in,out} to be + referenced they exist. + * devices.cc: Regenerate. + * fhandler_console.cc (fhandler_console::set_unit): Ditto. + 2012-04-11 Corinna Vinschen <corinna@vinschen.de> * syscalls.cc (fhandler_base::stat_fixup): Fix inode numbers of diff --git a/winsup/cygwin/devices.cc b/winsup/cygwin/devices.cc index 1c4a851..d67bcf4 100644 --- a/winsup/cygwin/devices.cc +++ b/winsup/cygwin/devices.cc @@ -67,18 +67,16 @@ exists_ntdev_silent (const device& dev) static int exists_console (const device& dev) { - if (!iscons_dev (myself->ctty)) - return false; int devn = *const_cast<device *> (&dev); switch (devn) { case FH_CONSOLE: case FH_CONIN: case FH_CONOUT: - return true; + return !!GetConsoleCP (); default: /* Only show my own console device (for now?) */ - return myself->ctty == devn; + return iscons_dev (myself->ctty) && myself->ctty == devn; } } diff --git a/winsup/cygwin/devices.in b/winsup/cygwin/devices.in index e5032f6..b656886 100644 --- a/winsup/cygwin/devices.in +++ b/winsup/cygwin/devices.in @@ -63,18 +63,16 @@ exists_ntdev_silent (const device& dev) static int exists_console (const device& dev) { - if (!iscons_dev (myself->ctty)) - return false; int devn = *const_cast<device *> (&dev); switch (devn) { case FH_CONSOLE: case FH_CONIN: case FH_CONOUT: - return true; + return !!GetConsoleCP (); default: /* Only show my own console device (for now?) */ - return myself->ctty == devn; + return iscons_dev (myself->ctty) && myself->ctty == devn; } } diff --git a/winsup/cygwin/fhandler_console.cc b/winsup/cygwin/fhandler_console.cc index 7478eae..d2e993f 100644 --- a/winsup/cygwin/fhandler_console.cc +++ b/winsup/cygwin/fhandler_console.cc @@ -136,18 +136,19 @@ fhandler_console::set_unit () fh_devices devset; lock_ttys here; HWND me; + fh_devices this_unit = dev (); + bool generic_console = this_unit == FH_CONIN || this_unit == FH_CONOUT; if (shared_console_info) { - fh_devices this_unit = dev (); fh_devices shared_unit = (fh_devices) shared_console_info->tty_min_state.getntty (); devset = (shared_unit == this_unit || this_unit == FH_CONSOLE - || this_unit == FH_CONIN || this_unit == FH_CONOUT + || generic_console || this_unit == FH_TTY) ? shared_unit : FH_ERROR; created = false; } - else if ((myself->ctty != -1 && !iscons_dev (myself->ctty)) + else if ((!generic_console && (myself->ctty != -1 && !iscons_dev (myself->ctty))) || !(me = GetConsoleWindow ())) devset = FH_ERROR; else |