In bash, calling foo
would display any output from that command on the stdout.
Calling foo > output
would redirect any output from that
You can do that for your entire script by using something like that at the beginning of your script :
#!/usr/bin/env bash
test x$1 = x$'\x00' && shift || { set -o pipefail ; ( exec 2>&1 ; $0 $'\x00' "$@" ) | tee mylogfile ; exit $? ; }
# do whaetever you want
This redirect both stderr and stdout outputs to the file called mylogfile
and let everything goes to stdout at the same time.
It is used some stupid tricks :
exec
without command to setup redirections,tee
to duplicates outputs,NUL
character specified by the $'string'
special bash notation) to specify that the script is restarted (no equivalent parameter may be used by your original work),pipefail
option.Ugly but useful for me in certain situations.