O piscar ocorre porque o script limpa a tela inteira. Se pintar o texto existente e apagar apenas quando necessário, não haverá trepidação.
Aqui está um exemplo:
#!/bin/sh
watchit() {
HOME=$(tput cup 0 0)
ED=$(tput ed)
EL=$(tput el)
ROWS=$(tput lines)
COLS=$(tput cols)
printf '%s%s' "$HOME" "$ED"
while true
do
CMD="$@"
${SHELL:=sh} -c "$CMD" | head -n $ROWS | while IFS= read LINE; do
printf '%-*.*s%s\n' $COLS $COLS "$LINE" "$EL"
done
printf '%s%s' "$ED" "$HOME"
sleep 1
done
}
watchit top -b -n 1
Ele faz isso:
- imprime a saída do comando especificado que caberá na tela (sem quebra automática ou rolagem)
- escreve sobre linhas existentes, limpando a parte de cada linha que não é sobrescrita
- usa o recurso
ed
do seu terminal para imprimir do local atual até o final da tela.
Se você quisesse manipular uma tela redimensionável, poderia mover as atribuições para ROWS
e COLS
dentro do loop externo, por exemplo,
#!/bin/sh
watchit() {
HOME=$(tput cup 0 0)
ED=$(tput ed)
EL=$(tput el)
printf '%s%s' "$HOME" "$ED"
while true
do
ROWS=$(tput lines)
COLS=$(tput cols)
CMD="$@"
${SHELL:=sh} -c "$CMD" | head -n $ROWS | while IFS= read LINE; do
printf '%-*.*s%s\n' $COLS $COLS "$LINE" "$EL"
done
printf '%s%s' "$ED" "$HOME"
sleep 1
done
}
watchit top -b -n 1
porque tput
pede o tamanho de tela atual do sistema.
Leitura adicional: