Rework the status bar

Goals of this patch :

- display the signal quality

I used a thermometer icon cause there is no available icon with a
filleable bar o_O

- display the currently used network technology (4g, 3g, etc...)

I used the mapping from:

https://gitlab.freedesktop.org/mobile-broadband/ModemManager/-/blob/master/include/ModemManager-enums.h#L220

Dylan also said:

Anything from POTS to GPRS = 2G
UMTS to EVDOB = 3G
LTE = 4G
5GNR = 5G

- display the modem infos when modemmonitor is disabled

We want to decorelate the modem monitor from the icon. We still want to
know easily if modem monitor is runing but we also want those modem
infos if not.

- simplify the modem state determination (no state file anymore)

The statusbar probe mmcli itself.

- fix the leading timer without call issue

This was caused by the "pgrep -f" command that was matching itself.
Using a simple "pgrep" looks good enough anyway.

- fix some sxmo_statusbar update spaming issues (vol control)

This one point took me a lot of time to findout a good solution. We want
the USR1 kill to be spamable without causing issue to the displayed bar.
We dont want mid rendered bar (half the icons).
We dont want empty bars (empty stdout line).

I use some variable to store pid, smart waits and a better trap function
to make it to works cleanly. Now we can spam statusbarupdate. Only the
last one will actually redraw the bar.

Signed-off-by: Stacy Harper <contact@stacyharper.net>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
This commit is contained in:
Stacy Harper 2021-09-12 09:34:55 +02:00 committed by Maarten van Gompel
parent 61451f6292
commit 55985a8f20
4 changed files with 132 additions and 107 deletions

View file

@ -32,8 +32,6 @@ export XDG_CONFIG_HOME="${XDG_CONFIG_HOME:-$HOME/.config}"
# shellcheck disable=SC2034 # shellcheck disable=SC2034
export CONTACTFILE="$XDG_CONFIG_HOME/sxmo/contacts.tsv" export CONTACTFILE="$XDG_CONFIG_HOME/sxmo/contacts.tsv"
# shellcheck disable=SC2034 # shellcheck disable=SC2034
export MODEMSTATEFILE="$XDG_RUNTIME_DIR/sxmo.modem.state"
# shellcheck disable=SC2034
export UNSUSPENDREASONFILE="$XDG_RUNTIME_DIR/sxmo.suspend.reason" export UNSUSPENDREASONFILE="$XDG_RUNTIME_DIR/sxmo.suspend.reason"
# shellcheck disable=SC2034 # shellcheck disable=SC2034
export LASTSTATE="$XDG_RUNTIME_DIR/sxmo.suspend.laststate" export LASTSTATE="$XDG_RUNTIME_DIR/sxmo.suspend.laststate"

View file

