Subshells¶
It is often convenient to make multiple temporary changes to the program state (current working directory, environment etc.) in a subshell such that the main program does not have to reset its own values.
In Idio, subshells use the {{...}}
notation.
As a far too involved example, let’s create a virtualenv and run a script from it:
printf "%d in %s: IDIOLIB is %s\n" PID PWD IDIOLIB
{{
tmp-dir := (libc/make-tmp-dir)
;; change directory in the subshell
cd tmp-dir
lib-dir := #S{lib/idio/${IDIO_MM_VERSION}}
mkdir -p bin lib-dir
;; IDIO_EXE is the absolute path of the running executable
ln -s IDIO_EXE bin
;; but IDIO_EXE is versioned, idio.M.N, and we want to use the
;; command idio
ln -s #S{idio.${IDIO_MM_VERSION}} bin/idio
;; let's see what we did, there
ls -l #S{${tmp-dir}/bin}
with-output-to-file #S{${lib-dir}/tell-me.idio} (function #n {
;; Using an interpolated string serves no purpose, here, as there
;; is nothing to expand, however, it is habit-forming when
;; generating code
puts #S{
;; this is the script for the virtualenv idio running in the subshell
printf "%d in %s: IDIOLIB is %s\n" PID PWD IDIOLIB
}
})
;; report on the subshell
printf "%d in %s: IDIOLIB is %s\n" PID PWD IDIOLIB
;; change PATH in the subshell
PATH = #S{${tmp-dir}/bin:${PATH}}
idio tell-me
cd HOME
rm -rf tmp-dir
}}
printf "%d in %s: IDIOLIB is %s\n" PID PWD IDIOLIB
$ idio simple-subshell
226136 in /home/idf: IDIOLIB is /home/idf/.local/lib/idio/0.3
total 0
lrwxrwxrwx. 1 idf idf 8 Nov 15 11:47 idio -> idio.0.3
lrwxrwxrwx. 1 idf idf 29 Nov 15 11:47 idio.0.3 -> /home/idf/.local/bin/idio.0.3
226138 in /tmp/idio-tmp-EIUqVO: IDIOLIB is /home/idf/.local/lib/idio/0.3
226143 in /tmp/idio-tmp-EIUqVO: IDIOLIB is /tmp/idio-tmp-EIUqVO/lib/idio/0.3:/home/idf/.local/lib/idio/0.3
226136 in /home/idf: IDIOLIB is /home/idf/.local/lib/idio/0.3
Here, you can see the Process ID associated with the subshell is different to the parent and is different to the idio running from the subshell.
Last built at 2024-12-30T07:11:22Z+0000 from 77077af (dev) for Idio 0.3