-
Notifications
You must be signed in to change notification settings - Fork 196
/
Copy pathlogactivewin.sh
executable file
·75 lines (60 loc) · 2.44 KB
/
logactivewin.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#!/bin/bash
LANG=en_US.utf8
# logs the active window titles over time. Logs are written
# in logs/windowX.txt, where X is unix timestamp of 7am of the
# recording day. The logs are written if a window change event occurs
# (with 2 second frequency check time), or every 10 minutes if
# no changes occur.
waittime="2" # number of seconds between executions of loop
maxtime="600" # if last write happened more than this many seconds ago, write even if no window title changed
#------------------------------
mkdir -p logs
last_write="0"
lasttitle=""
while true
do
islocked=true
# Try to figure out which Desktop Manager is running and set the
# screensaver commands accordingly.
if [[ $GDMSESSION == 'xfce' ]]; then
# Assume XFCE folks use xscreensaver (the default).
screensaverstate=$(xscreensaver-command -time | cut -f2 -d: | cut -f2-3 -d' ')
if [[ $screensaverstate =~ "screen non-blanked" ]]; then islocked=false; fi
elif [[ $GDMSESSION == 'ubuntu' || $GDMSESSION == 'ubuntu-2d' || $GDMSESSION == 'gnome-shell' || $GDMSESSION == 'gnome-classic' || $GDMSESSION == 'gnome-fallback' || $GDMSESSION == 'cinnamon' ]]; then
# Assume the GNOME/Ubuntu/cinnamon folks are using gnome-screensaver.
screensaverstate=$(gnome-screensaver-command -q 2>&1 /dev/null)
if [[ $screensaverstate =~ .*inactive.* ]]; then islocked=false; fi
elif [[ $XDG_SESSION_DESKTOP == 'KDE' ]]; then
islocked=$(qdbus org.kde.screensaver /ScreenSaver org.freedesktop.ScreenSaver.GetActive)
else
# If we can't find the screensaver, assume it's missing.
islocked=false
fi
if [ $islocked = true ]; then
curtitle="__LOCKEDSCREEN"
else
id=$(xdotool getactivewindow)
curtitle=$(wmctrl -lpG | while read -a a; do w=${a[0]}; if (($((16#${w:2}))==id)) ; then echo "${a[@]:8}"; break; fi; done)
fi
perform_write=false
# if window title changed, perform write
if [[ "$lasttitle" != "$curtitle" ]]; then
perform_write=true
fi
T="$(date +%s)"
# if more than some time has elapsed, do a write anyway
#elapsed_seconds=$(expr $T - $last_write)
#if [ $elapsed_seconds -ge $maxtime ]; then
# perform_write=true
#fi
# log window switch if appropriate
if [ "$perform_write" = true ]; then
# number of seconds elapsed since Jan 1, 1970 0:00 UTC
logfile="logs/window_$(python rewind7am.py).txt"
echo "$T $curtitle" >> $logfile
echo "logged window title: $(date) $curtitle into $logfile"
last_write=$T
fi
lasttitle="$curtitle" # swap
sleep "$waittime" # sleep
done