У меня довольно странная проблема. Я не могу понять, почему это происходит и как это исправить.
Сценарий:
#!system/bin/sh
#set -x
reader() {
t2=-1
grep -v -E "add device|name:" | while IFS=' ' read -r t1 a b c d _; do
t1=${t1%%-*}
t=`expr $t1 - $t2`
if let 't > 0 && t2 > -1'; then
echo "sleep $t"
fi
printf 'sendevent %s' "${a%?}"
printf '%5d %5d %5d\n' "0x$b" "0x$c" "0x$d"
t2=$t1
done
}
let() {
IFS=, command eval [ '$(($*))' -ne 0 ]
}
countDown() {
echo 'Starting in...'
i=4
while [[ $i -gt 1 ]]; do
i=$(($i-1))
echo "$i"
sleep 1
done
printf '%s\n\n\n' 'Go!'
# echo "$*"
"$@" | reader
}
clear
printf '%s >' 'Catch by [n]umber of events or [t]imeout?'
read type
case $type in
n)
printf '%s >' 'Events to catch?'
read arg
echo "Gonna catch $arg events!"
countDown getevent -t -c "$arg"
;;
t)
printf '%s >' 'Timeout (in seconds)?'
read arg
echo "Gonna catch events for $arg seconds!"
countDown timeout -t $arg getevent -t
esac
Цель скрипта:
Перехватывайте действия пользователя (например, нажатия клавиш, касания экрана и т. д.) с помощью команды getevent и выводит сценарий на стандартный вывод, который можно использовать для репликации этих событий.
Дополнительная информация:
вывод getevent в шестнадцатеричном формате sendevent принимает десятичный формат
Ожидаемый результат:
Catch by [n]umber or by [t]imeout? n
Events to catch? > 4
Gonna catch 4 events...
Starting in...
3
2
1
Go!
sendevent /dev/input/event5 1 102 1
sendevent /dev/input/event5 0 0 0
sleep 3
sendevent /dev/input/event5 1 102 0
sendevent /dev/input/event5 0 0 0
Проблема:
Код работает, как и ожидалось, когда выбрано «n». При выборе «t» сценарий завершает работу через указанное количество секунд. Однако он ничего не выводит — первая строка цикла while даже не запускается.
С set -x вот что показано (последние несколько строк):
+ printf %s\n\n\n Go!
Go!
+ reader
+ t2=-1
+ grep -v -E add device|name:
+ timeout -t 5 getevent -t
+ IFS = read -r t1 a b c d _
Запуск только этого показывает вывод на стандартный вывод (вывод, который должен быть прочитан и изменен внутри цикла while):
timeout -t 5 getevent -t
Любые идеи?
Спасибо.
ИЗМЕНИТЬ:
Хорошо, я думаю, что это проблема с буферизацией. По сути, это приводит к аналогичной проблеме: getevent > output
Файл обновляется при каждом наборе событий, но не мгновенно (и может никогда не обновляться, если создается недостаточное количество событий). Я не знаю никаких обходных путей на Android.