shopt -s extdebug
callstack(){
deep=${#BASH_ARGV[*]}
echo "deep $deep"
i=0
for ff in ${BASH_ARGV[@]}
do
echo "$i $ff"
i=$(($i+1))
done
}
f3()
{
echo $FUNCNAME: calling callstack
callstack
echo FUNCNAME stack: ${FUNCNAME[@]}
caller 0
echo $FUNCNAME: returning
}
f2()
{
echo $FUNCNAME: calling f3
f3 3 z
echo $FUNCNAME: return from f3
}
f1()
{
echo $FUNCNAME: calling f2
f2 2 y
echo $FUNCNAME: return from f2
}
echo main: calling f1
f1 1 x
echo main: f1 returns