aboutsummaryrefslogtreecommitdiff
path: root/sway-de/local/bin
diff options
context:
space:
mode:
authorMatt Singleton <matt@xcolour.net>2023-04-02 14:21:49 -0500
committerMatt Singleton <matt@xcolour.net>2023-04-02 14:21:49 -0500
commitb483c295c082207dd7e8063949c2ff5b1ed14daf (patch)
tree96af8f2cdd86e25f8a0967b0a55209aa3fc47fc1 /sway-de/local/bin
parenta19790b7f5e606c3082dd0c8664e4fd460e7df91 (diff)
new stow-based configuration management for graphical environment
Diffstat (limited to 'sway-de/local/bin')
-rwxr-xr-xsway-de/local/bin/dmenu-wl5
-rwxr-xr-xsway-de/local/bin/dnf-needs-restarting26
-rwxr-xr-xsway-de/local/bin/setbright30
-rwxr-xr-xsway-de/local/bin/setvol30
4 files changed, 91 insertions, 0 deletions
diff --git a/sway-de/local/bin/dmenu-wl b/sway-de/local/bin/dmenu-wl
new file mode 100755
index 0000000..7ac2273
--- /dev/null
+++ b/sway-de/local/bin/dmenu-wl
@@ -0,0 +1,5 @@
+#!/bin/bash
+
+set -euo pipefail
+
+wofi -d "$@"
diff --git a/sway-de/local/bin/dnf-needs-restarting b/sway-de/local/bin/dnf-needs-restarting
new file mode 100755
index 0000000..a080649
--- /dev/null
+++ b/sway-de/local/bin/dnf-needs-restarting
@@ -0,0 +1,26 @@
+#!/bin/bash
+
+set -eo pipefail
+
+if command -v dnf > /dev/null; then
+ DNFCMD="dnf"
+fi
+if command -v jq > /dev/null; then
+ JQCMD="jq"
+fi
+if [ -z "$DNFCMD" ] || [ -z "$JQCMD" ]; then
+ echo "{\"tooltip\": \"requires 'jq' and 'dnf'\", \"text\": \"\"}"
+ exit 1
+fi
+
+set -u
+
+if ! output="$($DNFCMD needs-restarting -r)"; then
+ icon=""
+else
+ icon=""
+fi
+
+# this is a literal expression for `jq`
+# shellcheck disable=SC2016
+$JQCMD --unbuffered -n -c '{tooltip: $ARGS.positional[0], text: $ARGS.positional[1]}' --args "$output" "$icon"
diff --git a/sway-de/local/bin/setbright b/sway-de/local/bin/setbright
new file mode 100755
index 0000000..7d2784a
--- /dev/null
+++ b/sway-de/local/bin/setbright
@@ -0,0 +1,30 @@
+#!/bin/bash
+
+set -euo pipefail
+
+wobsock="$XDG_RUNTIME_DIR/wob.sock"
+if [ ! -p "$wobsock" ]; then
+ echo $wobsock
+ echo "communication socket not found"
+ exit 2
+fi
+
+current=$(brightnessctl -m info | cut -d, -f4 | tr --delete '%')
+case $1 in
+ up)
+ increment=$(( 5 - ( current % 5 ) ))
+ new=$(( current + increment ))
+ if [ $new -gt 100 ]; then
+ new=100
+ fi
+ brightnessctl set $new% > /dev/null 2>&1
+ echo $new > $wobsock;;
+ down)
+ increment=$(( ( ( current - 1 ) % 5 ) + 1 ))
+ new=$(( current - increment ))
+ if [ $new -lt 0 ]; then
+ new=0
+ fi
+ brightnessctl set $new% > /dev/null 2>&1
+ echo $new > $wobsock;;
+esac
diff --git a/sway-de/local/bin/setvol b/sway-de/local/bin/setvol
new file mode 100755
index 0000000..f8bb4df
--- /dev/null
+++ b/sway-de/local/bin/setvol
@@ -0,0 +1,30 @@
+#!/bin/bash
+
+set -euo pipefail
+
+wobsock="$XDG_RUNTIME_DIR/wob.sock"
+if [ ! -p "$wobsock" ]; then
+ echo $wobsock
+ echo "communication socket not found"
+ exit 2
+fi
+
+current_volume=$(pactl get-sink-volume @DEFAULT_SINK@ | grep Volume | sed -e 's/.* \([0-9][0-9]*\)%.*/\1/')
+case $1 in
+ up)
+ increment=$(( 5 - ( current_volume % 5 ) ))
+ newvol=$(( current_volume + increment ))
+ if [ $newvol -gt 100 ]; then
+ newvol=100
+ fi
+ pactl set-sink-volume @DEFAULT_SINK@ $newvol%
+ echo $newvol > $wobsock;;
+ down)
+ increment=$(( ( ( current_volume - 1 ) % 5 ) + 1 ))
+ newvol=$(( current_volume - increment ))
+ if [ $newvol -lt 0 ]; then
+ newvol=0
+ fi
+ pactl set-sink-volume @DEFAULT_SINK@ $newvol%
+ echo $newvol > $wobsock;;
+esac