Por que a expansão de variáveis sem $ funciona em expressões?

15
#!/bin/bash

VALUE=10

if [[ VALUE -eq 10 ]]
then
    echo "Yes"
fi

Para minha surpresa, isso gera "Sim". Eu teria esperado que isso exigisse [[ $VALUE -eq 10 ]] . Eu verifiquei a seção CONDITIONAL EXPRESSIONS de man bash , mas não encontrei nada para explicar esse comportamento.

    
por Heinzi 25.05.2012 / 18:13

1 resposta

11

[[ é bash reserved word, portanto, regras especiais de expansão, como expansão aritmética, são aplicadas, não como no caso de [ . Também é utilizado o operador binário aritmético -eq . Portanto, o shell procura por expressões inteiras e, se o texto for encontrado no primeiro item, ele tenta expandi-lo como parâmetro. É chamado de expansão aritmética e está presente em man bash .

RESERVED WORDS
       Reserved words are words that have a special meaning to the shell.  
       The following words are recognized as reserved 
       …
       [[ ]]

[[ expression ]]
       Return  a  status  of 0 or 1 depending on the evaluation of 
       the conditional expression expression.  Expressions are 
       composed of the primaries described below under CONDITIONAL 
       EXPRESSIONS.  Word splitting and pathname expansion are not 
       performed on the words between the  [[  and  ]];  tilde 
       expansion, parameter and variable expansion, >>>_arithmetic 
       expansion_<<<, command substitution, process substitution, and 
       quote removal are performed.  

Arithmetic Expansion
       …
       The evaluation is performed according to the rules listed below 
       under ARITHMETIC EVALUATION.

ARITHMETIC EVALUATION
       …
       Within an expression, shell variables may also be referenced 
       by name without using the parameter expansion syntax.

Então, por exemplo:

[[ hdjakshdka -eq fkshdfwuefy ]]

retornará sempre verdadeiro

Mas este retornará um erro

$ [[ 1235hsdkjfh -eq 81749hfjsdkhf ]]
-bash: [[: 1235hsdkjfh: value too great for base (error token is "1235hsdkjfh")

Também há recursão disponível:

$ VALUE=VALUE ; [[ VALUE -eq 12 ]]
-bash: [[: VALUE: expression recursion level exceeded (error token is "VALUE")
    
por 25.05.2012 / 19:58