bunch of new stuff, a few fixes
[distro-setup] / prof-tail
index 7028ae722d64a2e34b63a4522bad2aac9a3f8f4f..9830747337c8aa0852435e6ab024e08641e48ffd 100644 (file)
--- a/prof-tail
+++ b/prof-tail
@@ -18,6 +18,11 @@ xmpp_users=(
   jtuttle
 )
 
+# start emacs daemon for profanity if it doesnt exist.
+if ! pgrep -f '^emacs --daemon=profanity$' &>/dev/null; then
+  emacs --daemon=profanity &>/dev/null
+fi
+
 
 while true; do
   midnight=$(date -d '00:00:00 tomorrow' +%s)
@@ -25,13 +30,16 @@ while true; do
   log_today=$(date '+%Y_%m_%d').log
   logdir=/home/iank/.local/share/profanity/chatlogs/iank_at_fsf.org
 
+  # when this fails, it has PIPESTATUS: 124 0 1 0 0, which seems to end up with 1 as the overall code, which is not what
+  # i expected. todo: investigate if and why that is, and narrow the ||:
+  # shellcheck disable=SC2046 # intentional
   timeout --foreground $secs_till_midnight tail -n0 -qF \
           $(for u in ${xmpp_users[@]}; do echo $logdir/${u}_at_fsf.org/$log_today; done) 2>/dev/null \
-    | awk '$3 != "me:" {print $3; fflush()}'  | sed -u 's/^/pm /;s/@.*//' || [[ $? == 124 ]] &
+    | awk '$3 != "me:" {print $3; fflush()}'  | sed -u 's/^/pm /;s/@.*//' ||: &
 
   timeout --foreground $secs_till_midnight tail -n0 -qF \
           $logdir/rooms/*/$log_today 2>/dev/null \
-    | awk '$3 != "iank:"' | grep -i '\biank\b' | awk '{print $3; fflush()}' | sed 's/^/room /;s/@.*//' || [[ $? == 124 ]]
+    | awk '$3 != "iank:"' | grep -i '\biank\b' | awk '{print $3; fflush()}' | sed 's/^/room /;s/@.*//' ||:
 
   sleep 1