xinput test
может сообщать обо всех событиях клавиатуры на X-сервер. В системе GNU:
xinput list |
grep -Po 'id=\K\d+(?=.*slave\s*keyboard)' |
xargs -P0 -n1 xinput test
Если вы хотите получить имена ключей из кодов ключей, вы можете постобработать этот вывод с помощью:
awk 'BEGIN{while (("xmodmap -pke" | getline) > 0) k[$2]=$4}
{print $0 "[" k[$NF] "]"}'
Добавить > file.log
для хранения в лог-файл. Или | tee file.log
чтобы оба войти и увидеть это.
xinput
запрашивает XinputExtension X-сервера. Это так же близко, как вы собираетесь получить в качестве стандарта (я не знаю ни одного стандарта, который охватывает утилиты X) или обычной команды для этого. Это также не требует прав суперпользователя.
Если X-сервер и xinput поддерживают версию 2 XinputExtension, вы можете использовать test-xi2
вместо test
которой больше информации, в частности о состоянии модификаторов (shift, ctrl, alt ...). Пример:
$ xinput test-xi2 --root
EVENT type 2 (KeyPress)
device: 11 (11)
detail: 54
flags:
root: 846.80/451.83
event: 846.80/451.83
buttons:
modifiers: locked 0 latched 0 base 0x4 effective: 0x4
group: locked 0 latched 0 base 0 effective: 0
valuators:
windows: root 0x26c event 0x26c child 0x10006e6
Вы можете перевести detail
ключевой код (in ) в keyym с помощью xmodmap -pke
снова, и effective
модификатор битовой маски к чему-то более полезному с помощью xmodmap -pm
. Например:
xinput test-xi2 --root | perl -lne '
BEGIN{$"=",";
open X, "-|", "xmodmap -pke";
while (<X>) {$k{$1}=$2 if /^keycode\s+(\d+) = (\w+)/}
open X, "-|", "xmodmap -pm"; <X>;<X>;
while (<X>) {if (/^(\w+)\s+(\w*)/){($k=$2)=~s/_[LR]$//;$m[$i++]=$k||$1}}
close X;
}
if (/^EVENT type.*\((.*)\)/) {$e = $1}
elsif (/detail: (\d+)/) {$d=$1}
elsif (/modifiers:.*effective: (.*)/) {
$m=$1;
if ($e =~ /^Key/){
my @mods;
for (0..$#m) {push @mods, $m[$_] if (hex($m) & (1<<$_))}
print "$e $d [$k{$d}] $m [@mods]"
}
}'
будет выводить:
KeyPress 24 [q] 0x19 [Shift,Alt,Num_Lock]
когда я нажимаю Shift + Alt + q, когда включена цифровая блокировка.
Обратите внимание, что вам не нужно иметь привилегии суперпользователя для установки программы. Если у вас есть доступ на запись в какое-то место в файловой системе, где предоставлено разрешение на выполнение (ваш домашний каталог /tmp
, /var/tmp
...), вы можете скопировать xinput
команду из совместимой системы и выполнить ее.