mirror of
https://github.com/LukeSmithxyz/voidrice.git
synced 2026-01-30 09:48:11 +01:00
Merge upstream
This commit is contained in:
commit
68c82a1e10
47
.config/firefox/larbs.js
Normal file
47
.config/firefox/larbs.js
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
// These are changes made on top of the Arkenfox JS file to tweak it as
|
||||||
|
// desired. Any of these settings can be overridden by the user.
|
||||||
|
|
||||||
|
// Disable the Twitter/R*ddit/Faceberg ads in the URL bar:
|
||||||
|
user_pref("browser.urlbar.quicksuggest.enabled", false);
|
||||||
|
user_pref("browser.urlbar.suggest.topsites", false); // [FF78+]
|
||||||
|
|
||||||
|
// Do not suggest web history in the URL bar:
|
||||||
|
user_pref("browser.urlbar.suggest.history", false);
|
||||||
|
|
||||||
|
// Do not prefil forms:
|
||||||
|
user_pref("signon.prefillForms", false);
|
||||||
|
|
||||||
|
// Do not autocomplete in the URL bar:
|
||||||
|
user_pref("browser.urlbar.autoFill", false);
|
||||||
|
|
||||||
|
// Enable the addition of search keywords:
|
||||||
|
user_pref("keyword.enabled", true);
|
||||||
|
|
||||||
|
// Allow access to http (i.e. not https) sites:
|
||||||
|
user_pref("dom.security.https_only_mode", false);
|
||||||
|
|
||||||
|
// Keep cookies until expiration or user deletion:
|
||||||
|
user_pref("network.cookie.lifetimePolicy", 0);
|
||||||
|
|
||||||
|
user_pref("dom.webnotifications.serviceworker.enabled", false);
|
||||||
|
|
||||||
|
// Disable push notifications:
|
||||||
|
user_pref("dom.push.enabled", false);
|
||||||
|
|
||||||
|
// Disable the pocket antifeature:
|
||||||
|
user_pref("extensions.pocket.enabled", false);
|
||||||
|
|
||||||
|
// Don't autodelete cookies on shutdown:
|
||||||
|
user_pref("privacy.clearOnShutdown.cookies", false);
|
||||||
|
|
||||||
|
// Enable custom userChrome.js:
|
||||||
|
user_pref("toolkit.legacyUserProfileCustomizations.stylesheets", true);
|
||||||
|
|
||||||
|
// This could otherwise cause some issues on bank logins and other annoying sites:
|
||||||
|
user_pref("network.http.referer.XOriginPolicy", 0);
|
||||||
|
|
||||||
|
// Disable Firefox sync and its menu entries
|
||||||
|
user_pref("identity.fxaccounts.enabled", false);
|
||||||
|
|
||||||
|
// Fix the issue where right mouse button instantly clicks
|
||||||
|
user_pref("ui.context_menus.after_mouseup", true);
|
||||||
@ -4,32 +4,36 @@
|
|||||||
<alias>
|
<alias>
|
||||||
<family>serif</family>
|
<family>serif</family>
|
||||||
<prefer>
|
<prefer>
|
||||||
<family>Linux Libertine</family>
|
<family>Libertinus Serif</family>
|
||||||
<family>Joy Pixels</family>
|
<family>Joy Pixels</family>
|
||||||
<family>Noto Color Emoji</family>
|
<family>Noto Color Emoji</family>
|
||||||
|
<family>FontAwesome</family>
|
||||||
</prefer>
|
</prefer>
|
||||||
</alias>
|
</alias>
|
||||||
<alias>
|
<alias>
|
||||||
<family>sans-serif</family>
|
<family>sans-serif</family>
|
||||||
<prefer>
|
<prefer>
|
||||||
<family>Linux Biolinum</family>
|
<family>Libertinus Sans</family>
|
||||||
<family>Joy Pixels</family>
|
<family>Joy Pixels</family>
|
||||||
<family>Noto Color Emoji</family>
|
<family>Noto Color Emoji</family>
|
||||||
|
<family>FontAwesome</family>
|
||||||
</prefer>
|
</prefer>
|
||||||
</alias>
|
</alias>
|
||||||
<alias>
|
<alias>
|
||||||
<family>sans</family>
|
<family>sans</family>
|
||||||
<prefer>
|
<prefer>
|
||||||
<family>Linux Biolinum</family>
|
<family>Libertinus Sans</family>
|
||||||
<family>Joy Pixels</family>
|
<family>Joy Pixels</family>
|
||||||
<family>Noto Color Emoji</family>
|
<family>Noto Color Emoji</family>
|
||||||
|
<family>FontAwesome</family>
|
||||||
</prefer>
|
</prefer>
|
||||||
</alias>
|
</alias>
|
||||||
<alias>
|
<alias>
|
||||||
<family>monospace</family>
|
<family>monospace</family>
|
||||||
<prefer>
|
<prefer>
|
||||||
<family>Noto Sans Mono</family>
|
<family>Noto Sans Mono</family>
|
||||||
<family>Liberation Mono</family>
|
<family>Libertinus Mono</family>
|
||||||
|
<family>FontAwesome</family>
|
||||||
<family>Braille</family>
|
<family>Braille</family>
|
||||||
</prefer>
|
</prefer>
|
||||||
</alias>
|
</alias>
|
||||||
|
|||||||
77
.config/lf/icons
Normal file
77
.config/lf/icons
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
di 📁
|
||||||
|
fi 📃
|
||||||
|
tw 🤝
|
||||||
|
ow 📂
|
||||||
|
ln ⛓
|
||||||
|
or ❌
|
||||||
|
ex 🎯
|
||||||
|
*.txt ✍
|
||||||
|
*.mom ✍
|
||||||
|
*.me ✍
|
||||||
|
*.ms ✍
|
||||||
|
*.avif 🖼
|
||||||
|
*.png 🖼
|
||||||
|
*.webp 🖼
|
||||||
|
*.ico 🖼
|
||||||
|
*.jpg 📸
|
||||||
|
*.jpe 📸
|
||||||
|
*.jpeg 📸
|
||||||
|
*.gif 🖼
|
||||||
|
*.svg 🗺
|
||||||
|
*.tif 🖼
|
||||||
|
*.tiff 🖼
|
||||||
|
*.xcf 🖌
|
||||||
|
*.html 🌎
|
||||||
|
*.xml 📰
|
||||||
|
*.gpg 🔒
|
||||||
|
*.css 🎨
|
||||||
|
*.pdf 📚
|
||||||
|
*.djvu 📚
|
||||||
|
*.epub 📚
|
||||||
|
*.csv 📓
|
||||||
|
*.xlsx 📓
|
||||||
|
*.tex 📜
|
||||||
|
*.md 📘
|
||||||
|
*.r 📊
|
||||||
|
*.R 📊
|
||||||
|
*.rmd 📊
|
||||||
|
*.Rmd 📊
|
||||||
|
*.m 📊
|
||||||
|
*.mp3 🎵
|
||||||
|
*.opus 🎵
|
||||||
|
*.ogg 🎵
|
||||||
|
*.m4a 🎵
|
||||||
|
*.flac 🎼
|
||||||
|
*.wav 🎼
|
||||||
|
*.mkv 🎥
|
||||||
|
*.mp4 🎥
|
||||||
|
*.webm 🎥
|
||||||
|
*.mpeg 🎥
|
||||||
|
*.avi 🎥
|
||||||
|
*.mov 🎥
|
||||||
|
*.mpg 🎥
|
||||||
|
*.wmv 🎥
|
||||||
|
*.m4b 🎥
|
||||||
|
*.flv 🎥
|
||||||
|
*.zip 📦
|
||||||
|
*.rar 📦
|
||||||
|
*.7z 📦
|
||||||
|
*.tar 📦
|
||||||
|
*.z64 🎮
|
||||||
|
*.v64 🎮
|
||||||
|
*.n64 🎮
|
||||||
|
*.gba 🎮
|
||||||
|
*.nes 🎮
|
||||||
|
*.gdi 🎮
|
||||||
|
*.1 ℹ
|
||||||
|
*.nfo ℹ
|
||||||
|
*.info ℹ
|
||||||
|
*.log 📙
|
||||||
|
*.iso 📀
|
||||||
|
*.img 📀
|
||||||
|
*.bib 🎓
|
||||||
|
*.ged 👪
|
||||||
|
*.part 💔
|
||||||
|
*.torrent 🔽
|
||||||
|
*.jar ♨
|
||||||
|
*.java ♨
|
||||||
170
.config/lf/lfrc
170
.config/lf/lfrc
@ -1,2 +1,168 @@
|
|||||||
set previewer ~/.config/lf/preview
|
# Luke's lf settings
|
||||||
set cleaner ~/.config/lf/cleaner
|
|
||||||
|
|
||||||
|
# Note on Image Previews
|
||||||
|
# For those wanting image previews, like this system, there are four steps to
|
||||||
|
# set it up. These are done automatically for LARBS users, but I will state
|
||||||
|
# them here for others doing it manually.
|
||||||
|
#
|
||||||
|
# 1. ueberzug must be installed.
|
||||||
|
# 2. The scope file (~/.config/lf/scope for me), must have a command similar to
|
||||||
|
# mine to generate ueberzug images.
|
||||||
|
# 3. A `set cleaner` line as below is a cleaner script.
|
||||||
|
# 4. lf should be started through a wrapper script (~/.local/bin/lfub for me)
|
||||||
|
# that creates the environment for ueberzug. This command can be be aliased
|
||||||
|
# in your shellrc (`alias lf="lfub") or if set to a binding, should be
|
||||||
|
# called directly instead of normal lf.
|
||||||
|
|
||||||
|
# Basic vars
|
||||||
|
set shellopts '-eu'
|
||||||
|
set ifs "\n"
|
||||||
|
set scrolloff 10
|
||||||
|
set icons
|
||||||
|
set period 1
|
||||||
|
set hiddenfiles ".*:*.aux:*.log:*.bbl:*.bcf:*.blg:*.run.xml"
|
||||||
|
set cleaner '~/.config/lf/cleaner'
|
||||||
|
set previewer '~/.config/lf/scope'
|
||||||
|
set autoquit true
|
||||||
|
|
||||||
|
# cmds/functions
|
||||||
|
cmd open ${{
|
||||||
|
case $(file --mime-type "$(readlink -f $f)" -b) in
|
||||||
|
application/vnd.openxmlformats-officedocument.spreadsheetml.sheet) localc $fx ;;
|
||||||
|
image/vnd.djvu|application/pdf|application/octet-stream|application/postscript) setsid -f zathura $fx >/dev/null 2>&1 ;;
|
||||||
|
text/*|application/json|inode/x-empty|application/x-subrip) $EDITOR $fx;;
|
||||||
|
image/x-xcf) setsid -f gimp $f >/dev/null 2>&1 ;;
|
||||||
|
image/svg+xml) display -- $f ;;
|
||||||
|
image/*) rotdir $f | grep -i "\.\(png\|jpg\|jpeg\|gif\|webp\|avif\|tif\|ico\)\(_large\)*$" |
|
||||||
|
setsid -f nsxiv -aio 2>/dev/null | while read -r file; do
|
||||||
|
[ -z "$file" ] && continue
|
||||||
|
lf -remote "send select \"$file\""
|
||||||
|
lf -remote "send toggle"
|
||||||
|
done &
|
||||||
|
;;
|
||||||
|
audio/*|video/x-ms-asf) mpv --audio-display=no $f ;;
|
||||||
|
video/*) setsid -f mpv $f -quiet >/dev/null 2>&1 ;;
|
||||||
|
application/pdf|application/vnd.djvu|application/epub*) setsid -f zathura $fx >/dev/null 2>&1 ;;
|
||||||
|
application/pgp-encrypted) $EDITOR $fx ;;
|
||||||
|
application/vnd.openxmlformats-officedocument.wordprocessingml.document|application/vnd.oasis.opendocument.text|application/vnd.openxmlformats-officedocument.spreadsheetml.sheet|application/octet-stream|application/vnd.oasis.opendocument.spreadsheet|application/vnd.oasis.opendocument.spreadsheet-template|application/vnd.openxmlformats-officedocument.presentationml.presentation|application/vnd.oasis.opendocument.presentation-template|application/vnd.oasis.opendocument.presentation|application/vnd.ms-powerpoint|application/vnd.oasis.opendocument.graphics|application/vnd.oasis.opendocument.graphics-template|application/vnd.oasis.opendocument.formula|application/vnd.oasis.opendocument.database) setsid -f libreoffice $fx >/dev/null 2>&1 ;;
|
||||||
|
*) for f in $fx; do setsid -f $OPENER $f >/dev/null 2>&1; done;;
|
||||||
|
esac
|
||||||
|
}}
|
||||||
|
|
||||||
|
cmd mkdir $mkdir -p "$@"
|
||||||
|
|
||||||
|
cmd extract ${{
|
||||||
|
clear; tput cup $(($(tput lines)/3)); tput bold
|
||||||
|
set -f
|
||||||
|
printf "%s\n\t" "$fx"
|
||||||
|
printf "extract?[y/N]"
|
||||||
|
read ans
|
||||||
|
[ $ans = "y" ] && {
|
||||||
|
case $fx in
|
||||||
|
*.tar.bz2) tar xjf $fx ;;
|
||||||
|
*.tar.gz) tar xzf $fx ;;
|
||||||
|
*.bz2) bunzip2 $fx ;;
|
||||||
|
*.rar) unrar e $fx ;;
|
||||||
|
*.gz) gunzip $fx ;;
|
||||||
|
*.tar) tar xf $fx ;;
|
||||||
|
*.tbz2) tar xjf $fx ;;
|
||||||
|
*.tgz) tar xzf $fx ;;
|
||||||
|
*.zip) unzip $fx ;;
|
||||||
|
*.Z) uncompress $fx ;;
|
||||||
|
*.7z) 7z x $fx ;;
|
||||||
|
*.tar.xz) tar xf $fx ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
|
||||||
|
cmd delete ${{
|
||||||
|
clear; tput cup $(($(tput lines)/3)); tput bold
|
||||||
|
set -f
|
||||||
|
printf "%s\n\t" "$fx"
|
||||||
|
printf "delete?[y/N]"
|
||||||
|
read ans
|
||||||
|
[ $ans = "y" ] && rm -rf -- $fx
|
||||||
|
}}
|
||||||
|
|
||||||
|
cmd moveto ${{
|
||||||
|
clear; tput cup $(($(tput lines)/3)); tput bold
|
||||||
|
set -f
|
||||||
|
clear; echo "Move to where?"
|
||||||
|
dest="$(sed -e 's/\s*#.*//' -e '/^$/d' -e 's/^\S*\s*//' ${XDG_CONFIG_HOME:-$HOME/.config}/shell/bm-dirs | fzf | sed 's|~|$HOME|')" &&
|
||||||
|
for x in $fx; do
|
||||||
|
eval mv -iv \"$x\" \"$dest\"
|
||||||
|
done &&
|
||||||
|
notify-send "🚚 File(s) moved." "File(s) moved to $dest."
|
||||||
|
}}
|
||||||
|
|
||||||
|
cmd copyto ${{
|
||||||
|
clear; tput cup $(($(tput lines)/3)); tput bold
|
||||||
|
set -f
|
||||||
|
clear; echo "Copy to where?"
|
||||||
|
dest="$(sed -e 's/\s*#.*//' -e '/^$/d' -e 's/^\S*\s*//' ${XDG_CONFIG_HOME:-$HOME/.config}/shell/bm-dirs | fzf | sed 's|~|$HOME|')" &&
|
||||||
|
for x in $fx; do
|
||||||
|
eval cp -ivr \"$x\" \"$dest\"
|
||||||
|
done &&
|
||||||
|
notify-send "📋 File(s) copied." "File(s) copies to $dest."
|
||||||
|
}}
|
||||||
|
|
||||||
|
cmd setbg "$1"
|
||||||
|
|
||||||
|
cmd bulkrename ${{
|
||||||
|
tmpfile_old="$(mktemp)"
|
||||||
|
tmpfile_new="$(mktemp)"
|
||||||
|
|
||||||
|
[ -n "$fs" ] && fs=$(basename -a $fs) || fs=$(ls)
|
||||||
|
|
||||||
|
echo "$fs" > "$tmpfile_old"
|
||||||
|
echo "$fs" > "$tmpfile_new"
|
||||||
|
$EDITOR "$tmpfile_new"
|
||||||
|
|
||||||
|
[ "$(wc -l < "$tmpfile_old")" -eq "$(wc -l < "$tmpfile_new")" ] || { rm -f "$tmpfile_old" "$tmpfile_new"; exit 1; }
|
||||||
|
|
||||||
|
paste "$tmpfile_old" "$tmpfile_new" | while IFS="$(printf '\t')" read -r src dst
|
||||||
|
do
|
||||||
|
[ "$src" = "$dst" ] || [ -e "$dst" ] || mv -- "$src" "$dst"
|
||||||
|
done
|
||||||
|
|
||||||
|
rm -f "$tmpfile_old" "$tmpfile_new"
|
||||||
|
lf -remote "send $id unselect"
|
||||||
|
}}
|
||||||
|
|
||||||
|
# Bindings
|
||||||
|
map <c-f> $lf -remote "send $id select \"$(fzf)\""
|
||||||
|
map J $lf -remote "send $id cd $(sed -e 's/\s*#.*//' -e '/^$/d' -e 's/^\S*\s*//' ${XDG_CONFIG_HOME:-$HOME/.config}/shell/bm-dirs | fzf)"
|
||||||
|
map gh
|
||||||
|
map g top
|
||||||
|
map D delete
|
||||||
|
map E extract
|
||||||
|
map C copyto
|
||||||
|
map M moveto
|
||||||
|
map <c-n> push :mkdir<space>""<left>
|
||||||
|
map <c-r> reload
|
||||||
|
map <c-s> set hidden!
|
||||||
|
map <enter> shell
|
||||||
|
map x $$f
|
||||||
|
map X !$f
|
||||||
|
map o &mimeopen "$f"
|
||||||
|
map O $mimeopen --ask "$f"
|
||||||
|
|
||||||
|
map A :rename; cmd-end # at the very end
|
||||||
|
map c push A<c-u> # new rename
|
||||||
|
map I :rename; cmd-home # at the very beginning
|
||||||
|
map i :rename # before extension
|
||||||
|
map a :rename; cmd-right # after extension
|
||||||
|
map B bulkrename
|
||||||
|
map b $setbg $f
|
||||||
|
|
||||||
|
map <c-e> down
|
||||||
|
map <c-y> up
|
||||||
|
map V push :!nvim<space>
|
||||||
|
|
||||||
|
map W $setsid -f $TERMINAL >/dev/null 2>&1
|
||||||
|
|
||||||
|
map Y $printf "%s" "$fx" | xclip -selection clipboard
|
||||||
|
|
||||||
|
# Source Bookmarks
|
||||||
|
source "~/.config/lf/shortcutrc"
|
||||||
|
|||||||
@ -13,20 +13,27 @@ image() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
ifub() {
|
|
||||||
[ -n "$DISPLAY" ] && [ -z "$WAYLAND_DISPLAY" ] && command -V ueberzug >/dev/null 2>&1
|
|
||||||
}
|
|
||||||
|
|
||||||
# Note that the cache file name is a function of file information, meaning if
|
# Note that the cache file name is a function of file information, meaning if
|
||||||
# an image appears in multiple places across the machine, it will not have to
|
# an image appears in multiple places across the machine, it will not have to
|
||||||
# be regenerated once seen.
|
# be regenerated once seen.
|
||||||
|
|
||||||
case "$(file --dereference --brief --mime-type -- "$1")" in
|
case "$(file --dereference --brief --mime-type -- "$1")" in
|
||||||
|
image/avif) CACHE="${XDG_CACHE_HOME:-$HOME/.cache}/lf/thumb.$(stat --printf '%n\0%i\0%F\0%s\0%W\0%Y' -- "$(readlink -f "$1")" | sha256sum | cut -d' ' -f1)"
|
||||||
|
[ ! -f "$CACHE" ] && convert "$1" "$CACHE.jpg"
|
||||||
|
image "$CACHE.jpg" "$2" "$3" "$4" "$5" "$1" ;;
|
||||||
|
image/vnd.djvu)
|
||||||
|
CACHE="${XDG_CACHE_HOME:-$HOME/.cache}/lf/thumb.$(stat --printf '%n\0%i\0%F\0%s\0%W\0%Y' -- "$(readlink -f "$1")" | sha256sum | cut -d' ' -f1)"
|
||||||
|
[ ! -f "$CACHE" ] && djvused "$1" -e 'select 1; save-page-with /dev/stdout' | convert -density 200 - "$CACHE.jpg" > /dev/null 2>&1
|
||||||
|
image "$CACHE.jpg" "$2" "$3" "$4" "$5" "$1" ;;
|
||||||
|
image/svg+xml)
|
||||||
|
CACHE="${XDG_CACHE_HOME:-$HOME/.cache}/lf/thumb.$(stat --printf '%n\0%i\0%F\0%s\0%W\0%Y' -- "$(readlink -f "$1")" | sha256sum | cut -d' ' -f1)"
|
||||||
|
[ ! -f "$CACHE" ] && inkscape --convert-dpi-method=none -o "$CACHE.png" --export-overwrite -D --export-png-color-mode=RGBA_16 "$1"
|
||||||
|
image "$CACHE.png" "$2" "$3" "$4" "$5" "$1"
|
||||||
|
;;
|
||||||
image/*) image "$1" "$2" "$3" "$4" "$5" "$1" ;;
|
image/*) image "$1" "$2" "$3" "$4" "$5" "$1" ;;
|
||||||
text/html) lynx -width="$4" -display_charset=utf-8 -dump "$1" ;;
|
text/html) lynx -width="$4" -display_charset=utf-8 -dump "$1" ;;
|
||||||
text/troff) man ./ "$1" | col -b ;;
|
text/troff) man ./ "$1" | col -b ;;
|
||||||
text/* | */xml | application/json) bat --terminal-width "$(($4-2))" -f "$1" ;;
|
text/* | */xml | application/json | application/x-ndjson) bat -p --theme ansi --terminal-width "$(($4-2))" -f "$1" ;;
|
||||||
application/zip) atool --list -- "$1" ;;
|
|
||||||
audio/* | application/octet-stream) mediainfo "$1" || exit 1 ;;
|
audio/* | application/octet-stream) mediainfo "$1" || exit 1 ;;
|
||||||
video/* )
|
video/* )
|
||||||
CACHE="${XDG_CACHE_HOME:-$HOME/.cache}/lf/thumb.$(stat --printf '%n\0%i\0%F\0%s\0%W\0%Y' -- "$(readlink -f "$1")" | sha256sum | cut -d' ' -f1)"
|
CACHE="${XDG_CACHE_HOME:-$HOME/.cache}/lf/thumb.$(stat --printf '%n\0%i\0%F\0%s\0%W\0%Y' -- "$(readlink -f "$1")" | sha256sum | cut -d' ' -f1)"
|
||||||
@ -38,6 +45,12 @@ case "$(file --dereference --brief --mime-type -- "$1")" in
|
|||||||
[ ! -f "$CACHE.jpg" ] && pdftoppm -jpeg -f 1 -singlefile "$1" "$CACHE"
|
[ ! -f "$CACHE.jpg" ] && pdftoppm -jpeg -f 1 -singlefile "$1" "$CACHE"
|
||||||
image "$CACHE.jpg" "$2" "$3" "$4" "$5" "$1"
|
image "$CACHE.jpg" "$2" "$3" "$4" "$5" "$1"
|
||||||
;;
|
;;
|
||||||
|
*/epub+zip|*/mobi*)
|
||||||
|
CACHE="${XDG_CACHE_HOME:-$HOME/.cache}/lf/thumb.$(stat --printf '%n\0%i\0%F\0%s\0%W\0%Y' -- "$(readlink -f "$1")" | sha256sum | cut -d' ' -f1)"
|
||||||
|
[ ! -f "$CACHE.jpg" ] && gnome-epub-thumbnailer "$1" "$CACHE.jpg"
|
||||||
|
image "$CACHE.jpg" "$2" "$3" "$4" "$5" "$1"
|
||||||
|
;;
|
||||||
|
application/*zip) atool --list -- "$1" ;;
|
||||||
*opendocument*) odt2txt "$1" ;;
|
*opendocument*) odt2txt "$1" ;;
|
||||||
application/pgp-encrypted) gpg -d -- "$1" ;;
|
application/pgp-encrypted) gpg -d -- "$1" ;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
20
.config/mimeapps.list
Normal file
20
.config/mimeapps.list
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
[Default Applications]
|
||||||
|
|
||||||
|
# xdg-open will use these settings to determine how to open filetypes.
|
||||||
|
# These .desktop entries can also be seen and changed in ~/.local/share/applications/
|
||||||
|
|
||||||
|
text/x-shellscript=text.desktop;
|
||||||
|
x-scheme-handler/magnet=torrent.desktop;
|
||||||
|
application/x-bittorrent=torrent.desktop;
|
||||||
|
x-scheme-handler/mailto=mail.desktop;
|
||||||
|
text/plain=text.desktop;
|
||||||
|
application/postscript=pdf.desktop;
|
||||||
|
application/pdf=pdf.desktop;
|
||||||
|
image/png=img.desktop;
|
||||||
|
image/jpeg=img.desktop;
|
||||||
|
image/gif=img.desktop;
|
||||||
|
application/rss+xml=rss.desktop
|
||||||
|
video/x-matroska=video.desktop
|
||||||
|
video/mp4=video.desktop
|
||||||
|
x-scheme-handler/lbry=lbry.desktop
|
||||||
|
inode/directory=file.desktop
|
||||||
@ -30,3 +30,5 @@ progressbar_color = black:b
|
|||||||
progressbar_elapsed_color = blue:b
|
progressbar_elapsed_color = blue:b
|
||||||
statusbar_color = red
|
statusbar_color = red
|
||||||
statusbar_time_color = cyan:b
|
statusbar_time_color = cyan:b
|
||||||
|
execute_on_song_change="pkill -RTMIN+11 dwmblocks"
|
||||||
|
execute_on_player_state_change="pkill -RTMIN+11 dwmblocks"
|
||||||
|
|||||||
@ -32,7 +32,7 @@ color article white default bold
|
|||||||
browser linkhandler
|
browser linkhandler
|
||||||
macro , open-in-browser
|
macro , open-in-browser
|
||||||
macro t set browser "qndl" ; open-in-browser ; set browser linkhandler
|
macro t set browser "qndl" ; open-in-browser ; set browser linkhandler
|
||||||
macro a set browser "tsp yt-dlp --embed-metadata -xic -f bestaudio/best" ; open-in-browser ; set browser linkhandler
|
macro a set browser "tsp yt-dlp --embed-metadata -xic -f bestaudio/best --restrict-filenames" ; open-in-browser ; set browser linkhandler
|
||||||
macro v set browser "setsid -f mpv" ; open-in-browser ; set browser linkhandler
|
macro v set browser "setsid -f mpv" ; open-in-browser ; set browser linkhandler
|
||||||
macro w set browser "lynx" ; open-in-browser ; set browser linkhandler
|
macro w set browser "lynx" ; open-in-browser ; set browser linkhandler
|
||||||
macro d set browser "dmenuhandler" ; open-in-browser ; set browser linkhandler
|
macro d set browser "dmenuhandler" ; open-in-browser ; set browser linkhandler
|
||||||
|
|||||||
@ -1,7 +1,10 @@
|
|||||||
https://lukesmith.xyz/rss.xml
|
https://lukesmith.xyz/rss.xml
|
||||||
https://notrelated.xyz/rss
|
https://videos.lukesmith.xyz/feeds/videos.xml?videoChannelId=2 "~Luke Smith (Videos)"
|
||||||
https://www.youtube.com/feeds/videos.xml?channel_id=UC2eYFnH61tmytImy1mTYvhA "~Luke Smith (YouTube)"
|
https://www.youtube.com/feeds/videos.xml?channel_id=UC2eYFnH61tmytImy1mTYvhA "~Luke Smith (YouTube)"
|
||||||
|
https://lindypress.net/rss
|
||||||
|
https://notrelated.xyz/rss
|
||||||
https://landchad.net/rss.xml
|
https://landchad.net/rss.xml
|
||||||
https://based.cooking/index.xml
|
https://based.cooking/index.xml
|
||||||
https://artixlinux.org/feed.php "tech"
|
https://artixlinux.org/feed.php "tech"
|
||||||
https://www.archlinux.org/feeds/news/ "tech"
|
https://www.archlinux.org/feeds/news/ "tech"
|
||||||
|
https://github.com/LukeSmithxyz/voidrice/commits/master.atom "~LARBS dotfiles"
|
||||||
|
|||||||
@ -4,12 +4,12 @@ do
|
|||||||
case "$1" in
|
case "$1" in
|
||||||
"w") setbg "$file" & ;;
|
"w") setbg "$file" & ;;
|
||||||
"c")
|
"c")
|
||||||
[ -z "$destdir" ] && destdir="$(sed "s/\s.*#.*$//;/^\s*$/d" ${XDG_CONFIG_HOME:-$HOME/.config}/shell/bm-dirs | awk '{print $2}' | dmenu -l 20 -i -p "Copy file(s) to where?" | sed "s|~|$HOME|g")"
|
[ -z "$destdir" ] && destdir="$(sed "s/#.*$//;/^\s*$/d" ${XDG_CONFIG_HOME:-$HOME/.config}/shell/bm-dirs | awk '{print $2}' | dmenu -l 20 -i -p "Copy file(s) to where?" | sed "s|~|$HOME|g")"
|
||||||
[ ! -d "$destdir" ] && notify-send "$destdir is not a directory, cancelled." && exit
|
[ ! -d "$destdir" ] && notify-send "$destdir is not a directory, cancelled." && exit
|
||||||
cp "$file" "$destdir" && notify-send -i "$(readlink -f "$file")" "$file copied to $destdir." &
|
cp "$file" "$destdir" && notify-send -i "$(readlink -f "$file")" "$file copied to $destdir." &
|
||||||
;;
|
;;
|
||||||
"m")
|
"m")
|
||||||
[ -z "$destdir" ] && destdir="$(sed "s/\s.*#.*$//;/^\s*$/d" ${XDG_CONFIG_HOME:-$HOME/.config}/shell/bm-dirs | awk '{print $2}' | dmenu -l 20 -i -p "Move file(s) to where?" | sed "s|~|$HOME|g")"
|
[ -z "$destdir" ] && destdir="$(sed "s/#.*$//;/^\s*$/d" ${XDG_CONFIG_HOME:-$HOME/.config}/shell/bm-dirs | awk '{print $2}' | dmenu -l 20 -i -p "Move file(s) to where?" | sed "s|~|$HOME|g")"
|
||||||
[ ! -d "$destdir" ] && notify-send "$destdir is not a directory, cancelled." && exit
|
[ ! -d "$destdir" ] && notify-send "$destdir is not a directory, cancelled." && exit
|
||||||
mv "$file" "$destdir" && notify-send -i "$(readlink -f "$file")" "$file moved to $destdir." &
|
mv "$file" "$destdir" && notify-send -i "$(readlink -f "$file")" "$file moved to $destdir." &
|
||||||
;;
|
;;
|
||||||
@ -28,6 +28,6 @@ do
|
|||||||
"d")
|
"d")
|
||||||
[ "$(printf "No\\nYes" | dmenu -i -p "Really delete $file?")" = "Yes" ] && rm "$file" && notify-send "$file deleted." ;;
|
[ "$(printf "No\\nYes" | dmenu -i -p "Really delete $file?")" = "Yes" ] && rm "$file" && notify-send "$file deleted." ;;
|
||||||
"g") ifinstalled gimp && setsid -f gimp "$file" ;;
|
"g") ifinstalled gimp && setsid -f gimp "$file" ;;
|
||||||
"i") notify-send "File information" "$(mediainfo "$file")" ;;
|
"i") notify-send "File information" "$(mediainfo "$file" | sed "s/[ ]\+:/:/g;s/: /: <b>/;s/$/<\/b>/" | grep "<b>")" ;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
@ -8,13 +8,15 @@ if ! filereadable(system('echo -n "${XDG_CONFIG_HOME:-$HOME/.config}/nvim/autolo
|
|||||||
autocmd VimEnter * PlugInstall
|
autocmd VimEnter * PlugInstall
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
map ,, :keepp /<++><CR>ca<
|
||||||
|
imap ,, <esc>:keepp /<++><CR>ca<
|
||||||
|
|
||||||
call plug#begin(system('echo -n "${XDG_CONFIG_HOME:-$HOME/.config}/nvim/plugged"'))
|
call plug#begin(system('echo -n "${XDG_CONFIG_HOME:-$HOME/.config}/nvim/plugged"'))
|
||||||
Plug 'tpope/vim-surround'
|
Plug 'tpope/vim-surround'
|
||||||
Plug 'windwp/nvim-autopairs'
|
Plug 'windwp/nvim-autopairs'
|
||||||
Plug 'preservim/nerdtree'
|
Plug 'preservim/nerdtree'
|
||||||
Plug 'junegunn/goyo.vim'
|
Plug 'junegunn/goyo.vim'
|
||||||
Plug 'jreybert/vimagit'
|
Plug 'jreybert/vimagit'
|
||||||
Plug 'lukesmithxyz/vimling'
|
|
||||||
Plug 'vimwiki/vimwiki'
|
Plug 'vimwiki/vimwiki'
|
||||||
Plug 'itchyny/lightline.vim'
|
Plug 'itchyny/lightline.vim'
|
||||||
Plug 'tpope/vim-commentary'
|
Plug 'tpope/vim-commentary'
|
||||||
@ -224,11 +226,19 @@ EOF
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
" vimling:
|
" vimling:
|
||||||
nm <leader><leader>d :call ToggleDeadKeys()<CR>
|
nm <leader>d :call ToggleDeadKeys()<CR>
|
||||||
imap <leader><leader>d <esc>:call ToggleDeadKeys()<CR>a
|
imap <leader>d <esc>:call ToggleDeadKeys()<CR>a
|
||||||
nm <leader><leader>i :call ToggleIPA()<CR>
|
nm <leader>i :call ToggleIPA()<CR>
|
||||||
imap <leader><leader>i <esc>:call ToggleIPA()<CR>a
|
imap <leader>i <esc>:call ToggleIPA()<CR>a
|
||||||
nm <leader><leader>q :call ToggleProse()<CR>
|
nm <leader>q :call ToggleProse()<CR>
|
||||||
|
|
||||||
|
" vim-airline
|
||||||
|
if !exists('g:airline_symbols')
|
||||||
|
let g:airline_symbols = {}
|
||||||
|
endif
|
||||||
|
let g:airline_symbols.colnr = ' C:'
|
||||||
|
let g:airline_symbols.linenr = ' L:'
|
||||||
|
let g:airline_symbols.maxlinenr = '☰ '
|
||||||
|
|
||||||
" Shortcutting split navigation, saving a keypress:
|
" Shortcutting split navigation, saving a keypress:
|
||||||
map <C-h> <C-w>h
|
map <C-h> <C-w>h
|
||||||
@ -250,10 +260,10 @@ EOF
|
|||||||
nnoremap S :%s//g<Left><Left>
|
nnoremap S :%s//g<Left><Left>
|
||||||
|
|
||||||
" Compile document, be it groff/LaTeX/markdown/etc.
|
" Compile document, be it groff/LaTeX/markdown/etc.
|
||||||
map <leader>c :w! \| !compiler "<c-r>%"<CR>
|
map <leader>c :w! \| !compiler "%:p"<CR>
|
||||||
|
|
||||||
" Open corresponding .pdf/.html or preview
|
" Open corresponding .pdf/.html or preview
|
||||||
map <leader>p :!opout <c-r>%<CR><CR>
|
map <leader>p :!opout "%:p"<CR>
|
||||||
|
|
||||||
" Runs a script that cleans out tex build files whenever I close out of a .tex file.
|
" Runs a script that cleans out tex build files whenever I close out of a .tex file.
|
||||||
autocmd VimLeave *.tex !texclear %
|
autocmd VimLeave *.tex !texclear %
|
||||||
@ -267,7 +277,7 @@ EOF
|
|||||||
autocmd BufRead,BufNewFile *.tex set filetype=tex
|
autocmd BufRead,BufNewFile *.tex set filetype=tex
|
||||||
|
|
||||||
" Save file as sudo on files that require root permission
|
" Save file as sudo on files that require root permission
|
||||||
cnoremap w!! execute 'silent! write !sudo tee % >/dev/null' <bar> edit!
|
cabbrev w!! execute 'silent! write !sudo tee % >/dev/null' <bar> edit!
|
||||||
|
|
||||||
" Enable Goyo by default for mutt writing
|
" Enable Goyo by default for mutt writing
|
||||||
autocmd BufRead,BufNewFile /tmp/neomutt* let g:goyo_width=80
|
autocmd BufRead,BufNewFile /tmp/neomutt* let g:goyo_width=80
|
||||||
@ -279,7 +289,8 @@ EOF
|
|||||||
autocmd BufWritePre * let currPos = getpos(".")
|
autocmd BufWritePre * let currPos = getpos(".")
|
||||||
autocmd BufWritePre * %s/\s\+$//e
|
autocmd BufWritePre * %s/\s\+$//e
|
||||||
autocmd BufWritePre * %s/\n\+\%$//e
|
autocmd BufWritePre * %s/\n\+\%$//e
|
||||||
autocmd BufWritePre *.[ch] %s/\%$/\r/e
|
autocmd BufWritePre *.[ch] %s/\%$/\r/e " add trailing newline for ANSI C standard
|
||||||
|
autocmd BufWritePre *neomutt* %s/^--$/-- /e " dash-dash-space signature delimiter in emails
|
||||||
autocmd BufWritePre * cal cursor(currPos[1], currPos[2])
|
autocmd BufWritePre * cal cursor(currPos[1], currPos[2])
|
||||||
|
|
||||||
" When shortcut files are updated, renew bash and ranger configs with new material:
|
" When shortcut files are updated, renew bash and ranger configs with new material:
|
||||||
@ -312,3 +323,8 @@ function! ToggleHiddenAll()
|
|||||||
endif
|
endif
|
||||||
endfunction
|
endfunction
|
||||||
nnoremap <leader>h :call ToggleHiddenAll()<CR>
|
nnoremap <leader>h :call ToggleHiddenAll()<CR>
|
||||||
|
" Load command shortcuts generated from bm-dirs and bm-files via shortcuts script.
|
||||||
|
" Here leader is ";".
|
||||||
|
" So ":vs ;cfz" will expand into ":vs /home/<user>/.config/zsh/.zshrc"
|
||||||
|
" if typed fast without the timeout.
|
||||||
|
silent! source ~/.config/nvim/shortcuts.vim
|
||||||
|
|||||||
2
.config/python/pythonrc
Normal file
2
.config/python/pythonrc
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
import readline
|
||||||
|
readline.write_history_file = lambda *args: None
|
||||||
@ -9,20 +9,29 @@
|
|||||||
# Use $XINITRC variable if file exists.
|
# Use $XINITRC variable if file exists.
|
||||||
[ -f "$XINITRC" ] && alias startx="startx $XINITRC"
|
[ -f "$XINITRC" ] && alias startx="startx $XINITRC"
|
||||||
|
|
||||||
|
[ -f "$MBSYNCRC" ] && alias mbsync="mbsync -c $MBSYNCRC"
|
||||||
|
|
||||||
# sudo not required for some system commands
|
# sudo not required for some system commands
|
||||||
for command in mount umount sv pacman updatedb su shutdown poweroff reboot ; do
|
for command in mount umount sv pacman updatedb su shutdown poweroff reboot ; do
|
||||||
alias $command="sudo $command"
|
alias $command="sudo $command"
|
||||||
done; unset command
|
done; unset command
|
||||||
|
|
||||||
|
se() {
|
||||||
|
choice="$(find ~/.local/bin -mindepth 1 -printf '%P\n' | fzf)"
|
||||||
|
[ -f "$HOME/.local/bin/$choice" ] && $EDITOR "$HOME/.local/bin/$choice"
|
||||||
|
;}
|
||||||
|
|
||||||
# Verbosity and settings that you pretty much just always are going to want.
|
# Verbosity and settings that you pretty much just always are going to want.
|
||||||
alias \
|
alias \
|
||||||
cp="cp -iv" \
|
cp="cp -iv" \
|
||||||
mv="mv -iv" \
|
mv="mv -iv" \
|
||||||
rm="rm -vI" \
|
rm="rm -vI" \
|
||||||
bc="bc -ql" \
|
bc="bc -ql" \
|
||||||
|
rsync="rsync -vrPlu" \
|
||||||
mkd="mkdir -pv" \
|
mkd="mkdir -pv" \
|
||||||
yt="yt-dlp --embed-metadata -i" \
|
yt="yt-dlp --embed-metadata -i" \
|
||||||
yta="yt -x -f bestaudio/best" \
|
yta="yt -x -f bestaudio/best" \
|
||||||
|
ytt="yt --skip-download --write-thumbnail" \
|
||||||
ffmpeg="ffmpeg -hide_banner"
|
ffmpeg="ffmpeg -hide_banner"
|
||||||
|
|
||||||
# Colorize commands when possible.
|
# Colorize commands when possible.
|
||||||
@ -52,4 +61,4 @@ alias \
|
|||||||
lf="lfub" \
|
lf="lfub" \
|
||||||
magit="nvim -c MagitOnly" \
|
magit="nvim -c MagitOnly" \
|
||||||
ref="shortcuts >/dev/null; source ${XDG_CONFIG_HOME:-$HOME/.config}/shell/shortcutrc ; source ${XDG_CONFIG_HOME:-$HOME/.config}/shell/zshnameddirrc" \
|
ref="shortcuts >/dev/null; source ${XDG_CONFIG_HOME:-$HOME/.config}/shell/shortcutrc ; source ${XDG_CONFIG_HOME:-$HOME/.config}/shell/zshnameddirrc" \
|
||||||
weath="less -S ${XDG_DATA_HOME:-$HOME/.local/share}/weatherreport" \
|
weath="less -S ${XDG_CACHE_HOME:-$HOME/.cache}/weatherreport" \
|
||||||
|
|||||||
@ -20,4 +20,4 @@ cfmb ${XDG_CONFIG_HOME:-$HOME/.config}/ncmpcpp/bindings # ncmpcpp (music player)
|
|||||||
cfmc ${XDG_CONFIG_HOME:-$HOME/.config}/ncmpcpp/config # ncmpcpp (music player) config
|
cfmc ${XDG_CONFIG_HOME:-$HOME/.config}/ncmpcpp/config # ncmpcpp (music player) config
|
||||||
cfl ${XDG_CONFIG_HOME:-$HOME/.config}/lf/lfrc # lf (file browser) config
|
cfl ${XDG_CONFIG_HOME:-$HOME/.config}/lf/lfrc # lf (file browser) config
|
||||||
cfL ${XDG_CONFIG_HOME:-$HOME/.config}/lf/scope # lf's scope/preview file
|
cfL ${XDG_CONFIG_HOME:-$HOME/.config}/lf/scope # lf's scope/preview file
|
||||||
cfX ${XDG_CONFIG_HOME:-$HOME/.config}/sxiv/exec/key-handler # sxiv (image viewer) key/script handler
|
cfX ${XDG_CONFIG_HOME:-$HOME/.config}/nsxiv/exec/key-handler # nsxiv (image viewer) key/script handler
|
||||||
|
|||||||
@ -1,9 +1,10 @@
|
|||||||
#!/bin/zsh
|
#!/bin/sh
|
||||||
|
# shellcheck disable=SC2155
|
||||||
|
|
||||||
# profile file. Runs on login. Environmental variables are set here.
|
# Profile file, runs on login. Environmental variables are set here.
|
||||||
|
|
||||||
# If you don't plan on reverting to bash, you can remove the link in ~/.profile
|
# Add all directories in `~/.local/bin` to $PATH
|
||||||
# to clean up.
|
export PATH="$PATH:$(find ~/.local/bin -type d | paste -sd ':' -)"
|
||||||
|
|
||||||
# Adds `~/.local/bin` to $PATH
|
# Adds `~/.local/bin` to $PATH
|
||||||
export PATH="$PATH:${$(find ~/.local/bin -type d -printf %p:)%%:}"
|
export PATH="$PATH:${$(find ~/.local/bin -type d -printf %p:)%%:}"
|
||||||
@ -12,48 +13,53 @@ export PATH="$PATH:${$(find ~/.local/share/cargo/bin -type d -printf %p:)%%:}"
|
|||||||
# Adds `/usr/bin/vendor_perl` to $PATH
|
# Adds `/usr/bin/vendor_perl` to $PATH
|
||||||
export PATH="$PATH:${$(find /usr/bin/vendor_perl -type d -printf %p:)%%:}"
|
export PATH="$PATH:${$(find /usr/bin/vendor_perl -type d -printf %p:)%%:}"
|
||||||
|
|
||||||
unsetopt PROMPT_SP
|
unsetopt PROMPT_SP 2>/dev/null
|
||||||
|
|
||||||
# Default programs:
|
# Default programs:
|
||||||
export EDITOR="nvim"
|
export EDITOR="nvim"
|
||||||
export TERMINAL="kitty"
|
export TERMINAL="kitty"
|
||||||
|
export TERMINAL_PROG="kitty"
|
||||||
export BROWSER="firefox"
|
export BROWSER="firefox"
|
||||||
export READER="zathura"
|
export READER="zathura"
|
||||||
export FILE="lf"
|
export FILE="lf"
|
||||||
|
|
||||||
|
# Change the default crypto/weather monitor sites.
|
||||||
|
# export CRYPTOURL="rate.sx"
|
||||||
|
# export WTTRURL="wttr.in"
|
||||||
|
|
||||||
# ~/ Clean-up:
|
# ~/ Clean-up:
|
||||||
export XDG_CONFIG_HOME="$HOME/.config"
|
export XDG_CONFIG_HOME="$HOME/.config"
|
||||||
export XDG_DATA_HOME="$HOME/.local/share"
|
export XDG_DATA_HOME="$HOME/.local/share"
|
||||||
export XDG_CACHE_HOME="$HOME/.cache"
|
export XDG_CACHE_HOME="$HOME/.cache"
|
||||||
export XINITRC="${XDG_CONFIG_HOME:-$HOME/.config}/x11/xinitrc"
|
export XINITRC="$XDG_CONFIG_HOME/x11/xinitrc"
|
||||||
#export XAUTHORITY="$XDG_RUNTIME_DIR/Xauthority" # This line will break some DMs.
|
#export XAUTHORITY="$XDG_RUNTIME_DIR/Xauthority" # This line will break some DMs.
|
||||||
export NOTMUCH_CONFIG="${XDG_CONFIG_HOME:-$HOME/.config}/notmuch-config"
|
export NOTMUCH_CONFIG="$XDG_CONFIG_HOME/notmuch-config"
|
||||||
export GTK2_RC_FILES="${XDG_CONFIG_HOME:-$HOME/.config}/gtk-2.0/gtkrc-2.0"
|
export GTK2_RC_FILES="$XDG_CONFIG_HOME/gtk-2.0/gtkrc-2.0"
|
||||||
export LESSHISTFILE="-"
|
export WGETRC="$XDG_CONFIG_HOME/wget/wgetrc"
|
||||||
export WGETRC="${XDG_CONFIG_HOME:-$HOME/.config}/wget/wgetrc"
|
export INPUTRC="$XDG_CONFIG_HOME/shell/inputrc"
|
||||||
export INPUTRC="${XDG_CONFIG_HOME:-$HOME/.config}/shell/inputrc"
|
export ZDOTDIR="$XDG_CONFIG_HOME/zsh"
|
||||||
export ZDOTDIR="${XDG_CONFIG_HOME:-$HOME/.config}/zsh"
|
#export GNUPGHOME="$XDG_DATA_HOME/gnupg"
|
||||||
#export ALSA_CONFIG_PATH="$XDG_CONFIG_HOME/alsa/asoundrc"
|
export WINEPREFIX="$XDG_DATA_HOME/wineprefixes/default"
|
||||||
#export GNUPGHOME="${XDG_DATA_HOME:-$HOME/.local/share}/gnupg"
|
export KODI_DATA="$XDG_DATA_HOME/kodi"
|
||||||
export WINEPREFIX="${XDG_DATA_HOME:-$HOME/.local/share}/wineprefixes/default"
|
export PASSWORD_STORE_DIR="$XDG_DATA_HOME/password-store"
|
||||||
export KODI_DATA="${XDG_DATA_HOME:-$HOME/.local/share}/kodi"
|
|
||||||
export PASSWORD_STORE_DIR="${XDG_DATA_HOME:-$HOME/.local/share}/password-store"
|
|
||||||
export TMUX_TMPDIR="$XDG_RUNTIME_DIR"
|
export TMUX_TMPDIR="$XDG_RUNTIME_DIR"
|
||||||
export ANDROID_SDK_HOME="${XDG_CONFIG_HOME:-$HOME/.config}/android"
|
export ANDROID_SDK_HOME="$XDG_CONFIG_HOME/android"
|
||||||
export CARGO_HOME="${XDG_DATA_HOME:-$HOME/.local/share}/cargo"
|
export CARGO_HOME="$XDG_DATA_HOME/cargo"
|
||||||
export GOPATH="${XDG_DATA_HOME:-$HOME/.local/share}/go"
|
export GOPATH="$XDG_DATA_HOME/go"
|
||||||
export ANSIBLE_CONFIG="${XDG_CONFIG_HOME:-$HOME/.config}/ansible/ansible.cfg"
|
export GOMODCACHE="$XDG_CACHE_HOME/go/mod"
|
||||||
export UNISON="${XDG_DATA_HOME:-$HOME/.local/share}/unison"
|
export ANSIBLE_CONFIG="$XDG_CONFIG_HOME/ansible/ansible.cfg"
|
||||||
export HISTFILE="${XDG_DATA_HOME:-$HOME/.local/share}/history"
|
export UNISON="$XDG_DATA_HOME/unison"
|
||||||
export WEECHAT_HOME="${XDG_CONFIG_HOME:-$HOME/.config}/weechat"
|
export HISTFILE="$XDG_DATA_HOME/history"
|
||||||
export MBSYNCRC="${XDG_CONFIG_HOME:-$HOME/.config}/mbsync/config"
|
export MBSYNCRC="$XDG_CONFIG_HOME/mbsync/config"
|
||||||
export ELECTRUMDIR="${XDG_DATA_HOME:-$HOME/.local/share}/electrum"
|
export ELECTRUMDIR="$XDG_DATA_HOME/electrum"
|
||||||
|
export PYTHONSTARTUP="$XDG_CONFIG_HOME/python/pythonrc"
|
||||||
|
export SQLITE_HISTORY="$XDG_DATA_HOME/sqlite_history"
|
||||||
|
|
||||||
# Other program settings:
|
# Other program settings:
|
||||||
export DICS="/usr/share/stardict/dic/"
|
export DICS="/usr/share/stardict/dic/"
|
||||||
export SUDO_ASKPASS="$HOME/.local/bin/dmenupass"
|
export SUDO_ASKPASS="$HOME/.local/bin/dmenupass"
|
||||||
export FZF_DEFAULT_OPTS="--layout=reverse --height 40%"
|
export FZF_DEFAULT_OPTS="--layout=reverse --height 40%"
|
||||||
export LESS=-R
|
export LESS="R"
|
||||||
export LESS_TERMCAP_mb="$(printf '%b' '[1;31m')"
|
export LESS_TERMCAP_mb="$(printf '%b' '[1;31m')"
|
||||||
export LESS_TERMCAP_md="$(printf '%b' '[1;36m')"
|
export LESS_TERMCAP_md="$(printf '%b' '[1;36m')"
|
||||||
export LESS_TERMCAP_me="$(printf '%b' '[0m')"
|
export LESS_TERMCAP_me="$(printf '%b' '[0m')"
|
||||||
@ -62,101 +68,15 @@ export LESS_TERMCAP_se="$(printf '%b' '[0m')"
|
|||||||
export LESS_TERMCAP_us="$(printf '%b' '[1;32m')"
|
export LESS_TERMCAP_us="$(printf '%b' '[1;32m')"
|
||||||
export LESS_TERMCAP_ue="$(printf '%b' '[0m')"
|
export LESS_TERMCAP_ue="$(printf '%b' '[0m')"
|
||||||
export LESSOPEN="| /usr/bin/highlight -O ansi %s 2>/dev/null"
|
export LESSOPEN="| /usr/bin/highlight -O ansi %s 2>/dev/null"
|
||||||
export QT_QPA_PLATFORMTHEME="gtk2" # Have QT use gtk2 theme.
|
export QT_QPA_PLATFORMTHEME="gtk2" # Have QT use gtk2 theme.
|
||||||
export MOZ_USE_XINPUT2="1" # Mozilla smooth scrolling/touchpads.
|
export MOZ_USE_XINPUT2=1 # Mozilla smooth scrolling/touchpads.
|
||||||
export AWT_TOOLKIT="MToolkit wmname LG3D" #May have to install wmname
|
export AWT_TOOLKIT="MToolkit wmname LG3D" # May have to install wmname
|
||||||
export _JAVA_AWT_WM_NONREPARENTING=1 # Fix for Java applications in dwm
|
export _JAVA_AWT_WM_NONREPARENTING=1 # Fix for Java applications in dwm
|
||||||
|
|
||||||
# This is the list for lf icons:
|
[ ! -f "$XDG_CONFIG_HOME/shell/shortcutrc" ] && setsid -f shortcuts >/dev/null 2>&1
|
||||||
export LF_ICONS="di=📁:\
|
|
||||||
fi=📃:\
|
|
||||||
tw=🤝:\
|
|
||||||
ow=📂:\
|
|
||||||
ln=⛓:\
|
|
||||||
or=❌:\
|
|
||||||
ex=🎯:\
|
|
||||||
*.txt=✍:\
|
|
||||||
*.mom=✍:\
|
|
||||||
*.me=✍:\
|
|
||||||
*.ms=✍:\
|
|
||||||
*.png=🖼:\
|
|
||||||
*.webp=🖼:\
|
|
||||||
*.ico=🖼:\
|
|
||||||
*.jpg=📸:\
|
|
||||||
*.jpe=📸:\
|
|
||||||
*.jpeg=📸:\
|
|
||||||
*.gif=🖼:\
|
|
||||||
*.svg=🗺:\
|
|
||||||
*.tif=🖼:\
|
|
||||||
*.tiff=🖼:\
|
|
||||||
*.xcf=🖌:\
|
|
||||||
*.html=🌎:\
|
|
||||||
*.xml=📰:\
|
|
||||||
*.gpg=🔒:\
|
|
||||||
*.css=🎨:\
|
|
||||||
*.pdf=📚:\
|
|
||||||
*.djvu=📚:\
|
|
||||||
*.epub=📚:\
|
|
||||||
*.csv=📓:\
|
|
||||||
*.xlsx=📓:\
|
|
||||||
*.tex=📜:\
|
|
||||||
*.md=📘:\
|
|
||||||
*.r=📊:\
|
|
||||||
*.R=📊:\
|
|
||||||
*.rmd=📊:\
|
|
||||||
*.Rmd=📊:\
|
|
||||||
*.m=📊:\
|
|
||||||
*.mp3=🎵:\
|
|
||||||
*.opus=🎵:\
|
|
||||||
*.ogg=🎵:\
|
|
||||||
*.m4a=🎵:\
|
|
||||||
*.flac=🎼:\
|
|
||||||
*.wav=🎼:\
|
|
||||||
*.mkv=🎥:\
|
|
||||||
*.mp4=🎥:\
|
|
||||||
*.webm=🎥:\
|
|
||||||
*.mpeg=🎥:\
|
|
||||||
*.avi=🎥:\
|
|
||||||
*.mov=🎥:\
|
|
||||||
*.mpg=🎥:\
|
|
||||||
*.wmv=🎥:\
|
|
||||||
*.m4b=🎥:\
|
|
||||||
*.flv=🎥:\
|
|
||||||
*.zip=📦:\
|
|
||||||
*.rar=📦:\
|
|
||||||
*.7z=📦:\
|
|
||||||
*.tar.gz=📦:\
|
|
||||||
*.z64=🎮:\
|
|
||||||
*.v64=🎮:\
|
|
||||||
*.n64=🎮:\
|
|
||||||
*.gba=🎮:\
|
|
||||||
*.nes=🎮:\
|
|
||||||
*.gdi=🎮:\
|
|
||||||
*.1=ℹ:\
|
|
||||||
*.nfo=ℹ:\
|
|
||||||
*.info=ℹ:\
|
|
||||||
*.log=📙:\
|
|
||||||
*.iso=📀:\
|
|
||||||
*.img=📀:\
|
|
||||||
*.bib=🎓:\
|
|
||||||
*.ged=👪:\
|
|
||||||
*.part=💔:\
|
|
||||||
*.torrent=🔽:\
|
|
||||||
*.jar=♨:\
|
|
||||||
*.java=♨:\
|
|
||||||
"
|
|
||||||
|
|
||||||
[ ! -f ${XDG_CONFIG_HOME:-$HOME/.config}/shell/shortcutrc ] && shortcuts >/dev/null 2>&1 &
|
# Start graphical server on user's current tty if not already running.
|
||||||
|
[ "$(tty)" = "/dev/tty1" ] && ! pidof -s Xorg >/dev/null 2>&1 && exec startx "$XINITRC"
|
||||||
if pacman -Qs libxft-bgra >/dev/null 2>&1; then
|
|
||||||
# Start graphical server on user's current tty if not already running.
|
|
||||||
[ "$(tty)" = "/dev/tty1" ] && ! pidof -s Xorg >/dev/null 2>&1 && exec startx "$XINITRC"
|
|
||||||
else
|
|
||||||
echo "\033[31mIMPORTANT\033[0m: Note that \033[32m\`libxft-bgra\`\033[0m must be installed for this build of dwm.
|
|
||||||
Please run:
|
|
||||||
\033[32myay -S libxft-bgra-git\033[0m
|
|
||||||
and replace \`libxft\`. Afterwards, you may start the graphical server by running \`startx\`."
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Switch escape and caps if tty and no passwd required:
|
# Switch escape and caps if tty and no passwd required:
|
||||||
sudo -n loadkeys ${XDG_DATA_HOME:-$HOME/.local/share}/larbs/ttymaps.kmap 2>/dev/null
|
sudo -n loadkeys "$XDG_DATA_HOME/larbs/ttymaps.kmap" 2>/dev/null
|
||||||
|
|||||||
1
.config/sxiv
Symbolic link
1
.config/sxiv
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
nsxiv
|
||||||
@ -12,6 +12,7 @@ map K zoom in
|
|||||||
map J zoom out
|
map J zoom out
|
||||||
map i recolor
|
map i recolor
|
||||||
map p print
|
map p print
|
||||||
|
map g goto top
|
||||||
|
|
||||||
set default-bg "{background}"
|
set default-bg "{background}"
|
||||||
set default-fg "{foreground}"
|
set default-fg "{foreground}"
|
||||||
|
|||||||
@ -13,5 +13,6 @@ if [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/x11/xprofile" ]; then
|
|||||||
else
|
else
|
||||||
. "$HOME/.xprofile"
|
. "$HOME/.xprofile"
|
||||||
fi
|
fi
|
||||||
|
# Activate dbus variables
|
||||||
ssh-agent dwm
|
dbus-update-activation-environment --all
|
||||||
|
dbus-launch ssh-agent dwm
|
||||||
|
|||||||
@ -8,12 +8,11 @@ if [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/x11/xrandr" ]; then
|
|||||||
fi
|
fi
|
||||||
setbg & # set the background with the `setbg` script
|
setbg & # set the background with the `setbg` script
|
||||||
#xrdb ${XDG_CONFIG_HOME:-$HOME/.config}/x11/xresources & # Uncomment to use Xresources colors/settings on startup
|
#xrdb ${XDG_CONFIG_HOME:-$HOME/.config}/x11/xresources & # Uncomment to use Xresources colors/settings on startup
|
||||||
remaps & # run the remaps script, switching caps/esc and more; check it for more info
|
|
||||||
|
|
||||||
autostart="mpd xcompmgr dunst unclutter"
|
autostart="mpd xcompmgr dunst unclutter remapd"
|
||||||
|
|
||||||
for program in $autostart; do
|
for program in $autostart; do
|
||||||
pidof -s "$program" || "$program" &
|
pidof -sx "$program" || "$program" &
|
||||||
done >/dev/null 2>&1
|
done >/dev/null 2>&1
|
||||||
|
|
||||||
# Ensure that xrdb has finished running before moving on to start the WM/DE.
|
# Ensure that xrdb has finished running before moving on to start the WM/DE.
|
||||||
|
|||||||
@ -29,6 +29,18 @@ plugins=(git colored-man-pages)
|
|||||||
|
|
||||||
source $ZSH/oh-my-zsh.sh
|
source $ZSH/oh-my-zsh.sh
|
||||||
|
|
||||||
|
# Use lf to switch directories and bind it to ctrl-o
|
||||||
|
lfcd () {
|
||||||
|
tmp="$(mktemp -uq)"
|
||||||
|
trap 'rm -f $tmp >/dev/null 2>&1 && trap - HUP INT QUIT TERM PWR EXIT' HUP INT QUIT TERM PWR EXIT
|
||||||
|
lf -last-dir-path="$tmp" "$@"
|
||||||
|
if [ -f "$tmp" ]; then
|
||||||
|
dir="$(cat "$tmp")"
|
||||||
|
[ -d "$dir" ] && [ "$dir" != "$(pwd)" ] && cd "$dir"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
bindkey -s '^o' '^ulfcd\n'
|
||||||
|
|
||||||
_comp_options+=(globdots)
|
_comp_options+=(globdots)
|
||||||
|
|
||||||
motdmaker && cat ~/.cache/motd
|
motdmaker && cat ~/.cache/motd
|
||||||
|
|||||||
23
.local/bin/arkenfox-auto-update
Executable file
23
.local/bin/arkenfox-auto-update
Executable file
@ -0,0 +1,23 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# A wrapper for the arkenfox-updater that runs it on all pre-existing Arkenfox
|
||||||
|
# user.js files on the machine.
|
||||||
|
|
||||||
|
# On installation of LARBS, this file is copied to /usr/local/lib/ where it is
|
||||||
|
# run by a pacman hook set up. The user should not have to run this manually.
|
||||||
|
|
||||||
|
# Search for all Firefox and Librewolf profiles using Arkenfox.
|
||||||
|
profiles="$(grep -sH "arkenfox user.js" \
|
||||||
|
/home/*/.librewolf/*.default-release/user.js \
|
||||||
|
/home/*/.mozilla/firefox/*.default-release/user.js)"
|
||||||
|
|
||||||
|
IFS='
|
||||||
|
'
|
||||||
|
|
||||||
|
# Update each found profile.
|
||||||
|
for profile in $profiles; do
|
||||||
|
userjs=${profile%%/user.js*}
|
||||||
|
user=$(stat -c '%U' "$userjs") || continue
|
||||||
|
|
||||||
|
su -l "$user" -c "arkenfox-updater -c -p $userjs -s"
|
||||||
|
done
|
||||||
@ -9,10 +9,10 @@ echo "Enter the artist/author:"; read -r author
|
|||||||
echo "Enter the publication year:"; read -r year
|
echo "Enter the publication year:"; read -r year
|
||||||
|
|
||||||
inputaudio="$1"
|
inputaudio="$1"
|
||||||
ext="${1#*.}"
|
ext="${1##*.}"
|
||||||
|
|
||||||
# Get a safe file name from the book.
|
# Get a safe file name from the book.
|
||||||
escbook="$(echo "$booktitle" | iconv -cf UTF-8 -t ASCII//TRANSLIT | tr -d '[:punct:]' | tr '[:upper:]' '[:lower:]' | tr ' ' '-' | sed "s/-\+/-/g;s/\(^-\|-\$\)//g")"
|
escbook="$(echo "$booktitle" | iconv -c -f UTF-8 -t ASCII//TRANSLIT | tr -d '[:punct:]' | tr '[:upper:]' '[:lower:]' | tr ' ' '-' | sed "s/-\+/-/g;s/\(^-\|-\$\)//g")"
|
||||||
|
|
||||||
! mkdir -p "$escbook" &&
|
! mkdir -p "$escbook" &&
|
||||||
echo "Do you have write access in this directory?" &&
|
echo "Do you have write access in this directory?" &&
|
||||||
@ -31,7 +31,7 @@ do
|
|||||||
cmd="$cmd -metadata artist=\"$author\" -metadata title=\"$title\" -metadata album=\"$booktitle\" -metadata year=\"$year\" -metadata track=\"$track\" -metadata total=\"$total\" -ss \"$start\" -to \"$end\" -vn -c:a copy \"$file\" "
|
cmd="$cmd -metadata artist=\"$author\" -metadata title=\"$title\" -metadata album=\"$booktitle\" -metadata year=\"$year\" -metadata track=\"$track\" -metadata total=\"$total\" -ss \"$start\" -to \"$end\" -vn -c:a copy \"$file\" "
|
||||||
fi
|
fi
|
||||||
title="$(echo "$x" | cut -d' ' -f2-)"
|
title="$(echo "$x" | cut -d' ' -f2-)"
|
||||||
esctitle="$(echo "$title" | iconv -cf UTF-8 -t ASCII//TRANSLIT | tr -d '[:punct:]' | tr '[:upper:]' '[:lower:]' | tr ' ' '-' | sed "s/-\+/-/g;s/\(^-\|-\$\)//g")"
|
esctitle="$(echo "$title" | iconv -c -f UTF-8 -t ASCII//TRANSLIT | tr -d '[:punct:]' | tr '[:upper:]' '[:lower:]' | tr ' ' '-' | sed "s/-\+/-/g;s/\(^-\|-\$\)//g")"
|
||||||
track="$((track+1))"
|
track="$((track+1))"
|
||||||
start="$end"
|
start="$end"
|
||||||
done < "$2"
|
done < "$2"
|
||||||
|
|||||||
@ -17,13 +17,15 @@ ext="${file##*.}"
|
|||||||
cd "$dir" || exit 1
|
cd "$dir" || exit 1
|
||||||
|
|
||||||
textype() { \
|
textype() { \
|
||||||
|
textarget="$(getcomproot "$file" || echo "$file")"
|
||||||
|
echo "$textarget"
|
||||||
command="pdflatex"
|
command="pdflatex"
|
||||||
( head -n5 "$file" | grep -qi 'xelatex' ) && command="xelatex"
|
( head -n5 "$textarget" | grep -qi 'xelatex' ) && command="xelatex"
|
||||||
$command --output-directory="$dir" "$base" &&
|
$command --output-directory="${textarget%/*}" "${textarget%.*}"
|
||||||
grep -qi addbibresource "$file" &&
|
grep -qi addbibresource "$textarget" &&
|
||||||
biber --input-directory "$dir" "$base" &&
|
biber --input-directory "${textarget%/*}" "${textarget%.*}" &&
|
||||||
$command --output-directory="$dir" "$base" &&
|
$command --output-directory="${textarget%/*}" "${textarget%.*}" &&
|
||||||
$command --output-directory="$dir" "$base"
|
$command --output-directory="${textarget%/*}" "${textarget%.*}"
|
||||||
}
|
}
|
||||||
|
|
||||||
case "$ext" in
|
case "$ext" in
|
||||||
@ -37,9 +39,9 @@ case "$ext" in
|
|||||||
java) javac -d classes "$file" && java -cp classes "${1%.*}" ;;
|
java) javac -d classes "$file" && java -cp classes "${1%.*}" ;;
|
||||||
m) octave "$file" ;;
|
m) octave "$file" ;;
|
||||||
md) if [ -x "$(command -v lowdown)" ]; then
|
md) if [ -x "$(command -v lowdown)" ]; then
|
||||||
lowdown --parse-no-intraemph "$file" -Tms | groff -mpdfmark -ms -kept > "$base".pdf
|
lowdown --parse-no-intraemph "$file" -Tms | groff -mpdfmark -ms -kept -T pdf > "$base".pdf
|
||||||
elif [ -x "$(command -v groffdown)" ]; then
|
elif [ -x "$(command -v groffdown)" ]; then
|
||||||
groffdown -i "$file" | groff > "$base.pdf"
|
groffdown -i "$file" | groff -T pdf > "$base".pdf
|
||||||
else
|
else
|
||||||
pandoc -t ms --highlight-style=kate -s -o "$base".pdf "$file"
|
pandoc -t ms --highlight-style=kate -s -o "$base".pdf "$file"
|
||||||
fi ; ;;
|
fi ; ;;
|
||||||
@ -49,7 +51,7 @@ case "$ext" in
|
|||||||
py) python "$file" ;;
|
py) python "$file" ;;
|
||||||
[rR]md) Rscript -e "rmarkdown::render('$file', quiet=TRUE)" ;;
|
[rR]md) Rscript -e "rmarkdown::render('$file', quiet=TRUE)" ;;
|
||||||
rs) cargo build ;;
|
rs) cargo build ;;
|
||||||
sass) sassc -a "$file" "$base.css" ;;
|
sass) sassc -a "$file" "$base".css ;;
|
||||||
scad) openscad -o "$base".stl "$file" ;;
|
scad) openscad -o "$base".stl "$file" ;;
|
||||||
sent) setsid -f sent "$file" 2>/dev/null ;;
|
sent) setsid -f sent "$file" 2>/dev/null ;;
|
||||||
tex) textype "$file" ;;
|
tex) textype "$file" ;;
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
# Toggles all cronjobs off/on.
|
# Toggles all cronjobs off/on.
|
||||||
# Stores disabled crontabs in ~/.consaved until restored.
|
# Stores disabled crontabs in ~/.config/cronsaved until restored.
|
||||||
|
|
||||||
([ -f "${XDG_CONFIG_HOME:-$HOME/.config}"/cronsaved ] && crontab - < "${XDG_CONFIG_HOME:-$HOME/.config}"/cronsaved && rm "${XDG_CONFIG_HOME:-$HOME/.config}"/cronsaved && notify-send "🕓 Cronjobs re-enabled.") || ( crontab -l > "${XDG_CONFIG_HOME:-$HOME/.config}"/cronsaved && crontab -r && notify-send "🕓 Cronjobs saved and disabled.")
|
([ -f "${XDG_CONFIG_HOME:-$HOME/.config}"/cronsaved ] && crontab - < "${XDG_CONFIG_HOME:-$HOME/.config}"/cronsaved && rm "${XDG_CONFIG_HOME:-$HOME/.config}"/cronsaved && notify-send "🕓 Cronjobs re-enabled.") || ( crontab -l > "${XDG_CONFIG_HOME:-$HOME/.config}"/cronsaved && crontab -r && notify-send "🕓 Cronjobs saved and disabled.")
|
||||||
|
|||||||
@ -58,7 +58,6 @@ onescreen() { # If only one output available or chosen.
|
|||||||
|
|
||||||
postrun() { # Stuff to run to clean up.
|
postrun() { # Stuff to run to clean up.
|
||||||
setbg # Fix background if screen size/arangement has changed.
|
setbg # Fix background if screen size/arangement has changed.
|
||||||
remaps # Re-remap keys if keyboard added (for laptop bases)
|
|
||||||
{ killall dunst ; setsid -f dunst ;} >/dev/null 2>&1 # Restart dunst to ensure proper location on screen
|
{ killall dunst ; setsid -f dunst ;} >/dev/null 2>&1 # Restart dunst to ensure proper location on screen
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -2,19 +2,19 @@
|
|||||||
|
|
||||||
# Feed this script a link and it will give dmenu
|
# Feed this script a link and it will give dmenu
|
||||||
# some choice programs to use to open it.
|
# some choice programs to use to open it.
|
||||||
feed="${1:-$(printf "%s" | dmenu -p 'Paste URL or file path')}"
|
feed="${1:-$(true | dmenu -p 'Paste URL or file path')}"
|
||||||
|
|
||||||
case "$(printf "Copy URL\\nsxiv\\nsetbg\\nPDF\\nbrowser\\nlynx\\nvim\\nmpv\\nmpv loop\\nmpv float\\nqueue download\\nqueue yt-dlp\\nqueue yt-dlp audio" | dmenu -i -p "Open it with?")" in
|
case "$(printf "copy url\\nnsxiv\\nsetbg\\nPDF\\nbrowser\\nlynx\\nvim\\nmpv\\nmpv loop\\nmpv float\\nqueue download\\nqueue yt-dlp\\nqueue yt-dlp audio" | dmenu -i -p "Open it with?")" in
|
||||||
"Copy URL") echo "$feed" | xclip -selection clipboard ;;
|
"copy url") echo "$feed" | xclip -selection clipboard ;;
|
||||||
mpv) setsid -f mpv -quiet "$feed" >/dev/null 2>&1 ;;
|
mpv) setsid -f mpv -quiet "$feed" >/dev/null 2>&1 ;;
|
||||||
"mpv loop") setsid -f mpv -quiet --loop "$feed" >/dev/null 2>&1 ;;
|
"mpv loop") setsid -f mpv -quiet --loop "$feed" >/dev/null 2>&1 ;;
|
||||||
"mpv float") setsid -f "$TERMINAL" -e mpv --geometry=+0-0 --autofit=30% --title="mpvfloat" "$feed" >/dev/null 2>&1 ;;
|
"mpv float") setsid -f "$TERMINAL" -e mpv --geometry=+0-0 --autofit=30% --title="mpvfloat" "$feed" >/dev/null 2>&1 ;;
|
||||||
"queue yt-dlp") qndl "$feed" >/dev/null 2>&1 ;;
|
"queue yt-dlp") qndl "$feed" >/dev/null 2>&1 ;;
|
||||||
"queue yt-dlp audio") qndl "$feed" 'yt-dlp --embed-metadata -icx -f bestaudio/best' >/dev/null 2>&1 ;;
|
"queue yt-dlp audio") qndl "$feed" 'yt-dlp -o "%(title)s.%(ext)s" -f bestaudio --embed-metadata --restrict-filenames' ;;
|
||||||
"queue download") qndl "$feed" 'curl -LO' >/dev/null 2>&1 ;;
|
"queue download") qndl "$feed" 'curl -LO' >/dev/null 2>&1 ;;
|
||||||
PDF) curl -sL "$feed" > "/tmp/$(echo "$feed" | sed "s/.*\///;s/%20/ /g")" && zathura "/tmp/$(echo "$feed" | sed "s/.*\///;s/%20/ /g")" >/dev/null 2>&1 ;;
|
PDF) curl -sL "$feed" > "/tmp/$(echo "$feed" | sed "s|.*/||;s/%20/ /g")" && zathura "/tmp/$(echo "$feed" | sed "s|.*/||;s/%20/ /g")" >/dev/null 2>&1 ;;
|
||||||
sxiv) curl -sL "$feed" > "/tmp/$(echo "$feed" | sed "s/.*\///;s/%20/ /g")" && sxiv -a "/tmp/$(echo "$feed" | sed "s/.*\///;s/%20/ /g")" >/dev/null 2>&1 ;;
|
nsxiv) curl -sL "$feed" > "/tmp/$(echo "$feed" | sed "s|.*/||;s/%20/ /g")" && nsxiv -a "/tmp/$(echo "$feed" | sed "s|.*/||;s/%20/ /g")" >/dev/null 2>&1 ;;
|
||||||
vim) curl -sL "$feed" > "/tmp/$(echo "$feed" | sed "s/.*\///;s/%20/ /g")" && setsid -f "$TERMINAL" -e "$EDITOR" "/tmp/$(echo "$feed" | sed "s/.*\///;s/%20/ /g")" >/dev/null 2>&1 ;;
|
vim) curl -sL "$feed" > "/tmp/$(echo "$feed" | sed "s|.*/||;s/%20/ /g")" && setsid -f "$TERMINAL" -e "$EDITOR" "/tmp/$(echo "$feed" | sed "s|.*/||;s/%20/ /g")" >/dev/null 2>&1 ;;
|
||||||
setbg) curl -L "$feed" > $XDG_CACHE_HOME/pic ; xwallpaper --zoom $XDG_CACHE_HOME/pic >/dev/null 2>&1 ;;
|
setbg) curl -L "$feed" > $XDG_CACHE_HOME/pic ; xwallpaper --zoom $XDG_CACHE_HOME/pic >/dev/null 2>&1 ;;
|
||||||
browser) setsid -f "$BROWSER" "$feed" >/dev/null 2>&1 ;;
|
browser) setsid -f "$BROWSER" "$feed" >/dev/null 2>&1 ;;
|
||||||
lynx) lynx "$feed" >/dev/null 2>&1 ;;
|
lynx) lynx "$feed" >/dev/null 2>&1 ;;
|
||||||
|
|||||||
@ -1,67 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# Gives a dmenu prompt to mount unmounted drives and Android phones. If
|
|
||||||
# they're in /etc/fstab, they'll be mounted automatically. Otherwise, you'll
|
|
||||||
# be prompted to give a mountpoint from already existsing directories. If you
|
|
||||||
# input a novel directory, it will prompt you to create that directory.
|
|
||||||
|
|
||||||
getmount() { \
|
|
||||||
[ -z "$chosen" ] && exit 1
|
|
||||||
# shellcheck disable=SC2086
|
|
||||||
mp="$(find $1 2>/dev/null | dmenu -i -p "Type in mount point.")" || exit 1
|
|
||||||
test -z "$mp" && exit 1
|
|
||||||
if [ ! -d "$mp" ]; then
|
|
||||||
mkdiryn=$(printf "No\\nYes" | dmenu -i -p "$mp does not exist. Create it?") || exit 1
|
|
||||||
[ "$mkdiryn" = "Yes" ] && (mkdir -p "$mp" || sudo -A mkdir -p "$mp")
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
mountusb() { \
|
|
||||||
chosen="$(echo "$usbdrives" | dmenu -i -p "Mount which drive?")" || exit 1
|
|
||||||
chosen="$(echo "$chosen" | awk '{print $1}')"
|
|
||||||
sudo -A mount "$chosen" 2>/dev/null && notify-send "💻 USB mounting" "$chosen mounted." && exit 0
|
|
||||||
alreadymounted=$(lsblk -nrpo "name,type,mountpoint" | awk '$3!~/\/boot|\/home$|SWAP/&&length($3)>1{printf "-not ( -path *%s -prune ) ",$3}')
|
|
||||||
getmount "/mnt /media /mount /home -maxdepth 5 -type d $alreadymounted"
|
|
||||||
partitiontype="$(lsblk -no "fstype" "$chosen")"
|
|
||||||
case "$partitiontype" in
|
|
||||||
"vfat") sudo -A mount -t vfat "$chosen" "$mp" -o rw,umask=0000;;
|
|
||||||
"exfat") sudo -A mount "$chosen" "$mp" -o uid="$(id -u)",gid="$(id -g)";;
|
|
||||||
*) sudo -A mount "$chosen" "$mp"; user="$(whoami)"; ug="$(groups | awk '{print $1}')"; sudo -A chown "$user":"$ug" "$mp";;
|
|
||||||
esac
|
|
||||||
notify-send "💻 USB mounting" "$chosen mounted to $mp."
|
|
||||||
}
|
|
||||||
|
|
||||||
mountandroid() { \
|
|
||||||
chosen="$(echo "$anddrives" | dmenu -i -p "Which Android device?")" || exit 1
|
|
||||||
chosen="$(echo "$chosen" | cut -d : -f 1)"
|
|
||||||
getmount "$HOME -maxdepth 3 -type d"
|
|
||||||
simple-mtpfs --device "$chosen" "$mp"
|
|
||||||
echo "OK" | dmenu -i -p "Tap Allow on your phone if it asks for permission and then press enter" || exit 1
|
|
||||||
simple-mtpfs --device "$chosen" "$mp"
|
|
||||||
notify-send "🤖 Android Mounting" "Android device mounted to $mp."
|
|
||||||
}
|
|
||||||
|
|
||||||
asktype() { \
|
|
||||||
choice="$(printf "USB\\nAndroid" | dmenu -i -p "Mount a USB drive or Android device?")" || exit 1
|
|
||||||
case $choice in
|
|
||||||
USB) mountusb ;;
|
|
||||||
Android) mountandroid ;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
anddrives=$(simple-mtpfs -l 2>/dev/null)
|
|
||||||
usbdrives="$(lsblk -rpo "name,type,size,mountpoint" | grep 'part\|rom' | awk '$4==""{printf "%s (%s)\n",$1,$3}')"
|
|
||||||
|
|
||||||
if [ -z "$usbdrives" ]; then
|
|
||||||
[ -z "$anddrives" ] && echo "No USB drive or Android device detected" && exit
|
|
||||||
echo "Android device(s) detected."
|
|
||||||
mountandroid
|
|
||||||
else
|
|
||||||
if [ -z "$anddrives" ]; then
|
|
||||||
echo "USB drive(s) detected."
|
|
||||||
mountusb
|
|
||||||
else
|
|
||||||
echo "Mountable USB drive(s) and Android device(s) detected."
|
|
||||||
asktype
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
@ -9,6 +9,8 @@
|
|||||||
#
|
#
|
||||||
# If there is already a running instance, user will be prompted to end it.
|
# If there is already a running instance, user will be prompted to end it.
|
||||||
|
|
||||||
|
getdim() { xrandr | grep -oP '(?<=current ).*(?=,)' | tr -d ' ' ;}
|
||||||
|
|
||||||
updateicon() { \
|
updateicon() { \
|
||||||
echo "$1" > /tmp/recordingicon
|
echo "$1" > /tmp/recordingicon
|
||||||
pkill -RTMIN+9 "${STATUSBAR:-dwmblocks}"
|
pkill -RTMIN+9 "${STATUSBAR:-dwmblocks}"
|
||||||
@ -16,26 +18,23 @@ updateicon() { \
|
|||||||
|
|
||||||
killrecording() {
|
killrecording() {
|
||||||
recpid="$(cat /tmp/recordingpid)"
|
recpid="$(cat /tmp/recordingpid)"
|
||||||
# kill with SIGTERM, allowing finishing touches.
|
|
||||||
kill -15 "$recpid"
|
kill -15 "$recpid"
|
||||||
rm -f /tmp/recordingpid
|
rm -f /tmp/recordingpid
|
||||||
updateicon ""
|
updateicon ""
|
||||||
pkill -RTMIN+9 "${STATUSBAR:-dwmblocks}"
|
pkill -RTMIN+9 "${STATUSBAR:-dwmblocks}"
|
||||||
# even after SIGTERM, ffmpeg may still run, so SIGKILL it.
|
|
||||||
sleep 3
|
|
||||||
kill -9 "$recpid"
|
|
||||||
exit
|
|
||||||
}
|
}
|
||||||
|
|
||||||
screencast() { \
|
screencast() { \
|
||||||
ffmpeg -y \
|
ffmpeg -y \
|
||||||
-f x11grab \
|
-f x11grab \
|
||||||
-framerate 60 \
|
-framerate 30 \
|
||||||
-s "$(xdpyinfo | awk '/dimensions/ {print $2;}')" \
|
-s "$(getdim)" \
|
||||||
-i "$DISPLAY" \
|
-i "$DISPLAY" \
|
||||||
-f alsa -i default \
|
-r 24 \
|
||||||
-r 30 \
|
-use_wallclock_as_timestamps 1 \
|
||||||
-c:v h264 -crf 0 -preset ultrafast -c:a aac \
|
-f alsa -thread_queue_size 1024 -i default \
|
||||||
|
-c:v h264 \
|
||||||
|
-crf 0 -preset ultrafast -c:a aac \
|
||||||
"$HOME/screencast-$(date '+%y%m%d-%H%M-%S').mp4" &
|
"$HOME/screencast-$(date '+%y%m%d-%H%M-%S').mp4" &
|
||||||
echo $! > /tmp/recordingpid
|
echo $! > /tmp/recordingpid
|
||||||
updateicon "⏺️🎙️"
|
updateicon "⏺️🎙️"
|
||||||
@ -43,7 +42,8 @@ screencast() { \
|
|||||||
|
|
||||||
video() { ffmpeg \
|
video() { ffmpeg \
|
||||||
-f x11grab \
|
-f x11grab \
|
||||||
-s "$(xdpyinfo | awk '/dimensions/ {print $2;}')" \
|
-framerate 30 \
|
||||||
|
-s "$(getdim)" \
|
||||||
-i "$DISPLAY" \
|
-i "$DISPLAY" \
|
||||||
-c:v libx264 -qp 0 -r 30 \
|
-c:v libx264 -qp 0 -r 30 \
|
||||||
"$HOME/video-$(date '+%y%m%d-%H%M-%S').mkv" &
|
"$HOME/video-$(date '+%y%m%d-%H%M-%S').mkv" &
|
||||||
@ -104,7 +104,7 @@ videoselected()
|
|||||||
|
|
||||||
ffmpeg \
|
ffmpeg \
|
||||||
-f x11grab \
|
-f x11grab \
|
||||||
-framerate 60 \
|
-framerate 30 \
|
||||||
-video_size "$W"x"$H" \
|
-video_size "$W"x"$H" \
|
||||||
-i :0.0+"$X,$Y" \
|
-i :0.0+"$X,$Y" \
|
||||||
-c:v libx264 -qp 0 -r 30 \
|
-c:v libx264 -qp 0 -r 30 \
|
||||||
|
|||||||
@ -1,44 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# A dmenu prompt to unmount drives.
|
|
||||||
# Provides you with mounted partitions, select one to unmount.
|
|
||||||
# Drives mounted at /, /boot and /home will not be options to unmount.
|
|
||||||
|
|
||||||
unmountusb() {
|
|
||||||
[ -z "$drives" ] && exit
|
|
||||||
chosen="$(echo "$drives" | dmenu -i -p "Unmount which drive?")" || exit 1
|
|
||||||
chosen="$(echo "$chosen" | awk '{print $1}')"
|
|
||||||
[ -z "$chosen" ] && exit
|
|
||||||
sudo -A umount "$chosen" && notify-send "💻 USB unmounting" "$chosen unmounted."
|
|
||||||
}
|
|
||||||
|
|
||||||
unmountandroid() { \
|
|
||||||
chosen="$(awk '/simple-mtpfs/ {print $2}' /etc/mtab | dmenu -i -p "Unmount which device?")" || exit 1
|
|
||||||
[ -z "$chosen" ] && exit
|
|
||||||
sudo -A umount -l "$chosen" && notify-send "🤖 Android unmounting" "$chosen unmounted."
|
|
||||||
}
|
|
||||||
|
|
||||||
asktype() { \
|
|
||||||
choice="$(printf "USB\\nAndroid" | dmenu -i -p "Unmount a USB drive or Android device?")" || exit 1
|
|
||||||
case "$choice" in
|
|
||||||
USB) unmountusb ;;
|
|
||||||
Android) unmountandroid ;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
|
|
||||||
drives=$(lsblk -nrpo "name,type,size,mountpoint,label" | awk -F':' '{gsub(/ /,":")}$4!~/\/boot|\/efi|\/home$|SWAP/&&length($4)>1{printf "%s (%s) %s\n",$4,$3,$5}')
|
|
||||||
|
|
||||||
if ! grep simple-mtpfs /etc/mtab; then
|
|
||||||
[ -z "$drives" ] && echo "No drives to unmount." && exit
|
|
||||||
echo "Unmountable USB drive detected."
|
|
||||||
unmountusb
|
|
||||||
else
|
|
||||||
if [ -z "$drives" ]
|
|
||||||
then
|
|
||||||
echo "Unmountable Android device detected."
|
|
||||||
unmountandroid
|
|
||||||
else
|
|
||||||
echo "Unmountable USB drive(s) and Android device(s) detected."
|
|
||||||
asktype
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
@ -3,7 +3,7 @@
|
|||||||
# The famous "get a menu of emojis to copy" script.
|
# The famous "get a menu of emojis to copy" script.
|
||||||
|
|
||||||
# Get user selection via dmenu from emoji file.
|
# Get user selection via dmenu from emoji file.
|
||||||
chosen=$(cut -d ';' -f1 ~/.local/share/larbs/emoji | dmenu -i -l 30 | sed "s/ .*//")
|
chosen=$(cut -d ';' -f1 ~/.local/share/larbs/chars/* | dmenu -i -l 30 | sed "s/ .*//")
|
||||||
|
|
||||||
# Exit if none chosen.
|
# Exit if none chosen.
|
||||||
[ -z "$chosen" ] && exit
|
[ -z "$chosen" ] && exit
|
||||||
@ -13,6 +13,6 @@ chosen=$(cut -d ';' -f1 ~/.local/share/larbs/emoji | dmenu -i -l 30 | sed "s/ .*
|
|||||||
if [ -n "$1" ]; then
|
if [ -n "$1" ]; then
|
||||||
xdotool type "$chosen"
|
xdotool type "$chosen"
|
||||||
else
|
else
|
||||||
printf "$chosen" | xclip -selection clipboard
|
printf "%s" "$chosen" | xclip -selection clipboard
|
||||||
notify-send "'$chosen' copied to clipboard." &
|
notify-send "'$chosen' copied to clipboard." &
|
||||||
fi
|
fi
|
||||||
|
|||||||
@ -4,7 +4,7 @@
|
|||||||
if [ -f "$1" ]; then
|
if [ -f "$1" ]; then
|
||||||
# Try to get DOI from pdfinfo or pdftotext output.
|
# Try to get DOI from pdfinfo or pdftotext output.
|
||||||
doi=$(pdfinfo "$1" | grep -io "doi:.*") ||
|
doi=$(pdfinfo "$1" | grep -io "doi:.*") ||
|
||||||
doi=$(pdftotext "$1" 2>/dev/null - | grep -io "doi:.*" -m 1) ||
|
doi=$(pdftotext "$1" 2>/dev/null - | sed -n '/[dD][oO][iI]:/{s/.*[dD][oO][iI]:\s*\(\S\+[[:alnum:]]\).*/\1/p;q}') ||
|
||||||
exit 1
|
exit 1
|
||||||
else
|
else
|
||||||
doi="$1"
|
doi="$1"
|
||||||
|
|||||||
12
.local/bin/getcomproot
Executable file
12
.local/bin/getcomproot
Executable file
@ -0,0 +1,12 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# A helper script for LaTeX/groff files used by `compiler` and `opout`.
|
||||||
|
# The user can add the root file of a larger project as a comment as below:
|
||||||
|
# % root = mainfile.tex
|
||||||
|
# And the compiler script will run on that instead of the opened file.
|
||||||
|
|
||||||
|
texroot="$(grep -i "^.\+\s*root\s*=\s*\S\+" "$1")"
|
||||||
|
texroot="${texroot##*=}"
|
||||||
|
texroot="${texroot//[\"\' ]}"
|
||||||
|
|
||||||
|
[ -f "$texroot" ] && readlink -f "$texroot" || exit 1
|
||||||
@ -1,6 +1,6 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
# This is a wrapper script for lb that allows it to create image previews with
|
# This is a wrapper script for lf that allows it to create image previews with
|
||||||
# ueberzug. This works in concert with the lf configuration file and the
|
# ueberzug. This works in concert with the lf configuration file and the
|
||||||
# lf-cleaner script.
|
# lf-cleaner script.
|
||||||
|
|
||||||
|
|||||||
@ -1,23 +1,26 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
# Feed script a url or file location.
|
# Feed script a url or file location.
|
||||||
# If an image, it will view in sxiv,
|
# If an image, it will view in nsxiv,
|
||||||
# if a video or gif, it will view in mpv
|
# if a video or gif, it will view in mpv
|
||||||
# if a music file or pdf, it will download,
|
# if a music file or pdf, it will download,
|
||||||
# otherwise it opens link in browser.
|
# otherwise it opens link in browser.
|
||||||
|
|
||||||
# If no url given. Opens browser. For using script as $BROWSER.
|
if [ -z "$1" ]; then
|
||||||
[ -z "$1" ] && { "$BROWSER"; exit; }
|
url="$(xclip -o)"
|
||||||
|
else
|
||||||
|
url="$1"
|
||||||
|
fi
|
||||||
|
|
||||||
case "$1" in
|
case "$url" in
|
||||||
*mkv|*webm|*mp4|*youtube.com/watch*|*youtube.com/playlist*|*youtu.be*|*hooktube.com*|*bitchute.com*|*videos.lukesmith.xyz*|*odysee.com*)
|
*mkv|*webm|*mp4|*youtube.com/watch*|*youtube.com/playlist*|*youtube.com/shorts*|*youtu.be*|*hooktube.com*|*bitchute.com*|*videos.lukesmith.xyz*|*odysee.com*)
|
||||||
setsid -f mpv -quiet "$1" >/dev/null 2>&1 ;;
|
setsid -f mpv -quiet "$url" >/dev/null 2>&1 ;;
|
||||||
*png|*jpg|*jpe|*jpeg|*gif)
|
*png|*jpg|*jpe|*jpeg|*gif|*webp)
|
||||||
curl -sL "$1" > "/tmp/$(echo "$1" | sed "s/.*\///;s/%20/ /g")" && sxiv -a "/tmp/$(echo "$1" | sed "s/.*\///;s/%20/ /g")" >/dev/null 2>&1 & ;;
|
curl -sL "$url" > "/tmp/$(echo "$url" | sed "s/.*\///;s/%20/ /g")" && nsxiv -a "/tmp/$(echo "$url" | sed "s/.*\///;s/%20/ /g")" >/dev/null 2>&1 & ;;
|
||||||
*pdf|*cbz|*cbr)
|
*pdf|*cbz|*cbr)
|
||||||
curl -sL "$1" > "/tmp/$(echo "$1" | sed "s/.*\///;s/%20/ /g")" && zathura "/tmp/$(echo "$1" | sed "s/.*\///;s/%20/ /g")" >/dev/null 2>&1 & ;;
|
curl -sL "$url" > "/tmp/$(echo "$url" | sed "s/.*\///;s/%20/ /g")" && zathura "/tmp/$(echo "$url" | sed "s/.*\///;s/%20/ /g")" >/dev/null 2>&1 & ;;
|
||||||
*mp3|*flac|*opus|*mp3?source*)
|
*mp3|*flac|*opus|*mp3?source*)
|
||||||
qndl "$1" 'curl -LO' >/dev/null 2>&1 ;;
|
qndl "$url" 'curl -LO' >/dev/null 2>&1 ;;
|
||||||
*)
|
*)
|
||||||
[ -f "$1" ] && setsid -f "$TERMINAL" -e "$EDITOR" "$1" >/dev/null 2>&1 || setsid -f "$BROWSER" "$1" >/dev/null 2>&1
|
[ -f "$url" ] && setsid -f "$TERMINAL" -e "$EDITOR" "$url" >/dev/null 2>&1 || setsid -f "$BROWSER" "$url" >/dev/null 2>&1
|
||||||
esac
|
esac
|
||||||
|
|||||||
@ -4,11 +4,15 @@
|
|||||||
# choose the kind of screenshot to take, including copying the image or even
|
# choose the kind of screenshot to take, including copying the image or even
|
||||||
# highlighting an area to copy. scrotcucks on suicidewatch right now.
|
# highlighting an area to copy. scrotcucks on suicidewatch right now.
|
||||||
|
|
||||||
|
# variables
|
||||||
|
output="$(date '+%y%m%d-%H%M-%S').png"
|
||||||
|
xclip_cmd="xclip -sel clip -t image/png"
|
||||||
|
|
||||||
case "$(printf "a selected area\\ncurrent window\\nfull screen\\na selected area (copy)\\ncurrent window (copy)\\nfull screen (copy)" | dmenu -l 6 -i -p "Screenshot which area?")" in
|
case "$(printf "a selected area\\ncurrent window\\nfull screen\\na selected area (copy)\\ncurrent window (copy)\\nfull screen (copy)" | dmenu -l 6 -i -p "Screenshot which area?")" in
|
||||||
"a selected area") maim -s pic-selected-"$(date '+%y%m%d-%H%M-%S').png" ;;
|
"a selected area") maim -u -s pic-selected-"${output}" ;;
|
||||||
"current window") maim -i "$(xdotool getactivewindow)" pic-window-"$(date '+%y%m%d-%H%M-%S').png" ;;
|
"current window") maim -q -d 0.2 -i "$(xdotool getactivewindow)" pic-window-"${output}" ;;
|
||||||
"full screen") maim pic-full-"$(date '+%y%m%d-%H%M-%S').png" ;;
|
"full screen") maim -q -d 0.2 pic-full-"${output}" ;;
|
||||||
"a selected area (copy)") maim -s | xclip -selection clipboard -t image/png ;;
|
"a selected area (copy)") maim -u -s | ${xclip_cmd} ;;
|
||||||
"current window (copy)") maim -i "$(xdotool getactivewindow)" | xclip -selection clipboard -t image/png ;;
|
"current window (copy)") maim -q -d 0.2 -i "$(xdotool getactivewindow)" | ${xclip_cmd} ;;
|
||||||
"full screen (copy)") maim | xclip -selection clipboard -t image/png ;;
|
"full screen (copy)") maim -q -d 0.2 | ${xclip_cmd} ;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
114
.local/bin/mounter
Executable file
114
.local/bin/mounter
Executable file
@ -0,0 +1,114 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Mounts Android Phones and USB drives (encrypted or not). This script will
|
||||||
|
# replace the older `dmenumount` which had extra steps and couldn't handle
|
||||||
|
# encrypted drives.
|
||||||
|
# TODO: Try decrypt for drives in crtypttab
|
||||||
|
# TODO: Add some support for connecting iPhones (although they are annoying).
|
||||||
|
|
||||||
|
IFS='
|
||||||
|
'
|
||||||
|
# Function for escaping cell-phone names.
|
||||||
|
escape(){ echo "$@" | iconv -cf UTF-8 -t ASCII//TRANSLIT | tr -d '[:punct:]' | tr '[:upper:]' '[:lower:]' | tr ' ' '-' | sed "s/-\+/-/g;s/\(^-\|-\$\)//g" ;}
|
||||||
|
|
||||||
|
# Check for phones.
|
||||||
|
phones="$(simple-mtpfs -l 2>/dev/null | sed "s/^/📱/")"
|
||||||
|
mountedphones="$(grep "simple-mtpfs" /etc/mtab)"
|
||||||
|
# If there are already mounted phones, remove them from the list of mountables.
|
||||||
|
[ -n "$mountedphones" ] && phones="$(for phone in $phones; do
|
||||||
|
for mounted in $mountedphones; do
|
||||||
|
escphone="$(escape "$phone")"
|
||||||
|
[[ "$mounted" =~ "$escphone" ]] && break 1
|
||||||
|
done && continue 1
|
||||||
|
echo "$phone"
|
||||||
|
done)"
|
||||||
|
|
||||||
|
# Check for drives.
|
||||||
|
lsblkoutput="$(lsblk -rpo "uuid,name,type,size,label,mountpoint,fstype")"
|
||||||
|
# Get all LUKS drives
|
||||||
|
allluks="$(echo "$lsblkoutput" | grep crypto_LUKS)"
|
||||||
|
# Get a list of the LUKS drive UUIDs already decrypted.
|
||||||
|
decrypted="$(find /dev/disk/by-id/dm-uuid-CRYPT-LUKS2-* | sed "s|.*LUKS2-||;s|-.*||")"
|
||||||
|
# Functioning for formatting drives correctly for dmenu:
|
||||||
|
filter() { sed "s/ /:/g" | awk -F':' '$7==""{printf "%s%s (%s) %s\n",$1,$3,$5,$6}' ; }
|
||||||
|
|
||||||
|
# Get only LUKS drives that are not decrypted.
|
||||||
|
unopenedluks="$(for drive in $allluks; do
|
||||||
|
uuid="${drive%% *}"
|
||||||
|
uuid="${uuid//-}" # This is a bashism.
|
||||||
|
[ -n "$decrypted" ] && for open in $decrypted; do
|
||||||
|
[ "$uuid" = "$open" ] && break 1
|
||||||
|
done && continue 1
|
||||||
|
echo "🔒 $drive"
|
||||||
|
done | filter)"
|
||||||
|
|
||||||
|
# Get all normal, non-encrypted or decrypted partitions that are not mounted.
|
||||||
|
normalparts="$(echo "$lsblkoutput"| grep -v crypto_LUKS | grep 'part\|rom\|crypt' | sed "s/^/💾 /" | filter )"
|
||||||
|
|
||||||
|
# Add all to one variable. If no mountable drives found, exit.
|
||||||
|
alldrives="$(echo "$phones
|
||||||
|
$unopenedluks
|
||||||
|
$normalparts" | sed "/^$/d;s/ *$//")"
|
||||||
|
|
||||||
|
# Quit the script if a sequential command fails.
|
||||||
|
set -e
|
||||||
|
|
||||||
|
test -n "$alldrives"
|
||||||
|
|
||||||
|
# Feed all found drives to dmenu and get user choice.
|
||||||
|
chosen="$(echo "$alldrives" | dmenu -p "Mount which drive?" -i)"
|
||||||
|
|
||||||
|
# Function for prompting user for a mountpoint.
|
||||||
|
getmount(){
|
||||||
|
mp="$(find /mnt /media /mount /home -maxdepth 1 -type d 2>/dev/null | dmenu -i -p "Mount this drive where?")"
|
||||||
|
test -n "$mp"
|
||||||
|
if [ ! -d "$mp" ]; then
|
||||||
|
mkdiryn=$(printf "No\\nYes" | dmenu -i -p "$mp does not exist. Create it?")
|
||||||
|
[ "$mkdiryn" = "Yes" ] && (mkdir -p "$mp" || sudo -A mkdir -p "$mp")
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
attemptmount(){
|
||||||
|
# Attempt to mount without a mountpoint, to see if drive is in fstab.
|
||||||
|
sudo -A mount "$chosen" || return 1
|
||||||
|
notify-send "💾Drive Mounted." "$chosen mounted."
|
||||||
|
exit
|
||||||
|
}
|
||||||
|
|
||||||
|
case "$chosen" in
|
||||||
|
💾*)
|
||||||
|
chosen="${chosen%% *}"
|
||||||
|
chosen="${chosen:1}" # This is a bashism.
|
||||||
|
attemptmount || getmount
|
||||||
|
sudo -A mount "$chosen" "$mp" -o uid="$(id -u)",gid="$(id -g)"
|
||||||
|
notify-send "💾Drive Mounted." "$chosen mounted to $mp."
|
||||||
|
;;
|
||||||
|
|
||||||
|
🔒*)
|
||||||
|
chosen="${chosen%% *}"
|
||||||
|
chosen="${chosen:1}" # This is a bashism.
|
||||||
|
# Number the drive.
|
||||||
|
while true; do
|
||||||
|
[ -f "/dev/mapper/usb$num" ] || break
|
||||||
|
num="$(printf "%02d" "$((num +1))")"
|
||||||
|
done
|
||||||
|
|
||||||
|
# Decrypt in a terminal window
|
||||||
|
${TERMINAL:-st} -n floatterm -g 60x1 -e sudo cryptsetup open "$chosen" "usb$num"
|
||||||
|
# Check if now decrypted.
|
||||||
|
test -b "/dev/mapper/usb$num"
|
||||||
|
|
||||||
|
attemptmount || getmount
|
||||||
|
sudo -A mount "/dev/mapper/usb$num" "$mp" -o uid="$(id -u)",gid="$(id -g)"
|
||||||
|
notify-send "🔓Decrypted drive Mounted." "$chosen decrypted and mounted to $mp."
|
||||||
|
;;
|
||||||
|
|
||||||
|
📱*)
|
||||||
|
notify-send "❗Note" "Remember to allow file access on your phone now."
|
||||||
|
getmount
|
||||||
|
number="${chosen%%:*}"
|
||||||
|
number="${chosen:1}" # This is a bashism.
|
||||||
|
sudo -A simple-mtpfs -o allow_other -o fsname="simple-mtpfs-$(escape "$chosen")" --device "$number" "$mp"
|
||||||
|
notify-send "🤖 Android Mounted." "Android device mounted to $mp."
|
||||||
|
;;
|
||||||
|
esac
|
||||||
@ -7,7 +7,7 @@
|
|||||||
basename="${1%.*}"
|
basename="${1%.*}"
|
||||||
|
|
||||||
case "${*}" in
|
case "${*}" in
|
||||||
*.tex|*.m[dse]|*.[rR]md|*.mom|*.[0-9]) setsid -f xdg-open "$basename".pdf >/dev/null 2>&1 ;;
|
*.tex|*.sil|*.m[dse]|*.[rR]md|*.mom|*.[0-9]) target="$(getcomproot "$1" || echo "$1")" ; setsid -f xdg-open "${target%.*}".pdf >/dev/null 2>&1 ;;
|
||||||
*.html) setsid -f "$BROWSER" "$basename".html >/dev/null 2>&1 ;;
|
*.html) setsid -f "$BROWSER" "$basename".html >/dev/null 2>&1 ;;
|
||||||
*.sent) setsid -f sent "$1" >/dev/null 2>&1 ;;
|
*.sent) setsid -f sent "$1" >/dev/null 2>&1 ;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
@ -9,31 +9,29 @@
|
|||||||
# computer to have its time properly synced. This can be done with the command
|
# computer to have its time properly synced. This can be done with the command
|
||||||
# below which requires the package `ntp`.
|
# below which requires the package `ntp`.
|
||||||
|
|
||||||
ifinstalled pass pass-otp
|
ifinstalled pass pass-otp || exit 1
|
||||||
|
|
||||||
dir="${PASSWORD_STORE_DIR}"
|
dir="${PASSWORD_STORE_DIR}"
|
||||||
|
|
||||||
choice="$({ echo "🆕add" ; echo "🕙sync-time" ; ls ${dir}/*-otp.gpg ;} | sed "s/.*\///;s/-otp.gpg//" | dmenu -p "Pick a 2FA:")"
|
choice="$({ echo "🆕add" ; echo "🕙sync-time" ; ls "$dir"/*-otp.gpg ;} | sed "s/.*\///;s/-otp.gpg//" | dmenu -p "Pick a 2FA:")"
|
||||||
|
|
||||||
case $choice in
|
case $choice in
|
||||||
🆕add )
|
🆕add )
|
||||||
ifinstalled maim zbar xclip || exit 1
|
ifinstalled maim zbar || exit 1
|
||||||
|
|
||||||
temp="$dir/temp.png"
|
temp=$(mktemp -p "$XDG_RUNTIME_DIR" --suffix=.png)
|
||||||
otp="otp-test-script"
|
otp="otp-test-script"
|
||||||
trap 'shred -fu $temp; pass rm $otp' HUP INT QUIT TERM PWR EXIT
|
trap 'rm -f $temp; pass rm -f $otp' HUP INT QUIT TERM PWR EXIT
|
||||||
|
|
||||||
notify-send "Scan the image." "Scan the OTP QR code."
|
notify-send "Scan the image." "Scan the OTP QR code."
|
||||||
|
|
||||||
maim -s "$temp" || exit 1
|
maim -s "$temp" || exit 1
|
||||||
info="$(zbarimg -q "$temp")"
|
info="$(zbarimg -q "$temp")"
|
||||||
info="${info#QR-Code:}"
|
info="${info#QR-Code:}"
|
||||||
issuer="$(echo "$info" | grep -o "issuer=[A-z0-9]\+")"
|
|
||||||
name="${issuer#issuer=}"
|
|
||||||
|
|
||||||
if echo "$info" | pass otp insert "$otp"; then
|
if echo "$info" | pass otp insert "$otp"; then
|
||||||
while true ; do
|
while true ; do
|
||||||
export name="$(dmenu -p "Give this One Time Password a one-word name:")"
|
export name="$(echo | dmenu -p "Give this One Time Password a one-word name:")"
|
||||||
echo "$name" | grep -q -- "^[A-z0-9-]\+$" && break
|
echo "$name" | grep -q -- "^[A-z0-9-]\+$" && break
|
||||||
done
|
done
|
||||||
pass mv "$otp" "$name-otp"
|
pass mv "$otp" "$name-otp"
|
||||||
@ -41,7 +39,6 @@ case $choice in
|
|||||||
else
|
else
|
||||||
notify-send "No OTP data found." "Try to scan the image again more precisely."
|
notify-send "No OTP data found." "Try to scan the image again more precisely."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
;;
|
;;
|
||||||
🕙sync-time )
|
🕙sync-time )
|
||||||
ifinstalled ntp || exit 1
|
ifinstalled ntp || exit 1
|
||||||
|
|||||||
@ -3,7 +3,7 @@
|
|||||||
# first argument is the video link, second is the quality (360, 480 or 1080)
|
# first argument is the video link, second is the quality (360, 480 or 1080)
|
||||||
# 13/07/20 - Arthur Bais
|
# 13/07/20 - Arthur Bais
|
||||||
|
|
||||||
instance=$(echo "$1" | sed "s/\/w.\+//")
|
instance=$(echo "$1" | sed "s|/w.\+||")
|
||||||
vidid=$(echo "$1" | sed "s/.\+\///")
|
vidid=$(echo "$1" | sed "s|.\+/||")
|
||||||
link=$(curl -s "$instance/api/v1/videos/$vidid" | grep -o "$instance/download/torrents/.\{37\}$2.torrent")
|
link=$(curl -s "$instance/api/v1/videos/$vidid" | grep -o "$instance/download/torrents/.\{37\}$2.torrent")
|
||||||
transadd "$link"
|
transadd "$link"
|
||||||
|
|||||||
@ -1,8 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# A dmenu binary prompt script.
|
|
||||||
# Gives a dmenu prompt labeled with $1 to perform command $2.
|
|
||||||
# For example:
|
|
||||||
# `./prompt "Do you want to shutdown?" "shutdown -h now"`
|
|
||||||
|
|
||||||
[ "$(printf "No\\nYes" | dmenu -i -p "$1" -nb darkred -sb red -sf white -nf gray )" = "Yes" ] && $2
|
|
||||||
8
.local/bin/remapd
Executable file
8
.local/bin/remapd
Executable file
@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Rerun the remaps script whenever a new input device is added.
|
||||||
|
|
||||||
|
while :; do
|
||||||
|
remaps
|
||||||
|
grep -qP -m1 '[^un]bind.+\/[^:]+\(usb\)' <(udevadm monitor -u -t seat -s input -s usb)
|
||||||
|
done
|
||||||
@ -8,4 +8,4 @@ setxkbmap -option caps:super,altwin:menu_win
|
|||||||
# When caps lock is pressed only once, treat it as escape.
|
# When caps lock is pressed only once, treat it as escape.
|
||||||
killall xcape 2>/dev/null ; xcape -e 'Super_L=Escape'
|
killall xcape 2>/dev/null ; xcape -e 'Super_L=Escape'
|
||||||
# Turn off caps lock if on since there is no longer a key for it.
|
# Turn off caps lock if on since there is no longer a key for it.
|
||||||
xset -q | grep "Caps Lock:\s*on" && xdotool key Caps_Lock
|
xset -q | grep -q "Caps Lock:\s*on" && xdotool key Caps_Lock
|
||||||
|
|||||||
@ -1,11 +1,11 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
# When I open an image from the file manager in sxiv (the image viewer), I want
|
# When I open an image from the file manager in nsxiv (the image viewer), I want
|
||||||
# to be able to press the next/previous keys to key through the rest of the
|
# to be able to press the next/previous keys to key through the rest of the
|
||||||
# images in the same directory. This script "rotates" the content of a
|
# images in the same directory. This script "rotates" the content of a
|
||||||
# directory based on the first chosen file, so that if I open the 15th image,
|
# directory based on the first chosen file, so that if I open the 15th image,
|
||||||
# if I press next, it will go to the 16th etc. Autistic, I know, but this is
|
# if I press next, it will go to the 16th etc. Autistic, I know, but this is
|
||||||
# one of the reasons that sxiv is great for being able to read standard input.
|
# one of the reasons that nsxiv is great for being able to read standard input.
|
||||||
|
|
||||||
[ -z "$1" ] && echo "usage: rotdir regex 2>&1" && exit 1
|
[ -z "$1" ] && echo "usage: rotdir regex 2>&1" && exit 1
|
||||||
base="$(basename "$1")"
|
base="$(basename "$1")"
|
||||||
|
|||||||
@ -1,10 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# Open a terminal window in the same directory as the currently active window.
|
|
||||||
|
|
||||||
PID=$(xprop -id "$(xprop -root | xprop -root | sed -n "/_NET_ACTIVE_WINDOW/ s/^.*# // p")" | sed -n "/PID/ s/^.*= // p")
|
|
||||||
PID="$(pstree -lpA "$PID")"
|
|
||||||
PID="${PID##*(}"
|
|
||||||
PID="${PID%)}"
|
|
||||||
cd "$(readlink /proc/"$PID"/cwd)" || return 1
|
|
||||||
"$TERMINAL"
|
|
||||||
22
.local/bin/sd
Executable file
22
.local/bin/sd
Executable file
@ -0,0 +1,22 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Open a terminal window in the same directory as the currently active window.
|
||||||
|
|
||||||
|
windowPID=$(xprop -id "$(xprop -root | sed -n "/_NET_ACTIVE_WINDOW/ s/^.*# // p")" | sed -n "/PID/ s/^.*= // p")
|
||||||
|
PIDlist=$(pstree -lpATna "$windowPID" | sed -En 's/.*,([0-9]+).*/\1/p' | tac)
|
||||||
|
for PID in $PIDlist; do
|
||||||
|
cmdline=$(ps -o args= -p "$PID")
|
||||||
|
process_group_leader=$(ps -o comm= -p "$(ps -o pgid= -p "$PID" | tr -d ' ')")
|
||||||
|
cwd=$(readlink /proc/"$PID"/cwd)
|
||||||
|
# zsh and lf won't be ignored even if it shows ~ or /
|
||||||
|
case "$cmdline" in
|
||||||
|
'lf -server') continue ;;
|
||||||
|
"${SHELL##*/}"|'lf'|'lf '*) break ;;
|
||||||
|
esac
|
||||||
|
# git (and its sub-processes) will show the root of a repository instead of the actual cwd, so they're ignored
|
||||||
|
[ "$process_group_leader" = 'git' ] || [ ! -d "$cwd" ] && continue
|
||||||
|
# This is to ignore programs that show ~ or / instead of the actual working directory
|
||||||
|
[ "$cwd" != "$HOME" ] && [ "$cwd" != '/' ] && break
|
||||||
|
done
|
||||||
|
[ "$PWD" != "$cwd" ] && [ -d "$cwd" ] && { cd "$cwd" || exit 1; }
|
||||||
|
"$TERMINAL"
|
||||||
@ -13,17 +13,23 @@ bgloc="${XDG_DATA_HOME:-$HOME/.local/share}/bg"
|
|||||||
dunstconf="${XDG_CONFIG_HOME:-$HOME/.config}/dunst/dunstrc"
|
dunstconf="${XDG_CONFIG_HOME:-$HOME/.config}/dunst/dunstrc"
|
||||||
zathuraconf="${XDG_CONFIG_HOME:-$HOME/.config}/zathura/zathurarc"
|
zathuraconf="${XDG_CONFIG_HOME:-$HOME/.config}/zathura/zathurarc"
|
||||||
|
|
||||||
|
# Give -s as parameter to make notifications silent.
|
||||||
|
while getopts "s" o; do case "${o}" in
|
||||||
|
s) silent='1' ;;
|
||||||
|
esac done
|
||||||
|
|
||||||
|
shift $((OPTIND - 1))
|
||||||
|
|
||||||
trueloc="$(readlink -f "$1")" &&
|
trueloc="$(readlink -f "$1")" &&
|
||||||
case "$(file --mime-type -b "$trueloc")" in
|
case "$(file --mime-type -b "$trueloc")" in
|
||||||
image/* ) ln -sf "$(readlink -f "$1")" "$bgloc" && notify-send -i "$bgloc" "Changing wallpaper..." ;;
|
image/* ) ln -sf "$trueloc" "$bgloc" && [ -z "$silent" ] && notify-send -i "$bgloc" "Changing wallpaper..." ;;
|
||||||
inode/directory ) ln -sf "$(find "$trueloc" -iregex '.*.\(jpg\|jpeg\|png\|gif\)' -type f | shuf -n 1)" "$bgloc" && notify-send -i "$bgloc" "Random Wallpaper chosen." ;;
|
inode/directory ) ln -sf "$(find "$trueloc" -iregex '.*.\(jpg\|jpeg\|png\|gif\)' -type f | shuf -n 1)" "$bgloc" && [ -z "$silent" ] && notify-send -i "$bgloc" "Random Wallpaper chosen." ;;
|
||||||
*) notify-send "Error" "Not a valid image." ; exit 1;;
|
*) [ -z "$silent" ] && notify-send "🖼️ Error" "Not a valid image or directory." ; exit 1;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# If pywal is installed, use it.
|
# If pywal is installed, use it.
|
||||||
if command -v wal >/dev/null 2>&1 ; then
|
if command -v wal >/dev/null 2>&1 ; then
|
||||||
wal -i "$(readlink -f $bgloc)" -o "${XDG_CONFIG_HOME:-$HOME/.config}/wal/postrun" >/dev/null 2>&1 &&
|
wal -n -i "$(readlink -f $bgloc)" -o "${XDG_CONFIG_HOME:-$HOME/.config}/wal/postrun" >/dev/null 2>&1
|
||||||
pidof dwm >/dev/null && xdotool key super+F12
|
|
||||||
# If pywal is removed, return config files to normal.
|
# If pywal is removed, return config files to normal.
|
||||||
else
|
else
|
||||||
[ -f "$dunstconf.bak" ] && unlink "$dunstconf" && mv "$dunstconf.bak" "$dunstconf"
|
[ -f "$dunstconf.bak" ] && unlink "$dunstconf" && mv "$dunstconf.bak" "$dunstconf"
|
||||||
@ -31,3 +37,5 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
xwallpaper --zoom "$bgloc"
|
xwallpaper --zoom "$bgloc"
|
||||||
|
# If running, dwm hit the key to refresh the color scheme.
|
||||||
|
pidof dwm >/dev/null && xdotool key super+F5
|
||||||
|
|||||||
@ -22,9 +22,9 @@ printf "\" vim: filetype=vim\\n" > "$vifm_shortcuts"
|
|||||||
# Format the `directories` file in the correct syntax and sent it to all three configs.
|
# Format the `directories` file in the correct syntax and sent it to all three configs.
|
||||||
eval "echo \"$(cat "$bmdirs")\"" | \
|
eval "echo \"$(cat "$bmdirs")\"" | \
|
||||||
awk "!/^\s*#/ && !/^\s*\$/ {gsub(\"\\\s*#.*$\",\"\");
|
awk "!/^\s*#/ && !/^\s*\$/ {gsub(\"\\\s*#.*$\",\"\");
|
||||||
printf(\"%s=\42cd %s && ls -a\42 \\\\\n\",\$1,\$2) >> \"$shell_shortcuts\" ;
|
printf(\"%s=\42cd %s && ls -A\42 \\\\\n\",\$1,\$2) >> \"$shell_shortcuts\" ;
|
||||||
printf(\"hash -d %s=%s \n\",\$1,\$2) >> \"$zsh_named_dirs\" ;
|
printf(\"hash -d %s=%s \n\",\$1,\$2) >> \"$zsh_named_dirs\" ;
|
||||||
printf(\"abbr %s \42cd %s; and ls -a\42\n\",\$1,\$2) >> \"$fish_shortcuts\" ;
|
printf(\"abbr %s \42cd %s; and ls -A\42\n\",\$1,\$2) >> \"$fish_shortcuts\" ;
|
||||||
printf(\"map g%s :cd %s<CR>\nmap t%s <tab>:cd %s<CR><tab>\nmap M%s <tab>:cd %s<CR><tab>:mo<CR>\nmap Y%s <tab>:cd %s<CR><tab>:co<CR> \n\",\$1,\$2, \$1, \$2, \$1, \$2, \$1, \$2) >> \"$vifm_shortcuts\" ;
|
printf(\"map g%s :cd %s<CR>\nmap t%s <tab>:cd %s<CR><tab>\nmap M%s <tab>:cd %s<CR><tab>:mo<CR>\nmap Y%s <tab>:cd %s<CR><tab>:co<CR> \n\",\$1,\$2, \$1, \$2, \$1, \$2, \$1, \$2) >> \"$vifm_shortcuts\" ;
|
||||||
printf(\"config.bind(';%s', \42set downloads.location.directory %s ;; hint links download\42) \n\",\$1,\$2) >> \"$qute_shortcuts\" ;
|
printf(\"config.bind(';%s', \42set downloads.location.directory %s ;; hint links download\42) \n\",\$1,\$2) >> \"$qute_shortcuts\" ;
|
||||||
printf(\"map g%s cd %s\nmap t%s tab_new %s\nmap m%s shell mv -v %%s %s\nmap Y%s shell cp -rv %%s %s \n\",\$1,\$2,\$1,\$2, \$1, \$2, \$1, \$2) >> \"$ranger_shortcuts\" ;
|
printf(\"map g%s cd %s\nmap t%s tab_new %s\nmap m%s shell mv -v %%s %s\nmap Y%s shell cp -rv %%s %s \n\",\$1,\$2,\$1,\$2, \$1, \$2, \$1, \$2) >> \"$ranger_shortcuts\" ;
|
||||||
|
|||||||
@ -9,7 +9,7 @@
|
|||||||
# Application cache if not stated elsewhere.
|
# Application cache if not stated elsewhere.
|
||||||
cache="${XDG_CACHE_HOME:-$HOME/.cache}/slider"
|
cache="${XDG_CACHE_HOME:-$HOME/.cache}/slider"
|
||||||
|
|
||||||
while getopts "hvrpi:c:a:o:d:f:t:e:x:" o; do case "${o}" in
|
while getopts "hvrpi:c:a:o:d:f:t:e:x:s:" o; do case "${o}" in
|
||||||
c) bgc="$OPTARG" ;;
|
c) bgc="$OPTARG" ;;
|
||||||
t) fgc="$OPTARG" ;;
|
t) fgc="$OPTARG" ;;
|
||||||
f) font="$OPTARG" ;;
|
f) font="$OPTARG" ;;
|
||||||
|
|||||||
@ -13,7 +13,7 @@ case $BLOCK_BUTTON in
|
|||||||
- Scroll to change adjust xbacklight." ;;
|
- Scroll to change adjust xbacklight." ;;
|
||||||
4) xbacklight -inc 10 ;;
|
4) xbacklight -inc 10 ;;
|
||||||
5) xbacklight -dec 10 ;;
|
5) xbacklight -dec 10 ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# Loop through all attached batteries and format the info
|
# Loop through all attached batteries and format the info
|
||||||
|
|||||||
@ -19,11 +19,11 @@ case "$clock" in
|
|||||||
esac
|
esac
|
||||||
|
|
||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) notify-send "This Month" "$(cal --color=always | sed "s/..7m/<b><span color=\"red\">/;s/..27m/<\/span><\/b>/")" && notify-send "Appointments" "$(calcurse -d3)" ;;
|
1) notify-send "This Month" "$(cal | sed "s/\<$(date +'%e')\>/<b><span color='red'>&<\/span><\/b>/")" && notify-send "Appointments" "$(calcurse -d3)" ;;
|
||||||
2) setsid -f "$TERMINAL" -e calcurse ;;
|
2) setsid -f "$TERMINAL" -e calcurse ;;
|
||||||
3) notify-send "📅 Time/date module" "\- Left click to show upcoming appointments for the next three days via \`calcurse -d3\` and show the month via \`cal\`
|
3) notify-send "📅 Time/date module" "\- Left click to show upcoming appointments for the next three days via \`calcurse -d3\` and show the month via \`cal\`
|
||||||
- Middle click opens calcurse if installed" ;;
|
- Middle click opens calcurse if installed" ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
date "+%Y %b %d (%a) $icon%I:%M:%S%p"
|
date "+%Y %b %d (%a) $icon%I:%M:%S%p"
|
||||||
|
|||||||
@ -6,7 +6,7 @@ case $BLOCK_BUTTON in
|
|||||||
3) notify-send "🖥 CPU module " "\- Shows CPU temperature.
|
3) notify-send "🖥 CPU module " "\- Shows CPU temperature.
|
||||||
- Click to show intensive processes.
|
- Click to show intensive processes.
|
||||||
- Middle click to open htop." ;;
|
- Middle click to open htop." ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
sensors | awk '/Core 0/ {print "🌡" $3}'
|
sensors | awk '/Core 0/ {print "🌡" $3}'
|
||||||
|
|||||||
@ -12,7 +12,7 @@ case $BLOCK_BUTTON in
|
|||||||
2) setsid -f "$TERMINAL" -e htop ;;
|
2) setsid -f "$TERMINAL" -e htop ;;
|
||||||
3) notify-send "🪨 CPU load module" "Each bar represents
|
3) notify-send "🪨 CPU load module" "Each bar represents
|
||||||
one CPU core";;
|
one CPU core";;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# id total idle
|
# id total idle
|
||||||
|
|||||||
@ -11,7 +11,7 @@ case $BLOCK_BUTTON in
|
|||||||
1) notify-send "💽 Disk space" "$(df -h --output=target,used,size)" ;;
|
1) notify-send "💽 Disk space" "$(df -h --output=target,used,size)" ;;
|
||||||
3) notify-send "💽 Disk module" "\- Shows used hard drive space.
|
3) notify-send "💽 Disk module" "\- Shows used hard drive space.
|
||||||
- Click to show all disk info." ;;
|
- Click to show all disk info." ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
case "$location" in
|
case "$location" in
|
||||||
|
|||||||
@ -6,7 +6,8 @@ secs=600 # Download a new doppler radar if one hasn't been downloaded in $secs s
|
|||||||
radarloc="${XDG_CACHE_HOME:-$HOME/.cache}/radar"
|
radarloc="${XDG_CACHE_HOME:-$HOME/.cache}/radar"
|
||||||
doppler="${XDG_CACHE_HOME:-$HOME/.cache}/doppler.gif"
|
doppler="${XDG_CACHE_HOME:-$HOME/.cache}/doppler.gif"
|
||||||
|
|
||||||
pickloc() { chosen="$(echo "US: Northeast
|
pickloc() { chosen="$(echo "US: CONUS: Continental United States
|
||||||
|
US: Northeast
|
||||||
US: Southeast
|
US: Southeast
|
||||||
US: PacNorthWest
|
US: PacNorthWest
|
||||||
US: PacSouthWest
|
US: PacSouthWest
|
||||||
@ -55,7 +56,7 @@ US: KUDX: Rapid City, SD
|
|||||||
US: KRIW: Riverton, WY
|
US: KRIW: Riverton, WY
|
||||||
US: KSGF: Springfield, MO
|
US: KSGF: Springfield, MO
|
||||||
US: KLSX: St. LOUIS, MO
|
US: KLSX: St. LOUIS, MO
|
||||||
US: KFSD: Sioux Falls, IA
|
US: KFSD: Sioux Falls, SD
|
||||||
US: KTWX: Topeka, KS
|
US: KTWX: Topeka, KS
|
||||||
US: KICT: Wichita, KS
|
US: KICT: Wichita, KS
|
||||||
US: KVWX: Paducah, KY
|
US: KVWX: Paducah, KY
|
||||||
@ -183,7 +184,7 @@ US: KVNX: Norman, OK
|
|||||||
US: KVBX: Vandenberg Afb: Orcutt, CA
|
US: KVBX: Vandenberg Afb: Orcutt, CA
|
||||||
EU: Europe
|
EU: Europe
|
||||||
EU: GB: Great Brittain
|
EU: GB: Great Brittain
|
||||||
EU: SCAN: Scandinavia
|
EU: SCAN: Scandinavia. Norway, Sweden And Denmark
|
||||||
EU: ALPS: The Alps
|
EU: ALPS: The Alps
|
||||||
EU: NL: The Netherlands
|
EU: NL: The Netherlands
|
||||||
EU: DE: Germany
|
EU: DE: Germany
|
||||||
@ -222,26 +223,45 @@ AF: TZ: Tanzania
|
|||||||
AF: TN: Tunisia
|
AF: TN: Tunisia
|
||||||
AF: ZM: Zambia
|
AF: ZM: Zambia
|
||||||
AF: KE: Kenya
|
AF: KE: Kenya
|
||||||
AF: AO: Angola" | dmenu -r -i -l 50 -p "Select a radar to use as default:" | tr "[:lower:]" "[:upper:]")"
|
AF: AO: Angola
|
||||||
|
DE: BAW: Baden-Württemberg
|
||||||
|
DE: BAY: Bavaria
|
||||||
|
DE: BBB: Berlin
|
||||||
|
DE: BBB: Brandenburg
|
||||||
|
DE: HES: Hesse
|
||||||
|
DE: MVP: Mecklenburg-Western Pomerania
|
||||||
|
DE: NIB: Lower Saxony
|
||||||
|
DE: NIB: Bremen
|
||||||
|
DE: NRW: North Rhine-Westphalia
|
||||||
|
DE: RPS: Rhineland-Palatinate
|
||||||
|
DE: RPS: Saarland
|
||||||
|
DE: SAC: Saxony
|
||||||
|
DE: SAA: Saxony-Anhalt
|
||||||
|
DE: SHH: Schleswig-Holstein
|
||||||
|
DE: SHH: Hamburg
|
||||||
|
DE: THU: Thuringia" | dmenu -r -i -l 50 -p "Select a radar to use as default:" | tr "[:lower:]" "[:upper:]")"
|
||||||
|
|
||||||
|
# Ensure user did not escape.
|
||||||
|
[ -z "$chosen" ] && exit 1
|
||||||
|
|
||||||
# Set continent code and radar code.
|
# Set continent code and radar code.
|
||||||
continentcode=$(echo "$chosen" | sed "s/:.*//")
|
continentcode=${chosen%%:*}
|
||||||
radarcode=$(echo "$chosen" | sed "s/..: // ; s/:.*//")
|
radarcode=${chosen#* } radarcode=${radarcode%:*}
|
||||||
|
|
||||||
# Sanity check of selection and ensure user did not escape.
|
# Print codes to $radarloc file.
|
||||||
echo "$radarcode" | grep -q "^[A-Z]\+$" && printf "%s,%s\\n" "$continentcode" "$radarcode" > "$radarloc" ;}
|
printf "%s,%s\\n" "$continentcode" "$radarcode" > "$radarloc" ;}
|
||||||
|
|
||||||
getdoppler() {
|
getdoppler() {
|
||||||
cont="$(sed "s/,.*//" "$radarloc")"
|
cont=$(cut -c -2 "$radarloc")
|
||||||
loc="$(cut -c 4- "$radarloc")"
|
loc=$(cut -c 4- "$radarloc")
|
||||||
notify-send "🌦️ Doppler RADAR" "Pulling most recent Doppler RADAR for $loc."
|
notify-send "🌦️ Doppler RADAR" "Pulling most recent Doppler RADAR for $loc."
|
||||||
if [ "$cont" = "US" ] ; then
|
case "$cont" in
|
||||||
curl -sL "https://radar.weather.gov/ridge/lite/${loc}_loop.gif" > "$doppler" ;
|
"US") curl -sL "https://radar.weather.gov/ridge/standard/${loc}_loop.gif" > "$doppler" ;;
|
||||||
elif [ "$cont" = "EU" ] ; then
|
"EU") curl -sL "https://api.sat24.com/animated/${loc}/rainTMC/2/" > "$doppler" ;;
|
||||||
curl -sL "https://api.sat24.com/animated/${loc}/rainTMC/2/" > "$doppler" ;
|
"AF") curl -sL "https://api.sat24.com/animated/${loc}/rain/2/" > "$doppler" ;;
|
||||||
elif [ "$cont" = "AF" ] ; then
|
"DE") loc="$(echo "$loc" | tr "[:upper:]" "[:lower:]")"
|
||||||
curl -sL "https://api.sat24.com/animated/${loc}/rain/2/" > "$doppler" ;
|
curl -sL "https://www.dwd.de/DWD/wetter/radar/radfilm_${loc}_akt.gif" > "$doppler" ;;
|
||||||
fi
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
showdoppler() { setsid -f mpv --no-osc --loop=inf --no-terminal "$doppler" ;}
|
showdoppler() { setsid -f mpv --no-osc --loop=inf --no-terminal "$doppler" ;}
|
||||||
@ -254,7 +274,7 @@ case $BLOCK_BUTTON in
|
|||||||
3) notify-send "🗺️ Doppler RADAR module" "\- Left click for local Doppler RADAR.
|
3) notify-send "🗺️ Doppler RADAR module" "\- Left click for local Doppler RADAR.
|
||||||
- Middle click to update RADAR location.
|
- Middle click to update RADAR location.
|
||||||
After $secs seconds, new clicks will also automatically update the doppler RADAR." ;;
|
After $secs seconds, new clicks will also automatically update the doppler RADAR." ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
echo 🗺️
|
echo 🌅
|
||||||
|
|||||||
@ -1,35 +1,53 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
# Displays todays precipication chance (☔) and daily low (🥶) and high (🌞).
|
# Displays today's precipication chance (☔), and daily low (🥶) and high (🌞).
|
||||||
# Usually intended for the statusbar.
|
# Usually intended for the statusbar.
|
||||||
|
|
||||||
# If we have internet, get a weather report from wttr.in and store it locally.
|
url="${WTTRURL:-wttr.in}"
|
||||||
# You could set up a shell alias to view the full file in a pager in the
|
weatherreport="${XDG_CACHE_HOME:-$HOME/.cache}/weatherreport"
|
||||||
# terminal if desired. This function will only be run once a day when needed.
|
|
||||||
weatherreport="${XDG_DATA_HOME:-$HOME/.local/share}/weatherreport"
|
|
||||||
getforecast() { curl -sf "wttr.in/$LOCATION" > "$weatherreport" || exit 1 ;}
|
|
||||||
|
|
||||||
# Some very particular and terse stream manipulation. We get the maximum
|
# Get a weather report from 'wttr.in' and save it locally.
|
||||||
# precipitation chance and the daily high and low from the downloaded file and
|
getforecast() { timeout --signal=1 2s curl -sf "$url/$LOCATION" > "$weatherreport" || exit 1; }
|
||||||
# display them with coresponding emojis.
|
|
||||||
showweather() { printf "%s" "$(sed '16q;d' "$weatherreport" |
|
# Forecast should be updated only once a day.
|
||||||
grep -wo "[0-9]*%" | sort -rn | sed "s/^/☔/g;1q" | tr -d '\n')"
|
checkforecast() {
|
||||||
sed '13q;d' "$weatherreport" | grep -o "m\\([-+]\\)*[0-9]\\+" | sed 's/+//g' | sort -n -t 'm' -k 2n | sed -e 1b -e '$!d' | tr '\n|m' ' ' | awk '{print " 🥶" $1 "°","🌞" $2 "°"}' ;}
|
[ -s "$weatherreport" ] && [ "$(stat -c %y "$weatherreport" 2>/dev/null |
|
||||||
|
cut -d' ' -f1)" = "$(date '+%Y-%m-%d')" ]
|
||||||
|
}
|
||||||
|
|
||||||
|
getprecipchance() {
|
||||||
|
echo "$weatherdata" | sed '16q;d' | # Extract line 16 from file
|
||||||
|
grep -wo "[0-9]*%" | # Find a sequence of digits followed by '%'
|
||||||
|
sort -rn | # Sort in descending order
|
||||||
|
head -1q # Extract first line
|
||||||
|
}
|
||||||
|
|
||||||
|
getdailyhighlow() {
|
||||||
|
echo "$weatherdata" | sed '13q;d' | # Extract line 13 from file
|
||||||
|
grep -o "m\\([-+]\\)*[0-9]\\+" | # Find temperatures in the format "m<signed number>"
|
||||||
|
sed 's/[+m]//g' | # Remove '+' and 'm'
|
||||||
|
sort -g | # Sort in ascending order
|
||||||
|
sed -e 1b -e '$!d' # Extract the first and last lines
|
||||||
|
}
|
||||||
|
|
||||||
|
readfile() { weatherdata="$(cat "$weatherreport")" ;}
|
||||||
|
|
||||||
|
showweather() {
|
||||||
|
readfile
|
||||||
|
printf "☔%s 🥶%s° 🌞%s°\n" "$(getprecipchance)" $(getdailyhighlow)
|
||||||
|
}
|
||||||
|
|
||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) setsid -f "$TERMINAL" -e less -Srf "$weatherreport" ;;
|
1) setsid -f "$TERMINAL" -e less -Sf "$weatherreport" ;;
|
||||||
2) getforecast && showweather ;;
|
2) getforecast && showweather ;;
|
||||||
3) notify-send "🌈 Weather module" "\- Left click for full forecast.
|
3) notify-send "🌈 Weather module" "\- Left click for full forecast.
|
||||||
- Middle click to update forecast.
|
- Middle click to update forecast.
|
||||||
☔: Chance of rain/snow
|
☔: Chance of rain/snow
|
||||||
🥶: Daily low
|
🥶: Daily low
|
||||||
🌞: Daily high" ;;
|
🌞: Daily high" ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# The test if our forcecast is updated to the day. If it isn't download a new
|
checkforecast || getforecast
|
||||||
# weather report from wttr.in with the above function.
|
|
||||||
[ "$(stat -c %y "$weatherreport" 2>/dev/null | cut -d' ' -f1)" = "$(date '+%Y-%m-%d')" ] ||
|
|
||||||
getforecast
|
|
||||||
|
|
||||||
showweather
|
showweather
|
||||||
|
|||||||
@ -13,5 +13,5 @@ case $BLOCK_BUTTON in
|
|||||||
2) restartwm ;;
|
2) restartwm ;;
|
||||||
3) notify-send "❓ Help module" "\- Left click to open LARBS guide.
|
3) notify-send "❓ Help module" "\- Left click to open LARBS guide.
|
||||||
- Middle click to refresh window manager." ;;
|
- Middle click to refresh window manager." ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac; echo "❓"
|
esac; echo "❓"
|
||||||
|
|||||||
@ -14,13 +14,20 @@ case $BLOCK_BUTTON in
|
|||||||
🌐: ethernet working
|
🌐: ethernet working
|
||||||
🔒: vpn is active
|
🔒: vpn is active
|
||||||
" ;;
|
" ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
if grep -xq 'up' /sys/class/net/w*/operstate 2>/dev/null ; then
|
# Wifi
|
||||||
|
if [ "$(cat /sys/class/net/w*/operstate 2>/dev/null)" = 'up' ] ; then
|
||||||
wifiicon="$(awk '/^\s*w/ { print "📶", int($3 * 100 / 70) "% " }' /proc/net/wireless)"
|
wifiicon="$(awk '/^\s*w/ { print "📶", int($3 * 100 / 70) "% " }' /proc/net/wireless)"
|
||||||
elif grep -xq 'down' /sys/class/net/w*/operstate 2>/dev/null ; then
|
elif [ "$(cat /sys/class/net/w*/operstate 2>/dev/null)" = 'down' ] ; then
|
||||||
grep -xq '0x1003' /sys/class/net/w*/flags && wifiicon="📡 " || wifiicon="❌ "
|
[ "$(cat /sys/class/net/w*/flags 2>/dev/null)" = '0x1003' ] && wifiicon="📡 " || wifiicon="❌ "
|
||||||
fi
|
fi
|
||||||
|
|
||||||
printf "%s%s%s\n" "$wifiicon" "$(sed "s/down/❎/;s/up/🌐/" /sys/class/net/e*/operstate 2>/dev/null)" "$(sed "s/.*/🔒/" /sys/class/net/tun*/operstate 2>/dev/null)"
|
# Ethernet
|
||||||
|
[ "$(cat /sys/class/net/e*/operstate 2>/dev/null)" = 'up' ] && ethericon="🌐" || ethericon="❎"
|
||||||
|
|
||||||
|
# TUN
|
||||||
|
[ -n "$(cat /sys/class/net/tun*/operstate 2>/dev/null)" ] && tunicon=" 🔒"
|
||||||
|
|
||||||
|
printf "%s%s%s\n" "$wifiicon" "$ethericon" "$tunicon"
|
||||||
|
|||||||
@ -5,6 +5,11 @@
|
|||||||
#
|
#
|
||||||
# https://www.maketecheasier.com/ip-address-geolocation-lookups-linux/
|
# https://www.maketecheasier.com/ip-address-geolocation-lookups-linux/
|
||||||
|
|
||||||
ifinstalled "geoip" || exit
|
set -e
|
||||||
addr="$(curl ifconfig.me 2>/dev/null)" || exit
|
|
||||||
grep "flag: " "${XDG_DATA_HOME:-$HOME/.local/share}/larbs/emoji" | grep "$(geoiplookup "$addr" | sed 's/.*, //')" | sed "s/flag: //;s/;.*//"
|
ifinstalled "geoip"
|
||||||
|
addr="$(geoiplookup "$(curl -sfm 1 ifconfig.me 2>/dev/null)")"
|
||||||
|
name="${addr##*, }"
|
||||||
|
flag="$(grep "flag: $name" "${XDG_DATA_HOME:-$HOME/.local/share}/larbs/emoji")"
|
||||||
|
flag="${flag%% *}"
|
||||||
|
printf "%s %s\\n" "$flag" "$name"
|
||||||
|
|||||||
@ -5,12 +5,13 @@ kb="$(setxkbmap -query | grep -oP 'layout:\s*\K\w+')" || exit 1
|
|||||||
|
|
||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) kb_choice="$(awk '/! layout/{flag=1; next} /! variant/{flag=0} flag {print $2, "- " $1}' /usr/share/X11/xkb/rules/base.lst | dmenu -l 15)"
|
1) kb_choice="$(awk '/! layout/{flag=1; next} /! variant/{flag=0} flag {print $2, "- " $1}' /usr/share/X11/xkb/rules/base.lst | dmenu -l 15)"
|
||||||
|
[ -z "$kb_choice" ] && exit 0
|
||||||
kb="$(echo "$kb_choice" | awk '{print $3}')"
|
kb="$(echo "$kb_choice" | awk '{print $3}')"
|
||||||
setxkbmap "$kb"
|
setxkbmap "$kb"
|
||||||
pkill -RTMIN+30 "${STATUSBAR:-dwmblocks}";;
|
pkill -RTMIN+30 "${STATUSBAR:-dwmblocks}";;
|
||||||
3) notify-send "⌨ Keyboard/language module" "$(printf "%s" "\- Current layout: $(setxkbmap -query | grep -oP 'layout:\s*\K\w+')")
|
3) notify-send "⌨ Keyboard/language module" "$(printf "%s" "\- Current layout: $(setxkbmap -query | grep -oP 'layout:\s*\K\w+')")
|
||||||
- Left click to change keyboard.";;
|
- Left click to change keyboard.";;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
echo "$kb"
|
echo "$kb"
|
||||||
|
|||||||
@ -4,13 +4,13 @@
|
|||||||
# When clicked, brings up `neomutt`.
|
# When clicked, brings up `neomutt`.
|
||||||
|
|
||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) setsid -f "$TERMINAL" -e neomutt ;;
|
1) setsid -w -f "$TERMINAL" -e neomutt; pkill -RTMIN+12 "${STATUSBAR:-dwmblocks}" ;;
|
||||||
2) setsid -f mw -Y >/dev/null ;;
|
2) setsid -f mw -Y >/dev/null ;;
|
||||||
3) notify-send "📬 Mail module" "\- Shows unread mail
|
3) notify-send "📬 Mail module" "\- Shows unread mail
|
||||||
- Shows 🔃 if syncing mail
|
- Shows 🔃 if syncing mail
|
||||||
- Left click opens neomutt
|
- Left click opens neomutt
|
||||||
- Middle click syncs mail" ;;
|
- Middle click syncs mail" ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
unread="$(find "${XDG_DATA_HOME:-$HOME/.local/share}"/mail/*/[Ii][Nn][Bb][Oo][Xx]/new/* -type f | wc -l 2>/dev/null)"
|
unread="$(find "${XDG_DATA_HOME:-$HOME/.local/share}"/mail/*/[Ii][Nn][Bb][Oo][Xx]/new/* -type f | wc -l 2>/dev/null)"
|
||||||
|
|||||||
@ -6,7 +6,7 @@ case $BLOCK_BUTTON in
|
|||||||
3) notify-send "🧠 Memory module" "\- Shows Memory Used/Total.
|
3) notify-send "🧠 Memory module" "\- Shows Memory Used/Total.
|
||||||
- Click to show memory hogs.
|
- Click to show memory hogs.
|
||||||
- Middle click to open htop." ;;
|
- Middle click to open htop." ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
free --mebi | sed -n '2{p;q}' | awk '{printf ("🧠%2.2fGiB/%2.2fGiB\n", ( $3 / 1024), ($2 / 1024))}'
|
free --mebi | sed -n '2{p;q}' | awk '{printf ("🧠%2.2fGiB/%2.2fGiB\n", ( $3 / 1024), ($2 / 1024))}'
|
||||||
|
|||||||
@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
moonfile="${XDG_DATA_HOME:-$HOME/.local/share}/moonphase"
|
moonfile="${XDG_DATA_HOME:-$HOME/.local/share}/moonphase"
|
||||||
|
|
||||||
[ "$(stat -c %y "$moonfile" 2>/dev/null | cut -d' ' -f1)" = "$(date '+%Y-%m-%d')" ] ||
|
[ -s "$moonfile" ] && [ "$(stat -c %y "$moonfile" 2>/dev/null | cut -d' ' -f1)" = "$(date '+%Y-%m-%d')" ] ||
|
||||||
{ curl -sf "wttr.in/?format=%m" > "$moonfile" || exit 1 ;}
|
{ curl -sf "wttr.in/?format=%m" > "$moonfile" || exit 1 ;}
|
||||||
|
|
||||||
icon="$(cat "$moonfile")"
|
icon="$(cat "$moonfile")"
|
||||||
@ -33,5 +33,5 @@ case $BLOCK_BUTTON in
|
|||||||
- 🌖: Waning Gibbous
|
- 🌖: Waning Gibbous
|
||||||
- 🌗: Last Quarter
|
- 🌗: Last Quarter
|
||||||
- 🌘: Waning Crescent" ;;
|
- 🌘: Waning Crescent" ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
filter() { mpc | sed "/^volume:/d;s/\\&/&/g;s/\\[paused\\].*/⏸/g;/\\[playing\\].*/d;/^ERROR/Q" | paste -sd ' ' -;}
|
filter() { sed "/^volume:/d;s/\\[paused\\].*/⏸/g;/\\[playing\\].*/d;/^ERROR/Q" | paste -sd ' ' -;}
|
||||||
|
|
||||||
pidof -x sb-mpdup >/dev/null 2>&1 || sb-mpdup >/dev/null 2>&1 &
|
pidof -x sb-mpdup >/dev/null 2>&1 || sb-mpdup >/dev/null 2>&1 &
|
||||||
|
|
||||||
@ -14,6 +14,6 @@ case $BLOCK_BUTTON in
|
|||||||
- Scroll changes track.";; # right click, pause/unpause
|
- Scroll changes track.";; # right click, pause/unpause
|
||||||
4) mpc prev | filter ;; # scroll up, previous
|
4) mpc prev | filter ;; # scroll up, previous
|
||||||
5) mpc next | filter ;; # scroll down, next
|
5) mpc next | filter ;; # scroll down, next
|
||||||
6) mpc status | filter ; "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) mpc status | filter ; setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
*) mpc status | filter ;;
|
*) mpc status | filter ;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
@ -8,7 +8,7 @@ case $BLOCK_BUTTON in
|
|||||||
1) setsid -f "$TERMINAL" -e bmon ;;
|
1) setsid -f "$TERMINAL" -e bmon ;;
|
||||||
3) notify-send "🌐 Network traffic module" "🔻: Traffic received
|
3) notify-send "🌐 Network traffic module" "🔻: Traffic received
|
||||||
🔺: Traffic transmitted" ;;
|
🔺: Traffic transmitted" ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
update() {
|
update() {
|
||||||
@ -17,7 +17,7 @@ update() {
|
|||||||
read -r i < "$arg"
|
read -r i < "$arg"
|
||||||
sum=$(( sum + i ))
|
sum=$(( sum + i ))
|
||||||
done
|
done
|
||||||
cache=${XDG_CACHE_HOME:-$HOME/.cache}/${1##*/}
|
cache=/tmp/${1##*/}
|
||||||
[ -f "$cache" ] && read -r old < "$cache" || old=0
|
[ -f "$cache" ] && read -r old < "$cache" || old=0
|
||||||
printf %d\\n "$sum" > "$cache"
|
printf %d\\n "$sum" > "$cache"
|
||||||
printf %d\\n $(( sum - old ))
|
printf %d\\n $(( sum - old ))
|
||||||
|
|||||||
@ -5,13 +5,13 @@
|
|||||||
|
|
||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) setsid "$TERMINAL" -e newsboat ;;
|
1) setsid "$TERMINAL" -e newsboat ;;
|
||||||
2) setsid -f newsup >/dev/null exit ;;
|
2) setsid -f newsup >/dev/null && exit ;;
|
||||||
3) notify-send "📰 News module" "\- Shows unread news items
|
3) notify-send "📰 News module" "\- Shows unread news items
|
||||||
- Shows 🔃 if updating with \`newsup\`
|
- Shows 🔃 if updating with \`newsup\`
|
||||||
- Left click opens newsboat
|
- Left click opens newsboat
|
||||||
- Middle click syncs RSS feeds
|
- Middle click syncs RSS feeds
|
||||||
<b>Note:</b> Only one instance of newsboat (including updates) may be running at a time." ;;
|
<b>Note:</b> Only one instance of newsboat (including updates) may be running at a time." ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
cat /tmp/newsupdate 2>/dev/null || echo "$(newsboat -x print-unread | awk '{ if($1>0) print "📰" $1}')$(cat "${XDG_CONFIG_HOME:-$HOME/.config}"/newsboat/.update 2>/dev/null)"
|
cat /tmp/newsupdate 2>/dev/null || echo "$(newsboat -x print-unread | awk '{ if($1>0) print "📰" $1}')$(cat "${XDG_CONFIG_HOME:-$HOME/.config}"/newsboat/.update 2>/dev/null)"
|
||||||
|
|||||||
@ -23,7 +23,7 @@ case $BLOCK_BUTTON in
|
|||||||
3) notify-send "🎁 Upgrade module" "📦: number of upgradable packages
|
3) notify-send "🎁 Upgrade module" "📦: number of upgradable packages
|
||||||
- Left click to upgrade packages
|
- Left click to upgrade packages
|
||||||
- Middle click to show upgradable packages" ;;
|
- Middle click to show upgradable packages" ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
pacman -Qu | grep -Fcv "[ignored]" | sed "s/^/📦/;s/^📦0$//g"
|
pacman -Qu | grep -Fcv "[ignored]" | sed "s/^/📦/;s/^📦0$//g"
|
||||||
|
|||||||
@ -1,50 +1,56 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
# Usage:
|
# Usage:
|
||||||
# price <url> <Name of currency> <icon> <Price to show in>
|
# price <currency-base currency> <name of currency> <icon> <signal>
|
||||||
# price bat "Basic Attention Token" 🦁
|
# price bat-btc "Basic Attention Token" 🦁 24
|
||||||
|
# This will give the price of BAT denominated in BTC and will update on
|
||||||
|
# signal 24.
|
||||||
# When the name of the currency is multi-word, put it in quotes.
|
# When the name of the currency is multi-word, put it in quotes.
|
||||||
|
|
||||||
[ -z "$3" ] && exit 1
|
[ -z "$1" ] && exit 1
|
||||||
|
|
||||||
# use $4 as currency, if not passed in use "usd" as default
|
url="${CRYPTOURL:-rate.sx}"
|
||||||
currency="${4:-usd}"
|
target="${1%%-*}"
|
||||||
|
denom="${1##*-}"
|
||||||
|
name="${2:-$1}"
|
||||||
|
icon="${3:-💰}"
|
||||||
|
case "$denom" in
|
||||||
|
"$target"|usd) denom="usd"; symb="$" ;;
|
||||||
|
gbp) symb="£" ;;
|
||||||
|
eur) symb="€" ;;
|
||||||
|
btc) symb="" ;;
|
||||||
|
esac
|
||||||
interval="@14d" # History contained in chart preceded by '@' (7d = 7 days)
|
interval="@14d" # History contained in chart preceded by '@' (7d = 7 days)
|
||||||
dir="${XDG_DATA_HOME:-$HOME/.local/share}/crypto-prices"
|
dir="${XDG_CACHE_HOME:-$HOME/.cache}/crypto-prices"
|
||||||
pricefile="$dir/$1-$currency"
|
pricefile="$dir/$target-$denom"
|
||||||
chartfile="$dir/$1-$currency-chart"
|
chartfile="$dir/$target-$denom-chart"
|
||||||
|
filestat="$(stat -c %x "$pricefile" 2>/dev/null)"
|
||||||
updateprice() { temp="$(mktemp)"
|
|
||||||
curl -s "$currency.rate.sx/1$1" > "$temp" &&
|
|
||||||
mv -f "$temp" "$pricefile" &&
|
|
||||||
curl -s "$currency.rate.sx/$1$interval" > "$temp" &&
|
|
||||||
mv -f "$temp" "$chartfile" ;}
|
|
||||||
|
|
||||||
[ -d "$dir" ] || mkdir -p "$dir"
|
[ -d "$dir" ] || mkdir -p "$dir"
|
||||||
|
|
||||||
[ "$(stat -c %x "$pricefile" 2>/dev/null | cut -d' ' -f1)" != "$(date '+%Y-%m-%d')" ] &&
|
updateprice() { curl -sf -m 1 --fail-early $denom.$url/{1$target,$target$interval} --output "$pricefile" --output "$chartfile" ||
|
||||||
updateprice "$1"
|
rm -f "$pricefile" "$chartfile" ;}
|
||||||
|
|
||||||
|
[ "${filestat%% *}" != "$(date '+%Y-%m-%d')" ] &&
|
||||||
|
updateme="1"
|
||||||
|
|
||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) setsid "$TERMINAL" -e less -Srf "$chartfile" ;;
|
1) setsid "$TERMINAL" -e less -Srf "$chartfile" ;;
|
||||||
2) notify-send -u low "$3 Updating..." "Updating $2 price..."
|
2) notify-send -u low "$icon Updating..." "Updating $name price..." ; updateme="1" ; showupdate="1" ;;
|
||||||
updateprice "$1" && notify-send "$3 Update complete." "$2 price is now
|
3) uptime="$(date -d "$filestat" '+%D at %T' | sed "s|$(date '+%D')|Today|")"
|
||||||
\$$(cat "$pricefile")" ;;
|
notify-send "$icon $name module" "\- <b>Exact price: \$$(cat "$pricefile")</b>
|
||||||
3) uptime="$(date -d "$(stat -c %x "$pricefile")" '+%D at %T' | sed "s|$(date '+%D')|Today|")"
|
|
||||||
notify-send "$3 $2 module" "\- <b>Exact price: \$$(cat "$pricefile")</b>
|
|
||||||
- Left click for chart of changes.
|
- Left click for chart of changes.
|
||||||
- Middle click to update.
|
- Middle click to update.
|
||||||
- Shows 🔃 if updating prices.
|
- Shows 🔃 if updating prices.
|
||||||
- <b>Last updated:
|
- <b>Last updated:
|
||||||
$uptime</b>" ;;
|
$uptime</b>" ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
case "$currency" in
|
[ -n "$updateme" ] &&
|
||||||
usd) symb="$" ;;
|
updateprice "$target" &&
|
||||||
gbp) symb="£" ;;
|
[ -n "$showupdate" ] &&
|
||||||
eur) symb="€" ;;
|
notify-send "$icon Update complete." "$name price is now
|
||||||
btc) symb="₿" ;;
|
\$$(cat "$pricefile")"
|
||||||
esac
|
|
||||||
|
|
||||||
printf "$3$symb%0.2f$after" "$(cat "$pricefile")"
|
[ -f "$pricefile" ] && printf "%s%s%0.2f" "$icon" "$symb" "$(cat "$pricefile")"
|
||||||
|
|||||||
@ -13,7 +13,7 @@ case $BLOCK_BUTTON in
|
|||||||
1) setsid -f "$TERMINAL" -e tsp -l ;;
|
1) setsid -f "$TERMINAL" -e tsp -l ;;
|
||||||
3) notify-send "Tasks module" "🤖: number of running/queued background tasks
|
3) notify-send "Tasks module" "🤖: number of running/queued background tasks
|
||||||
- Left click opens tsp" ;; # Right click
|
- Left click opens tsp" ;; # Right click
|
||||||
2) $EDITOR "$0" ;; # Middle click
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
[ "$num" != "0(0)" ] &&
|
[ "$num" != "0(0)" ] &&
|
||||||
|
|||||||
@ -11,9 +11,9 @@ transmission-remote -l | grep % |
|
|||||||
sort -h | uniq -c | awk '{print $3 $1}' | paste -sd ' ' -
|
sort -h | uniq -c | awk '{print $3 $1}' | paste -sd ' ' -
|
||||||
|
|
||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) setsid -f "$TERMINAL" -e tremc ;;
|
1) setsid -f "$TERMINAL" -e stig ;;
|
||||||
2) td-toggle ;;
|
2) td-toggle ;;
|
||||||
3) notify-send "🌱 Torrent module" "\- Left click to open tremc.
|
3) notify-send "🌱 Torrent module" "\- Left click to open stig.
|
||||||
- Middle click to toggle transmission.
|
- Middle click to toggle transmission.
|
||||||
- Shift click to edit script.
|
- Shift click to edit script.
|
||||||
Module shows number of torrents:
|
Module shows number of torrents:
|
||||||
@ -23,5 +23,5 @@ Module shows number of torrents:
|
|||||||
🔽: downloading
|
🔽: downloading
|
||||||
✅: done
|
✅: done
|
||||||
🌱: done and seeding" ;;
|
🌱: done and seeding" ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
@ -3,28 +3,37 @@
|
|||||||
# Prints the current volume or 🔇 if muted.
|
# Prints the current volume or 🔇 if muted.
|
||||||
|
|
||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) setsid -f "$TERMINAL" -e pulsemixer ;;
|
1) setsid -w -f "$TERMINAL" -e pulsemixer; pkill -RTMIN+10 "${STATUSBAR:-dwmblocks}" ;;
|
||||||
2) pamixer -t ;;
|
2) wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle ;;
|
||||||
4) pamixer --allow-boost -i 1 ;;
|
4) wpctl set-volume @DEFAULT_AUDIO_SINK@ 1%+ ;;
|
||||||
5) pamixer --allow-boost -d 1 ;;
|
5) wpctl set-volume @DEFAULT_AUDIO_SINK@ 1%- ;;
|
||||||
3) notify-send "📢 Volume module" "\- Shows volume 🔊, 🔇 if muted.
|
3) notify-send "📢 Volume module" "\- Shows volume 🔊, 🔇 if muted.
|
||||||
- Middle click to mute.
|
- Middle click to mute.
|
||||||
- Scroll to change." ;;
|
- Scroll to change." ;;
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) setsid -f "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
[ $(pamixer --get-mute) = true ] && echo 🔇 && exit
|
vol="$(wpctl get-volume @DEFAULT_AUDIO_SINK@)"
|
||||||
|
|
||||||
vol="$(pamixer --get-volume)"
|
# If muted, print 🔇 and exit.
|
||||||
|
[ "$vol" != "${vol%\[MUTED\]}" ] && echo 🔇 && exit
|
||||||
|
|
||||||
if [ "$vol" -gt "70" ]; then
|
vol="${vol#Volume: }"
|
||||||
icon="🔊"
|
|
||||||
elif [ "$vol" -gt "30" ]; then
|
split() {
|
||||||
icon="🔉"
|
# For ommiting the . without calling and external program.
|
||||||
elif [ "$vol" -gt "0" ]; then
|
IFS=$2
|
||||||
icon="🔈"
|
set -- $1
|
||||||
else
|
printf '%s' "$@"
|
||||||
echo 🔇 && exit
|
}
|
||||||
fi
|
|
||||||
|
vol="$(printf "%.0f" "$(split "$vol" ".")")"
|
||||||
|
|
||||||
|
case 1 in
|
||||||
|
$((vol >= 70)) ) icon="🔊" ;;
|
||||||
|
$((vol >= 30)) ) icon="🔉" ;;
|
||||||
|
$((vol >= 1)) ) icon="🔈" ;;
|
||||||
|
* ) echo 🔇 && exit ;;
|
||||||
|
esac
|
||||||
|
|
||||||
echo "$icon$vol%"
|
echo "$icon$vol%"
|
||||||
|
|||||||
@ -17,7 +17,7 @@ case "$(printf "🔒 lock\n🚪 leave $WM\n♻️ renew $WM\n🐻 hibernate\n
|
|||||||
'🔒 lock') slock ;;
|
'🔒 lock') slock ;;
|
||||||
"🚪 leave $WM") kill -TERM "$(wmpid)" ;;
|
"🚪 leave $WM") kill -TERM "$(wmpid)" ;;
|
||||||
"♻️ renew $WM") kill -HUP "$(wmpid)" ;;
|
"♻️ renew $WM") kill -HUP "$(wmpid)" ;;
|
||||||
'🐻 hibernate') slock $ctl hibernate ;;
|
'🐻 hibernate') slock $ctl hibernate -i ;;
|
||||||
'💤 sleep') slock $ctl suspend -i ;;
|
'💤 sleep') slock $ctl suspend -i ;;
|
||||||
'🔃 reboot') $ctl reboot -i ;;
|
'🔃 reboot') $ctl reboot -i ;;
|
||||||
'🖥️shutdown') $ctl poweroff -i ;;
|
'🖥️shutdown') $ctl poweroff -i ;;
|
||||||
|
|||||||
@ -13,7 +13,7 @@ Options:
|
|||||||
-c: comment
|
-c: comment
|
||||||
You will be prompted for title, artist, album and track if not given." && exit 1 ;}
|
You will be prompted for title, artist, album and track if not given." && exit 1 ;}
|
||||||
|
|
||||||
while getopts "a:t:A:n:N:d:g:c:f:" o; do case "${o}" in
|
while getopts "a:t:A:n:N:d:g:c:" o; do case "${o}" in
|
||||||
a) artist="${OPTARG}" ;;
|
a) artist="${OPTARG}" ;;
|
||||||
t) title="${OPTARG}" ;;
|
t) title="${OPTARG}" ;;
|
||||||
A) album="${OPTARG}" ;;
|
A) album="${OPTARG}" ;;
|
||||||
@ -22,7 +22,6 @@ while getopts "a:t:A:n:N:d:g:c:f:" o; do case "${o}" in
|
|||||||
d) date="${OPTARG}" ;;
|
d) date="${OPTARG}" ;;
|
||||||
g) genre="${OPTARG}" ;;
|
g) genre="${OPTARG}" ;;
|
||||||
c) comment="${OPTARG}" ;;
|
c) comment="${OPTARG}" ;;
|
||||||
f) file="${OPTARG}" ;;
|
|
||||||
*) printf "Invalid option: -%s\\n" "$OPTARG" && err ;;
|
*) printf "Invalid option: -%s\\n" "$OPTARG" && err ;;
|
||||||
esac done
|
esac done
|
||||||
|
|
||||||
@ -30,38 +29,21 @@ shift $((OPTIND - 1))
|
|||||||
|
|
||||||
file="$1"
|
file="$1"
|
||||||
|
|
||||||
[ ! -f "$file" ] && echo "Provide file to tag." && err
|
temp="$(mktemp -p "$(dirname "$file")")"
|
||||||
|
trap 'rm -f $temp' HUP INT QUIT TERM PWR EXIT
|
||||||
|
|
||||||
[ -z "$title" ] && echo "Enter a title." && read -r title
|
[ ! -f "$file" ] && echo 'Provide file to tag.' && err
|
||||||
[ -z "$artist" ] && echo "Enter an artist." && read -r artist
|
|
||||||
[ -z "$album" ] && echo "Enter an album." && read -r album
|
|
||||||
[ -z "$track" ] && echo "Enter a track number." && read -r track
|
|
||||||
|
|
||||||
case "$file" in
|
[ -z "$title" ] && echo 'Enter a title.' && read -r title
|
||||||
*.ogg) echo "Title=$title
|
[ -z "$artist" ] && echo 'Enter an artist.' && read -r artist
|
||||||
Artist=$artist
|
[ -z "$album" ] && echo 'Enter an album.' && read -r album
|
||||||
Album=$album
|
[ -z "$track" ] && echo 'Enter a track number.' && read -r track
|
||||||
Track=$track
|
|
||||||
Total=$total
|
cp -f "$file" "$temp" && ffmpeg -i "$temp" -map 0 -y -codec copy \
|
||||||
Date=$date
|
-metadata title="$title" \
|
||||||
Genre=$genre
|
-metadata album="$album" \
|
||||||
Comment=$comment" | vorbiscomment -w "$file" ;;
|
-metadata artist="$artist" \
|
||||||
*.opus) echo "Title=$title
|
-metadata track="${track}${total:+/"$total"}" \
|
||||||
Artist=$artist
|
${date:+-metadata date="$date"} \
|
||||||
Album=$album
|
${genre:+-metadata genre="$genre"} \
|
||||||
Track=$track
|
${comment:+-metadata comment="$comment"} "$file"
|
||||||
Total=$total
|
|
||||||
Date=$date
|
|
||||||
Genre=$genre
|
|
||||||
Comment=$comment" | opustags -i -S "$file" ;;
|
|
||||||
*.mp3) eyeD3 -Q --remove-all -a "$artist" -A "$album" -t "$title" -n "$track" -N "$total" -Y "$date" "$file" ;;
|
|
||||||
*.flac) echo "TITLE=$title
|
|
||||||
ARTIST=$artist
|
|
||||||
ALBUM=$album
|
|
||||||
TRACKNUMBER=$track
|
|
||||||
TOTALTRACKS=$total
|
|
||||||
DATE=$date
|
|
||||||
GENRE=$genre
|
|
||||||
DESCRIPTION=$comment" | metaflac --remove-all-tags --import-tags-from=- "$file" ;;
|
|
||||||
*) echo "File type not implemented yet." ;;
|
|
||||||
esac
|
|
||||||
|
|||||||
@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
if pidof transmission-daemon >/dev/null ;
|
if pidof transmission-daemon >/dev/null ;
|
||||||
then
|
then
|
||||||
[ "$(printf "No\\nYes" | dmenu -i -p "Turn off transmission-daemon?")" = "Yes" ] && killall transmission-da && notify-send "transmission-daemon disabled."
|
[ "$(printf "No\\nYes" | dmenu -i -p "Turn off transmission-daemon?")" = "Yes" ] && killall transmission-daemon && notify-send "transmission-daemon disabled."
|
||||||
else
|
else
|
||||||
ifinstalled transmission-cli || exit
|
ifinstalled transmission-cli || exit
|
||||||
[ "$(printf "No\\nYes" | dmenu -i -p "Turn on transmission daemon?")" = "Yes" ] && transmission-daemon && notify-send "transmission-daemon enabled."
|
[ "$(printf "No\\nYes" | dmenu -i -p "Turn on transmission daemon?")" = "Yes" ] && transmission-daemon && notify-send "transmission-daemon enabled."
|
||||||
|
|||||||
@ -9,7 +9,7 @@ case "$1" in
|
|||||||
dir=$(dirname "$file")
|
dir=$(dirname "$file")
|
||||||
base="${file%.*}"
|
base="${file%.*}"
|
||||||
find "$dir" -maxdepth 1 -type f -regextype gnu-awk -regex "^$base\\.(4tc|xref|tmp|pyc|pyg|pyo|fls|vrb|fdb_latexmk|bak|swp|aux|log|synctex\\(busy\\)|lof|lot|maf|idx|mtc|mtc0|nav|out|snm|toc|bcf|run\\.xml|synctex\\.gz|blg|bbl)" -delete
|
find "$dir" -maxdepth 1 -type f -regextype gnu-awk -regex "^$base\\.(4tc|xref|tmp|pyc|pyg|pyo|fls|vrb|fdb_latexmk|bak|swp|aux|log|synctex\\(busy\\)|lof|lot|maf|idx|mtc|mtc0|nav|out|snm|toc|bcf|run\\.xml|synctex\\.gz|blg|bbl)" -delete
|
||||||
rm -rdf "$dir/_minted-$(basename -- $base)"
|
rm -rdf "$dir/_minted-$(basename -- "$base")"
|
||||||
;;
|
;;
|
||||||
*) printf "Give .tex file as argument.\\n" ;;
|
*) printf "Give .tex file as argument.\\n" ;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
ifinstalled tremc transmission-cli || exit
|
ifinstalled stig transmission-cli || exit 1
|
||||||
|
|
||||||
! pidof transmission-daemon >/dev/null && transmission-daemon && notify-send "Starting torrent daemon..."
|
! pidof transmission-daemon >/dev/null && transmission-daemon && notify-send "Starting torrent daemon..."
|
||||||
|
|
||||||
$TERMINAL -e tremc; pkill -RTMIN+7 "${STATUSBAR:-dwmblocks}"
|
$TERMINAL -e stig; pkill -RTMIN+7 "${STATUSBAR:-dwmblocks}"
|
||||||
|
|||||||
@ -6,21 +6,21 @@
|
|||||||
|
|
||||||
vidlist="
|
vidlist="
|
||||||
dwm (window manager) https://videos.lukesmith.xyz/videos/watch/f6b78db7-b368-4647-bc64-28c08fff1988
|
dwm (window manager) https://videos.lukesmith.xyz/videos/watch/f6b78db7-b368-4647-bc64-28c08fff1988
|
||||||
|
dwmblocks (status bar) https://videos.lukesmith.xyz/w/mmxHMbqZZEr5FManB57Yy1
|
||||||
pacman (installing/managing programs) https://videos.lukesmith.xyz/videos/watch/8e7cadb9-0fed-47ce-a2a8-6635fa48614b
|
pacman (installing/managing programs) https://videos.lukesmith.xyz/videos/watch/8e7cadb9-0fed-47ce-a2a8-6635fa48614b
|
||||||
status bar https://videos.lukesmith.xyz/videos/watch/a4d5326b-0aac-496e-bfc3-5acd5cee89f0
|
sxiv/nsxiv (image viewer) https://videos.lukesmith.xyz/videos/watch/ad4c8d85-90c3-4f3d-a1f3-89129e64a3c2
|
||||||
sxiv (image viewer) https://videos.lukesmith.xyz/videos/watch/ad4c8d85-90c3-4f3d-a1f3-89129e64a3c2
|
st (terminal) https://videos.lukesmith.xyz/videos/watch/efddd39d-bac5-4599-b572-177beb4ce6e8
|
||||||
st (terminal) https://videos.lukesmith.xyz/videos/watch/efddd39d-bac5-4599-b572-177beb4ce6e8
|
|
||||||
i3 (old window manager) https://videos.lukesmith.xyz/videos/watch/b861525c-7ada-40ee-a2bb-b5e1ffe0f48b
|
i3 (old window manager) https://videos.lukesmith.xyz/videos/watch/b861525c-7ada-40ee-a2bb-b5e1ffe0f48b
|
||||||
neomutt (email) https://videos.lukesmith.xyz/videos/watch/83122e83-52d9-4278-ae1a-7d1beeb50c8e
|
neomutt (email) https://videos.lukesmith.xyz/videos/watch/83122e83-52d9-4278-ae1a-7d1beeb50c8e
|
||||||
ncmpcpp (music player) https://videos.lukesmith.xyz/videos/watch/b5ac6f0d-a220-4433-88e3-e98fc791dc0a
|
ncmpcpp (music player) https://videos.lukesmith.xyz/videos/watch/b5ac6f0d-a220-4433-88e3-e98fc791dc0a
|
||||||
newsboat (RSS reader) https://videos.lukesmith.xyz/videos/watch/bd2c3fff-40fa-47ea-aa98-5b1ec0c903b6
|
newsboat (RSS reader) https://videos.lukesmith.xyz/videos/watch/bd2c3fff-40fa-47ea-aa98-5b1ec0c903b6
|
||||||
lf (file manager) https://videos.lukesmith.xyz/w/rKeHsF5ZHDNDbR1buUKB1c
|
lf (file manager) https://videos.lukesmith.xyz/w/rKeHsF5ZHDNDbR1buUKB1c
|
||||||
zathura (pdf viewer) https://videos.lukesmith.xyz/videos/watch/c780f75a-11f6-48a9-a191-d079ebc36ea4
|
zathura (pdf viewer) https://videos.lukesmith.xyz/videos/watch/c780f75a-11f6-48a9-a191-d079ebc36ea4
|
||||||
gpg keys https://videos.lukesmith.xyz/videos/watch/040f5530-4830-4583-9ddc-2080b421531b
|
gpg keys https://videos.lukesmith.xyz/videos/watch/040f5530-4830-4583-9ddc-2080b421531b
|
||||||
calcurse (calendar) https://videos.lukesmith.xyz/videos/watch/4b937e8b-7654-46e3-8d01-79392ec5b3d1
|
calcurse (calendar) https://videos.lukesmith.xyz/videos/watch/4b937e8b-7654-46e3-8d01-79392ec5b3d1
|
||||||
urlview https://videos.lukesmith.xyz/videos/watch/31a4918f-633b-4bd6-b08e-956ac75d0324
|
urlview https://videos.lukesmith.xyz/videos/watch/31a4918f-633b-4bd6-b08e-956ac75d0324
|
||||||
colorschemes with pywal https://videos.lukesmith.xyz/videos/watch/1b476003-61b2-4609-ac4b-820c3d128643
|
colorschemes with pywal https://videos.lukesmith.xyz/videos/watch/1b476003-61b2-4609-ac4b-820c3d128643
|
||||||
vi mode in shell https://videos.lukesmith.xyz/videos/watch/228aa50c-836f-456f-9f0d-a45157fe4313
|
vi mode in shell https://videos.lukesmith.xyz/videos/watch/228aa50c-836f-456f-9f0d-a45157fe4313
|
||||||
pass (password manager) https://videos.lukesmith.xyz/videos/watch/432fc942-5e28-4682-9beb-f5cb237a1dd6
|
pass (password manager) https://videos.lukesmith.xyz/videos/watch/432fc942-5e28-4682-9beb-f5cb237a1dd6
|
||||||
"
|
"
|
||||||
echo "$vidlist" | grep -P "^$(echo "$vidlist" | grep "https:" | sed 's/\t.*//g' | dmenu -i -p "Learn about what? (ESC to cancel)" -l 20 | awk '{print $1}')\s" | sed 's/.*\t//' | xargs -r mpv
|
echo "$vidlist" | grep -P "^$(echo "$vidlist" | grep "https:" | sed 's/\t.*//g' | dmenu -i -p "Learn about what? (ESC to cancel)" -l 20 | awk '{print $1}')\s" | sed 's/.*\t//' | xargs -r mpv
|
||||||
|
|||||||
28
.local/bin/unmounter
Executable file
28
.local/bin/unmounter
Executable file
@ -0,0 +1,28 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Unmount USB drives or Android phones. Replaces the older `dmenuumount`. Fewer
|
||||||
|
# prompt and also de-decrypts LUKS drives that are unmounted.
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
mounteddroids="$(grep simple-mtpfs /etc/mtab | awk '{print "📱" $2}')"
|
||||||
|
lsblkoutput="$(lsblk -nrpo "name,type,size,mountpoint")"
|
||||||
|
mounteddrives="$(echo "$lsblkoutput" | awk '($2=="part"||$2="crypt")&&$4!~/\/boot|\/home$|SWAP/&&length($4)>1{printf "💾%s (%s)\n",$4,$3}')"
|
||||||
|
|
||||||
|
allunmountable="$(echo "$mounteddroids
|
||||||
|
$mounteddrives" | sed "/^$/d;s/ *$//")"
|
||||||
|
test -n "$allunmountable"
|
||||||
|
|
||||||
|
chosen="$(echo "$allunmountable" | dmenu -i -p "Unmount which drive?")"
|
||||||
|
chosen="${chosen%% *}"
|
||||||
|
test -n "$chosen"
|
||||||
|
|
||||||
|
sudo -A umount -l "/${chosen#*/}"
|
||||||
|
notify-send "Device unmounted." "$chosen has been unmounted."
|
||||||
|
|
||||||
|
# Close the chosen drive if decrypted.
|
||||||
|
cryptid="$(echo "$lsblkoutput" | grep "/${chosen#*/}$")"
|
||||||
|
cryptid="${cryptid%% *}"
|
||||||
|
test -b /dev/mapper/"${cryptid##*/}"
|
||||||
|
sudo -A cryptsetup close "$cryptid"
|
||||||
|
notify-send "🔒Device dencryption closed." "Drive is now securely locked again."
|
||||||
3
.local/bin/xdg-terminal-exec
Executable file
3
.local/bin/xdg-terminal-exec
Executable file
@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
"$TERMINAL" -e "$@"
|
||||||
@ -1,4 +1,4 @@
|
|||||||
[Desktop Entry]
|
[Desktop Entry]
|
||||||
Type=Application
|
Type=Application
|
||||||
Name=Image viewer
|
Name=Image viewer
|
||||||
Exec=/usr/bin/sxiv -a %f
|
Exec=/usr/bin/nsxiv -a %f
|
||||||
|
|||||||
4
.local/share/applications/video.desktop
Normal file
4
.local/share/applications/video.desktop
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
[Desktop Entry]
|
||||||
|
Type=Application
|
||||||
|
Name=Video viewer
|
||||||
|
Exec=/usr/bin/mpv -quiet %f
|
||||||
1630
.local/share/larbs/chars/emoji
Normal file
1630
.local/share/larbs/chars/emoji
Normal file
File diff suppressed because it is too large
Load Diff
1456
.local/share/larbs/chars/font-awesome
Normal file
1456
.local/share/larbs/chars/font-awesome
Normal file
File diff suppressed because it is too large
Load Diff
@ -1,9 +1,8 @@
|
|||||||
_
|
_ __ _____ _(_)_ __
|
||||||
_____ _(_)_ __
|
| '_ \/ __\ \/ / \ \ / /
|
||||||
/ __\ \/ / \ \ / /
|
| | | \__ \> <| |\ V /
|
||||||
\__ \> <| |\ V /
|
|_| |_|___/_/\_\_| \_/
|
||||||
|___/_/\_\_| \_/
|
nsxiv is the image viewer.
|
||||||
sxiv is the image viewer.
|
|
||||||
h/j/k/l - Pan image
|
h/j/k/l - Pan image
|
||||||
-/+ - Zoom out/in
|
-/+ - Zoom out/in
|
||||||
Enter - Toggle thumbnail mode
|
Enter - Toggle thumbnail mode
|
||||||
@ -12,4 +11,4 @@ sxiv is the image viewer.
|
|||||||
r - Reload image if changed
|
r - Reload image if changed
|
||||||
m - Mark/unmark image
|
m - Mark/unmark image
|
||||||
w - Zoom to fit window
|
w - Zoom to fit window
|
||||||
ctrl-x - Run external command (see ~/.config/sxiv/exec/key-handler for options)
|
ctrl-x - Run external command (see ~/.config/nsxiv/exec/key-handler for options)
|
||||||
@ -8,7 +8,7 @@ These are the dotfiles deployed by [LARBS](https://github.com/quadcerebrumal/LAR
|
|||||||
- zsh (shell)
|
- zsh (shell)
|
||||||
- lf (file manager)
|
- lf (file manager)
|
||||||
- mpd/ncmpcpp (music)
|
- mpd/ncmpcpp (music)
|
||||||
- sxiv (image/gif viewer)
|
- nsxiv (image/gif viewer)
|
||||||
- mpv (video player)
|
- mpv (video player)
|
||||||
- other stuff like xdg default programs, inputrc and more, etc.
|
- other stuff like xdg default programs, inputrc and more, etc.
|
||||||
- I try to minimize what's directly in `~` so:
|
- I try to minimize what's directly in `~` so:
|
||||||
@ -41,4 +41,4 @@ curl -LO raw.githubusercontent.com/quadcerebrumal/LARBS/master/larbs.sh
|
|||||||
```
|
```
|
||||||
|
|
||||||
or clone the repo files directly to your home directory and install the
|
or clone the repo files directly to your home directory and install the
|
||||||
[dependencies](https://github.com/quadcerebrumal/LARBS/blob/master/progs.csv).
|
[dependencies](https://github.com/raketexyz/LARBS/blob/master/progs.csv).
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user