Fish Shell:
Exibindo saídas de depuração

Como Fazer:

Vou te mostrar como imprimir mensagens para depurar teu código em Fish. Simples e rápido.

# Imprime uma mensagem na saída padrão
echo "Debug: Valor da variável é" $minha_variavel

# Executa um comando e imprime seu resultado
set output (comando_aqui)
echo "Debug: O resultado foi" $output

# Para mostrar a mensagem de erro, redireciona a saída padrão para a saída de erro
echo "Debug: Ops, algo deu errado" >&2

Saída possível após a execução:

Debug: Valor da variável é 42
Debug: O resultado foi sucesso
Debug: Ops, algo deu errado

Mergulho Profundo:

Lá nos tempos antigos do Unix, a depuração já era uma necessidade. Usávamos ferramentas como printf para C ou o comando echo nos primeiros shells. No Fish, continuamos usando echo, mas com algumas vantagens. O Fish possui sintaxe simplificada e colorização automática que facilita na hora de separar as saídas de depuração do resto. Além disso, redirecionamentos como >&2 são intuitivos: você está dizendo pro shell “ei, manda isso aqui pra saída de erro, por favor”.

Como alternativa ao método clássico, podemos também usar funções específicas do Fish, como printf, que dá mais controle sobre o formato da saída. E, para os fãs do silêncio, um truque é usar set -l ou set -g para criar variáveis temporárias, passando informações sem poluir a saída.

A implementação desse recurso é direta: o comando de eco é parte do próprio shell e trabalha junto com o sistema de redirecionamento de fluxo do Unix, que permite a especificação de pra onde vão as mensagens — seja pra tela do usuário, seja pra um arquivo ou pra outro programa.

Veja Também: