X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=pod%2Fperlfork.pod;h=8f3b919e7a2a64ea45cbb6f6dec5af200e99fd3c;hb=53ae2428795d0b9d42a1657c22c5f1b557784379;hp=832710a80cd8d21ec4e42d1e93ef14481e8bf90e;hpb=0c2f6559512b2211f892f1a6ae8db4739c5369b4;p=p5sagit%2Fp5-mst-13.2.git diff --git a/pod/perlfork.pod b/pod/perlfork.pod index 832710a..8f3b919 100644 --- a/pod/perlfork.pod +++ b/pod/perlfork.pod @@ -100,7 +100,7 @@ waiting for after the exec(). exit() always exits just the executing pseudo-process, after automatically wait()-ing for any outstanding child pseudo-processes. Note that this means that the process as a whole will not exit unless all running pseudo-processes -have exited. +have exited. See below for some limitations with open filehandles. =item Open handles to files, directories and network sockets @@ -177,6 +177,13 @@ the seek position in the parent will change it in the child and vice-versa. One can avoid this by opening files that need distinct seek pointers separately in the child. +On some operating systems, notably Solaris and Unixware, calling C +from a child process will flush and close open filehandles in the parent, +thereby corrupting the filehandles. On these systems, calling C<_exit()> +is suggested instead. C<_exit()> is available in Perl through the +C module. Please consult your systems manpages for more information +on this. + =item Forking pipe open() not yet implemented The C and C constructs are not yet