2012-02-05 20 views
38

En BASH, ¿es posible obtener el nombre de la función en el cuerpo de la función? Tomando los siguientes códigos como ejemplo, quiero imprimir el nombre de la función "Test" en su cuerpo, pero "$ 0" parece referirse al nombre del script en lugar del nombre de la función. Entonces, ¿cómo obtener el nombre de la función?En BASH, ¿es posible obtener el nombre de la función en el cuerpo de la función?

#!/bin/bash 

function Test 
{ 
    if [ $# -lt 1 ] 
    then 
     # how to get the function name here? 
     echo "$0 num" 1>&2 
     exit 1 
    fi 
    local num="${1}" 
    echo "${num}" 
} 

# the correct function 
Test 100 

# missing argument, the function should exit with error 
Test 

exit 0 

Respuesta

64

Trate ${FUNCNAME[0]}. Esta matriz contiene la pila de llamadas actual. Para citar la página del manual:

FUNCNAME 
      An array variable containing the names of all shell functions 
      currently in the execution call stack. The element with index 0 
      is the name of any currently-executing shell function. The bot‐ 
      tom-most element is "main". This variable exists only when a 
      shell function is executing. Assignments to FUNCNAME have no 
      effect and return an error status. If FUNCNAME is unset, it 
      loses its special properties, even if it is subsequently reset. 
+1

Gracias, esto realmente ayuda. Aprendo más que solo la solución de mi pregunta. Esta matriz podría usarse para imprimir la pila de llamadas cuando falla la secuencia de comandos. –

+5

Claro. En ese sentido, también puede encontrar el contenido de 'BASH_LINENO' de interés. – FatalError

+0

O puede usar el $ FUNCNAME más corto y equivalente. –

29

El nombre de la función es en ${FUNCNAME[ 0 ]} FUNCNAME es una matriz que contiene todos los nombres de las funciones en la pila de llamadas, por lo que:

 
$ ./sample 
foo 
bar 
$ cat sample 
#!/bin/bash 

foo() { 
     echo ${FUNCNAME[ 0 ]} # prints 'foo' 
     echo ${FUNCNAME[ 1 ]} # prints 'bar' 
} 
bar() { foo; } 
bar 
Cuestiones relacionadas