On 2/12/13 2:07 PM, Matei David wrote:

OK. Let me try this again.  One key to the explanations is that child
processes inherit all of the parent's open file descriptors.

> ... there seem to be not 2 but 3(!) types of file descriptors:
> 1. fds which are copied across both subshells and exec; like 4

File descriptors that are explicitly created by user redirections are
inherited and not set close-on-exec.

> 2. fds which are not copied across subshells; like 60&63

You created a coproc; bash opened pipes to the coproc and is careful to
close those when child processes are created. Having, say, the read end
of a pipe open in multiple processes really messes with SIGPIPE generation.
Multiple fds open for write means that read will never see EOF, even if the
process you intend to write to it exits.

This is true for pipes in general, so bash is very careful to keep track of
file descriptors open on pipes and close them in child processes.

> 3. fds which are copied across subshells, but not exec; like 10

File descriptors which are used internally to save state of file
descriptors used in redirections are set close-on-exec.

> I knew about types 1&2, but not about type 3. Apparently with your first
> suggestion, fd 10 is created and survives a subshell creation. Is this
> correct??

Yes.  A subshell gets copies of its parent's file descriptors.

Chet

-- 
``The lyf so short, the craft so long to lerne.'' - Chaucer
                 ``Ars longa, vita brevis'' - Hippocrates
Chet Ramey, ITS, CWRU    c...@case.edu    http://cnswww.cns.cwru.edu/~chet/

Reply via email to