Реагировать только на последнее событие dbus-monitor внутри группы - PullRequest
0 голосов
/ 30 сентября 2018

Я пишу сценарий для реагирования на dbus-monitor, но есть группа из 17 событий, зарегистрированных в 8/100 секунды.Я не хочу реагировать на все 17 событий.Только последнее событие, предполагающее, что другое событие не произойдет в течение одной или двух секунд.

Я не уверен, как закодировать это в bash?

Пример журнала событий (сжатый с помощью grep):

$ cat "dbus-monitor-plugin.txt" | grep time= | grep xrandr
method call time=1538331767.151461 sender=:1.59 -> destination=:1.11 serial=1242 path=/org/freedesktop/ColorManager/devices/xrandr_Toshiba_America_Info_Systems_Inc_TSB_TV_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.151706 sender=:1.59 -> destination=:1.11 serial=1248 path=/org/freedesktop/ColorManager/devices/xrandr_Toshiba_America_Info_Systems_Inc_TSB_TV_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.152338 sender=:1.59 -> destination=:1.11 serial=1252 path=/org/freedesktop/ColorManager/devices/xrandr_Sony_SONY_TV___00_16843009_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.152597 sender=:1.59 -> destination=:1.11 serial=1255 path=/org/freedesktop/ColorManager/devices/xrandr_eDP_1_1_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.152606 sender=:1.59 -> destination=:1.11 serial=1256 path=/org/freedesktop/ColorManager/devices/xrandr_Toshiba_America_Info_Systems_Inc_TSB_TV_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.156892 sender=:1.59 -> destination=:1.11 serial=1263 path=/org/freedesktop/ColorManager/devices/xrandr_Sony_SONY_TV___00_16843009_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.157062 sender=:1.59 -> destination=:1.11 serial=1264 path=/org/freedesktop/ColorManager/devices/xrandr_eDP_1_1_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.157095 sender=:1.59 -> destination=:1.11 serial=1267 path=/org/freedesktop/ColorManager/devices/xrandr_Toshiba_America_Info_Systems_Inc_TSB_TV_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.157699 sender=:1.59 -> destination=:1.11 serial=1271 path=/org/freedesktop/ColorManager/devices/xrandr_Sony_SONY_TV___00_16843009_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.157707 sender=:1.59 -> destination=:1.11 serial=1272 path=/org/freedesktop/ColorManager/devices/xrandr_eDP_1_1_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.158672 sender=:1.59 -> destination=:1.11 serial=1280 path=/org/freedesktop/ColorManager/devices/xrandr_Toshiba_America_Info_Systems_Inc_TSB_TV_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.158788 sender=:1.59 -> destination=:1.11 serial=1284 path=/org/freedesktop/ColorManager/devices/xrandr_Sony_SONY_TV___00_16843009_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.158954 sender=:1.59 -> destination=:1.11 serial=1286 path=/org/freedesktop/ColorManager/devices/xrandr_eDP_1_1_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.159344 sender=:1.59 -> destination=:1.11 serial=1289 path=/org/freedesktop/ColorManager/devices/xrandr_Toshiba_America_Info_Systems_Inc_TSB_TV_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.159867 sender=:1.59 -> destination=:1.11 serial=1295 path=/org/freedesktop/ColorManager/devices/xrandr_Sony_SONY_TV___00_16843009_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.159946 sender=:1.59 -> destination=:1.11 serial=1296 path=/org/freedesktop/ColorManager/devices/xrandr_eDP_1_1_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
method call time=1538331767.159979 sender=:1.59 -> destination=:1.11 serial=1299 path=/org/freedesktop/ColorManager/devices/xrandr_Toshiba_America_Info_Systems_Inc_TSB_TV_rick_1000; interface=org.freedesktop.DBus.Properties; member=GetAll
...