From 37ff7062874b72bafa99afe661f42653565ed511 Mon Sep 17 00:00:00 2001 From: Mitsuo Tokumori Date: Wed, 11 Sep 2024 04:25:38 +0900 Subject: RESTRUCTURE. Replicate relative paths in public/ --- public/.local/bin/README.txt | 17 +++++ public/.local/bin/audio_control.sh | 37 +++++++++ public/.local/bin/brightness_control.sh | 17 +++++ public/.local/bin/build-latex.sh | 21 +++++ public/.local/bin/dmenu-webshortcuts.sh | 93 +++++++++++++++++++++++ public/.local/bin/input_control.sh | 62 +++++++++++++++ public/.local/bin/laptop-backup.sh | 38 +++++++++ public/.local/bin/laptop-xinput_setup.sh | 13 ++++ public/.local/bin/laptop-xrandr.sh | 23 ++++++ public/.local/bin/lp1-unzip_deletebinaries_zip.sh | 20 +++++ public/.local/bin/myfile-handler.sh | 7 ++ public/.local/bin/network_control.sh | 53 +++++++++++++ public/.local/bin/ocrthis.sh | 20 +++++ public/.local/bin/rename_pictures.sh | 16 ++++ public/.local/bin/sb-audio | 35 +++++++++ public/.local/bin/sb-battery | 37 +++++++++ public/.local/bin/sb-input | 9 +++ public/.local/bin/sb-network | 52 +++++++++++++ public/.local/bin/scan_loop.sh | 33 ++++++++ public/.local/bin/screenshot.sh | 21 +++++ public/.local/bin/screenshot_ocr.sh | 29 +++++++ public/.local/bin/setbg.sh | 9 +++ public/.local/bin/setup_default_apps.sh | 31 ++++++++ public/.local/bin/updatewebsite.sh | 9 +++ 24 files changed, 702 insertions(+) create mode 100644 public/.local/bin/README.txt create mode 100755 public/.local/bin/audio_control.sh create mode 100755 public/.local/bin/brightness_control.sh create mode 100755 public/.local/bin/build-latex.sh create mode 100755 public/.local/bin/dmenu-webshortcuts.sh create mode 100755 public/.local/bin/input_control.sh create mode 100755 public/.local/bin/laptop-backup.sh create mode 100755 public/.local/bin/laptop-xinput_setup.sh create mode 100755 public/.local/bin/laptop-xrandr.sh create mode 100755 public/.local/bin/lp1-unzip_deletebinaries_zip.sh create mode 100755 public/.local/bin/myfile-handler.sh create mode 100755 public/.local/bin/network_control.sh create mode 100755 public/.local/bin/ocrthis.sh create mode 100755 public/.local/bin/rename_pictures.sh create mode 100755 public/.local/bin/sb-audio create mode 100755 public/.local/bin/sb-battery create mode 100755 public/.local/bin/sb-input create mode 100755 public/.local/bin/sb-network create mode 100755 public/.local/bin/scan_loop.sh create mode 100755 public/.local/bin/screenshot.sh create mode 100755 public/.local/bin/screenshot_ocr.sh create mode 100755 public/.local/bin/setbg.sh create mode 100755 public/.local/bin/setup_default_apps.sh create mode 100755 public/.local/bin/updatewebsite.sh (limited to 'public/.local/bin') diff --git a/public/.local/bin/README.txt b/public/.local/bin/README.txt new file mode 100644 index 0000000..280b362 --- /dev/null +++ b/public/.local/bin/README.txt @@ -0,0 +1,17 @@ +My Linux executable scripts. + +NOTES +* Beware of not leaking personal information + +I also use other people's awesome scrips. I store them in `~/code` and then +slink the ones I use in `~/.local/bin`. + +NOTATION +(notation is messed up, I'd be better if only used dashed prefixes) +* All scripts here should end in ".sh" +* `laptop-*` scripts might only work on my current machine +* `sb-*` scripts are meant to be called by dwmblocks +* `*_control` scripts are used in conjunction with xbindkeys(1) and `sb-*` + See also: + https://github.com/LukeSmithxyz/voidrice/tree/master/.local/bin/statusbar + https://github.com/LukeSmithxyz/dwmblocks/blob/master/config.h diff --git a/public/.local/bin/audio_control.sh b/public/.local/bin/audio_control.sh new file mode 100755 index 0000000..a257120 --- /dev/null +++ b/public/.local/bin/audio_control.sh @@ -0,0 +1,37 @@ +#!/bin/bash + +delta=${2:-10} +signal=10 + +# signal dwmblocks to update volume block +send_signal() { + pkill -RTMIN+$signal dwmblocks +} + +# WIP: change default sink (speaker). E.g., when connecting HDMI. +change_sink() { + pactl list sinks | grep "Name:" + # Use tab completion if set up interactively + pactl "set-default-sink alsa_output.pci-0000_05_00.6.analog-stereo" +} + +case $1 in + inc) pactl set-sink-volume @DEFAULT_SINK@ +$delta% ;; + dec) pactl set-sink-volume @DEFAULT_SINK@ -$delta% ;; + micinc) pactl set-source-volume @DEFAULT_SOURCE@ +$delta% ;; + micdec) pactl set-source-volume @DEFAULT_SOURCE@ -$delta% ;; + mutetoggle) pactl set-sink-mute @DEFAULT_SINK@ toggle ;; + deafentoggle) pactl set-source-mute @DEFAULT_SOURCE@ toggle ;; + *) + echo Speaker: + pactl get-sink-volume @DEFAULT_SINK@ + pactl get-sink-mute @DEFAULT_SINK@ + echo -e "\nMic:" + pactl get-source-volume @DEFAULT_SOURCE@ + pactl get-source-mute @DEFAULT_SOURCE@ + echo -e "\nApplications:" + pactl list sink-inputs | grep -e 'Sink Input' -e 'application.name' -e 'Volume:' + ;; +esac + +send_signal diff --git a/public/.local/bin/brightness_control.sh b/public/.local/bin/brightness_control.sh new file mode 100755 index 0000000..13345d7 --- /dev/null +++ b/public/.local/bin/brightness_control.sh @@ -0,0 +1,17 @@ +#!/bin/bash + +delta=${2:-10} +signal=11 + +# signal dwmblocks to update block +send_signal() { + pkill -RTMIN+$signal dwmblocks +} + +case $1 in + inc) xbacklight -inc $delta ;; + dec) xbacklight -dec $delta ;; + *) xbacklight -get ;; +esac + +send_signal diff --git a/public/.local/bin/build-latex.sh b/public/.local/bin/build-latex.sh new file mode 100755 index 0000000..7048246 --- /dev/null +++ b/public/.local/bin/build-latex.sh @@ -0,0 +1,21 @@ +# Build single latex file using xelatex + +if [ $# -ne 1 ]; then + echo "Usage: $(basename "$0") FILE" + exit 1 +fi + +cleanup() { + # cleanup of auxiliary files + rm -f *.aux *.fls *.fdb_latexmk + # rm *.log +} + +xelatex $1 || exit # Initial compilation +#bibtex # Bibliography tool +#xelatex $1 || exit # Incorporate bibliography changes +xelatex $1 || exit # Fix cross-references +#xelatex $1 || exit # 4th run just to be safe +cleanup +echo "## Mispelled words:" +pdftotext "${1%.tex}.pdf" - | hunspell -d en_US -i utf-8 -a | sort | uniq diff --git a/public/.local/bin/dmenu-webshortcuts.sh b/public/.local/bin/dmenu-webshortcuts.sh new file mode 100755 index 0000000..e1d233c --- /dev/null +++ b/public/.local/bin/dmenu-webshortcuts.sh @@ -0,0 +1,93 @@ +#!/bin/bash + +# Use dmenu and user-defined web shorcuts to query websites faster. +# +# This script tries to mimic Krunner Web Search Keywords functionality. +# See: https://userbase.kde.org/Plasma/Krunner#Browse_websites +# +# TODO: Integrate it to dmenu_run (so that this script doens't require a +# dedicated keybinding) +# +# Mitsuo +# 2023-11-23 + +input=$(echo "" | dmenu -p 'wp:Hello World') +## Set Internal Field Separator, save separated fields as an array in $CMD (-a), +## don't allow backslashes to escape any characters (-r). Feed $input as stdin. +#IFS=':' read -ra CMD <<< "$input" +#keyword=${CMD[0]} +#search_term=${CMD[1]} +keyword="${input%%:*}" +search_term="${input#*:}" + +# Define web shortcuts here +case "$keyword" in + # Search + "dd") xdg-open "https://duckduckgo.com/?t=h_&q=${search_term// /+}" ;; + "gg") xdg-open "https://www.google.com/search?q=$search_term" ;; + "bing") xdg-open "https://www.bing.com/search?q=${search_term// /+}" ;; + "metac") xdg-open "https://www.metacrawler.com/serp?q=${search_term// /+}" ;; + + # Finance + "ggf") xdg-open "https://www.google.com/finance/quote/$search_term?window=1Y" ;; + "yf") xdg-open "https://finance.yahoo.com/quote/$search_term" ;; + "bb") xdg-open "https://www.bloomberg.com/quote/$search_term" ;; + + # Maps + "ggm") xdg-open "https://www.google.com/maps/search/${search_term// /+}" ;; + "osm") xdg-open "https://www.openstreetmap.org/search?query=$search_term" ;; + + # Reference + "wp") xdg-open "https://en.wikipedia.org/wiki/${search_term// /_}" ;; + "wt") xdg-open "https://en.wiktionary.org/wiki/${search_term// /_}" ;; + "wv") xdg-open "https://en.wikivoyage.org/wiki/${search_term// /_}" ;; + "scholar") xdg-open "https://scholar.google.com/scholar?hl=en&q=${search_query// /+}" ;; + "arxiv") xdg-open "https://arxiv.org/search/?query=${search_query// /+}" ;; + + # Computer + "arch") xdg-open "https://wiki.archlinux.org/index.php?search=${search_term// /+}" ;; + "aur") xdg-open "https://aur.archlinux.org/packages?O=0&K=${search_term// /+}" ;; + "so") xdg-open "https://stackoverflow.com/search?q=${search_term// /+}" ;; + "gh") xdg-open "https://github.com/search?q=${search_term// /+}&type=repositories" ;; + "gl") xdg-open "https://about.gitlab.com/search?searchText=$search_term" ;; + "pypi") xdg-open "https://pypi.org/search/?q=${search_term// /+}&o=" ;; + "npm") xdg-open "https://www.npmjs.com/search?q=${search_term// /+}" ;; + + # Media + "yt") xdg-open "https://www.youtube.com/results?search_query=$search_term" ;; + "vm") xdg-open "https://vimeo.com/search?q=$search_term" ;; + "sp") xdg-open "https://open.spotify.com/search/$search_term" ;; + "sc") xdg-open "https://soundcloud.com/search?q=$search_term" ;; + "dz") xdg-open "https://www.deezer.com/search/$search_term" ;; + "imdb") xdg-open "https://www.imdb.com/find/?q=$search_term" ;; + + # Social Media + "x") xdg-open "https://x.com/search?q=$search_term&src=typed_query" ;; + "rd") xdg-open "https://duckduckgo.com/?t=h_&q=site%3Areddit.com+${search_term// /+}&ia=web" ;; + "ig") xdg-open "https://duckduckgo.com/?q=site%3Ainstagram.com+${search_term// /+}&ia=web" ;; + "fb") xdg-open "https://duckduckgo.com/?q=site%3Afacebook.com+${search_term// /+}&ia=web" ;; + + # Shopping + "amzn") xdg-open "https://www.amazon.com/s?k=${search_term// /+}" ;; + "amznjp") xdg-open "https://www.amazon.co.jp/s?k=${search_term// /+}" ;; + "ebay") xdg-open "https://www.ebay.com/sch/i.html?_nkw=${search_term// /+}" ;; + + # Utilities + "ggt") xdg-open "https://translate.google.com/?sl=auto&tl=en&text=$search_term&op=translate" ;; + "en2es") xdg-open "https://www.wordreference.com/es/translation.asp?tranword=$search_term" ;; + "es2en") xdg-open "https://www.wordreference.com/es/en/translation.asp?spen=$search_term" ;; + "en2de") xdg-open "https://www.wordreference.com/es/en/translation.asp?spen=$search_term" ;; + "de2en") xdg-open "https://www.wordreference.com/deen/$search_term" ;; + "jisho") xdg-open "https://jisho.org/search/$search_term" ;; + "rae") xdg-open "https://dle.rae.es/?w=$search_term" ;; + + # Mitsuo + "pw") xdg-open "http://wiki.pulse15/index.php?search=${search_term// /+}" ;; + "factorio") xdg-open "https://wiki.factorio.com/${search_term// /_}" ;; + "dst") xdg-open "https://dontstarve.wiki.gg/wiki/${search_term// /_}" ;; + "mc") xdg-open "https://minecraft.wiki/w/${search_term// /_}" ;; + "terraria") xdg-open "https://terraria.wiki.gg/wiki/${search_term// /_}" ;; + + *) exit 1 ;; +esac + diff --git a/public/.local/bin/input_control.sh b/public/.local/bin/input_control.sh new file mode 100755 index 0000000..f63de3b --- /dev/null +++ b/public/.local/bin/input_control.sh @@ -0,0 +1,62 @@ +#!/bin/bash + +# Use either X keyboard extension layouts (setxkbmap), or fcitx (or both). +# +# At first I configured this to use setxkbmap, it works fine. +# +# fcitx already provides keybindings, but I wanted to display +# the current input method in dwmblocks immediatly. So I'm +# adding such support through fcitx5-remote. + +signal=20 + +# signal dwmblocks to update block +send_signal() { + pkill -RTMIN+$signal dwmblocks +} + +# Cycle X keyboard extension layouts +cycle_layouts() { + layouts=(us latam) # X keyboard extension + STATE_FILE="$XDG_STATE_HOME/keyboard_layout_state" + + if [ -f "$STATE_FILE" ]; then + index=$(cat "$STATE_FILE") + else + index=0 + fi + next_index=$(( (index + 1) % ${#layouts[@]} )) + echo $next_index > "$STATE_FILE" + + setxkbmap ${layouts[$index]} +} + +fcitx_control() { + # For this to correctly reflect the state of the system "Share Input State" + # should be set to "All" in fcitx5-configtool. + + case $1 in + en) + fcitx5-remote -c # Closed + fcitx5-remote -g Default + ;; + es) + fcitx5-remote -c # Closed + fcitx5-remote -g Spanish + ;; + ja) + fcitx5-remote -g Default + fcitx5-remote -o # Open + ;; + *) + fcitx5-remote -q # + fcitx5-remote -n + fcitx5-remote + ;; + esac +} + +#cycle_layouts +fcitx_control $1 + +send_signal diff --git a/public/.local/bin/laptop-backup.sh b/public/.local/bin/laptop-backup.sh new file mode 100755 index 0000000..a22c179 --- /dev/null +++ b/public/.local/bin/laptop-backup.sh @@ -0,0 +1,38 @@ +#!/bin/bash + +# Fast backup using rsync + +if [ $# -ne 2 ]; then + echo "Usage: $(basename "$0") /dev/sdX backup" + exit 1 +fi + +if [ "$(id -u)" -ne 0 ]; then + echo "This script must be run as root." + exit 1 +fi + +rsync_options="-auvP --delete" +device=$1 +name=$2 + +# Note: `name` (nor `device`) should not contain spaces + +cryptsetup open --type luks $device $name +if [ $? -ne 0 ]; then + # bad device + exit 1 +fi +mount /dev/mapper/$name /mnt/$name +# TODO: stop backing up /var. Backup is just for Postgres and Mediawiki. +# `/var` is used by too many applications. Specialy pacman that clutters it +# with cached binaries. +rsync $rsync_options /var /mnt/$name # <10G +rsync $rsync_options /home /mnt/$name # <900G +rsync $rsync_options /etc /mnt/$name # <20M +echo "Backup complete." +df -h #| grep -E "${name}|var|home|etc" +umount /mnt/$name +cryptsetup close $name + +echo "All done. Check \`$ lsblk\` before unplugging the storage device." diff --git a/public/.local/bin/laptop-xinput_setup.sh b/public/.local/bin/laptop-xinput_setup.sh new file mode 100755 index 0000000..e471869 --- /dev/null +++ b/public/.local/bin/laptop-xinput_setup.sh @@ -0,0 +1,13 @@ +#!/bin/bash + +# See https://wiki.archlinux.org/title/Libinput + +#xinput list +#xinput list-props + +pulse15() { + xinput set-prop "UNIW0001:00 093A:0255 Touchpad" "libinput Tapping Enabled" 1 + #xinput set-prop "UNIW0001:00 093A:0255 Touchpad" "libinput Tapping Enabled Default" 1 +} + +pulse15 diff --git a/public/.local/bin/laptop-xrandr.sh b/public/.local/bin/laptop-xrandr.sh new file mode 100755 index 0000000..cbe9479 --- /dev/null +++ b/public/.local/bin/laptop-xrandr.sh @@ -0,0 +1,23 @@ +#!/bin/bash + +# See https://wiki.archlinux.org/title/Multihead + +# Didn't know how to get the screen name, this works for now +#screen=$(xrandr | grep "primary" | awk '{ print $1 }') +# But now how do I get the rest? And the correct order? Maybe it's better just +# to define "hardcoded" functions and just call them. + +simple_2_monitor() { + # enable + xrandr --output eDP --auto \ + --output HDMI-A-0 --auto --left-of eDP + # disable + xrandr --output eDP --auto \ + --output HDMI-A-0 --off +} + +# Thank you: https://www.maketecheasier.com/how-to-setup-dual-monitors-with-xrandr/ +# xrandr --auto --output HDMI-A-0 --mode 1920x1080 --right-of eDP + +#simple_2_monitor +xrandr --auto --output HDMI-A-0 --mode 1920x1080 --right-of eDP diff --git a/public/.local/bin/lp1-unzip_deletebinaries_zip.sh b/public/.local/bin/lp1-unzip_deletebinaries_zip.sh new file mode 100755 index 0000000..3fa4afb --- /dev/null +++ b/public/.local/bin/lp1-unzip_deletebinaries_zip.sh @@ -0,0 +1,20 @@ +#!/bin/bash + +# Script for LP1 labs that are uploaded to Google Drive with binaries and +# that causes problems with Google Drive's automatic virus scan. + +# unzip +for f in *.zip; do unzip -q "$f"; done + +# delete build/ and dist/ directories (virus detection in Google Drive) +find . -type d -regex '^.*/\(dist\|build\)$' -print0 | xargs -0 rm -r + +# zip +rm *.zip # remove old zip files +for d in */; do + dirname="${d%/}" + zip -qr "$dirname.zip" "$d" +done + +# dos2unix (for me) +find . -type f -iregex ".*\.\(csv\|cpp\|h\|hpp\)" -print0 | xargs -0 dos2unix diff --git a/public/.local/bin/myfile-handler.sh b/public/.local/bin/myfile-handler.sh new file mode 100755 index 0000000..40360b8 --- /dev/null +++ b/public/.local/bin/myfile-handler.sh @@ -0,0 +1,7 @@ +#!/bin/bash +# A script to handle custom protocol +url="$1" + +file_path="${url#myfile://}" +file_path="${file_path/\~/$HOME}" +xdg-open "$file_path" diff --git a/public/.local/bin/network_control.sh b/public/.local/bin/network_control.sh new file mode 100755 index 0000000..4dc4b38 --- /dev/null +++ b/public/.local/bin/network_control.sh @@ -0,0 +1,53 @@ +#!/bin/bash + +signal=30 + +# signal dwmblocks to update network block +send_signal() { + pkill -RTMIN+$signal dwmblocks +} + +toggle_wifi() { + status=$(nmcli radio wifi) + + if [ "$status" = "enabled" ]; then + nmcli radio wifi off + else + nmcli radio wifi on + fi +} + +# This one is hard because it requires root, and the VPN interface name +# 2 ways to toggle, using systemctl, or wg-quick(1) +# This one might be better controled through a `dmenu` script. +toggle_vpn() { + : +} + +toggle_network_quarantine() { + # Check the status of all wireless devices + if rfkill list | grep -q "Soft blocked: no"; then + # not all blocked + rfkill block all + else + # all blocked + rfkill unblock all + fi +} + +# WIP +toggle_bluetooth() { + : +} + +case $1 in + wifitoggle) toggle_wifi ;; + vpntoggle) toggle_vpn ;; + bluetoothtoggle) toggle_bluetooth ;; + isolatetoggle) toggle_network_quarantine ;; + *) + echo "invalid option :)" + ;; +esac + +send_signal diff --git a/public/.local/bin/ocrthis.sh b/public/.local/bin/ocrthis.sh new file mode 100755 index 0000000..3010a6a --- /dev/null +++ b/public/.local/bin/ocrthis.sh @@ -0,0 +1,20 @@ +#!/bin/bash + +# Creates and OCR PDF out of an image +# (OCR limited to printed characters (handwriting or photograph OCR is bad, if +# any) +# +# Alternatively use `tesseract FILE text` + +if [ $# -ne 1 ]; then + echo "Usage: $(basename "$0") input_file" + # (there is `basename` and `dirname`) + exit 1 +fi + +b="$(basename "$1")" +convert "$1" "${b}.pdf" +# TODO: some contrast enhancement step would help. If text has low contrast +# with background (e.g., blue on black, green on black), then OCR fails. +ocrmypdf "${b}.pdf" "${b}.ocr.pdf" +mv -f "${b}.ocr.pdf" "${b}.pdf" diff --git a/public/.local/bin/rename_pictures.sh b/public/.local/bin/rename_pictures.sh new file mode 100755 index 0000000..a3f2463 --- /dev/null +++ b/public/.local/bin/rename_pictures.sh @@ -0,0 +1,16 @@ +#!/bin/bash + +# Very specific script to bulk rename pictures with some format +# (complex script for a simple task) + +exit # just in case + +shopt -s nullglob +for file in ss_*.png; do + date_part="${file:3:8}" + time_part="${file:12:6}" + new_name="ss-${date_part}T${time_part}0500.png" + + mv "$file" "$new_name" +done +shopt -u nullglob diff --git a/public/.local/bin/sb-audio b/public/.local/bin/sb-audio new file mode 100755 index 0000000..87ce7d7 --- /dev/null +++ b/public/.local/bin/sb-audio @@ -0,0 +1,35 @@ +#!/bin/sh + +# Prints the current volume and 🔇 if muted. + +case $BLOCK_BUTTON in + 1) setsid -w -f "$TERMINAL" -e pulsemixer; pkill -RTMIN+10 "${STATUSBAR:-dwmblocks}" ;; + 2) wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle ;; + 4) wpctl set-volume @DEFAULT_AUDIO_SINK@ 1%+ ;; + 5) wpctl set-volume @DEFAULT_AUDIO_SINK@ 1%- ;; + 3) notify-send "📢 Volume module" "\- Shows volume 🔊, 🔇 if muted. +- Middle click to mute. +- Scroll to change." ;; + 6) "$TERMINAL" -e "$EDITOR" "$0" ;; +esac + +#vol="$(wpctl get-volume @DEFAULT_AUDIO_SINK@)" + +vol="$(pactl get-sink-volume @DEFAULT_SINK@ | awk '/Volume/ { gsub(/%/,"",$5); print $5 }')" +micvol="$(pactl get-source-volume @DEFAULT_SOURCE@ | awk '/Volume/ { gsub(/%/,"",$5); print $5 }')" + +case 1 in + $((vol >= 70)) ) icon="🔊" ;; + $((vol >= 30)) ) icon="🔉" ;; + * ) icon="🔈" ;; +esac + +if pactl get-sink-mute @DEFAULT_SINK@ | grep -q yes; then + icon="🔇" +fi + +if pactl get-source-mute @DEFAULT_SOURCE@ | grep -q no; then + icon="🎤$micvol%"$icon +fi + +echo "$icon$vol%" diff --git a/public/.local/bin/sb-battery b/public/.local/bin/sb-battery new file mode 100755 index 0000000..93cbe08 --- /dev/null +++ b/public/.local/bin/sb-battery @@ -0,0 +1,37 @@ +#!/bin/sh + +# Prints all batteries, their percentage remaining and an emoji corresponding +# to charge status (🔌 for plugged up, 🔋 for discharging on battery, etc.). + +case $BLOCK_BUTTON in + 3) notify-send "🔋 Battery module" "🔋: discharging +🛑: not charging +♻: stagnant charge +🔌: charging +⚡: charged +❗: battery very low! +- Scroll to change adjust xbacklight." ;; + 4) xbacklight -inc 10 ;; + 5) xbacklight -dec 10 ;; + 6) "$TERMINAL" -e "$EDITOR" "$0" ;; +esac + +# Loop through all attached batteries and format the info +for battery in /sys/class/power_supply/BAT?*; do + # If non-first battery, print a space separator. + [ -n "${capacity+x}" ] && printf " " + # Sets up the status and capacity + case "$(cat "$battery/status" 2>&1)" in + "Full") status="⚡" ;; + "Discharging") status="🔋" ;; + "Charging") status="🔌" ;; + "Not charging") status="🛑" ;; + "Unknown") status="♻️" ;; + *) exit 1 ;; + esac + capacity="$(cat "$battery/capacity" 2>&1)" + # Will make a warn variable if discharging and low + [ "$status" = "🔋" ] && [ "$capacity" -le 25 ] && warn="❗" + # Prints the info + printf "%s%s%d%%" "$status" "$warn" "$capacity"; unset warn +done && printf "\\n" diff --git a/public/.local/bin/sb-input b/public/.local/bin/sb-input new file mode 100755 index 0000000..4fb1575 --- /dev/null +++ b/public/.local/bin/sb-input @@ -0,0 +1,9 @@ +#!/bin/bash + +icon="🌐" +layout="$(setxkbmap -query | grep layout | awk '{print $2}')" + +# fcitx state, 0 for close, 1 for inactive, 2 for active +test $(fcitx5-remote) = 2 && layout="日本語" + +echo $icon$layout diff --git a/public/.local/bin/sb-network b/public/.local/bin/sb-network new file mode 100755 index 0000000..0bdbe82 --- /dev/null +++ b/public/.local/bin/sb-network @@ -0,0 +1,52 @@ +#!/bin/sh + +# Prints some network connectivity status in emoji + +case $BLOCK_BUTTON in + 1) setsid -w -f "$TERMINAL" -e pulsemixer; pkill -RTMIN+10 "${STATUSBAR:-dwmblocks}" ;; + 2) wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle ;; + 4) wpctl set-volume @DEFAULT_AUDIO_SINK@ 1%+ ;; + 5) wpctl set-volume @DEFAULT_AUDIO_SINK@ 1%- ;; + 3) notify-send "📢 Volume module" "\- Shows volume 🔊, 🔇 if muted. +- Middle click to mute. +- Scroll to change." ;; + 6) "$TERMINAL" -e "$EDITOR" "$0" ;; +esac + + +set_wlan() { + nmcli_status=$(nmcli -t -f TYPE,STATE connection show --active) + wifi=$(echo $nmcli_status | grep -q "802-11-wireless:activated" && echo "📶") + vpn=$(echo $nmcli_status | grep -q "wireguard:activated" && echo "🔒") + wlan="$wifi$vpn" +} + + +set_bt() { + # If bluetooth is on, show number of connected devices and their initials + if ! bluetoothctl show | grep -q "Powered: yes"; then return; fi + ds=$(bluetoothctl devices Connected | cut -d ' ' -f 3-) + if [ -z "$ds" ]; then + bt=$(echo "🦷") + return + fi + N=$(echo "$ds" | wc -l) + ds=$(echo "$ds" | cut -c 1-3 | paste -sd ",") + bt=$(echo "🦷$N:$ds") +} + + +check_network_quarantine() { + # If all wireless devices are (software) blocked, + # change status bar icon and exit + if ! rfkill list | grep -q "Soft blocked: no"; then + echo "🗿" + exit + fi +} + + +check_network_quarantine +set_wlan +set_bt +echo "$wlan$bt" diff --git a/public/.local/bin/scan_loop.sh b/public/.local/bin/scan_loop.sh new file mode 100755 index 0000000..722e63d --- /dev/null +++ b/public/.local/bin/scan_loop.sh @@ -0,0 +1,33 @@ +#!/bin/bash + +# The scan loop is useful when Automatic Document Feeder (ADF) can't be used + +scan_device_uri="hpaio:/net/OfficeJet_Pro_6970?ip=192.168.18.21" +# ^This HP printer is remarkable. It's been working fine since 2017. I refill +# the cardridge with UV ink very easily (I've never purchased ink cardridges +# other than the ones that came with the printer). As of 2023, only the Cyan +# and Black cardridges/inkjets work but Black&White print is all I need. +# And the Linux support and CLI interface is amazing. + + +# Automatic Document Feeder +adf() { + hp-scan --mode=color --resolution=300 --size=a4 --adf #--duplex +} + + +# Scans until terminated with ^C. Saves .png files on CWD. +flatbed_loop() { + echo "Warning: scan loop will run until terminated with Ctrl-C" + i=0 + while true; do + # device show with $ hp-info + hp-scan --mode=color --size=a4 --device=$scan_device_uri + echo "page " $((i + 1)) " done, you have 4 seconds to load next page" + sleep 4 + i=$((expr $i + 1)) + done + # convert *.png output.pdf +} + +flatbed_loop diff --git a/public/.local/bin/screenshot.sh b/public/.local/bin/screenshot.sh new file mode 100755 index 0000000..be4a8f9 --- /dev/null +++ b/public/.local/bin/screenshot.sh @@ -0,0 +1,21 @@ +#!/bin/bash + +# Takes a screenshot and saves it + +# Inspired by Denshi's screenshot script (https://git.denshi.org/Scripts/tree/screenshot). +# See also https://www.youtube.com/watch?v=uYNTFg3_QaY&t=243s + +savepath="$HOME/media/Pictures/Screenshots" +filename="$HOSTNAME-$(date -Iseconds | tr -d ':-').png" + +if [ "$1" == "screen" ]; then + # capture the screen determined by the cursor location + shotgun -s "$savepath/$filename" +elif [ "$1" == "screens" ]; then + # TODO: This is not currently possible with shotgun 2.5.1 + : +else + # capture a region of the screen + shotgun -g $(hacksaw) "$savepath/$filename" +fi + diff --git a/public/.local/bin/screenshot_ocr.sh b/public/.local/bin/screenshot_ocr.sh new file mode 100755 index 0000000..d88accf --- /dev/null +++ b/public/.local/bin/screenshot_ocr.sh @@ -0,0 +1,29 @@ +#!/bin/bash + +# Select a region of the screen and perform OCR to it. Save text in clipboard. + +savepath="/tmp/screenshot_ocr.sh.d" +filename="$HOSTNAME-$(date -Iseconds | tr -d ':-').png" +# German: deu, Spanish: spa, Japanese vertical: jpn_vert +tesseract_options="-l eng+jpn" + +_init() { + if [ ! -d "$savepath" ]; then + mkdir -p "$savepath" + fi + cd "$savepath" +} + +_init +# Screenshot region of screen +shotgun -g $(hacksaw) "$filename" +# Exit if previous command was unsuccessful +test $? -ne 0 && exit +# Try to scan codes from the image +zbarimg $filename | xclip -selection "clipboard" +# Perform OCR and save to clipboard +tesseract $tesseract_options $filename - | xclip -selection "clipboard" +rm $filename + +# TODO: clean japanese output. If text is 80% japanese characters, then it +# should not contain spaces around the characters. diff --git a/public/.local/bin/setbg.sh b/public/.local/bin/setbg.sh new file mode 100755 index 0000000..78cdb2d --- /dev/null +++ b/public/.local/bin/setbg.sh @@ -0,0 +1,9 @@ +#!/bin/bash + +# Sets the background (Suckless setup) + +bgfile="$HOME/media/Pictures/Wallpapers/landscapes/japan/Lake_Kawaguchiko_Sakura_Mount_Fuji_3.jpg" +bgfile2="$HOME/media/Pictures/Wallpapers/mine/IMG_20200706_190712.jpg" + +xwallpaper --output eDP --zoom "$bgfile" +xwallpaper --output HDMI-A-0 --zoom "$bgfile2" diff --git a/public/.local/bin/setup_default_apps.sh b/public/.local/bin/setup_default_apps.sh new file mode 100755 index 0000000..9c58b95 --- /dev/null +++ b/public/.local/bin/setup_default_apps.sh @@ -0,0 +1,31 @@ +#!/bin/bash + +# Set defaults for xdg-open +# +# For a list of MIME types see https://www.iana.org/assignments/media-types/media-types.xhtml + +# Useful commands: +# xdg-mime query filetype FILE +# xdg-mime query default MIMETYPE + +# File +#pcmanfm + +# Image +xdg-mime default nsxiv.desktop image/bmp image/gif image/jpeg image/jpg image/png image/tiff image/x-bmp image/x-portable-anymap image/x-portable-bitmap image/x-portable-graymap image/x-tga image/x-xpixmap image/webp image/heic image/svg+xml application/postscript image/jp2 image/jxl image/avif image/heif + +# Video +#xdg-mime default mpv.desktop A_LOT_OF_MIME_TYPES + +# Mail +#thunderbird + +# Office +xdg-mime default org.pwmt.zathura.desktop application/pdf application/postscript image/vnd.djvu application/epub+zip +#libreoffice + +# Text +xdg-mime default nvim.desktop text/plain + +# Net +xdg-mime default org.qbittorrent.qBittorrent.desktop application/x-bittorrent x-scheme-handler/magnet diff --git a/public/.local/bin/updatewebsite.sh b/public/.local/bin/updatewebsite.sh new file mode 100755 index 0000000..71c99b2 --- /dev/null +++ b/public/.local/bin/updatewebsite.sh @@ -0,0 +1,9 @@ +#!/bin/bash + +# This script syncs local files to my VPS + +# Thank you: https://unix.stackexchange.com/a/2503/347754 +options="-uvrPs --delete-after --copy-links" +targetdir="tokumori.xyz:/var/www" + +rsync $options /home/mitsuo/mahcode/www/tokumori.xyz $targetdir -- cgit v1.2.3