Tente substituir sua linha grep
por um script awk
que libera sua saída.
xev | \
awk '/state 0x.*, keycode / { print $4; fflush() }' | \
while read keycode ; do
# etc.
done
Preciso checar alguns notebooks com teclas ruins, então gostaria de agilizar o máximo possível.
Não encontrei nada para essa tarefa específica, então minha ideia é um script que lê as teclas pressionadas e conhece todas as teclas do teclado, para que eu possa bater rápido nelas e relatar quais não estão pressionadas ainda. Eu suponho que eu poderia realizar isso com showkey
ou xev
, usando a saída:
xev | grep keysym
Exemplo de saída:
state 0x10, keycode 46 (keysym 0x6c, l), same_screen YES,
state 0x10, keycode 33 (keysym 0x70, p), same_screen YES,
state 0x11, keycode 50 (keysym 0xffe1, Shift_L), same_screen YES,
state 0x10, keycode 51 (keysym 0x5d, bracketright), same_screen YES,
state 0x10, keycode 36 (keysym 0xff0d, Return), same_screen YES,
O keysym legível é bastante útil, mas eu preciso testar os códigos de teclas, já que eles não mudam quando as teclas modificadoras são ativadas / desativadas (caps lock, num lock). Eu sou novo para bater, então eu estou colocando algo juntos. Este é o melhor resultado até agora:
#!/bin/bash
function findInArray() {
local n=$#
local value=${!n}
for ((i=1;i < $#;i++)) {
if [[ ${!i} == ${value}* ]]; then
echo "${!i}"
return 0
fi
}
echo
return 1
}
list=( 38:a 56:b 54:c 40:d 26:e 36:Return 50:Shift_L )
xev | \
# old grep solution
# grep -Po '(?<=keycode )[0-9]+(?= \(keysym 0x)' | \
# 200_success' suggestion
awk '/state 0x.*, keycode / { print $4; fflush() }' | \
while read keycode ;
do
found=$(findInArray "${list[@]}" ${keycode})
if [[ $found ]]; then
echo Pressed $found
list=(${list[@]/${keycode}\:*/})
echo 'Remaining ===>' ${list[@]}
if [[ ${#list[@]} == 0 ]]; then
echo All keys successfully tested!
pkill xev
exit 0
fi
fi
done
Enquanto eu usava grep
, estava apenas imprimindo a saída quando eu fechava xev
e não a mataria no final também. A sugestão awk
de @ 200_success resolveu esses problemas, mas não imprime a saída imediatamente: são necessários 5-6 pressionamentos de tecla para que a saída seja "liberada". Como posso consertar isso?
Nota: Eu sei que este script exigiria uma lista diferente de chaves para cada modelo diferente de teclado, mas tudo bem, já que tenho apenas alguns modelos para testar.
Editar 1: editei a questão com meu último código de script.
Editar 2: script atualizado de acordo com a sugestão @ 200_success.
Tente substituir sua linha grep
por um script awk
que libera sua saída.
xev | \
awk '/state 0x.*, keycode / { print $4; fflush() }' | \
while read keycode ; do
# etc.
done
Depois de mais algumas tentativas e erros, Google e man
, esta versão funciona como eu esperava:
#!/bin/bash
function findInArray() {
local n=$#
local value=${!n}
for ((i=1;i < $#;i++)) {
if [[ ${!i} == ${value}:* ]]; then
echo "${!i}"
return 0
fi
}
echo
return 1
}
list=( 10:1 11:2 12:3 36:Return 37:Control_L 38:a 39:s 134:Super_R 135:Menu )
clear
echo -e "${#list[@]} keys to test\n\n${list[@]}"
xev | \
awk -W interactive '/state 0x.*, keycode / { print $4; fflush() }' | \
while read keycode ;
do
found=$(findInArray "${list[@]}" ${keycode})
if [[ $found ]]; then
clear
echo Pressed $found
list=(${list[@]/$found/})
remaining=${#list[@]}
stdbuf -oL -eL echo -e "$remaining keys remaining\n\n${list[@]}"
if [[ $remaining == 0 ]]; then
clear
echo All keys successfully tested!
pkill xev
exit 0
fi
fi
done
Crie sua lista com base no xev
output (usei xev | grep keycode
, substituições do teclado e do regex em um editor de texto) e substitua-a.