@ -4,54 +4,92 @@
# shellcheck source=scripts/core/sxmo_common.sh # shellcheck source=scripts/core/sxmo_common.sh
. "$(dirname "$0")/sxmo_common.sh" . "$(dirname "$0")/sxmo_common.sh"
trap "update" USR1 percenticon() {
if [ "$1" -lt 20 ]; then
printf ""
elif [ "$1" -lt 40 ]; then
printf ""
elif [ "$1" -lt 60 ]; then
printf ""
elif [ "$1" -lt 80 ]; then
printf ""
else
printf ""
fi
}
bar() {
MMCLI="$(mmcli -m any -J)"
update() {
# In-call.. show length of call # In-call.. show length of call
CALLINFO=" " if pgrep sxmo_modemcall.sh > /dev/null; then
if pgrep -f sxmo_modemcall.sh; then
NOWS="$(date +"%s")" NOWS="$(date +"%s")"
CALLSTARTS="$(date +"%s" -d "$( CALLSTARTS="$(date +"%s" -d "$(
grep -aE 'call_start|call_pickup' "$XDG_DATA_HOME"/sxmo/modem/modemlog.tsv | grep -aE 'call_start|call_pickup' "$XDG_DATA_HOME"/sxmo/modem/modemlog.tsv |
tail -n1 | tail -n1 |
cut -f1 cut -f1
)")" )")"
CALLSECONDS="$(echo "$NOWS" - "$CALLSTARTS" | bc)" CALLSECONDS="$(printf "%s - %s" "$NOWS" "$CALLSTARTS" | bc)"
CALLINFO="${CALLSECONDS}s" printf "%ss " "$CALLSECONDS"
fi
MODEMSTATUS=""
if [ -z "$MMCLI" ]; then
printf ""
else
MODEMSTATUS="$(printf %s "$MMCLI" | jq -r .modem.generic.state)"
case "$MODEMSTATUS" in
locked)
printf ""
;;
registered|connected)
MODEMSIGNAL="$(printf %s "$MMCLI" | jq -r '.modem.generic."signal-quality".value')"
percenticon "$MODEMSIGNAL"
;;
disconnected)
printf "ﲁ"
;;
esac
fi
if [ "$MODEMSTATUS" = "connected" ]; then
printf " "
USEDTECHS="$(printf %s "$MMCLI" | jq -r '.modem.generic."access-technologies"[]')"
case "$USEDTECHS" in
*5gnr*)
printf 5g # no icon yet
;;
*lte*)
printf
;;
*umts*|*hsdpa*|*hsupa*|*hspa*|*1xrtt*|*evdo0*|*evdoa*|*evdob*)
printf
;;
*edge*)
printf E
;;
*pots*|*gsm*|*gprs*)
printf
;;
esac
fi
if pgrep -f sxmo_modemmonitor.sh > /dev/null; then
printf " "
fi
WLANSTATE="$(tr -d "\n" < /sys/class/net/wlan0/operstate)"
if [ "$WLANSTATE" = "up" ]; then
printf " "
fi fi
# symbol if wireguard/vpn is connected # symbol if wireguard/vpn is connected
VPN=""
VPNDEVICE="$(nmcli con show | grep vpn | awk '{ print $4 }')" VPNDEVICE="$(nmcli con show | grep vpn | awk '{ print $4 }')"
WGDEVICE="$(nmcli con show | grep wireguard | awk '{ print $4 }')" WGDEVICE="$(nmcli con show | grep wireguard | awk '{ print $4 }')"
if [ -n "$VPNDEVICE" ] && [ "$VPNDEVICE" != "--" ]; then if [ -n "$VPNDEVICE" ] && [ "$VPNDEVICE" != "--" ]; then
VPN="" printf " "
elif [ -n "$WGDEVICE" ] && [ "$WGDEVICE" != "--" ]; then elif [ -n "$WGDEVICE" ] && [ "$WGDEVICE" != "--" ]; then
VPN="" printf " "
fi
# W symbol if wireless is connect
WIRELESS=""
WLANSTATE="$(tr -d "\n" < /sys/class/net/wlan0/operstate)"
if [ "$WLANSTATE" = "up" ]; then
WIRELESS=""
fi
# M symbol if modem monitoring is on & modem present
MODEMMON=""
if [ -f "$MODEMSTATEFILE" ]; then
MODEMSTATE="$(cat "$MODEMSTATEFILE")"
if [ locked = "$MODEMSTATE" ]; then
MODEMMON=""
elif [ registered = "$MODEMSTATE" ]; then
MODEMMON=""
elif [ connected = "$MODEMSTATE" ]; then
MODEMMON=""
elif [ failed = "$MODEMSTATE" ] || [ disconnected = "$MODEMSTATE" ]; then
MODEMMON=""
else
MODEMMON=""
fi
fi fi
# Find battery and get percentage + status # Find battery and get percentage + status
@ -62,55 +100,60 @@ update() {
fi fi
done done
printf " "
if [ "$BATSTATUS" = "C" ]; then if [ "$BATSTATUS" = "C" ]; then
if [ "$PCT" -lt 20 ]; then if [ "$PCT" -lt 20 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 30 ]; then elif [ "$PCT" -lt 30 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 40 ]; then elif [ "$PCT" -lt 40 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 60 ]; then elif [ "$PCT" -lt 60 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 80 ]; then elif [ "$PCT" -lt 80 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 90 ]; then elif [ "$PCT" -lt 90 ]; then
BATSTATUS="$PCT% " printf ""
else else
BATSTATUS="$PCT% " printf ""
fi fi
else else
if [ "$PCT" -lt 10 ]; then if [ "$PCT" -lt 10 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 20 ]; then elif [ "$PCT" -lt 20 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 30 ]; then elif [ "$PCT" -lt 30 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 40 ]; then elif [ "$PCT" -lt 40 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 50 ]; then elif [ "$PCT" -lt 50 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 60 ]; then elif [ "$PCT" -lt 60 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 70 ]; then elif [ "$PCT" -lt 70 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 80 ]; then elif [ "$PCT" -lt 80 ]; then
BATSTATUS="$PCT% " printf ""
elif [ "$PCT" -lt 90 ]; then elif [ "$PCT" -lt 90 ]; then
BATSTATUS="$PCT% " printf ""
else else
BATSTATUS="$PCT% " printf ""
fi fi
fi fi
[ -z "$SXMO_BAR_HIDE_BAT_PER" ] && printf " %s%%" "$PCT"
printf " "
# Volume # Volume
AUDIODEV="$(sxmo_audiocurrentdevice.sh)" AUDIODEV="$(sxmo_audiocurrentdevice.sh)"
AUDIOSYMBOL=$(echo "$AUDIODEV" | cut -c1) AUDIOSYMBOL="$(printf %s "$AUDIODEV" | cut -c1)"
if [ "$AUDIOSYMBOL" = "L" ] || [ "$AUDIOSYMBOL" = "N" ]; then if [ "$AUDIOSYMBOL" = "L" ] || [ "$AUDIOSYMBOL" = "N" ]; then
AUDIOSYMBOL="" #speakers or none, use no special symbol printf "" #speakers or none, use no special symbol
elif [ "$AUDIOSYMBOL" = "H" ]; then elif [ "$AUDIOSYMBOL" = "H" ]; then
AUDIOSYMBOL=" " printf " "
elif [ "$AUDIOSYMBOL" = "E" ]; then elif [ "$AUDIOSYMBOL" = "E" ]; then
AUDIOSYMBOL=" " #earpiece printf " " #earpiece
fi fi
VOL=0 VOL=0
[ "$AUDIODEV" = "None" ] || VOL="$( [ "$AUDIODEV" = "None" ] || VOL="$(
@ -121,32 +164,45 @@ update() {
xargs printf %.0f xargs printf %.0f
)" )"
if [ "$AUDIODEV" != "None" ]; then if [ "$AUDIODEV" != "None" ]; then
if [ "$VOL" -eq 0 ]; then if [ "$VOL" -gt 66 ]; then
VOLUMESYMBOL="ﱝ" printf ""
elif [ "$VOL" -lt 25 ]; then elif [ "$VOL" -gt 33 ]; then
VOLUMESYMBOL="奄" printf ""
elif [ "$VOL" -gt 75 ]; then elif [ "$VOL" -gt 0 ]; then
VOLUMESYMBOL="墳" printf ""
else elif [ "$VOL" -eq 0 ]; then
VOLUMESYMBOL="奔" printf "ﱝ"
fi fi
fi fi
# Time
TIME="$(date +%R)"
BAR="$(echo "${CALLINFO} ${MODEMMON} ${WIRELESS} ${VPN} ${AUDIOSYMBOL}${VOLUMESYMBOL} ${BATSTATUS} ${TIME}" | sed 's| \+| |g')" printf " %s\0" "$(date +%R)"
}
case "$(sxmo_wm.sh)" in WM="$(sxmo_wm.sh)"
sway) printf "%s\n" "$BAR";;
dwm) xsetroot -name "$BAR";; forceupdate() {
kill "$SLEEPID"
}
trap "forceupdate" USR1
update() {
BAR="$(bar)"
[ -z "$SLEEPID" ] && return # to prevent mid rendering interuption
printf %s "$BAR" | case "$WM" in
sway|ssh) xargs -0 printf "%s\n";;
dwm) xargs -0 xsetroot -name;;
esac esac
} }
# E.g. on first boot justs to make sure the bar comes in quickly
update
while : while :
do do
sleep 30 & wait sleep 10 &
update SLEEPID=$!
update &
UPDATEID=$!
wait "$SLEEPID"
unset SLEEPID
wait "$UPDATEID"
done done

