Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCorinna Vinschen <corinna@vinschen.de>2005-02-01 19:43:29 +0300
committerCorinna Vinschen <corinna@vinschen.de>2005-02-01 19:43:29 +0300
commit01a94cf8662ffe333b0b75fc98aa44ada4320aeb (patch)
tree59d3c34e948fdeda77e0495f7c30821b444681ec /winsup/cygwin/pipe.cc
parente8309efda5499f88eb950ff652acdd3a6b07d678 (diff)
* pipe.cc (fhandler_pipe::open): Allow re-opening of /proc/<pid>/fd
pipes of the current process.
Diffstat (limited to 'winsup/cygwin/pipe.cc')
-rw-r--r--winsup/cygwin/pipe.cc33
1 files changed, 33 insertions, 0 deletions
diff --git a/winsup/cygwin/pipe.cc b/winsup/cygwin/pipe.cc
index 988ee5731..6ce540695 100644
--- a/winsup/cygwin/pipe.cc
+++ b/winsup/cygwin/pipe.cc
@@ -38,6 +38,39 @@ fhandler_pipe::fhandler_pipe ()
int
fhandler_pipe::open (int flags, mode_t mode)
{
+ const char *path = get_name ();
+ debug_printf ("path: %s", path);
+ if (!strncmp (get_name (), "/proc/", 6))
+ {
+ char *c;
+ HANDLE hdl;
+ int pid = strtol (path += 6, &c, 10);
+ if (!pid || !c || *c != '/')
+ goto out;
+ path = c;
+ if (strncmp (path, "/fd/pipe:[", 10))
+ goto out;
+ path += 10;
+ hdl = (HANDLE) atoi (path);
+ if (pid == myself->pid)
+ {
+ cygheap_fdenum cfd;
+ while (cfd.next () >= 0)
+ {
+ if (cfd->get_handle () == hdl)
+ {
+ if (!cfd->dup (this))
+ return 1;
+ return 0;
+ }
+ }
+ }
+ else
+ {
+ /* TODO: Open pipes of different process. Is that possible? */
+ }
+ }
+out:
set_errno (ENXIO);
return 0;
}