/usr/share/undistract-me/long-running.bash is in undistract-me 0.1.0+git20130402+3a9144bc1f-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 | # Copyright (c) 2008-2012 undistract-me developers. See LICENSE for details.
#
# Source this, and then run notify_when_long_running_commands_finish_install
#
# Relies on http://www.twistedmatrix.com/users/glyph/preexec.bash.txt
# Generate a notification for any command that takes longer than this amount
# of seconds to return to the shell. e.g. if LONG_RUNNING_COMMAND_TIMEOUT=10,
# then 'sleep 11' will always generate a notification.
# Default timeout is 10 seconds.
if [ -z "$LONG_RUNNING_COMMAND_TIMEOUT" ]; then
LONG_RUNNING_COMMAND_TIMEOUT=10
fi
# The pre-exec hook functionality is in a separate branch.
if [ -z "$LONG_RUNNING_PREEXEC_LOCATION" ]; then
LONG_RUNNING_PREEXEC_LOCATION=/usr/share/undistract-me/preexec.bash
fi
if [ -f "$LONG_RUNNING_PREEXEC_LOCATION" ]; then
. $LONG_RUNNING_PREEXEC_LOCATION
else
echo "Could not find preexec.bash"
fi
function notify_when_long_running_commands_finish_install() {
function active_window_id () {
if [[ -n $DISPLAY ]] ; then
set - $(xprop -root _NET_ACTIVE_WINDOW)
echo $5
return
fi
echo nowindowid
}
function sec_to_human () {
local H=''
local M=''
local S=''
local h=$(($1 / 3600))
[ $h -gt 0 ] && H="${h} hour" && [ $h -gt 1 ] && H="${H}s"
local m=$((($1 / 60) % 60))
[ $m -gt 0 ] && M=" ${m} min" && [ $m -gt 1 ] && M="${M}s"
local s=$(($1 % 60))
[ $s -gt 0 ] && S=" ${s} sec" && [ $s -gt 1 ] && S="${S}s"
echo $H$M$S
}
function precmd () {
if [[ -n "$__udm_last_command_started" ]]; then
local now current_window
printf -v now "%(%s)T" -1
current_window=$(active_window_id)
if [[ $current_window != $__udm_last_window ]] ||
[[ $current_window == "nowindowid" ]] ; then
local time_taken=$(( $now - $__udm_last_command_started ))
local time_taken_human=$(sec_to_human $time_taken)
local appname=$(basename "${__udm_last_command%% *}")
if [[ $time_taken -gt $LONG_RUNNING_COMMAND_TIMEOUT ]] &&
[[ -n $DISPLAY ]] &&
[[ ! " $LONG_RUNNING_IGNORE_LIST " == *" $appname "* ]] ; then
local icon=dialog-information
local urgency=low
if [[ $__preexec_exit_status != 0 ]]; then
icon=dialog-error
urgency=normal
fi
notify=$(command -v notify-send)
if [ -x "$notify" ]; then
$notify \
-i $icon \
-u $urgency \
"Long command completed" \
"\"$__udm_last_command\" took $time_taken_human"
else
echo -ne "\a"
fi
fi
if [[ -n $LONG_RUNNING_COMMAND_CUSTOM_TIMEOUT ]] &&
[[ -n $LONG_RUNNING_COMMAND_CUSTOM ]] &&
[[ $time_taken -gt $LONG_RUNNING_COMMAND_CUSTOM_TIMEOUT ]] ; then
# put in brackets to make it quiet
export __preexec_exit_status
( $LONG_RUNNING_COMMAND_CUSTOM \
"\"$__udm_last_command\" took $time_taken_human" & )
fi
fi
fi
}
function preexec () {
# use __udm to avoid global name conflicts
__udm_last_command_started=$(printf "%(%s)T\n" -1)
__udm_last_command=$(echo "$1")
__udm_last_window=$(active_window_id)
}
preexec_install
}
|