View file

@ -12,8 +12,6 @@ err() {
} }
gracefulexit() { gracefulexit() {
rm "$MODEMSTATEFILE"
sxmo_statusbarupdate.sh
sleep 1 sleep 1
echo "sxmo_modemmonitor: gracefully exiting (on signal or after error)">&2 echo "sxmo_modemmonitor: gracefully exiting (on signal or after error)">&2
kill -9 0 kill -9 0
@ -223,17 +221,9 @@ checkfornewtexts() {
} }
initialmodemstatus() { initialmodemstatus() {
touch "$MODEMSTATEFILE"
state=$(mmcli -m "$(modem_n)") state=$(mmcli -m "$(modem_n)")
if echo "$state" | grep -q -E "^.*state:.*connected.*$"; then if echo "$state" | grep -q -E "^.*state:.*locked.*$"; then
echo connected > "$MODEMSTATEFILE"
elif echo "$state" | grep -q -E "^.*state:.*registered.*$"; then
echo registered > "$MODEMSTATEFILE"
elif echo "$state" | grep -q -E "^.*state:.*locked.*$"; then
echo locked > "$MODEMSTATEFILE"
pidof unlocksim || sxmo_hooks.sh unlocksim & pidof unlocksim || sxmo_hooks.sh unlocksim &
else
echo unknown > "$MODEMSTATEFILE"
fi fi
} }
@ -243,6 +233,7 @@ mainloop() {
checkforincomingcalls checkforincomingcalls
checkfornewtexts checkfornewtexts
initialmodemstatus
# Monitor for incoming calls # Monitor for incoming calls
dbus-monitor --system "interface='org.freedesktop.ModemManager1.Modem.Voice',type='signal',member='CallAdded'" | \ dbus-monitor --system "interface='org.freedesktop.ModemManager1.Modem.Voice',type='signal',member='CallAdded'" | \
@ -262,11 +253,6 @@ mainloop() {
echo "$line" | grep -E "^signal" && checkforfinishedcalls echo "$line" | grep -E "^signal" && checkforfinishedcalls
done & done &
#Monitor for modem state changes
# arg1 holds the new state: MM_MODEM_STATE_FAILED = -1, MM_MODEM_STATE_UNKNOWN = 0, ... MM_MODEM_STATE_REGISTERED=8, MM_MODEM_STATE_CONNECTED = 11
initialmodemstatus
sxmo_statusbarupdate.sh
dbus-monitor --system "interface='org.freedesktop.ModemManager1.Modem',type='signal',member='StateChanged'" | \ dbus-monitor --system "interface='org.freedesktop.ModemManager1.Modem',type='signal',member='StateChanged'" | \
while read -r line; do while read -r line; do
if echo "$line" | grep -E "^signal.*StateChanged"; then if echo "$line" | grep -E "^signal.*StateChanged"; then
@ -274,25 +260,14 @@ mainloop() {
read -r oldstate #unused but we need to read past it read -r oldstate #unused but we need to read past it
read -r newstate read -r newstate
if echo "$newstate" | grep "int32 2"; then if echo "$newstate" | grep "int32 2"; then
echo locked > "$MODEMSTATEFILE"
pidof unlocksim || sxmo_hooks.sh unlocksim & pidof unlocksim || sxmo_hooks.sh unlocksim &
elif echo "$newstate" | grep "int32 8"; then elif echo "$newstate" | grep "int32 8"; then
echo registered > "$MODEMSTATEFILE"
#if there is a PIN entry menu open, kill it: #if there is a PIN entry menu open, kill it:
# shellcheck disable=SC2009 # shellcheck disable=SC2009
ps aux | grep dmenu | grep PIN | gawk '{ print $1 }' | xargs kill ps aux | grep dmenu | grep PIN | gawk '{ print $1 }' | xargs kill
checkforfinishedcalls checkforfinishedcalls
checkforincomingcalls checkforincomingcalls
checkfornewtexts checkfornewtexts
elif echo "$newstate" | grep "int32 11"; then
echo connected > "$MODEMSTATEFILE"
#3G/2G/4G available
elif echo "$newstate" | grep "int32 -1"; then
echo failed > "$MODEMSTATEFILE"
elif echo "$newstate" | grep "int32 3"; then
echo disabled > "$MODEMSTATEFILE"
else
echo unknown > "$MODEMSTATEFILE"
fi fi
sxmo_statusbarupdate.sh sxmo_statusbarupdate.sh
fi fi
@ -316,7 +291,6 @@ mainloop() {
echo "sxmo_modemmonitor: modem not found, waiting for modem... (try #$TRIES)">&2 echo "sxmo_modemmonitor: modem not found, waiting for modem... (try #$TRIES)">&2
sleep 3 sleep 3
if [ "$TRIES" -eq 10 ]; then if [ "$TRIES" -eq 10 ]; then
echo failed > "$MODEMSTATEFILE"
echo "sxmo_modemmonitor: forcing modem restart">&2 echo "sxmo_modemmonitor: forcing modem restart">&2
sxmo_modemmonitortoggle.sh restart #will kill the modemmonitor too sxmo_modemmonitortoggle.sh restart #will kill the modemmonitor too
break break
@ -331,9 +305,6 @@ mainloop() {
wait wait
wait wait
wait wait
rm "$MODEMSTATEFILE" 2>/dev/null
sxmo_statusbarupdate.sh
} }

View file

@ -99,7 +99,6 @@ on() {
while ! printf %s "$(mmcli -L)" 2> /dev/null | grep -qoE 'Modem\/([0-9]+)'; do while ! printf %s "$(mmcli -L)" 2> /dev/null | grep -qoE 'Modem\/([0-9]+)'; do
TRIES=$((TRIES+1)) TRIES=$((TRIES+1))
if [ "$TRIES" -eq 10 ]; then if [ "$TRIES" -eq 10 ]; then
printf "failed\n" > "$MODEMSTATEFILE"
notify-send --urgency=critical "We failed to start the modem monitor. We may need hard reboot." notify-send --urgency=critical "We failed to start the modem monitor. We may need hard reboot."
fi fi
sleep 5 sleep 5
@ -128,4 +127,5 @@ case "$1" in
off) off;; off) off;;
esac esac
sleep 1
sxmo_statusbarupdate.sh sxmo_statusbarupdate.sh