Tengo la siguiente función recursiva para establecer variables de entorno:
function par_set {
PAR=$1
VAL=$2
if [ "" != "$1" ]
then
export ${PAR}=${VAL}
echo ${PAR}=${VAL}
shift
shift
par_set $*
fi
}
Si lo llamo solo, establece la variable y hace eco en stdout:
$ par_set FN WORKS
FN=WORKS
$ echo "FN = "$FN
FN = WORKS
Redirigir stdout a un archivo también funciona:
$ par_set REDIR WORKS > out
cat out
REDIR=WORKS
$ echo "REDIR = "$REDIR
REDIR = WORKS
Pero, si canalizo stdout a otro comando, la variable no se establece:
$ par_set PIPE FAILS |sed -e's/FAILS/BARFS/'
PIPE=BARFS
$ echo "PIPE = "$PIPE
PIPE =
¿Por qué la tubería impide que la función exporte la variable? ¿Hay alguna manera de solucionar esto sin recurrir a archivos temporales o canalizaciones con nombre?
Resuelto:
Código de trabajo gracias a Gilles:
par_set $(echo $*|tr '=' ' ') > >(sed -e's/^/ /' >> ${LOG})
Esto permite que el script se llame así:
$ . ./script.sh PROCESS_SUB ROCKS PIPELINES=NOGOOD
$ echo $PROCESS_SUB
ROCKS
$ echo $PIPELINES
NOGOOD
$ cat log
7:20140606155622162731431:script.sh:29581:Parse Command Line parameters. Params must be in matched pairs separated by one or more '=' or ' '.
PROCESS_SUB=ROCKS
PIPELINES=NOGOOD
Proyecto alojado en bitbucket https://bitbucket.org/adalby/monitor-bash si está interesado en el código completo.