diff options
author | Dustin Walker <dustin.walker@email.wsu.edu> | 2025-01-16 17:00:08 -0500 |
---|---|---|
committer | Dustin Walker <dustin.walker@email.wsu.edu> | 2025-01-16 17:00:08 -0500 |
commit | fcf44b17142cbeaf1f6a4b66e5ab0eed1483ebe4 (patch) | |
tree | f9d4625d612af99557ff0249dbf5f1fccc6175c8 /.script |
Diffstat (limited to '.script')
-rwxr-xr-x | .script/bootstrapxbps | 75 | ||||
-rwxr-xr-x | .script/dwmstatus | 79 | ||||
-rwxr-xr-x | .script/refreshstatus | 5 | ||||
-rwxr-xr-x | .script/weather | 2 |
4 files changed, 161 insertions, 0 deletions
diff --git a/.script/bootstrapxbps b/.script/bootstrapxbps new file mode 100755 index 0000000..310327c --- /dev/null +++ b/.script/bootstrapxbps @@ -0,0 +1,75 @@ +#!/bin/sh +# +# bootstrapxbps +# +# This script takes a comma separated .csv file with the following format: +# A,B,C,... +# where: +# A = an xbps package name. +# all other columns will be ignored. +# +# First, "xbps-install -Suvy" will be called 3 times to ensure up to date repositories and existing packages. +# Then, all A values will be put into a call to "xbps-install". + +Help() +{ + echo "bootstrapxbps [-h] [-e] file.csv" + echo "file.csv is a comma separated value file. Separate with ," + echo "Package names will be gathered from the 0th column." + echo "-h Help" + echo "-e Install nonfree and multilib repositories before bootstrap" +} + +Usage() +{ + echo "Usage:" + echo "bootstrapxbps -h" + echo "bootstrapxbps [-e] file.csv" +} + +ExtraRepos() +{ + # Install multilib repository separately. + xbps-install -Sy void-repo-multilib + xbps-install -Sy void-repo-multilib-nonfree + xbps-install -Sy void-repo-nonfree +} + +Upgrade() +{ + # Update repositories and existing packages. + xbps-install -Suy + xbps-install -Suy + xbps-install -Suy + + # Gather packages in .csv argument. + IFS="," + CMD="xbps-install" + + while read package comment; do + CMD="${CMD} ${package}" + done < "${1}" + + IFS=$OLDIFS + + # Install specified packages. + eval $CMD + + exit 0 +} + +while getopts 'he' c; do + case ${c} in + h) Help + exit 0 + ;; + e) ExtraRepos + ;; + \?) Usage + exit 1 + ;; + esac +done +shift $((OPTIND -1)) + +Upgrade $1 diff --git a/.script/dwmstatus b/.script/dwmstatus new file mode 100755 index 0000000..9f288e1 --- /dev/null +++ b/.script/dwmstatus @@ -0,0 +1,79 @@ +#!/bin/sh + +# This script sets the statusbar with the xsetroot command at the end. +# Call it inside ~/.xinitrc or ~/.xprofile. + +# Handle SIGTRAP signals sent by refbar to update the status bar immediately. +trap 'update' 5 + +# Set the deliminter character. +delim="|" + +# testweather checks to see if the most recent forecast is up to date. If it isnt' it +# downloads a new weather forecast, then signals to update the statusbar. Gets weather report from wttr.in. +testweather() { \ + [ "$(stat -c %y "$HOME/.local/share/weatherreport" 2>/dev/null | cut -d' ' -f1)" != "$(date '+%Y-%m-%d')" ] && + ping -q -c 1 1.1.1.1 >/dev/null && + curl -s "wttr.in/$location" > "$HOME/.local/share/weatherreport" && + notify-send "🌞 Weather" "New weather forecast for today." && + $HOME/.script/refreshstatus +} + +# Here is the cumulative function that outputs and formats the appearance of the statusbar. +# It can really be broken down into many submodules which are commented and explained. +status() { \ + # Get current mpd track filename or artist - title if possible. + mpc -f "[[%artist% - ]%title%]|[%file%]" 2>/dev/null | grep -v "volume:" | head -n 1 && echo "$delim" + + # If the weather report is current, show daily precipitation chance, low and high. + # Takes the weather report from wttr.in and formats it for the status bar. + [ "$(stat -c %y "$HOME/.local/share/weatherreport" 2>/dev/null | cut -d' ' -f1)" = "$(date '+%Y-%m-%d')" ] && + sed '16q;d' "$HOME/.local/share/weatherreport" | grep -wo "[0-9]*%" | sort -n | sed -e '$!d' | sed -e "s/^/ /g" | tr -d '\n' && + sed '13q;d' "$HOME/.local/share/weatherreport" | grep -o "m\\(-\\)*[0-9]\\+" | sort -n -t 'm' -k 2n | sed -e 1b -e '$!d' | tr '\n|m' ' ' | awk '{print " ",$1 "°","",$2 "°"}' && + echo "$delim" + + # Get the volume of ALSA's master volume output. Show an icon if or not muted. + amixer get Master | grep -o "[0-9]*%\|\[on\]\|\[off\]" | sed "s/\[on\]//;s/\[off\]//" + + echo "$delim" + + # Wifi quality percentage and icon if ethernet is connected. + grep "^\s*w" /proc/net/wireless | awk '{ print "", int($3 * 100 / 70) "%" }' + sed "s/down//;s/up//" /sys/class/net/e*/operstate + + # Will show all batteries with approximate icon for remaining power. + for x in /sys/class/power_supply/BAT?/capacity; + do + case "$(cat $x)" in + 100|9[0-9]) echo "" ;; + 8[0-9]|7[0-9]) echo "" ;; + 6[0-9]|5[0-9]) echo "" ;; + 4[0-9]|3[0-9]) echo "" ;; + *) echo "" ;; + esac + done && echo "$delim" + + # Date and time. + date '+%Y %b %d (%a) %I:%M%p' +} + +update() { \ + # Have xsetroot set dwm status bar with our formatted input. + # Note that the tr command replaces newlines with spaces. This is + # to prevent some weird issues that cause significant slowing of + # everything in dwm. Cause unknown. + xsetroot -name "$(status | tr '\n' ' ')" & wait + + # Check to see if new weather report is needed. + testweather & wait +} + +while :; do + update + # Sleep for a minute after changing the status bar before updating it + # again. We run sleep in the background and use wait until it finishes, + # because traps can interrupt wait immediately, but they can't do that with sleep. + sleep 1m & + wait +done + diff --git a/.script/refreshstatus b/.script/refreshstatus new file mode 100755 index 0000000..5d8c5ec --- /dev/null +++ b/.script/refreshstatus @@ -0,0 +1,5 @@ +#!/bin/sh + +# Refresh dwm status. +# Send SIGTRAP signal to dwmstatus script, which will handle it with a trap. +pkill -SIGTRAP dwmbar diff --git a/.script/weather b/.script/weather new file mode 100755 index 0000000..91634c5 --- /dev/null +++ b/.script/weather @@ -0,0 +1,2 @@ +#!/bin/sh +curl -s wttr.in/?format="%l:+%C+%t" > /tmp/weather |