Eu tenho o seguinte verificador de resposta em um script:
#!/bin/bash
test_fn()
{
WARNFILE=$1
echo
echo "--- BEGIN ---"
cat ${WARNFILE}
echo "--- END ---"
echo
while true; do
read -r -n 1 -p "Continue? [y/n]: " REPLY
case $REPLY in
[yY]) break ;;
[nNqQ]) echo;exit ;;
*) printf "\033[31m%s\033[0m\n" " invalid input: ${REPLY}"
esac
done
}
test_fn /tmp/warning
Funciona bem...
$ ./test.sh
--- BEGIN ---
test warning
--- END ---
Continue? [y/n]: a invalid input: a
Continue? [y/n]: s invalid input: s
Continue? [y/n]: d invalid input: d
Continue? [y/n]: w invalid input: w
Continue? [y/n]: s invalid input: s
Continue? [y/n]: q
$
...até eu mudar de linha:
test_fn /tmp/warning
com linha:
test_fn /tmp/warning | tee -a /tmp/logfile
então, embaralha as linhas:
$ ./test.sh
--- BEGIN ---
test warning
Continue? [y/n]: --- END ---
aContinue? [y/n]: invalid input: a
sContinue? [y/n]: invalid input: s
dContinue? [y/n]: invalid input: d
fContinue? [y/n]: invalid input: f
q
$
Alguém poderia por favor dizer por que funciona assim?
Para converter um comentário em uma resposta:
read -p
grava o prompt em stderr; para obter os resultados em linha paratee
, canalize o stderr da função para stdout antes dotee
with:Para demonstrar
read
o comportamento de: