On Tue, Jul 07, 2020 at 07:41:51AM -0400, Greg Wooledge wrote: > On Mon, Jul 06, 2020 at 09:45:59PM -0400, Dale R. Worley wrote: > > bug-b...@trodman.com writes: > > > foo | tee >(cat >&2) | bar > > > > I do wonder how portable >( ... ) is in practice, versus the portability > > of /dev/stderr. Maybe I worry about the former because I'm not > > practiced in named-FIFO programming and so think of it as non-universal. > > On Linux and BSD systems, >( ) will use a /dev/fd/ entry. On most > commercial Unix systems, where /dev/fd/ does not exist, it will use a > named pipe in /var/tmp. On a hypothetical system where neither one is > available (Microsoft Windows?), I believe it may use a temp file. That > decision is made at bash's compile time. > > The semantics of /dev/fd/* and named pipes are not quite identical, so > if you're relying on some very *special* mechanisms, then there could > indeed be portability issues. For most scripts, however, it shouldn't > matter.
Oh, the other thing I forgot to mention is that the semantics of /dev/fd/* differ between Linux and BSD. I don't have a reference available off the top of my head, but at some time in the past few years, it came up on one of the bug-bash or help-bash mailing lists -- someone's script acted differently on BSD than it did on Linux because of the different implementation of /dev/fd/ as used by a process substitution. People do *weird* shit with bash. The really surprising part is that they don't *think* it's weird.