Implementando um simples manipulador de eventos de teclado
Publicado por Sandro Marcell (última atualização em 18/07/2011)
[ Hits: 7.252 ]
Homepage: http://sanmarcell.wordpress.com
Muitas vezes um usuário quer que determinada ação ocorra em seu script ao se pressionar uma única tecla, mas no shell não há nenhum tipo de manipulador que faça esse serviço. O mais próximo seria utilizando o built-in trap para capturar sinais de interrupção tais como: Ctrl+C, Ctrl+D, etc... Porém para o propósito acima ele não se adequá muito bem. Para resolver isso você pode utilizar (adaptando é claro!) este simples shell script.
#!/bin/sh # # Implementacao simples dum "Manipulador de eventos de teclado" em shell script. # Autor: Sandro Marcell (smarcell) # <smarcell@myopera.com> | <http://www.myopera.com/smarcell/blog> # Boa Vista, Roraima - 10/05/2011. # PATH="/bin:/usr/bin:/usr/local/bin" # Define a tecla que controlara a parada do evento tecla_controle="s" # Boas praticas de programacao =) # - Sempre defina as variaveis antes de utiliza-las tecla_pressionada="" # Poe o terminal em modo especial de interpretacao de caracteres stty -echo -icanon min 0 # O evento ocorrera dentro deste loop while true do [ "$tecla_pressionada" = "$tecla_controle" ] && break # Seus codigos aqui! echo "Pressione a tecla '$tecla_controle' para sair do loop." ; sleep 1s read tecla_pressionada done # Restaura o modo padrao do terminal stty sane echo ">> Voce pressionou a tecla '$tecla_controle' e finalizou o loop!" exit 0
Pegar ip dinamico enviar para ftp
Desklets DoItYourself como monitor do sistema
EvalDate v1.0 - Script para Executar Programas em Datas Específicas.
dcalc: Calculadora Com Conversão de Bases
IA Turbina o Desktop Linux enquanto distros renovam forças
Como extrair chaves TOTP 2FA a partir de QRCODE (Google Authenticator)
Linux em 2025: Segurança prática para o usuário
Desktop Linux em alta: novos apps, distros e privacidade marcam o sábado
Atualizando o Fedora 42 para 43
Como saber se o seu e-mail já teve a senha vazada?
Como descobrir se a sua senha já foi vazada na internet?
E aí? O Warsaw já está funcionando no Debian 13? [RESOLVIDO] (15)
Secure boot, artigo interessante, nada técnico. (4)
copiar library para diretorio /usr/share/..... su com Falha na a... (1)









