Piping To/From Commands¶
It is often useful to be able to either write data to an external command or read data from an external command. For this there are four pipe meta-commands. All create asynchronous commands.
Two, pipe-into
and pipe-from
, will return a pipe handle.
This is another variation on an fd handle. As you might expect, you
cannot seek on a pipe handle because you can’t seek on the underlying
pipe file descriptor.
The other two, named-pipe-from
and named-pipe-into
, will
return the name of a file that can be opened for reading or writing
respectively. This is the equivalent of Bash’s Process
Substitution, <(...)
and >(...)
. Most operating systems will
use the /dev/fd/n
-style of filename but some will use real
FIFOs.
pipe variant¶
oph := pipe-into nslookup
printf "oph is %s\n" oph
hprintf oph "google.com\n"
close-handle oph
;; async command last in script
(wait)
$ idio pipe-into
oph is #<H opw! 5:"/dev/fd/5":1:0>
Server: 127.0.0.53
Address: 127.0.0.53#53
Non-authoritative answer:
Name: google.com
Address: 216.58.212.238
Name: google.com
Address: 2a00:1450:4009:80b::200e
Note
These examples have the asynchronous command at the end of the
script meaning Idio is likely to kill it as it exits
before the asynchronous command prints anything. We need a call to
wait
to ensure it gets a chance to run to completion.
named-pipe variant¶
opn := named-pipe-into nslookup
printf "opn is %s\n" opn
oph := open-output-file opn
hprintf oph "google.com\n"
close-handle oph
(wait)
$ idio named-pipe-into
opn is /dev/fd/5
Server: 127.0.0.53
Address: 127.0.0.53#53
Non-authoritative answer:
Name: google.com
Address: 216.58.212.238
Name: google.com
Address: 2a00:1450:4009:80b::200e
Last built at 2025-01-22T07:11:11Z+0000 from 77077af (dev) for Idio 0.3