mirror of
https://github.com/LukeSmithxyz/voidrice.git
synced 2026-03-20 01:37:45 +01:00
Merge branch 'LukeSmithxyz:master' into master
This commit is contained in:
commit
f9e1c86265
@ -1,152 +1,27 @@
|
|||||||
[global]
|
[global]
|
||||||
monitor = 0
|
monitor = 0
|
||||||
follow = keyboard
|
follow = keyboard
|
||||||
geometry = "350x5-0+24"
|
width = 370
|
||||||
indicate_hidden = yes
|
height = 350
|
||||||
shrink = yes
|
offset = 0x19
|
||||||
transparency = 20
|
padding = 2
|
||||||
notification_height = 0
|
horizontal_padding = 2
|
||||||
separator_height = 2
|
transparency = 25
|
||||||
padding = 0
|
font = Monospace 12
|
||||||
horizontal_padding = 8
|
|
||||||
frame_width = 3
|
|
||||||
frame_color = "#282828"
|
|
||||||
|
|
||||||
# Define a color for the separator.
|
|
||||||
# possible values are:
|
|
||||||
# * auto: dunst tries to find a color fitting to the background;
|
|
||||||
# * foreground: use the same color as the foreground;
|
|
||||||
# * frame: use the same color as the frame;
|
|
||||||
# * anything else will be interpreted as a X color.
|
|
||||||
separator_color = frame
|
|
||||||
|
|
||||||
# Sort messages by urgency.
|
|
||||||
sort = yes
|
|
||||||
|
|
||||||
idle_threshold = 120
|
|
||||||
font = Monospace 14
|
|
||||||
line_height = 0
|
|
||||||
markup = full
|
|
||||||
|
|
||||||
# The format of the message. Possible variables are:
|
|
||||||
# %a appname
|
|
||||||
# %s summary
|
|
||||||
# %b body
|
|
||||||
# %i iconname (including its path)
|
|
||||||
# %I iconname (without its path)
|
|
||||||
# %p progress value if set ([ 0%] to [100%]) or nothing
|
|
||||||
# %n progress value if set without any extra characters
|
|
||||||
# %% Literal %
|
|
||||||
# Markup is allowed
|
|
||||||
format = "<b>%s</b>\n%b"
|
format = "<b>%s</b>\n%b"
|
||||||
|
|
||||||
alignment = left
|
|
||||||
show_age_threshold = 60
|
|
||||||
word_wrap = yes
|
|
||||||
ellipsize = middle
|
|
||||||
ignore_newline = no
|
|
||||||
stack_duplicates = true
|
|
||||||
hide_duplicate_count = true
|
|
||||||
show_indicators = yes
|
|
||||||
icon_position = left
|
|
||||||
max_icon_size = 40
|
|
||||||
#icon_path = /usr/share/icons/gnome/16x16/status/:/usr/share/icons/gnome/16x16/devices/:/usr/share/icons/Adwaita/256x256/status/
|
|
||||||
sticky_history = yes
|
|
||||||
history_length = 20
|
|
||||||
dmenu = /usr/bin/dmenu -p dunst:
|
|
||||||
browser = /usr/bin/firefox -new-tab
|
|
||||||
|
|
||||||
# Always run rule-defined scripts, even if the notification is suppressed
|
|
||||||
always_run_script = true
|
|
||||||
|
|
||||||
title = Dunst
|
|
||||||
class = Dunst
|
|
||||||
startup_notification = false
|
|
||||||
force_xinerama = false
|
|
||||||
[experimental]
|
|
||||||
per_monitor_dpi = false
|
|
||||||
|
|
||||||
[shortcuts]
|
|
||||||
close = ctrl+space
|
|
||||||
close_all = ctrl+shift+space
|
|
||||||
history = ctrl+grave
|
|
||||||
context = ctrl+shift+period
|
|
||||||
|
|
||||||
[urgency_low]
|
[urgency_low]
|
||||||
# IMPORTANT: colors have to be defined in quotation marks.
|
background = "#1d2021"
|
||||||
# Otherwise the "#" and following would be interpreted as a comment.
|
|
||||||
background = "#282828"
|
|
||||||
foreground = "#928374"
|
foreground = "#928374"
|
||||||
timeout = 5
|
timeout = 3
|
||||||
# Icon for notifications with low urgency, uncomment to enable
|
|
||||||
#icon = /path/to/icon
|
|
||||||
|
|
||||||
[urgency_normal]
|
[urgency_normal]
|
||||||
background = "#458588"
|
|
||||||
foreground = "#ebdbb2"
|
foreground = "#ebdbb2"
|
||||||
|
background = "#458588"
|
||||||
timeout = 5
|
timeout = 5
|
||||||
|
|
||||||
[urgency_critical]
|
[urgency_critical]
|
||||||
background = "#cc2421"
|
background = "#1cc24d"
|
||||||
foreground = "#ebdbb2"
|
foreground = "#ebdbb2"
|
||||||
frame_color = "#fabd2f"
|
frame_color = "#fabd2f"
|
||||||
timeout = 0
|
timeout = 10
|
||||||
|
|
||||||
# Every section that isn't one of the above is interpreted as a rules to
|
|
||||||
# override settings for certain messages.
|
|
||||||
# Messages can be matched by "appname", "summary", "body", "icon", "category",
|
|
||||||
# "msg_urgency" and you can override the "timeout", "urgency", "foreground",
|
|
||||||
# "background", "new_icon" and "format".
|
|
||||||
# Shell-like globbing will get expanded.
|
|
||||||
#
|
|
||||||
# SCRIPTING
|
|
||||||
# You can specify a script that gets run when the rule matches by
|
|
||||||
# setting the "script" option.
|
|
||||||
# The script will be called as follows:
|
|
||||||
# script appname summary body icon urgency
|
|
||||||
# where urgency can be "LOW", "NORMAL" or "CRITICAL".
|
|
||||||
#
|
|
||||||
# NOTE: if you don't want a notification to be displayed, set the format
|
|
||||||
# to "".
|
|
||||||
# NOTE: It might be helpful to run dunst -print in a terminal in order
|
|
||||||
# to find fitting options for rules.
|
|
||||||
|
|
||||||
#[espeak]
|
|
||||||
# summary = "*"
|
|
||||||
# script = dunst_espeak.sh
|
|
||||||
|
|
||||||
#[script-test]
|
|
||||||
# summary = "*script*"
|
|
||||||
# script = dunst_test.sh
|
|
||||||
|
|
||||||
#[ignore]
|
|
||||||
# # This notification will not be displayed
|
|
||||||
# summary = "foobar"
|
|
||||||
# format = ""
|
|
||||||
|
|
||||||
#[history-ignore]
|
|
||||||
# # This notification will not be saved in history
|
|
||||||
# summary = "foobar"
|
|
||||||
# history_ignore = yes
|
|
||||||
|
|
||||||
#[signed_on]
|
|
||||||
# appname = Pidgin
|
|
||||||
# summary = "*signed on*"
|
|
||||||
# urgency = low
|
|
||||||
#
|
|
||||||
#[signed_off]
|
|
||||||
# appname = Pidgin
|
|
||||||
# summary = *signed off*
|
|
||||||
# urgency = low
|
|
||||||
#
|
|
||||||
#[says]
|
|
||||||
# appname = Pidgin
|
|
||||||
# summary = *says*
|
|
||||||
# urgency = critical
|
|
||||||
#
|
|
||||||
#[twitter]
|
|
||||||
# appname = Pidgin
|
|
||||||
# summary = *twitter.com*
|
|
||||||
# urgency = normal
|
|
||||||
#
|
|
||||||
# vim: ft=cfg
|
|
||||||
|
|||||||
@ -30,6 +30,7 @@
|
|||||||
<prefer>
|
<prefer>
|
||||||
<family>Noto Sans Mono</family>
|
<family>Noto Sans Mono</family>
|
||||||
<family>Liberation Mono</family>
|
<family>Liberation Mono</family>
|
||||||
|
<family>Braille</family>
|
||||||
</prefer>
|
</prefer>
|
||||||
</alias>
|
</alias>
|
||||||
</fontconfig>
|
</fontconfig>
|
||||||
|
|||||||
4
.config/lf/cleaner
Executable file
4
.config/lf/cleaner
Executable file
@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
if [ -n "$FIFO_UEBERZUG" ]; then
|
||||||
|
printf '{"action": "remove", "identifier": "PREVIEW"}\n' > "$FIFO_UEBERZUG"
|
||||||
|
fi
|
||||||
@ -1,34 +1,64 @@
|
|||||||
# Luke's lf settings
|
# Luke's lf settings
|
||||||
|
|
||||||
|
|
||||||
|
# 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
|
# Basic vars
|
||||||
set shell bash
|
|
||||||
set shellopts '-eu'
|
set shellopts '-eu'
|
||||||
set ifs "\n"
|
set ifs "\n"
|
||||||
set scrolloff 10
|
set scrolloff 10
|
||||||
set icons
|
set icons
|
||||||
set period 1
|
set period 1
|
||||||
set hiddenfiles ".*:*.aux:*.log:*.bbl:*.bcf:*.blg:*.run.xml"
|
set hiddenfiles ".*:*.aux:*.log:*.bbl:*.bcf:*.blg:*.run.xml"
|
||||||
|
set cleaner '~/.config/lf/cleaner'
|
||||||
# Vars that depend on environmental variables
|
set previewer '~/.config/lf/scope'
|
||||||
$lf -remote "send $id set previewer ${XDG_CONFIG_HOME:-$HOME/.config}/lf/scope"
|
|
||||||
|
|
||||||
# cmds/functions
|
# cmds/functions
|
||||||
cmd open ${{
|
cmd open ${{
|
||||||
case $(file --mime-type $f -b) in
|
case $(file --mime-type "$(readlink -f $f)" -b) in
|
||||||
image/vnd.djvu|application/pdf|application/octet-stream) setsid -f zathura $fx >/dev/null 2>&1 ;;
|
application/vnd.openxmlformats-officedocument.spreadsheetml.sheet) localc $fx ;;
|
||||||
text/*) $EDITOR $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) $EDITOR $fx;;
|
||||||
image/x-xcf) setsid -f gimp $f >/dev/null 2>&1 ;;
|
image/x-xcf) setsid -f gimp $f >/dev/null 2>&1 ;;
|
||||||
image/svg+xml) display -- $f ;;
|
image/svg+xml) display -- $f ;;
|
||||||
image/*) rotdir $f | grep -i "\.\(png\|jpg\|jpeg\|gif\|webp\|tif\|ico\)\(_large\)*$" | sxiv -aio 2>/dev/null | lf-select ;;
|
image/*) rotdir $f | grep -i "\.\(png\|jpg\|jpeg\|gif\|webp\|tif\|ico\)\(_large\)*$" |
|
||||||
|
setsid -f sxiv -aio 2>/dev/null | while read -r file; do
|
||||||
|
[ -z "$file" ] && continue
|
||||||
|
lf -remote "send select \"$file\""
|
||||||
|
lf -remote "send toggle"
|
||||||
|
done &
|
||||||
|
;;
|
||||||
audio/*) mpv --audio-display=no $f ;;
|
audio/*) mpv --audio-display=no $f ;;
|
||||||
video/*) setsid -f mpv $f -quiet >/dev/null 2>&1 ;;
|
video/*) setsid -f mpv $f -quiet >/dev/null 2>&1 ;;
|
||||||
application/pdf|application/vnd*|application/epub*) setsid -f zathura $fx >/dev/null 2>&1 ;;
|
application/pdf|application/vnd*|application/epub*) setsid -f zathura $fx >/dev/null 2>&1 ;;
|
||||||
|
application/pgp-encrypted) $EDITOR $fx ;;
|
||||||
*) for f in $fx; do setsid -f $OPENER $f >/dev/null 2>&1; done;;
|
*) for f in $fx; do setsid -f $OPENER $f >/dev/null 2>&1; done;;
|
||||||
esac
|
esac
|
||||||
}}
|
}}
|
||||||
|
|
||||||
cmd mkdir $mkdir -p "$(echo $* | tr ' ' '\ ')"
|
cmd mkdir $mkdir -p "$(echo $* | tr ' ' '\ ')"
|
||||||
|
|
||||||
|
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" ] && aunpack $fx
|
||||||
|
}}
|
||||||
|
|
||||||
cmd delete ${{
|
cmd delete ${{
|
||||||
clear; tput cup $(($(tput lines)/3)); tput bold
|
clear; tput cup $(($(tput lines)/3)); tput bold
|
||||||
set -f
|
set -f
|
||||||
@ -42,7 +72,7 @@ cmd moveto ${{
|
|||||||
clear; tput cup $(($(tput lines)/3)); tput bold
|
clear; tput cup $(($(tput lines)/3)); tput bold
|
||||||
set -f
|
set -f
|
||||||
clear; echo "Move to where?"
|
clear; echo "Move to where?"
|
||||||
dest="$(cut -d' ' -f2- ${XDG_CONFIG_HOME:-$HOME/.config}/shell/bm-dirs | fzf | sed 's|~|$HOME|' )" &&
|
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
|
for x in $fx; do
|
||||||
eval mv -iv \"$x\" \"$dest\"
|
eval mv -iv \"$x\" \"$dest\"
|
||||||
done &&
|
done &&
|
||||||
@ -53,7 +83,7 @@ cmd copyto ${{
|
|||||||
clear; tput cup $(($(tput lines)/3)); tput bold
|
clear; tput cup $(($(tput lines)/3)); tput bold
|
||||||
set -f
|
set -f
|
||||||
clear; echo "Copy to where?"
|
clear; echo "Copy to where?"
|
||||||
dest="$(cut -d' ' -f2- ${XDG_CONFIG_HOME:-$HOME/.config}/shell/bm-dirs | fzf | sed 's|~|$HOME|' )" &&
|
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
|
for x in $fx; do
|
||||||
eval cp -ivr \"$x\" \"$dest\"
|
eval cp -ivr \"$x\" \"$dest\"
|
||||||
done &&
|
done &&
|
||||||
@ -65,14 +95,16 @@ cmd bulkrename $vidir
|
|||||||
|
|
||||||
# Bindings
|
# Bindings
|
||||||
map <c-f> $lf -remote "send $id select '$(fzf)'"
|
map <c-f> $lf -remote "send $id select '$(fzf)'"
|
||||||
map J $lf -remote "send $id cd $(cut -d' ' -f2 ${XDG_CONFIG_HOME:-$HOME/.config}/shell/bm-dirs | 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 gh
|
||||||
map g top
|
map g top
|
||||||
map D delete
|
map D delete
|
||||||
|
map E extract
|
||||||
map C copyto
|
map C copyto
|
||||||
map M moveto
|
map M moveto
|
||||||
map <c-n> push :mkdir<space>
|
map <c-n> push :mkdir<space>
|
||||||
map <c-r> reload
|
map <c-r> reload
|
||||||
|
map <c-s> set hidden!
|
||||||
map <enter> shell
|
map <enter> shell
|
||||||
map x $$f
|
map x $$f
|
||||||
map X !$f
|
map X !$f
|
||||||
@ -90,3 +122,10 @@ map b $setbg $f
|
|||||||
map <c-e> down
|
map <c-e> down
|
||||||
map <c-y> up
|
map <c-y> up
|
||||||
map V push :!nvim<space>
|
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"
|
||||||
|
|||||||
@ -1,58 +1,44 @@
|
|||||||
#!/bin/bash
|
#!/bin/sh
|
||||||
|
|
||||||
set -C -f -u
|
# File preview handler for lf.
|
||||||
#IFS=$'\n'
|
|
||||||
|
set -C -f
|
||||||
IFS="$(printf '%b_' '\n')"; IFS="${IFS%_}"
|
IFS="$(printf '%b_' '\n')"; IFS="${IFS%_}"
|
||||||
|
|
||||||
# ANSI color codes are supported.
|
image() {
|
||||||
# STDIN is disabled, so interactive scripts won't work properly
|
if [ -n "$DISPLAY" ] && [ -z "$WAYLAND_DISPLAY" ] && command -V ueberzug >/dev/null 2>&1; then
|
||||||
|
printf '{"action": "add", "identifier": "PREVIEW", "x": "%s", "y": "%s", "width": "%s", "height": "%s", "scaler": "contain", "path": "%s"}\n' "$4" "$5" "$(($2-1))" "$(($3-1))" "$1" > "$FIFO_UEBERZUG"
|
||||||
# This script is considered a configuration file and must be updated manually.
|
else
|
||||||
|
mediainfo "$1"
|
||||||
# Meanings of exit codes:
|
fi
|
||||||
# code | meaning | action of ranger
|
|
||||||
# -----+------------+-------------------------------------------
|
|
||||||
# 0 | success | Display stdout as preview
|
|
||||||
# 1 | no preview | Display no preview at all
|
|
||||||
# 2 | plain text | Display the plain content of the file
|
|
||||||
|
|
||||||
# Script arguments
|
|
||||||
FILE_PATH="${1}" # Full path of the highlighted file
|
|
||||||
HEIGHT="${2}"
|
|
||||||
|
|
||||||
#FILE_EXTENSION="${FILE_PATH##*.}"
|
|
||||||
#FILE_EXTENSION_LOWER=$(echo ${FILE_EXTENSION} | tr '[:upper:]' '[:lower:]')
|
|
||||||
|
|
||||||
# Settings
|
|
||||||
HIGHLIGHT_SIZE_MAX=262143 # 256KiB
|
|
||||||
HIGHLIGHT_TABWIDTH=8
|
|
||||||
HIGHLIGHT_STYLE='pablo'
|
|
||||||
|
|
||||||
|
|
||||||
handle_mime() {
|
|
||||||
local mimetype="${1}"
|
|
||||||
case "${mimetype}" in
|
|
||||||
text/html) w3m -dump "${FILE_PATH}" ;;
|
|
||||||
text/troff) man ./ "${FILE_PATH}" | col -b ;;
|
|
||||||
text/* | */xml)
|
|
||||||
if [ "$( stat --printf='%s' -- "${FILE_PATH}" )" -gt "${HIGHLIGHT_SIZE_MAX}" ]; then
|
|
||||||
exit 2
|
|
||||||
fi
|
|
||||||
if [ "$( tput colors )" -ge 256 ]; then
|
|
||||||
local highlight_format='xterm256'
|
|
||||||
else
|
|
||||||
local highlight_format='ansi'
|
|
||||||
fi
|
|
||||||
highlight --replace-tabs="${HIGHLIGHT_TABWIDTH}" --out-format="${highlight_format}" \
|
|
||||||
--style="${HIGHLIGHT_STYLE}" --force -- "${FILE_PATH}" ;;
|
|
||||||
application/zip) atool --list -- "${FILE_PATH}" ;;
|
|
||||||
image/*) chafa --fill=block --symbols=block -c 256 -s 80x"${HEIGHT}" "${FILE_PATH}" || exit 1;;
|
|
||||||
video/* | audio/*|application/octet-stream) mediainfo "${FILE_PATH}" || exit 1;;
|
|
||||||
*/pdf) pdftotext -l 10 -nopgbrk -q -- "${FILE_PATH}" - ;;
|
|
||||||
*opendocument*) odt2txt "${FILE_PATH}" ;;
|
|
||||||
esac
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MIMETYPE="$( file --dereference --brief --mime-type -- "${FILE_PATH}" )"
|
ifub() {
|
||||||
handle_mime "${MIMETYPE}"
|
[ -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
|
||||||
|
# an image appears in multiple places across the machine, it will not have to
|
||||||
|
# be regenerated once seen.
|
||||||
|
|
||||||
|
case "$(file --dereference --brief --mime-type -- "$1")" in
|
||||||
|
image/*) image "$1" "$2" "$3" "$4" "$5" ;;
|
||||||
|
text/html) lynx -width="$4" -display_charset=utf-8 -dump "$1" ;;
|
||||||
|
text/troff) man ./ "$1" | col -b ;;
|
||||||
|
text/* | */xml | application/json) bat --terminal-width "$4" -f "$1" ;;
|
||||||
|
application/zip) atool --list -- "$1" ;;
|
||||||
|
audio/* | application/octet-stream) mediainfo "$1" || exit 1;;
|
||||||
|
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 | awk '{print $1}')"
|
||||||
|
[ ! -f "$CACHE" ] && ffmpegthumbnailer -i "$1" -o "$CACHE" -s 0
|
||||||
|
image "$CACHE" "$2" "$3" "$4" "$5"
|
||||||
|
;;
|
||||||
|
*/pdf)
|
||||||
|
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 | awk '{print $1}')"
|
||||||
|
[ ! -f "$CACHE.jpg" ] && pdftoppm -jpeg -f 1 -singlefile "$1" "$CACHE"
|
||||||
|
image "$CACHE.jpg" "$2" "$3" "$4" "$5"
|
||||||
|
;;
|
||||||
|
*opendocument*) odt2txt "$1" ;;
|
||||||
|
application/pgp-encrypted) gpg -d -- "$1" ;;
|
||||||
|
esac
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
1
.config/mpv/script_modules/mpvSockets
Submodule
1
.config/mpv/script_modules/mpvSockets
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit be9b7ca84456466e54331bab59441ac207659c1c
|
||||||
@ -1,3 +1,3 @@
|
|||||||
local mpv_scripts_dir_path = os.getenv("HOME") .. "/.config/mpv/scripts/"
|
local mpv_config_dir_path = require("mp").command_native({"expand-path", "~~/"})
|
||||||
function load(relative_path) dofile(mpv_scripts_dir_path .. relative_path) end
|
function load(relative_path) dofile(mpv_config_dir_path .. "/script_modules/" .. relative_path) end
|
||||||
load("mpvSockets/mpvSockets.lua")
|
load("mpvSockets/mpvSockets.lua")
|
||||||
|
|||||||
@ -1 +0,0 @@
|
|||||||
Subproject commit 8415a08d99a46213c918613cfe1e088071018db9
|
|
||||||
@ -36,7 +36,7 @@ macro a set browser "tsp youtube-dl --add-metadata -xic -f bestaudio/best" ; ope
|
|||||||
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
|
||||||
macro c set browser "xsel -b <<<" ; open-in-browser ; set browser linkhandler
|
macro c set browser "echo %u | xclip -r -sel c" ; open-in-browser ; set browser linkhandler
|
||||||
macro C set browser "youtube-viewer --comments=%u" ; open-in-browser ; set browser linkhandler
|
macro C set browser "youtube-viewer --comments=%u" ; open-in-browser ; set browser linkhandler
|
||||||
macro p set browser "peertubetorrent %u 480" ; open-in-browser ; set browser linkhandler
|
macro p set browser "peertubetorrent %u 480" ; open-in-browser ; set browser linkhandler
|
||||||
macro P set browser "peertubetorrent %u 1080" ; open-in-browser ; set browser linkhandler
|
macro P set browser "peertubetorrent %u 1080" ; open-in-browser ; set browser linkhandler
|
||||||
|
|||||||
@ -1,4 +1,7 @@
|
|||||||
https://lukesmith.xyz/rss.xml
|
https://lukesmith.xyz/rss.xml
|
||||||
https://notrelated.libsyn.com/rss
|
https://notrelated.xyz/rss
|
||||||
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://landchad.net/rss.xml
|
||||||
|
https://based.cooking/rss.xml
|
||||||
|
https://artixlinux.org/feed.php "tech"
|
||||||
https://www.archlinux.org/feeds/news/ "tech"
|
https://www.archlinux.org/feeds/news/ "tech"
|
||||||
|
|||||||
@ -14,7 +14,7 @@ Plug 'junegunn/goyo.vim'
|
|||||||
Plug 'jreybert/vimagit'
|
Plug 'jreybert/vimagit'
|
||||||
Plug 'lukesmithxyz/vimling'
|
Plug 'lukesmithxyz/vimling'
|
||||||
Plug 'vimwiki/vimwiki'
|
Plug 'vimwiki/vimwiki'
|
||||||
Plug 'bling/vim-airline'
|
Plug 'vim-airline/vim-airline'
|
||||||
Plug 'tpope/vim-commentary'
|
Plug 'tpope/vim-commentary'
|
||||||
Plug 'ap/vim-css-color'
|
Plug 'ap/vim-css-color'
|
||||||
call plug#end()
|
call plug#end()
|
||||||
@ -96,8 +96,8 @@ set noshowcmd
|
|||||||
|
|
||||||
" Ensure files are read as what I want:
|
" Ensure files are read as what I want:
|
||||||
let g:vimwiki_ext2syntax = {'.Rmd': 'markdown', '.rmd': 'markdown','.md': 'markdown', '.markdown': 'markdown', '.mdown': 'markdown'}
|
let g:vimwiki_ext2syntax = {'.Rmd': 'markdown', '.rmd': 'markdown','.md': 'markdown', '.markdown': 'markdown', '.mdown': 'markdown'}
|
||||||
map <leader>v :VimwikiIndex
|
map <leader>v :VimwikiIndex<CR>
|
||||||
let g:vimwiki_list = [{'path': '~/vimwiki', 'syntax': 'markdown', 'ext': '.md'}]
|
let g:vimwiki_list = [{'path': '~/.local/share/nvim/vimwiki', 'syntax': 'markdown', 'ext': '.md'}]
|
||||||
autocmd BufRead,BufNewFile /tmp/calcurse*,~/.calcurse/notes/* set filetype=markdown
|
autocmd BufRead,BufNewFile /tmp/calcurse*,~/.calcurse/notes/* set filetype=markdown
|
||||||
autocmd BufRead,BufNewFile *.ms,*.me,*.mom,*.man set filetype=groff
|
autocmd BufRead,BufNewFile *.ms,*.me,*.mom,*.man set filetype=groff
|
||||||
autocmd BufRead,BufNewFile *.tex set filetype=tex
|
autocmd BufRead,BufNewFile *.tex set filetype=tex
|
||||||
@ -111,15 +111,17 @@ set noshowcmd
|
|||||||
autocmd BufRead,BufNewFile /tmp/neomutt* map ZZ :Goyo\|x!<CR>
|
autocmd BufRead,BufNewFile /tmp/neomutt* map ZZ :Goyo\|x!<CR>
|
||||||
autocmd BufRead,BufNewFile /tmp/neomutt* map ZQ :Goyo\|q!<CR>
|
autocmd BufRead,BufNewFile /tmp/neomutt* map ZQ :Goyo\|q!<CR>
|
||||||
|
|
||||||
" Automatically deletes all trailing whitespace and newlines at end of file on save.
|
" Automatically deletes all trailing whitespace and newlines at end of file on save. & reset cursor position
|
||||||
|
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
|
||||||
|
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:
|
||||||
autocmd BufWritePost bm-files,bm-dirs !shortcuts
|
autocmd BufWritePost bm-files,bm-dirs !shortcuts
|
||||||
" Run xrdb whenever Xdefaults or Xresources are updated.
|
" Run xrdb whenever Xdefaults or Xresources are updated.
|
||||||
autocmd BufRead,BufNewFile xresources,xdefaults set filetype=xdefaults
|
autocmd BufRead,BufNewFile Xresources,Xdefaults,xresources,xdefaults set filetype=xdefaults
|
||||||
autocmd BufWritePost Xresources,Xdefaults,xresources,xdefaults !xrdb %
|
autocmd BufWritePost Xresources,Xdefaults,xresources,xdefaults !xrdb %
|
||||||
" Recompile dwmblocks on config edit.
|
" Recompile dwmblocks on config edit.
|
||||||
autocmd BufWritePost ~/.local/src/dwmblocks/config.h !cd ~/.local/src/dwmblocks/; sudo make install && { killall -q dwmblocks;setsid -f dwmblocks }
|
autocmd BufWritePost ~/.local/src/dwmblocks/config.h !cd ~/.local/src/dwmblocks/; sudo make install && { killall -q dwmblocks;setsid -f dwmblocks }
|
||||||
@ -130,7 +132,7 @@ if &diff
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
" Function for toggling the bottom statusbar:
|
" Function for toggling the bottom statusbar:
|
||||||
let s:hidden_all = 1
|
let s:hidden_all = 0
|
||||||
function! ToggleHiddenAll()
|
function! ToggleHiddenAll()
|
||||||
if s:hidden_all == 0
|
if s:hidden_all == 0
|
||||||
let s:hidden_all = 1
|
let s:hidden_all = 1
|
||||||
|
|||||||
5
.config/pinentry/preexec
Executable file
5
.config/pinentry/preexec
Executable file
@ -0,0 +1,5 @@
|
|||||||
|
#!/hint/sh
|
||||||
|
|
||||||
|
# Define additional functionality for pinentry. For example
|
||||||
|
test -e /usr/lib/libgcr-base-3.so.1 && exec /usr/bin/pinentry-gnome3 "$@"
|
||||||
|
#test -e /usr/lib/libQt5Widgets.so.5 && exec /usr/bin/pinentry-qt "$@"
|
||||||
247
.config/pipewire/pipewire.conf
Normal file
247
.config/pipewire/pipewire.conf
Normal file
@ -0,0 +1,247 @@
|
|||||||
|
# Daemon config file for PipeWire version "0.3.40" #
|
||||||
|
#
|
||||||
|
# Copy and edit this file in /etc/pipewire for system-wide changes
|
||||||
|
# or in ~/.config/pipewire for local changes.
|
||||||
|
|
||||||
|
context.properties = {
|
||||||
|
## Configure properties in the system.
|
||||||
|
#library.name.system = support/libspa-support
|
||||||
|
#context.data-loop.library.name.system = support/libspa-support
|
||||||
|
#support.dbus = true
|
||||||
|
#link.max-buffers = 64
|
||||||
|
link.max-buffers = 16 # version < 3 clients can't handle more
|
||||||
|
#mem.warn-mlock = false
|
||||||
|
#mem.allow-mlock = true
|
||||||
|
#mem.mlock-all = false
|
||||||
|
#clock.power-of-two-quantum = true
|
||||||
|
#log.level = 2
|
||||||
|
#cpu.zero.denormals = true
|
||||||
|
|
||||||
|
core.daemon = true # listening for socket connections
|
||||||
|
core.name = pipewire-0 # core name and socket name
|
||||||
|
|
||||||
|
## Properties for the DSP configuration.
|
||||||
|
#default.clock.rate = 48000
|
||||||
|
#default.clock.allowed-rates = [ 48000 ]
|
||||||
|
#default.clock.quantum = 1024
|
||||||
|
#default.clock.min-quantum = 32
|
||||||
|
#default.clock.max-quantum = 8192
|
||||||
|
#default.video.width = 640
|
||||||
|
#default.video.height = 480
|
||||||
|
#default.video.rate.num = 25
|
||||||
|
#default.video.rate.denom = 1
|
||||||
|
#
|
||||||
|
# These overrides are only applied when running in a vm.
|
||||||
|
vm.overrides = {
|
||||||
|
default.clock.min-quantum = 1024
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
context.spa-libs = {
|
||||||
|
#<factory-name regex> = <library-name>
|
||||||
|
#
|
||||||
|
# Used to find spa factory names. It maps an spa factory name
|
||||||
|
# regular expression to a library name that should contain
|
||||||
|
# that factory.
|
||||||
|
#
|
||||||
|
audio.convert.* = audioconvert/libspa-audioconvert
|
||||||
|
api.alsa.* = alsa/libspa-alsa
|
||||||
|
api.v4l2.* = v4l2/libspa-v4l2
|
||||||
|
api.libcamera.* = libcamera/libspa-libcamera
|
||||||
|
api.bluez5.* = bluez5/libspa-bluez5
|
||||||
|
api.vulkan.* = vulkan/libspa-vulkan
|
||||||
|
api.jack.* = jack/libspa-jack
|
||||||
|
support.* = support/libspa-support
|
||||||
|
#videotestsrc = videotestsrc/libspa-videotestsrc
|
||||||
|
#audiotestsrc = audiotestsrc/libspa-audiotestsrc
|
||||||
|
}
|
||||||
|
|
||||||
|
context.modules = [
|
||||||
|
#{ name = <module-name>
|
||||||
|
# [ args = { <key> = <value> ... } ]
|
||||||
|
# [ flags = [ [ ifexists ] [ nofail ] ]
|
||||||
|
#}
|
||||||
|
#
|
||||||
|
# Loads a module with the given parameters.
|
||||||
|
# If ifexists is given, the module is ignored when it is not found.
|
||||||
|
# If nofail is given, module initialization failures are ignored.
|
||||||
|
#
|
||||||
|
|
||||||
|
# Uses RTKit to boost the data thread priority.
|
||||||
|
{ name = libpipewire-module-rtkit
|
||||||
|
args = {
|
||||||
|
#nice.level = -11
|
||||||
|
#rt.prio = 88
|
||||||
|
#rt.time.soft = 2000000
|
||||||
|
#rt.time.hard = 2000000
|
||||||
|
}
|
||||||
|
flags = [ ifexists nofail ]
|
||||||
|
}
|
||||||
|
|
||||||
|
# Set thread priorities without using RTKit.
|
||||||
|
#{ name = libpipewire-module-rt
|
||||||
|
# args = {
|
||||||
|
# nice.level = -11
|
||||||
|
# rt.prio = 88
|
||||||
|
# rt.time.soft = 2000000
|
||||||
|
# rt.time.hard = 2000000
|
||||||
|
# }
|
||||||
|
# flags = [ ifexists nofail ]
|
||||||
|
#}
|
||||||
|
|
||||||
|
# The native communication protocol.
|
||||||
|
{ name = libpipewire-module-protocol-native }
|
||||||
|
|
||||||
|
# The profile module. Allows application to access profiler
|
||||||
|
# and performance data. It provides an interface that is used
|
||||||
|
# by pw-top and pw-profiler.
|
||||||
|
{ name = libpipewire-module-profiler }
|
||||||
|
|
||||||
|
# Allows applications to create metadata objects. It creates
|
||||||
|
# a factory for Metadata objects.
|
||||||
|
{ name = libpipewire-module-metadata }
|
||||||
|
|
||||||
|
# Creates a factory for making devices that run in the
|
||||||
|
# context of the PipeWire server.
|
||||||
|
{ name = libpipewire-module-spa-device-factory }
|
||||||
|
|
||||||
|
# Creates a factory for making nodes that run in the
|
||||||
|
# context of the PipeWire server.
|
||||||
|
{ name = libpipewire-module-spa-node-factory }
|
||||||
|
|
||||||
|
# Allows creating nodes that run in the context of the
|
||||||
|
# client. Is used by all clients that want to provide
|
||||||
|
# data to PipeWire.
|
||||||
|
{ name = libpipewire-module-client-node }
|
||||||
|
|
||||||
|
# Allows creating devices that run in the context of the
|
||||||
|
# client. Is used by the session manager.
|
||||||
|
{ name = libpipewire-module-client-device }
|
||||||
|
|
||||||
|
# The portal module monitors the PID of the portal process
|
||||||
|
# and tags connections with the same PID as portal
|
||||||
|
# connections.
|
||||||
|
{ name = libpipewire-module-portal
|
||||||
|
flags = [ ifexists nofail ]
|
||||||
|
}
|
||||||
|
|
||||||
|
# The access module can perform access checks and block
|
||||||
|
# new clients.
|
||||||
|
{ name = libpipewire-module-access
|
||||||
|
args = {
|
||||||
|
# access.allowed to list an array of paths of allowed
|
||||||
|
# apps.
|
||||||
|
#access.allowed = [
|
||||||
|
# /usr/bin/pipewire-media-session
|
||||||
|
#]
|
||||||
|
|
||||||
|
# An array of rejected paths.
|
||||||
|
#access.rejected = [ ]
|
||||||
|
|
||||||
|
# An array of paths with restricted access.
|
||||||
|
#access.restricted = [ ]
|
||||||
|
|
||||||
|
# Anything not in the above lists gets assigned the
|
||||||
|
# access.force permission.
|
||||||
|
#access.force = flatpak
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Makes a factory for wrapping nodes in an adapter with a
|
||||||
|
# converter and resampler.
|
||||||
|
{ name = libpipewire-module-adapter }
|
||||||
|
|
||||||
|
# Makes a factory for creating links between ports.
|
||||||
|
{ name = libpipewire-module-link-factory }
|
||||||
|
|
||||||
|
# Provides factories to make session manager objects.
|
||||||
|
{ name = libpipewire-module-session-manager }
|
||||||
|
]
|
||||||
|
|
||||||
|
context.objects = [
|
||||||
|
#{ factory = <factory-name>
|
||||||
|
# [ args = { <key> = <value> ... } ]
|
||||||
|
# [ flags = [ [ nofail ] ]
|
||||||
|
#}
|
||||||
|
#
|
||||||
|
# Creates an object from a PipeWire factory with the given parameters.
|
||||||
|
# If nofail is given, errors are ignored (and no object is created).
|
||||||
|
#
|
||||||
|
#{ factory = spa-node-factory args = { factory.name = videotestsrc node.name = videotestsrc Spa:Pod:Object:Param:Props:patternType = 1 } }
|
||||||
|
#{ factory = spa-device-factory args = { factory.name = api.jack.device foo=bar } flags = [ nofail ] }
|
||||||
|
#{ factory = spa-device-factory args = { factory.name = api.alsa.enum.udev } }
|
||||||
|
#{ factory = spa-node-factory args = { factory.name = api.alsa.seq.bridge node.name = Internal-MIDI-Bridge } }
|
||||||
|
#{ factory = adapter args = { factory.name = audiotestsrc node.name = my-test } }
|
||||||
|
#{ factory = spa-node-factory args = { factory.name = api.vulkan.compute.source node.name = my-compute-source } }
|
||||||
|
|
||||||
|
# A default dummy driver. This handles nodes marked with the "node.always-driver"
|
||||||
|
# property when no other driver is currently active. JACK clients need this.
|
||||||
|
{ factory = spa-node-factory
|
||||||
|
args = {
|
||||||
|
factory.name = support.node.driver
|
||||||
|
node.name = Dummy-Driver
|
||||||
|
node.group = pipewire.dummy
|
||||||
|
priority.driver = 20000
|
||||||
|
}
|
||||||
|
}
|
||||||
|
{ factory = spa-node-factory
|
||||||
|
args = {
|
||||||
|
factory.name = support.node.driver
|
||||||
|
node.name = Freewheel-Driver
|
||||||
|
priority.driver = 19000
|
||||||
|
node.group = pipewire.freewheel
|
||||||
|
node.freewheel = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
# This creates a new Source node. It will have input ports
|
||||||
|
# that you can link, to provide audio for this source.
|
||||||
|
#{ factory = adapter
|
||||||
|
# args = {
|
||||||
|
# factory.name = support.null-audio-sink
|
||||||
|
# node.name = "my-mic"
|
||||||
|
# node.description = "Microphone"
|
||||||
|
# media.class = "Audio/Source/Virtual"
|
||||||
|
# audio.position = "FL,FR"
|
||||||
|
# }
|
||||||
|
#}
|
||||||
|
|
||||||
|
# This creates a single PCM source device for the given
|
||||||
|
# alsa device path hw:0. You can change source to sink
|
||||||
|
# to make a sink in the same way.
|
||||||
|
#{ factory = adapter
|
||||||
|
# args = {
|
||||||
|
# factory.name = api.alsa.pcm.source
|
||||||
|
# node.name = "alsa-source"
|
||||||
|
# node.description = "PCM Source"
|
||||||
|
# media.class = "Audio/Source"
|
||||||
|
# api.alsa.path = "hw:0"
|
||||||
|
# api.alsa.period-size = 1024
|
||||||
|
# api.alsa.headroom = 0
|
||||||
|
# api.alsa.disable-mmap = false
|
||||||
|
# api.alsa.disable-batch = false
|
||||||
|
# audio.format = "S16LE"
|
||||||
|
# audio.rate = 48000
|
||||||
|
# audio.channels = 2
|
||||||
|
# audio.position = "FL,FR"
|
||||||
|
# }
|
||||||
|
#}
|
||||||
|
]
|
||||||
|
|
||||||
|
context.exec = [
|
||||||
|
#{ path = <program-name> [ args = "<arguments>" ] }
|
||||||
|
#
|
||||||
|
# Execute the given program with arguments.
|
||||||
|
#
|
||||||
|
# You can optionally start the session manager here,
|
||||||
|
# but it is better to start it as a systemd service.
|
||||||
|
# Run the session manager with -h for options.
|
||||||
|
#
|
||||||
|
{ path = "/usr/bin/pipewire-media-session" args = "" }
|
||||||
|
#
|
||||||
|
# You can optionally start the pulseaudio-server here as well
|
||||||
|
# but it is better to start it as a systemd service.
|
||||||
|
# It can be interesting to start another daemon here that listens
|
||||||
|
# on another address with the -a option (eg. -a tcp:4713).
|
||||||
|
#
|
||||||
|
{ path = "/usr/bin/pipewire" args = "-c pipewire-pulse.conf" }
|
||||||
|
]
|
||||||
@ -3,11 +3,20 @@
|
|||||||
# Use neovim for vim if present.
|
# Use neovim for vim if present.
|
||||||
[ -x "$(command -v nvim)" ] && alias vim="nvim" vimdiff="nvim -d"
|
[ -x "$(command -v nvim)" ] && alias vim="nvim" vimdiff="nvim -d"
|
||||||
|
|
||||||
|
# Use $XINITRC variable if file exists.
|
||||||
|
[ -f "$XINITRC" ] && alias startx="startx $XINITRC"
|
||||||
|
|
||||||
|
# sudo not required for some system commands
|
||||||
|
for command in mount umount sv pacman updatedb su shutdown poweroff reboot ; do
|
||||||
|
alias $command="sudo $command"
|
||||||
|
done; unset command
|
||||||
|
|
||||||
# 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" \
|
||||||
mkd="mkdir -pv" \
|
mkd="mkdir -pv" \
|
||||||
yt="youtube-dl --add-metadata -i" \
|
yt="youtube-dl --add-metadata -i" \
|
||||||
yta="yt -x -f bestaudio/best" \
|
yta="yt -x -f bestaudio/best" \
|
||||||
@ -26,17 +35,17 @@ alias \
|
|||||||
g="git" \
|
g="git" \
|
||||||
trem="transmission-remote" \
|
trem="transmission-remote" \
|
||||||
YT="youtube-viewer" \
|
YT="youtube-viewer" \
|
||||||
sdn="sudo shutdown -h now" \
|
sdn="shutdown -h now" \
|
||||||
f="$FILE" \
|
|
||||||
e="$EDITOR" \
|
e="$EDITOR" \
|
||||||
v="$EDITOR" \
|
v="$EDITOR" \
|
||||||
p="sudo pacman" \
|
p="pacman" \
|
||||||
xi="sudo xbps-install" \
|
xi="sudo xbps-install" \
|
||||||
xr="sudo xbps-remove -R" \
|
xr="sudo xbps-remove -R" \
|
||||||
xq="xbps-query" \
|
xq="xbps-query" \
|
||||||
z="zathura"
|
z="zathura"
|
||||||
|
|
||||||
alias \
|
alias \
|
||||||
|
lf="lfub" \
|
||||||
magit="nvim -c MagitOnly" \
|
magit="nvim -c MagitOnly" \
|
||||||
ref="shortcuts >/dev/null; source ${XDG_CONFIG_HOME:-$HOME/.config}/shortcutrc ; source ${XDG_CONFIG_HOME:-$HOME/.config}/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_DATA_HOME:-$HOME/.local/share}/weatherreport" \
|
||||||
|
|||||||
@ -4,6 +4,7 @@ cf ${XDG_CONFIG_HOME:-$HOME/.config}
|
|||||||
D ${XDG_DOWNLOAD_DIR:-$HOME/Downloads}
|
D ${XDG_DOWNLOAD_DIR:-$HOME/Downloads}
|
||||||
d ${XDG_DOCUMENTS_DIR:-$HOME/Documents}
|
d ${XDG_DOCUMENTS_DIR:-$HOME/Documents}
|
||||||
dt ${XDG_DATA_HOME:-$HOME/.local/share}
|
dt ${XDG_DATA_HOME:-$HOME/.local/share}
|
||||||
|
rr $HOME/.local/src
|
||||||
h $HOME
|
h $HOME
|
||||||
m ${XDG_MUSIC_DIR:-$HOME/Music}
|
m ${XDG_MUSIC_DIR:-$HOME/Music}
|
||||||
mn /mnt
|
mn /mnt
|
||||||
|
|||||||
@ -19,7 +19,7 @@ export BROWSER="brave"
|
|||||||
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:-$HOME/.config}/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:-$HOME/.config}/notmuch-config"
|
||||||
export GTK2_RC_FILES="${XDG_CONFIG_HOME:-$HOME/.config}/gtk-2.0/gtkrc-2.0"
|
export GTK2_RC_FILES="${XDG_CONFIG_HOME:-$HOME/.config}/gtk-2.0/gtkrc-2.0"
|
||||||
@ -40,6 +40,8 @@ export ANSIBLE_CONFIG="${XDG_CONFIG_HOME:-$HOME/.config}/ansible/ansible.cfg"
|
|||||||
export UNISON="${XDG_DATA_HOME:-$HOME/.local/share}/unison"
|
export UNISON="${XDG_DATA_HOME:-$HOME/.local/share}/unison"
|
||||||
export HISTFILE="${XDG_DATA_HOME:-$HOME/.local/share}/history"
|
export HISTFILE="${XDG_DATA_HOME:-$HOME/.local/share}/history"
|
||||||
export WEECHAT_HOME="${XDG_CONFIG_HOME:-$HOME/.config}/weechat"
|
export WEECHAT_HOME="${XDG_CONFIG_HOME:-$HOME/.config}/weechat"
|
||||||
|
export MBSYNCRC="${XDG_CONFIG_HOME:-$HOME/.config}/mbsync/config"
|
||||||
|
export ELECTRUMDIR="${XDG_DATA_HOME:-$HOME/.local/share}/electrum"
|
||||||
|
|
||||||
# Other program settings:
|
# Other program settings:
|
||||||
export DICS="/usr/share/stardict/dic/"
|
export DICS="/usr/share/stardict/dic/"
|
||||||
@ -142,7 +144,7 @@ ex=🎯:\
|
|||||||
|
|
||||||
if pacman -Qs libxft-bgra >/dev/null 2>&1; then
|
if pacman -Qs libxft-bgra >/dev/null 2>&1; then
|
||||||
# Start graphical server on user's current tty if not already running.
|
# Start graphical server on user's current tty if not already running.
|
||||||
[ "$(tty)" = "/dev/tty1" ] && ! pidof -s Xorg >/dev/null 2>&1 && exec startx
|
[ "$(tty)" = "/dev/tty1" ] && ! pidof -s Xorg >/dev/null 2>&1 && exec startx "$XINITRC"
|
||||||
else
|
else
|
||||||
echo "\033[31mIMPORTANT\033[0m: Note that \033[32m\`libxft-bgra\`\033[0m must be installed for this build of dwm.
|
echo "\033[31mIMPORTANT\033[0m: Note that \033[32m\`libxft-bgra\`\033[0m must be installed for this build of dwm.
|
||||||
Please run:
|
Please run:
|
||||||
|
|||||||
@ -1,11 +1,17 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
source "${HOME}/.cache/wal/colors.sh"
|
dunstconf="${XDG_CONFIG_HOME:-$HOME/.config}/dunst/dunstrc"
|
||||||
|
zathuraconf="${XDG_CONFIG_HOME:-$HOME/.config}/zathura/zathurarc"
|
||||||
|
|
||||||
mkdir -p "${HOME}/.config/dunst"
|
source "${XDG_CACHE_HOME:-$HOME/.cache}/wal/colors.sh"
|
||||||
mkdir -p "${HOME}/.config/zathura"
|
|
||||||
ln -sf "${HOME}/.cache/wal/dunstrc" "${HOME}/.config/dunst/dunstrc"
|
mkdir -p "${dunstconf%/*}" "${zathuraconf%/*}"
|
||||||
ln -sf "${HOME}/.cache/wal/zathurarc" "${HOME}/.config/zathura/zathurarc"
|
|
||||||
|
mv -n "$dunstconf" "$dunstconf.bak"
|
||||||
|
mv -n "$zathuraconf" "$zathuraconf.bak"
|
||||||
|
|
||||||
|
ln -sf "${XDG_CACHE_HOME:-$HOME/.cache}/wal/dunstrc" "$dunstconf"
|
||||||
|
ln -sf "${XDG_CACHE_HOME:-$HOME/.cache}/wal/zathurarc" "$zathuraconf"
|
||||||
|
|
||||||
fix_sequences() {
|
fix_sequences() {
|
||||||
e=$'\e'
|
e=$'\e'
|
||||||
@ -14,14 +20,13 @@ fix_sequences() {
|
|||||||
background_color="$(echo -e "${sequences}\c" | grep --color=never -Eo "${e}]11[^${e}\\\\]*?${e}\\\\" | grep --color=never -Eo "#[0-9A-Fa-f]{6}")"
|
background_color="$(echo -e "${sequences}\c" | grep --color=never -Eo "${e}]11[^${e}\\\\]*?${e}\\\\" | grep --color=never -Eo "#[0-9A-Fa-f]{6}")"
|
||||||
cursor_color="$(echo -e "${sequences}\c" | grep --color=never -Eo "${e}]12[^${e}\\\\]*?${e}\\\\" | grep --color=never -Eo "#[0-9A-Fa-f]{6}")"
|
cursor_color="$(echo -e "${sequences}\c" | grep --color=never -Eo "${e}]12[^${e}\\\\]*?${e}\\\\" | grep --color=never -Eo "#[0-9A-Fa-f]{6}")"
|
||||||
|
|
||||||
for term in /dev/pts/{0..9}*
|
for term in /dev/pts/{0..9}*; do
|
||||||
do
|
echo -e "\e]4;256;${cursor_color}\a\c" > "${term}" 2>/dev/null
|
||||||
echo -e "\e]4;256;${cursor_color}\a\c" > "${term}" 2>/dev/null
|
echo -e "\e]4;258;${background_color}\a\c" > "${term}" 2>/dev/null
|
||||||
echo -e "\e]4;258;${background_color}\a\c" > "${term}" 2>/dev/null
|
echo -e "\e]4;259;${foreground_color}\a\c" > "${term}" 2>/dev/null
|
||||||
echo -e "\e]4;259;${foreground_color}\a\c" > "${term}" 2>/dev/null
|
done
|
||||||
done
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fix_sequences <"${HOME}/.cache/wal/sequences"
|
fix_sequences <"${XDG_CACHE_HOME:-$HOME/.cache}/wal/sequences"
|
||||||
|
|
||||||
pkill dunst; dunst &
|
pkill dunst; setsid -f dunst
|
||||||
|
|||||||
@ -1,152 +1,27 @@
|
|||||||
[global]
|
[global]
|
||||||
monitor = 0
|
monitor = 0
|
||||||
follow = keyboard
|
follow = keyboard
|
||||||
geometry = "350x5-0+24"
|
width = 370
|
||||||
indicate_hidden = yes
|
height = 350
|
||||||
shrink = yes
|
offset = 0x19
|
||||||
transparency = 20
|
padding = 2
|
||||||
notification_height = 0
|
horizontal_padding = 2
|
||||||
separator_height = 2
|
transparency = 25
|
||||||
padding = 0
|
font = Monospace 12
|
||||||
horizontal_padding = 8
|
|
||||||
frame_width = 3
|
|
||||||
frame_color = "{color4}"
|
|
||||||
|
|
||||||
# Define a color for the separator.
|
|
||||||
# possible values are:
|
|
||||||
# * auto: dunst tries to find a color fitting to the background;
|
|
||||||
# * foreground: use the same color as the foreground;
|
|
||||||
# * frame: use the same color as the frame;
|
|
||||||
# * anything else will be interpreted as a X color.
|
|
||||||
separator_color = frame
|
|
||||||
|
|
||||||
# Sort messages by urgency.
|
|
||||||
sort = yes
|
|
||||||
|
|
||||||
idle_threshold = 120
|
|
||||||
font = Monospace 14
|
|
||||||
line_height = 0
|
|
||||||
markup = full
|
|
||||||
|
|
||||||
# The format of the message. Possible variables are:
|
|
||||||
# %a appname
|
|
||||||
# %s summary
|
|
||||||
# %b body
|
|
||||||
# %i iconname (including its path)
|
|
||||||
# %I iconname (without its path)
|
|
||||||
# %p progress value if set ([ 0%] to [100%]) or nothing
|
|
||||||
# %n progress value if set without any extra characters
|
|
||||||
# %% Literal %
|
|
||||||
# Markup is allowed
|
|
||||||
format = "<b>%s</b>\n%b"
|
format = "<b>%s</b>\n%b"
|
||||||
|
|
||||||
alignment = left
|
|
||||||
show_age_threshold = 60
|
|
||||||
word_wrap = yes
|
|
||||||
ellipsize = middle
|
|
||||||
ignore_newline = no
|
|
||||||
stack_duplicates = true
|
|
||||||
hide_duplicate_count = true
|
|
||||||
show_indicators = yes
|
|
||||||
icon_position = left
|
|
||||||
max_icon_size = 40
|
|
||||||
#icon_path = /usr/share/icons/gnome/16x16/status/:/usr/share/icons/gnome/16x16/devices/:/usr/share/icons/Adwaita/256x256/status/
|
|
||||||
sticky_history = yes
|
|
||||||
history_length = 20
|
|
||||||
dmenu = /usr/bin/dmenu -p dunst:
|
|
||||||
browser = /usr/bin/firefox -new-tab
|
|
||||||
|
|
||||||
# Always run rule-defined scripts, even if the notification is suppressed
|
|
||||||
always_run_script = true
|
|
||||||
|
|
||||||
title = Dunst
|
|
||||||
class = Dunst
|
|
||||||
startup_notification = false
|
|
||||||
force_xinerama = false
|
|
||||||
[experimental]
|
|
||||||
per_monitor_dpi = false
|
|
||||||
|
|
||||||
[shortcuts]
|
|
||||||
close = ctrl+space
|
|
||||||
close_all = ctrl+shift+space
|
|
||||||
history = ctrl+grave
|
|
||||||
context = ctrl+shift+period
|
|
||||||
|
|
||||||
[urgency_low]
|
[urgency_low]
|
||||||
# IMPORTANT: colors have to be defined in quotation marks.
|
background = "{color0}" # color0
|
||||||
# Otherwise the "#" and following would be interpreted as a comment.
|
foreground = "{color8}" # color8
|
||||||
background = "{background}"
|
timeout = 3
|
||||||
foreground = "{foreground}"
|
|
||||||
timeout = 5
|
|
||||||
# Icon for notifications with low urgency, uncomment to enable
|
|
||||||
#icon = /path/to/icon
|
|
||||||
|
|
||||||
[urgency_normal]
|
[urgency_normal]
|
||||||
background = "{background}"
|
foreground = "{color15}" # color15
|
||||||
foreground = "{foreground}"
|
background = "{color4}" # color4
|
||||||
timeout = 5
|
timeout = 5
|
||||||
|
|
||||||
[urgency_critical]
|
[urgency_critical]
|
||||||
background = "{background}"
|
background = "{color1}" # color1
|
||||||
foreground = "{foreground}"
|
foreground = "{color15}" # color15
|
||||||
frame_color = "#fabd2f"
|
frame_color = "{color11}" # color11
|
||||||
timeout = 0
|
timeout = 10
|
||||||
|
|
||||||
# Every section that isn't one of the above is interpreted as a rules to
|
|
||||||
# override settings for certain messages.
|
|
||||||
# Messages can be matched by "appname", "summary", "body", "icon", "category",
|
|
||||||
# "msg_urgency" and you can override the "timeout", "urgency", "foreground",
|
|
||||||
# "background", "new_icon" and "format".
|
|
||||||
# Shell-like globbing will get expanded.
|
|
||||||
#
|
|
||||||
# SCRIPTING
|
|
||||||
# You can specify a script that gets run when the rule matches by
|
|
||||||
# setting the "script" option.
|
|
||||||
# The script will be called as follows:
|
|
||||||
# script appname summary body icon urgency
|
|
||||||
# where urgency can be "LOW", "NORMAL" or "CRITICAL".
|
|
||||||
#
|
|
||||||
# NOTE: if you don't want a notification to be displayed, set the format
|
|
||||||
# to "".
|
|
||||||
# NOTE: It might be helpful to run dunst -print in a terminal in order
|
|
||||||
# to find fitting options for rules.
|
|
||||||
|
|
||||||
#[espeak]
|
|
||||||
# summary = "*"
|
|
||||||
# script = dunst_espeak.sh
|
|
||||||
|
|
||||||
#[script-test]
|
|
||||||
# summary = "*script*"
|
|
||||||
# script = dunst_test.sh
|
|
||||||
|
|
||||||
#[ignore]
|
|
||||||
# # This notification will not be displayed
|
|
||||||
# summary = "foobar"
|
|
||||||
# format = ""
|
|
||||||
|
|
||||||
#[history-ignore]
|
|
||||||
# # This notification will not be saved in history
|
|
||||||
# summary = "foobar"
|
|
||||||
# history_ignore = yes
|
|
||||||
|
|
||||||
#[signed_on]
|
|
||||||
# appname = Pidgin
|
|
||||||
# summary = "*signed on*"
|
|
||||||
# urgency = low
|
|
||||||
#
|
|
||||||
#[signed_off]
|
|
||||||
# appname = Pidgin
|
|
||||||
# summary = *signed off*
|
|
||||||
# urgency = low
|
|
||||||
#
|
|
||||||
#[says]
|
|
||||||
# appname = Pidgin
|
|
||||||
# summary = *says*
|
|
||||||
# urgency = critical
|
|
||||||
#
|
|
||||||
#[twitter]
|
|
||||||
# appname = Pidgin
|
|
||||||
# summary = *twitter.com*
|
|
||||||
# urgency = normal
|
|
||||||
#
|
|
||||||
# vim: ft=cfg
|
|
||||||
|
|||||||
@ -3,18 +3,16 @@
|
|||||||
# This file runs when a DM logs you into a graphical session.
|
# This file runs when a DM logs you into a graphical session.
|
||||||
# If you use startx/xinit like a Chad, this file will also be sourced.
|
# If you use startx/xinit like a Chad, this file will also be sourced.
|
||||||
|
|
||||||
mpd & # music player daemon-you might prefer it as a service though
|
xrandr --dpi 96 # Set DPI. User may want to use a larger number for larger screens.
|
||||||
remaps & # run the remaps script, switching caps/esc and more; check it for more info
|
|
||||||
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 & xrdbpid=$! # Uncomment to use Xresources colors/settings on startup
|
||||||
xcompmgr & # xcompmgr for transparency
|
remaps & # run the remaps script, switching caps/esc and more; check it for more info
|
||||||
dunst & # dunst for notifications
|
|
||||||
xset r rate 300 50 & # Speed xrate up
|
|
||||||
unclutter & # Remove mouse when idle
|
|
||||||
|
|
||||||
# This line autostarts an instance of Pulseaudio that does not exit on idle.
|
autostart="mpd xcompmgr dunst unclutter pipewire"
|
||||||
# This is "necessary" on Artix due to a current bug between PA and
|
|
||||||
# Chromium-based browsers where they fail to start PA and use dummy output.
|
for program in $autostart; do
|
||||||
pidof -s runit &&
|
pidof -s "$program" || setsid -f "$program"
|
||||||
! pidof -s pulseaudio >/dev/null 2>&1 &&
|
done >/dev/null 2>&1
|
||||||
setsid -f pulseaudio --start --exit-idle-time=-1 >/dev/null 2>&1
|
|
||||||
|
# Ensure that xrdb has finished running before moving on to start the WM/DE.
|
||||||
|
[ -n "$xrdbpid" ] && wait "$xrdbpid"
|
||||||
|
|||||||
@ -12,3 +12,4 @@ 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
|
||||||
|
|||||||
4
.gitmodules
vendored
4
.gitmodules
vendored
@ -1,3 +1,3 @@
|
|||||||
[submodule ".config/mpv/scripts/mpvSockets"]
|
[submodule ".config/mpv/script_modules/mpvSockets"]
|
||||||
path = .config/mpv/scripts/mpvSockets
|
path = .config/mpv/script_modules/mpvSockets
|
||||||
url = https://github.com/wis/mpvSockets.git
|
url = https://github.com/wis/mpvSockets.git
|
||||||
|
|||||||
1
.gtkrc-2.0
Symbolic link
1
.gtkrc-2.0
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
.config/gtk-2.0/gtkrc-2.0
|
||||||
@ -37,7 +37,7 @@ 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 -d nointem -e super "$file" -Tms | groff -mpdfmark -ms -kept > "$base".pdf
|
lowdown --parse-no-intraemph "$file" -Tms | groff -mpdfmark -ms -kept > "$base".pdf
|
||||||
elif [ -x "$(command -v groffdown)" ]; then
|
elif [ -x "$(command -v groffdown)" ]; then
|
||||||
groffdown -i "$file" | groff > "$base.pdf"
|
groffdown -i "$file" | groff > "$base.pdf"
|
||||||
else
|
else
|
||||||
@ -53,5 +53,5 @@ case "$ext" in
|
|||||||
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" ;;
|
||||||
*) head -n1 "$file" | grep "^#!/" | sed "s/^#!//" | xargs -r -I % "$file" ;;
|
*) sed -n '/^#!/s/^#!//p; q' "$file" | xargs -r -I % "$file" ;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
@ -2,8 +2,6 @@
|
|||||||
|
|
||||||
# Syncs repositories and downloads updates, meant to be run as a cronjob.
|
# Syncs repositories and downloads updates, meant to be run as a cronjob.
|
||||||
|
|
||||||
ping -q -c 1 example.org > /dev/null || exit
|
|
||||||
|
|
||||||
notify-send "📦 Repository Sync" "Checking for package updates..."
|
notify-send "📦 Repository Sync" "Checking for package updates..."
|
||||||
|
|
||||||
sudo pacman -Syyuw --noconfirm || notify-send "Error downloading updates.
|
sudo pacman -Syyuw --noconfirm || notify-send "Error downloading updates.
|
||||||
|
|||||||
@ -1,9 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# Notify me with notify-send if my battery is below 25%.
|
|
||||||
# You can set this to run via cron.
|
|
||||||
|
|
||||||
[ "$(cat /sys/class/power_supply/BAT0/status)" = "Charging" ] && exit
|
|
||||||
[ "$(cat /sys/class/power_supply/BAT0/capacity)" -lt 25 ] &&
|
|
||||||
export DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/$(id -u $USER)/bus &&
|
|
||||||
notify-send -u critical "Battery critically low."
|
|
||||||
@ -3,11 +3,9 @@
|
|||||||
# Set as a cron job to check for new RSS entries for newsboat.
|
# Set as a cron job to check for new RSS entries for newsboat.
|
||||||
# If newsboat is open, sends it an "R" key to refresh.
|
# If newsboat is open, sends it an "R" key to refresh.
|
||||||
|
|
||||||
ping -q -c 1 example.org > /dev/null || exit
|
|
||||||
|
|
||||||
/usr/bin/notify-send "📰 Updating RSS feeds..."
|
/usr/bin/notify-send "📰 Updating RSS feeds..."
|
||||||
|
|
||||||
pgrep -f newsboat$ && /usr/bin/xdotool key --window "$(/usr/bin/xdotool search --name newsboat)" R && exit
|
pgrep -f newsboat$ && /usr/bin/xdotool key --window "$(/usr/bin/xdotool search --name "^newsboat$")" R && exit
|
||||||
|
|
||||||
echo 🔃 > /tmp/newsupdate
|
echo 🔃 > /tmp/newsupdate
|
||||||
pkill -RTMIN+6 "${STATUSBAR:-dwmblocks}"
|
pkill -RTMIN+6 "${STATUSBAR:-dwmblocks}"
|
||||||
|
|||||||
@ -5,7 +5,7 @@
|
|||||||
feed="${1:-$(printf "%s" | dmenu -p 'Paste URL or file path')}"
|
feed="${1:-$(printf "%s" | 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-dl\\nqueue yt-dl audio" | dmenu -i -p "Open it with?")" in
|
case "$(printf "Copy URL\\nsxiv\\nsetbg\\nPDF\\nbrowser\\nlynx\\nvim\\nmpv\\nmpv loop\\nmpv float\\nqueue download\\nqueue yt-dl\\nqueue yt-dl 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 ;;
|
||||||
|
|||||||
@ -9,7 +9,7 @@ getmount() { \
|
|||||||
[ -z "$chosen" ] && exit 1
|
[ -z "$chosen" ] && exit 1
|
||||||
# shellcheck disable=SC2086
|
# shellcheck disable=SC2086
|
||||||
mp="$(find $1 2>/dev/null | dmenu -i -p "Type in mount point.")" || exit 1
|
mp="$(find $1 2>/dev/null | dmenu -i -p "Type in mount point.")" || exit 1
|
||||||
[ "$mp" = "" ] && exit 1
|
test -z "$mp" && exit 1
|
||||||
if [ ! -d "$mp" ]; then
|
if [ ! -d "$mp" ]; then
|
||||||
mkdiryn=$(printf "No\\nYes" | dmenu -i -p "$mp does not exist. Create it?") || exit 1
|
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")
|
[ "$mkdiryn" = "Yes" ] && (mkdir -p "$mp" || sudo -A mkdir -p "$mp")
|
||||||
|
|||||||
@ -31,7 +31,7 @@ screencast() { \
|
|||||||
ffmpeg -y \
|
ffmpeg -y \
|
||||||
-f x11grab \
|
-f x11grab \
|
||||||
-framerate 60 \
|
-framerate 60 \
|
||||||
-s "$(xdpyinfo | grep dimensions | awk '{print $2;}')" \
|
-s "$(xdpyinfo | awk '/dimensions/ {print $2;}')" \
|
||||||
-i "$DISPLAY" \
|
-i "$DISPLAY" \
|
||||||
-f alsa -i default \
|
-f alsa -i default \
|
||||||
-r 30 \
|
-r 30 \
|
||||||
@ -43,7 +43,7 @@ screencast() { \
|
|||||||
|
|
||||||
video() { ffmpeg \
|
video() { ffmpeg \
|
||||||
-f x11grab \
|
-f x11grab \
|
||||||
-s "$(xdpyinfo | grep dimensions | awk '{print $2;}')" \
|
-s "$(xdpyinfo | awk '/dimensions/ {print $2;}')" \
|
||||||
-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" &
|
||||||
|
|||||||
@ -26,7 +26,7 @@ asktype() { \
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
drives=$(lsblk -nrpo "name,type,size,mountpoint" | awk '$4!~/\/boot|\/home$|SWAP/&&length($4)>1{printf "%s (%s)\n",$4,$3}')
|
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
|
if ! grep simple-mtpfs /etc/mtab; then
|
||||||
[ -z "$drives" ] && echo "No drives to unmount." && exit
|
[ -z "$drives" ] && echo "No drives to unmount." && exit
|
||||||
|
|||||||
@ -1,45 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# A general, all-purpose extraction script. Not all extraction programs here
|
|
||||||
# are installed by LARBS automatically.
|
|
||||||
#
|
|
||||||
# Default behavior: Extract archive into new directory
|
|
||||||
# Behavior with `-c` option: Extract contents into current directory
|
|
||||||
|
|
||||||
while getopts "hc" o; do case "${o}" in
|
|
||||||
c) extracthere="True" ;;
|
|
||||||
*) printf "Options:\\n -c: Extract archive into current directory rather than a new one.\\n" && exit 1 ;;
|
|
||||||
esac done
|
|
||||||
|
|
||||||
if [ -z "$extracthere" ]; then
|
|
||||||
archive="$(readlink -f "$*")" &&
|
|
||||||
directory="$(echo "$archive" | sed 's/\.[^\/.]*$//')" &&
|
|
||||||
mkdir -p "$directory" &&
|
|
||||||
cd "$directory" || exit 1
|
|
||||||
else
|
|
||||||
archive="$(readlink -f "$(echo "$*" | cut -d' ' -f2)" 2>/dev/null)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
[ -z "$archive" ] && printf "Give archive to extract as argument.\\n" && exit 1
|
|
||||||
|
|
||||||
if [ -f "$archive" ] ; then
|
|
||||||
case "$archive" in
|
|
||||||
*.tar.bz2|*.tbz2) tar xvjf "$archive" ;;
|
|
||||||
*.tar.xz) tar -xf "$archive" ;;
|
|
||||||
*.tar.gz|*.tgz) tar xvzf "$archive" ;;
|
|
||||||
*.tar.zst) tar -I zstd -xf "$archive" ;;
|
|
||||||
*.lzma) unlzma "$archive" ;;
|
|
||||||
*.bz2) bunzip2 "$archive" ;;
|
|
||||||
*.rar) unrar x -ad "$archive" ;;
|
|
||||||
*.gz) gunzip "$archive" ;;
|
|
||||||
*.tar) tar xvf "$archive" ;;
|
|
||||||
*.zip) unzip "$archive" ;;
|
|
||||||
*.Z) uncompress "$archive" ;;
|
|
||||||
*.7z) 7z x "$archive" ;;
|
|
||||||
*.xz) unxz "$archive" ;;
|
|
||||||
*.exe) cabextract "$archive" ;;
|
|
||||||
*) printf "extract: '%s' - unknown archive method\\n" "$archive" ;;
|
|
||||||
esac
|
|
||||||
else
|
|
||||||
printf "File \"%s\" not found.\\n" "$archive"
|
|
||||||
fi
|
|
||||||
@ -11,4 +11,4 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Check crossref.org for the bib citation.
|
# Check crossref.org for the bib citation.
|
||||||
curl -s "http://api.crossref.org/works/$doi/transform/application/x-bibtex" -w "\\n"
|
curl -s "https://api.crossref.org/works/$doi/transform/application/x-bibtex" -w "\\n"
|
||||||
|
|||||||
@ -5,7 +5,8 @@
|
|||||||
# it informs the user that they need that command to continue. This is used in
|
# it informs the user that they need that command to continue. This is used in
|
||||||
# various other scripts for clarity's sake.
|
# various other scripts for clarity's sake.
|
||||||
|
|
||||||
for x in "$@";do
|
for x in "$@"; do
|
||||||
pacman -Qq "$x" >/dev/null 2>&1 ||
|
if ! which "$x" >/dev/null 2>&1 && ! pacman -Qq "$x" >/dev/null 2>&1; then
|
||||||
{ notify-send "📦 $x" "must be installed for this function." && exit 1 ;}
|
notify-send "📦 $x" "must be installed for this function." && exit 1 ;
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|||||||
@ -1,9 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# Reads file names from stdin and selects them in lf.
|
|
||||||
|
|
||||||
while read -r file; do
|
|
||||||
[ -z "$file" ] && continue
|
|
||||||
lf -remote "send select \"$file\""
|
|
||||||
lf -remote "send toggle"
|
|
||||||
done
|
|
||||||
24
.local/bin/lfub
Executable file
24
.local/bin/lfub
Executable file
@ -0,0 +1,24 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# This is a wrapper script for lb that allows it to create image previews with
|
||||||
|
# ueberzug. This works in concert with the lf configuration file and the
|
||||||
|
# lf-cleaner script.
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
cleanup() {
|
||||||
|
exec 3>&-
|
||||||
|
rm "$FIFO_UEBERZUG"
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ -n "$SSH_CLIENT" ] || [ -n "$SSH_TTY" ]; then
|
||||||
|
lf "$@"
|
||||||
|
else
|
||||||
|
[ ! -d "$HOME/.cache/lf" ] && mkdir -p "$HOME/.cache/lf"
|
||||||
|
export FIFO_UEBERZUG="$HOME/.cache/lf/ueberzug-$$"
|
||||||
|
mkfifo "$FIFO_UEBERZUG"
|
||||||
|
ueberzug layer -s <"$FIFO_UEBERZUG" -p json &
|
||||||
|
exec 3>"$FIFO_UEBERZUG"
|
||||||
|
trap cleanup HUP INT QUIT TERM PWR EXIT
|
||||||
|
lf "$@" 3>&-
|
||||||
|
fi
|
||||||
@ -10,7 +10,7 @@
|
|||||||
[ -z "$1" ] && { "$BROWSER"; exit; }
|
[ -z "$1" ] && { "$BROWSER"; exit; }
|
||||||
|
|
||||||
case "$1" in
|
case "$1" in
|
||||||
*mkv|*webm|*mp4|*youtube.com/watch*|*youtube.com/playlist*|*youtu.be*|*hooktube.com*|*bitchute.com*|*videos.lukesmith.xyz*)
|
*mkv|*webm|*mp4|*youtube.com/watch*|*youtube.com/playlist*|*youtu.be*|*hooktube.com*|*bitchute.com*|*videos.lukesmith.xyz*|*odysee.com*)
|
||||||
setsid -f mpv -quiet "$1" >/dev/null 2>&1 ;;
|
setsid -f mpv -quiet "$1" >/dev/null 2>&1 ;;
|
||||||
*png|*jpg|*jpe|*jpeg|*gif)
|
*png|*jpg|*jpe|*jpeg|*gif)
|
||||||
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 "$1" > "/tmp/$(echo "$1" | sed "s/.*\///;s/%20/ /g")" && sxiv -a "/tmp/$(echo "$1" | sed "s/.*\///;s/%20/ /g")" >/dev/null 2>&1 & ;;
|
||||||
|
|||||||
81
.local/bin/noisereduce
Executable file
81
.local/bin/noisereduce
Executable file
@ -0,0 +1,81 @@
|
|||||||
|
#!/usr/bin/sh
|
||||||
|
|
||||||
|
usage ()
|
||||||
|
{
|
||||||
|
printf "Usage : noisereduce <input video file> <output video file>\n"
|
||||||
|
exit
|
||||||
|
}
|
||||||
|
|
||||||
|
# Tests for requirements
|
||||||
|
ifinstalled ffmpeg || { echo >&2 "We require 'ffmpeg' but it's not installed."; exit 1; }
|
||||||
|
ifinstalled sox || { echo >&2 "We require 'ffmpeg' but it's not installed."; exit 1; }
|
||||||
|
|
||||||
|
if [ "$#" -ne 2 ]
|
||||||
|
then
|
||||||
|
usage
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -e "$1" ]
|
||||||
|
then
|
||||||
|
printf "File not found: %s\n" "$1"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -e "$2" ]
|
||||||
|
then
|
||||||
|
printf "File %s already exists, overwrite? [y/N]\n: " "$2"
|
||||||
|
read -r yn
|
||||||
|
case $yn in
|
||||||
|
[Yy]* ) ;;
|
||||||
|
* ) exit;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
inBasename=$(basename "$1")
|
||||||
|
inExt="${inBasename##*.}"
|
||||||
|
|
||||||
|
isVideoStr=$(ffprobe -v warning -show_streams "$1" | grep codec_type=video)
|
||||||
|
if [ -n "$isVideoStr" ]
|
||||||
|
then
|
||||||
|
isVideo=1
|
||||||
|
printf "Detected %s as a video file\n" "$inBasename"
|
||||||
|
else
|
||||||
|
isVideo=0
|
||||||
|
printf "Detected %s as an audio file\n" "$inBasename"
|
||||||
|
fi
|
||||||
|
|
||||||
|
printf "Sample noise start time [00:00:00]: "
|
||||||
|
read -r sampleStart
|
||||||
|
if [ -z "$sampleStart" ] ; then sampleStart="00:00:00"; fi
|
||||||
|
printf "Sample noise end time [00:00:00.900]: "
|
||||||
|
read -r sampleEnd
|
||||||
|
if [ -z "$sampleEnd" ] ; then sampleEnd="00:00:00.900"; fi
|
||||||
|
printf "Noise reduction amount [0.21]: "
|
||||||
|
read -r sensitivity
|
||||||
|
if [ -z "$sensitivity" ] ; then sensitivity="0.21"; fi
|
||||||
|
|
||||||
|
|
||||||
|
tmpVidFile="/tmp/noiseclean_tmpvid.$inExt"
|
||||||
|
tmpAudFile="/tmp/noiseclean_tmpaud.wav"
|
||||||
|
noiseAudFile="/tmp/noiseclean_noiseaud.wav"
|
||||||
|
noiseProfFile="/tmp/noiseclean_noise.prof"
|
||||||
|
tmpAudCleanFile="/tmp/noiseclean_tmpaud-clean.wav"
|
||||||
|
|
||||||
|
printf "Cleaning noise on %s...\n" "$1"
|
||||||
|
|
||||||
|
if [ $isVideo -eq "1" ]; then
|
||||||
|
ffmpeg -v warning -y -i "$1" -qscale:v 0 -vcodec copy -an "$tmpVidFile"
|
||||||
|
ffmpeg -v warning -y -i "$1" -qscale:a 0 "$tmpAudFile"
|
||||||
|
else
|
||||||
|
cp "$1" "$tmpAudFile"
|
||||||
|
fi
|
||||||
|
ffmpeg -v warning -y -i "$1" -vn -ss "$sampleStart" -t "$sampleEnd" "$noiseAudFile"
|
||||||
|
sox "$noiseAudFile" -n noiseprof "$noiseProfFile"
|
||||||
|
sox "$tmpAudFile" "$tmpAudCleanFile" noisered "$noiseProfFile" "$sensitivity"
|
||||||
|
if [ $isVideo -eq "1" ]; then
|
||||||
|
ffmpeg -v warning -y -i "$tmpAudCleanFile" -i "$tmpVidFile" -vcodec copy -qscale:v 0 -qscale:a 0 "$2"
|
||||||
|
else
|
||||||
|
cp "$tmpAudCleanFile" "$2"
|
||||||
|
fi
|
||||||
|
|
||||||
|
printf "Done"
|
||||||
@ -4,7 +4,7 @@
|
|||||||
# usually the pdf of a compiled document. I find this useful especially
|
# usually the pdf of a compiled document. I find this useful especially
|
||||||
# running from vim.
|
# running from vim.
|
||||||
|
|
||||||
basename="$(echo "${*}" | sed 's/\.[^\/.]*$//')"
|
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|*.m[dse]|*.[rR]md|*.mom|*.[0-9]) setsid -f xdg-open "$basename".pdf >/dev/null 2>&1 ;;
|
||||||
|
|||||||
53
.local/bin/otp
Executable file
53
.local/bin/otp
Executable file
@ -0,0 +1,53 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Get a one-time password, or add a OTP secret to your pass-otp store.
|
||||||
|
|
||||||
|
# The assumption of this script is that all otp passwords are stored with the
|
||||||
|
# suffix `-otp`. This script automatically appends newly added otps as such.
|
||||||
|
|
||||||
|
# For OTP passwords to be generated properly, it is important for the local
|
||||||
|
# computer to have its time properly synced. This can be done with the command
|
||||||
|
# below which requires the package `ntp`.
|
||||||
|
|
||||||
|
ifinstalled pass pass-otp
|
||||||
|
|
||||||
|
dir="${PASSWORD_STORE_DIR}"
|
||||||
|
|
||||||
|
choice="$({ echo "🆕add" ; echo "🕙sync-time" ; ls ${dir}/*-otp.gpg ;} | sed "s/.*\///;s/-otp.gpg//" | dmenu -p "Pick a 2FA:")"
|
||||||
|
|
||||||
|
case $choice in
|
||||||
|
🆕add )
|
||||||
|
ifinstalled maim zbar xclip || exit 1
|
||||||
|
|
||||||
|
temp="$dir/temp.png"
|
||||||
|
otp="otp-test-script"
|
||||||
|
trap 'shred -fu $temp; pass rm $otp' HUP INT QUIT TERM PWR EXIT
|
||||||
|
|
||||||
|
notify-send "Scan the image." "Scan the OTP QR code."
|
||||||
|
|
||||||
|
maim -s "$temp" || exit 1
|
||||||
|
info="$(zbarimg -q "$temp")"
|
||||||
|
info="${info#QR-Code:}"
|
||||||
|
issuer="$(echo "$info" | grep -o "issuer=[A-z0-9]\+")"
|
||||||
|
name="${issuer#issuer=}"
|
||||||
|
|
||||||
|
if echo "$info" | pass otp insert "$otp"; then
|
||||||
|
while true ; do
|
||||||
|
export name="$(dmenu -p "Give this One Time Password a one-word name:")"
|
||||||
|
echo "$name" | grep -q -- "^[A-z0-9-]\+$" && break
|
||||||
|
done
|
||||||
|
pass mv "$otp" "$name-otp"
|
||||||
|
notify-send "Successfully added." "$name-otp has been created."
|
||||||
|
else
|
||||||
|
notify-send "No OTP data found." "Try to scan the image again more precisely."
|
||||||
|
fi
|
||||||
|
|
||||||
|
;;
|
||||||
|
🕙sync-time )
|
||||||
|
ifinstalled ntp || exit 1
|
||||||
|
notify-send -u low "🕙 Synchronizing Time..." "Synching time with remote NTP servers..."
|
||||||
|
updatedata="$(sudo ntpdate pool.ntp.org)" &&
|
||||||
|
notify-send -u low "🕙 Synchronizing Time..." "Done. Time changed by ${updatedata#*offset }"
|
||||||
|
;;
|
||||||
|
*) pass otp -c ${choice}-otp ;;
|
||||||
|
esac
|
||||||
@ -3,5 +3,5 @@
|
|||||||
# first argument is the video link, second is the quality (480 or 1080)
|
# first argument is the video link, second is the quality (480 or 1080)
|
||||||
# 13/07/20 - Arthur Bais
|
# 13/07/20 - Arthur Bais
|
||||||
|
|
||||||
link="$(echo "$1" | sed "s/videos\/watch/download\/torrents/")""-$2.torrent"
|
link="$(echo "$1" | sed "s/w/download\/torrents/")""-$2.torrent"
|
||||||
transadd "$link"
|
transadd "$link"
|
||||||
|
|||||||
@ -7,7 +7,7 @@ queuefile="${XDG_DATA_HOME:-$HOME/.local/share}/newsboat/queue"
|
|||||||
|
|
||||||
while read -r line; do
|
while read -r line; do
|
||||||
[ -z "$line" ] && continue
|
[ -z "$line" ] && continue
|
||||||
url="$(echo "$line" | awk '{print $1}')"
|
url="${line%%[ ]*}"
|
||||||
qndl "$url" "curl -LO"
|
qndl "$url" "curl -LO"
|
||||||
done < "$queuefile"
|
done < "$queuefile"
|
||||||
|
|
||||||
|
|||||||
@ -1,10 +1,18 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
! echo "$1" | grep "https*://\S\+\.[A-Za-z]\+\S*" >/dev/null &&
|
if echo "$1" | grep -q "https*://\S\+\.[A-Za-z]\+\S*" ; then
|
||||||
notify-send "That doesn't look like a full URL." && exit
|
url="$1"
|
||||||
|
else
|
||||||
|
url="$(grep -Eom1 '<[^>]+(rel="self"|application/[a-z]+\+xml)[^>]+>' "$1" |
|
||||||
|
grep -o "https?://[^\" ]")"
|
||||||
|
|
||||||
|
echo "$url" | grep -q "https*://\S\+\.[A-Za-z]\+\S*" ||
|
||||||
|
notify-send "That doesn't look like a full URL." && exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
RSSFILE="${XDG_CONFIG_HOME:-$HOME/.config}/newsboat/urls"
|
RSSFILE="${XDG_CONFIG_HOME:-$HOME/.config}/newsboat/urls"
|
||||||
if awk '{print $1}' "$RSSFILE" | grep "^$1$" >/dev/null; then
|
if awk '{print $1}' "$RSSFILE" | grep "^$url$" >/dev/null; then
|
||||||
notify-send "You already have this RSS feed."
|
notify-send "You already have this RSS feed."
|
||||||
else
|
else
|
||||||
echo "$1" >> "$RSSFILE" && notify-send "RSS feed added."
|
echo "$url" >> "$RSSFILE" && notify-send "RSS feed added."
|
||||||
fi
|
fi
|
||||||
|
|||||||
@ -2,7 +2,9 @@
|
|||||||
|
|
||||||
# Open a terminal window in the same directory as the currently active window.
|
# Open a terminal window in the same directory as the currently active window.
|
||||||
|
|
||||||
PID=$(xprop -id "$(xprop -root | awk '/_NET_ACTIVE_WINDOW\(WINDOW\)/{print $NF}')" | grep -m 1 PID | cut -d " " -f 3)
|
PID=$(xprop -id "$(xprop -root | xprop -root | sed -n "/_NET_ACTIVE_WINDOW/ s/^.*# // p")" | sed -n "/PID/ s/^.*= // p")
|
||||||
PID="$(pstree -lpA "$PID" | tail -n 1 | awk -F'---' '{print $NF}' | sed -re 's/[^0-9]//g')"
|
PID="$(pstree -lpA "$PID")"
|
||||||
|
PID="${PID##*(}"
|
||||||
|
PID="${PID%)}"
|
||||||
cd "$(readlink /proc/"$PID"/cwd)" || return 1
|
cd "$(readlink /proc/"$PID"/cwd)" || return 1
|
||||||
"$TERMINAL"
|
"$TERMINAL"
|
||||||
|
|||||||
@ -9,6 +9,10 @@
|
|||||||
# Location of link to wallpaper link.
|
# Location of link to wallpaper link.
|
||||||
bgloc="${XDG_DATA_HOME:-$HOME/.local/share/}/bg"
|
bgloc="${XDG_DATA_HOME:-$HOME/.local/share/}/bg"
|
||||||
|
|
||||||
|
# Configuration files of applications that have their themes changed by pywal.
|
||||||
|
dunstconf="${XDG_CONFIG_HOME:-$HOME/.config}/dunst/dunstrc"
|
||||||
|
zathuraconf="${XDG_CONFIG_HOME:-$HOME/.config}/zathura/zathurarc"
|
||||||
|
|
||||||
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 "$(readlink -f "$1")" "$bgloc" && notify-send -i "$bgloc" "Changing wallpaper..." ;;
|
||||||
@ -17,8 +21,13 @@ case "$(file --mime-type -b "$trueloc")" in
|
|||||||
esac
|
esac
|
||||||
|
|
||||||
# If pywal is installed, use it.
|
# If pywal is installed, use it.
|
||||||
command -v wal >/dev/null 2>&1 &&
|
if command -v wal >/dev/null 2>&1 ; then
|
||||||
wal -i "$trueloc" -o "${XDG_CONFIG_HOME:-$HOME/.config}/wal/postrun" >/dev/null 2>&1 &&
|
wal -i "$(readlink -f $bgloc)" -o "${XDG_CONFIG_HOME:-$HOME/.config}/wal/postrun" >/dev/null 2>&1 &&
|
||||||
pidof dwm >/dev/null && xdotool key super+F12
|
pidof dwm >/dev/null && xdotool key super+F12
|
||||||
|
# If pywal is removed, return config files to normal.
|
||||||
|
else
|
||||||
|
[ -f "$dunstconf.bak" ] && unlink "$dunstconf" && mv "$dunstconf.bak" "$dunstconf"
|
||||||
|
[ -f "$zathuraconf.bak" ] && unlink "$zathuraconf" && mv "$zathuraconf.bak" "$zathuraconf"
|
||||||
|
fi
|
||||||
|
|
||||||
xwallpaper --zoom "$bgloc"
|
xwallpaper --zoom "$bgloc"
|
||||||
|
|||||||
@ -6,13 +6,14 @@ bmfiles="${XDG_CONFIG_HOME:-$HOME/.config}/shell/bm-files"
|
|||||||
# Output locations. Unactivated progs should go to /dev/null.
|
# Output locations. Unactivated progs should go to /dev/null.
|
||||||
shell_shortcuts="${XDG_CONFIG_HOME:-$HOME/.config}/shell/shortcutrc"
|
shell_shortcuts="${XDG_CONFIG_HOME:-$HOME/.config}/shell/shortcutrc"
|
||||||
zsh_named_dirs="${XDG_CONFIG_HOME:-$HOME/.config}/shell/zshnameddirrc"
|
zsh_named_dirs="${XDG_CONFIG_HOME:-$HOME/.config}/shell/zshnameddirrc"
|
||||||
|
lf_shortcuts="${XDG_CONFIG_HOME:-$HOME/.config}/lf/shortcutrc"
|
||||||
ranger_shortcuts="/dev/null"
|
ranger_shortcuts="/dev/null"
|
||||||
qute_shortcuts="/dev/null"
|
qute_shortcuts="/dev/null"
|
||||||
fish_shortcuts="/dev/null"
|
fish_shortcuts="/dev/null"
|
||||||
vifm_shortcuts="/dev/null"
|
vifm_shortcuts="/dev/null"
|
||||||
|
|
||||||
# Remove, prepare files
|
# Remove, prepare files
|
||||||
rm -f "$ranger_shortcuts" "$qute_shortcuts" "$zsh_named_dirs" 2>/dev/null
|
rm -f "$lf_shortcuts" "$ranger_shortcuts" "$qute_shortcuts" "$zsh_named_dirs" 2>/dev/null
|
||||||
printf "# vim: filetype=sh\\n" > "$fish_shortcuts"
|
printf "# vim: filetype=sh\\n" > "$fish_shortcuts"
|
||||||
printf "# vim: filetype=sh\\nalias " > "$shell_shortcuts"
|
printf "# vim: filetype=sh\\nalias " > "$shell_shortcuts"
|
||||||
printf "\" vim: filetype=vim\\n" > "$vifm_shortcuts"
|
printf "\" vim: filetype=vim\\n" > "$vifm_shortcuts"
|
||||||
@ -20,18 +21,20 @@ 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\" ;
|
||||||
|
printf(\"map C%s cd \42%s\42 \n\",\$1,\$2) >> \"$lf_shortcuts\" }"
|
||||||
|
|
||||||
# Format the `files` file in the correct syntax and sent it to both configs.
|
# Format the `files` file in the correct syntax and sent it to both configs.
|
||||||
eval "echo \"$(cat "$bmfiles")\"" | \
|
eval "echo \"$(cat "$bmfiles")\"" | \
|
||||||
awk "!/^\s*#/ && !/^\s*\$/ {gsub(\"\\\s*#.*$\",\"\");
|
awk "!/^\s*#/ && !/^\s*\$/ {gsub(\"\\\s*#.*$\",\"\");
|
||||||
printf(\"%s=\42\$EDITOR %s\42 \\\\\n\",\$1,\$2) >> \"$shell_shortcuts\" ;
|
printf(\"%s=\42\$EDITOR %s\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 \42\$EDITOR %s\42 \n\",\$1,\$2) >> \"$fish_shortcuts\" ;
|
printf(\"abbr %s \42\$EDITOR %s\42 \n\",\$1,\$2) >> \"$fish_shortcuts\" ;
|
||||||
printf(\"map %s :e %s<CR> \n\",\$1,\$2) >> \"$vifm_shortcuts\" ;
|
printf(\"map %s :e %s<CR> \n\",\$1,\$2) >> \"$vifm_shortcuts\" ;
|
||||||
printf(\"map %s shell \$EDITOR %s \n\",\$1,\$2) >> \"$ranger_shortcuts\" }"
|
printf(\"map %s shell \$EDITOR %s \n\",\$1,\$2) >> \"$ranger_shortcuts\" ;
|
||||||
|
printf(\"map E%s \$\$EDITOR \42%s\42 \n\",\$1,\$2) >> \"$lf_shortcuts\" }"
|
||||||
|
|||||||
@ -12,6 +12,7 @@ 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:" o; do case "${o}" in
|
||||||
c) bgc="$OPTARG" ;;
|
c) bgc="$OPTARG" ;;
|
||||||
t) fgc="$OPTARG" ;;
|
t) fgc="$OPTARG" ;;
|
||||||
|
f) font="$OPTARG" ;;
|
||||||
i) file="$OPTARG" ;;
|
i) file="$OPTARG" ;;
|
||||||
a) audio="$OPTARG" ;;
|
a) audio="$OPTARG" ;;
|
||||||
o) outfile="$OPTARG" ;;
|
o) outfile="$OPTARG" ;;
|
||||||
@ -34,6 +35,7 @@ while getopts "hvrpi:c:a:o:d:f:t:e:x:" o; do case "${o}" in
|
|||||||
-c color of background (use html names, black is default)
|
-c color of background (use html names, black is default)
|
||||||
-t text color for text slides (white is default)
|
-t text color for text slides (white is default)
|
||||||
-s text font size for text slides (150 is default)
|
-s text font size for text slides (150 is default)
|
||||||
|
-f text font for text slides (sans serif is default)
|
||||||
-o output video file
|
-o output video file
|
||||||
-e if no audio given, the time in seconds that the last slide will be shown (5 is default)
|
-e if no audio given, the time in seconds that the last slide will be shown (5 is default)
|
||||||
-x resolution (1920x1080 is default)
|
-x resolution (1920x1080 is default)
|
||||||
@ -96,7 +98,7 @@ do
|
|||||||
convert -size "${res:-1920x1080}" canvas:"${bgc:-black}" -gravity center "$content" -resize 1920x1080 -composite "$prepdir/$base"
|
convert -size "${res:-1920x1080}" canvas:"${bgc:-black}" -gravity center "$content" -resize 1920x1080 -composite "$prepdir/$base"
|
||||||
else
|
else
|
||||||
{ [ ! -f "$prepdir/$base" ] || [ -n "${redo+x}" ] ;} &&
|
{ [ ! -f "$prepdir/$base" ] || [ -n "${redo+x}" ] ;} &&
|
||||||
convert -size "${res:-1920x1080}" -background "${bgc:-black}" -fill "${fgc:-white}" -pointsize "${ppt:-150}" -gravity center label:"$content" "$prepdir/$base"
|
convert -size "${res:-1920x1080}" -background "${bgc:-black}" -fill "${fgc:-white}" -font "${font:-Sans}" -pointsize "${ppt:-150}" -gravity center label:"$content" "$prepdir/$base"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# If the first line, do not write yet.
|
# If the first line, do not write yet.
|
||||||
|
|||||||
@ -21,16 +21,17 @@ for battery in /sys/class/power_supply/BAT?*; do
|
|||||||
# If non-first battery, print a space separator.
|
# If non-first battery, print a space separator.
|
||||||
[ -n "${capacity+x}" ] && printf " "
|
[ -n "${capacity+x}" ] && printf " "
|
||||||
# Sets up the status and capacity
|
# Sets up the status and capacity
|
||||||
case "$(cat "$battery/status")" in
|
case "$(cat "$battery/status" 2>&1)" in
|
||||||
"Full") status="⚡" ;;
|
"Full") status="⚡" ;;
|
||||||
"Discharging") status="🔋" ;;
|
"Discharging") status="🔋" ;;
|
||||||
"Charging") status="🔌" ;;
|
"Charging") status="🔌" ;;
|
||||||
"Not charging") status="🛑" ;;
|
"Not charging") status="🛑" ;;
|
||||||
"Unknown") status="♻️" ;;
|
"Unknown") status="♻️" ;;
|
||||||
|
*) exit 1 ;;
|
||||||
esac
|
esac
|
||||||
capacity=$(cat "$battery/capacity")
|
capacity="$(cat "$battery/capacity" 2>&1)"
|
||||||
# Will make a warn variable if discharging and low
|
# Will make a warn variable if discharging and low
|
||||||
[ "$status" = "🔋" ] && [ "$capacity" -le 25 ] && warn="❗"
|
[ "$status" = "🔋" ] && [ "$capacity" -le 25 ] && warn="❗"
|
||||||
# Prints the info
|
# Prints the info
|
||||||
printf "%s%s%d%%" "$status" "$warn" "$capacity"; unset warn
|
printf "%s%s%d%%" "$status" "$warn" "$capacity"; unset warn
|
||||||
done && exit 0
|
done && printf "\\n"
|
||||||
|
|||||||
@ -1,54 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
# Shows the price for desired cryptocurrencies. Module updates automatically
|
|
||||||
# every calendar day, but can also be updated with a middle click.
|
|
||||||
|
|
||||||
# Currencies should be ;-separated:
|
|
||||||
# human-readable name;urlname;icon
|
|
||||||
coins="Bitcoin;btc;💰
|
|
||||||
Etherium;eth;🍸
|
|
||||||
Basic Attention Token;bat;🦁
|
|
||||||
LBC;lbc;📚"
|
|
||||||
|
|
||||||
# Directory where currency info is stored.
|
|
||||||
dir="${XDG_DATA_HOME:-$HOME/.local/share}/crypto-prices"
|
|
||||||
|
|
||||||
getprices() { # The command to get the desired prices
|
|
||||||
printf "🔃 "; printprices
|
|
||||||
{ rm -rf "${dir:?}/*"
|
|
||||||
echo "$coins" | while IFS=';' read -r human web icon; do
|
|
||||||
val="$(curl -s "rate.sx/1$web")" &&
|
|
||||||
echo "$icon;$val;$human" > "$dir/$web"
|
|
||||||
done; [ -d "$dir" ] && touch "$dir"
|
|
||||||
pkill -RTMIN+13 "${STATUSBAR:-dwmblocks}" ;} &
|
|
||||||
exit
|
|
||||||
}
|
|
||||||
|
|
||||||
printprices() { # Print/format all prices
|
|
||||||
for x in "$dir"/*; do
|
|
||||||
[ -f "$x" ] || break
|
|
||||||
info="$(cut -d';' -f-2 --output-delimiter=' ' "$x")"
|
|
||||||
printf "%s$%0.2f " "$info"
|
|
||||||
done | sed 's/ $/\n/'
|
|
||||||
}
|
|
||||||
|
|
||||||
[ ! -d "$dir" ] && mkdir -p "$dir" && { getprices; exit ;}
|
|
||||||
|
|
||||||
# If currencies haven't been updated today, try to update them.
|
|
||||||
[ "$(stat -c %x "$HOME/.local/share/crypto-prices" | cut -d' ' -f1)" != "$(date '+%Y-%m-%d')" ] &&
|
|
||||||
{ ping -q -c 1 example.org >/dev/null 2>&1 && getprices || exit ;}
|
|
||||||
|
|
||||||
case $BLOCK_BUTTON in
|
|
||||||
1) uptime="$(date -d "$(stat -c %x "$dir")" '+%D at %T' | sed "s|$(date '+%D')|Today|")"
|
|
||||||
notify-send "Exact prices in USD" "$(awk -F';' '{print $1, $3 ":\n\t$" $2}' "$dir"/*)
|
|
||||||
<b>Last updated:</b>
|
|
||||||
$uptime" ;;
|
|
||||||
2) getprices ;;
|
|
||||||
3) notify-send "💸 Crypto-currency module" "\- Left click for exact prices.
|
|
||||||
- Middle click to update.
|
|
||||||
- Shows 🔃 if updating prices.
|
|
||||||
- Manually add/remove currencies to list in the script." ;;
|
|
||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
printprices
|
|
||||||
260
.local/bin/statusbar/sb-doppler
Executable file
260
.local/bin/statusbar/sb-doppler
Executable file
@ -0,0 +1,260 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Show a Doppler RADAR of a user's preferred location.
|
||||||
|
|
||||||
|
secs=600 # Download a new doppler radar if one hasn't been downloaded in $secs seconds.
|
||||||
|
radarloc="${XDG_CACHE_HOME:-$HOME/.cache}/radar"
|
||||||
|
doppler="${XDG_CACHE_HOME:-$HOME/.cache}/doppler.gif"
|
||||||
|
|
||||||
|
pickloc() { chosen="$(echo "US: Northeast
|
||||||
|
US: Southeast
|
||||||
|
US: PacNorthWest
|
||||||
|
US: PacSouthWest
|
||||||
|
US: UpperMissVly
|
||||||
|
US: SouthMissVly
|
||||||
|
US: SouthPlains
|
||||||
|
US: NorthRockies
|
||||||
|
US: SouthRockies
|
||||||
|
US: Alaska
|
||||||
|
US: Carib
|
||||||
|
US: Hawaii
|
||||||
|
US: CentGrLakes
|
||||||
|
US: Conus-Large
|
||||||
|
US: KABR: Aberdeen, SD
|
||||||
|
US: KBIS: Bismarck, ND
|
||||||
|
US: KFTG: Denver/Boulder, CO
|
||||||
|
US: KDMX: Des Moines, IA
|
||||||
|
US: KDTX: Detroit, MI
|
||||||
|
US: KDDC: Dodge City, KS
|
||||||
|
US: KDLH: Duluth, MN
|
||||||
|
US: KCYS: Cheyenne, WY
|
||||||
|
US: KLOT: Chicago, IL
|
||||||
|
US: KGLD: Goodland, KS
|
||||||
|
US: KUEX: Hastings, NE
|
||||||
|
US: KGJX: Grand Junction, CO
|
||||||
|
US: KGRR: Grand Rapids, MI
|
||||||
|
US: KMVX: Fargo/Grand Forks, ND
|
||||||
|
US: KGRB: Green Bay, WI
|
||||||
|
US: KIND: Indianapolis, IN
|
||||||
|
US: KJKL: Jackson, KY
|
||||||
|
US: KARX: La Crosse, WI
|
||||||
|
US: KILX: Lincoln/Central Illinois, IL
|
||||||
|
US: KLVX: Louisville, KY
|
||||||
|
US: KMQT: Marquette
|
||||||
|
US: KMKX: Milwaukee, WI
|
||||||
|
US: KMPX: Minneapolis, MN
|
||||||
|
US: KAPX: Gaylord/Alpena, MI
|
||||||
|
US: KLNX: North Platte, NE
|
||||||
|
US: KIWX: N. Webster/Northern, IN
|
||||||
|
US: KOAX: Omaha, NE
|
||||||
|
US: KPAH: Paducah, KY
|
||||||
|
US: KEAX: Pleasant Hill, MO
|
||||||
|
US: KPUX: Pueblo, CO
|
||||||
|
US: KDVN: Quad Cities, IA
|
||||||
|
US: KUDX: Rapid City, SD
|
||||||
|
US: KRIW: Riverton, WY
|
||||||
|
US: KSGF: Springfield, MO
|
||||||
|
US: KLSX: St. LOUIS, MO
|
||||||
|
US: KFSD: Sioux Falls, IA
|
||||||
|
US: KTWX: Topeka, KS
|
||||||
|
US: KICT: Wichita, KS
|
||||||
|
US: KVWX: Paducah, KY
|
||||||
|
US: ICAO: Responsible Wfo
|
||||||
|
US: KLTX: WILMINGTON, NC
|
||||||
|
US: KCCX: State College/Central, PA
|
||||||
|
US: KLWX: Sterling, VA
|
||||||
|
US: KFCX: Blacksburg/Roanoke, VA
|
||||||
|
US: KRAX: Raleigh/Durham, NC
|
||||||
|
US: KGYX: Portland, ME
|
||||||
|
US: KDIX: Mt Holly/Philadelphia, PA
|
||||||
|
US: KPBZ: Pittsburgh, PA
|
||||||
|
US: KAKQ: Wakefield, VA
|
||||||
|
US: KMHX: Morehead City, NC
|
||||||
|
US: KGSP: Greer/Greenville/Sprtbg, SC
|
||||||
|
US: KILN: Wilmington/Cincinnati, OH
|
||||||
|
US: KCLE: Cleveland, OH
|
||||||
|
US: KCAE: Columbia, SC
|
||||||
|
US: KBGM: Binghamton, NY
|
||||||
|
US: KENX: Albany, NY
|
||||||
|
US: KBUF: Buffalo, NY
|
||||||
|
US: KCXX: Burlington, VT
|
||||||
|
US: KCBW: Caribou, ME
|
||||||
|
US: KBOX: Boston /Taunton, MA
|
||||||
|
US: KOKX: New York City, NY
|
||||||
|
US: KCLX: Charleston, SC
|
||||||
|
US: KRLX: Charleston, WV
|
||||||
|
US: ICAO: Responsible WFO
|
||||||
|
US: KBRO: Brownsville, TX
|
||||||
|
US: KABX: Albuquerque, NM
|
||||||
|
US: KAMA: Amarillo, TX
|
||||||
|
US: KFFC: Peachtree City/Atlanta, GA
|
||||||
|
US: KEWX: Austin/Sanantonio, TX
|
||||||
|
US: KBMX: Birmingham, AL
|
||||||
|
US: KCRP: Corpus Christi, TX
|
||||||
|
US: KFWS: Dallas / Ft. Worth, TX
|
||||||
|
US: KEPZ: El Paso, TX
|
||||||
|
US: KHGX: Houston/ Galveston, TX
|
||||||
|
US: KJAX: Jacksonville, FL
|
||||||
|
US: KBYX: Key West, FL
|
||||||
|
US: KMRX: Morristown/knoxville, TN
|
||||||
|
US: KLBB: Lubbock, TX
|
||||||
|
US: KLZK: Little Rock, AR
|
||||||
|
US: KLCH: Lake Charles, LA
|
||||||
|
US: KOHX: Nashville, TN
|
||||||
|
US: KMLB: Melbourne, FL
|
||||||
|
US: KNQA: Memphis, TN
|
||||||
|
US: KAMX: Miami, FL
|
||||||
|
US: KMAF: Midland/odessa, TX
|
||||||
|
US: KTLX: Norman, OK
|
||||||
|
US: KHTX: Huntsville, AL
|
||||||
|
US: KMOB: Mobile, AL
|
||||||
|
US: KTLH: Tallahassee, FL
|
||||||
|
US: KTBW: Tampa Bay Area, FL
|
||||||
|
US: KSJT: San Angelo, TX
|
||||||
|
US: KINX: Tulsa, OK
|
||||||
|
US: KSRX: Tulsa, OK
|
||||||
|
US: KLIX: New Orleans/slidell, LA
|
||||||
|
US: KDGX: Jackson, MS
|
||||||
|
US: KSHV: Shreveport, LA
|
||||||
|
US: ICAO: Responsible WFO
|
||||||
|
US: KLGX: Seattle / Tacoma, WA
|
||||||
|
US: KOTX: Spokane, WA
|
||||||
|
US: KEMX: Tucson, AZ
|
||||||
|
US: KYUX: Phoenix, AZ
|
||||||
|
US: KNKX: San Diego, CA
|
||||||
|
US: KMUX: Monterey/san Francisco, CA
|
||||||
|
US: KHNX: San Joaquin/hanford, CA
|
||||||
|
US: KSOX: San Diego, CA
|
||||||
|
US: KATX: Seattle / Tacoma, WA
|
||||||
|
US: KIWA: Phoenix, AZ
|
||||||
|
US: KRTX: Portland, OR
|
||||||
|
US: KSFX: Pocatello, ID
|
||||||
|
US: KRGX: Reno, NV
|
||||||
|
US: KDAX: Sacramento, CA
|
||||||
|
US: KMTX: Salt Lake City, UT
|
||||||
|
US: KPDT: Pendleton, OR
|
||||||
|
US: KMSX: Missoula, MT
|
||||||
|
US: KESX: Las Vegas, NV
|
||||||
|
US: KVTX: Los Angeles, CA
|
||||||
|
US: KMAX: Medford, OR
|
||||||
|
US: KFSX: Flagstaff, AZ
|
||||||
|
US: KGGW: Glasgow, MT
|
||||||
|
US: KLRX: Elko, NV
|
||||||
|
US: KBHX: Eureka, CA
|
||||||
|
US: KTFX: Great Falls, MT
|
||||||
|
US: KCBX: Boise, ID
|
||||||
|
US: KBLX: Billings, MT
|
||||||
|
US: KICX: Salt Lake City, UT
|
||||||
|
US: ICAO: Responsible Wfo W/ MSCF
|
||||||
|
US: PABC: Anchorage, AK
|
||||||
|
US: PAPD: Fairbanks, AK
|
||||||
|
US: PHKM: Honolulu, HI
|
||||||
|
US: PAHG: Anchorage, AK
|
||||||
|
US: PAKC: Anchorage, AK
|
||||||
|
US: PAIH: Anchorage, AK
|
||||||
|
US: PHMO: Honolulu, HI
|
||||||
|
US: PAEC: Fairbanks, AK
|
||||||
|
US: TJUA: San Juan, PR
|
||||||
|
US: PACG: Juneau, AK
|
||||||
|
US: PHKI: Honolulu, HI
|
||||||
|
US: PHWA: Honolulu, HI
|
||||||
|
US: ICAO: Responsible Wfo W/ MSCF
|
||||||
|
US: KFDR: Norman, OK
|
||||||
|
US: PGUA: Guam
|
||||||
|
US: KBBX: Sacramento, CA
|
||||||
|
US: KFDX: Albuquerque, NM
|
||||||
|
US: KGWX: Jackson, MS
|
||||||
|
US: KDOX: Wakefield, VA
|
||||||
|
US: KDYX: San Angelo, TX
|
||||||
|
US: KEYX: Las Vegas, NV
|
||||||
|
US: KEVX: Mobile, AL
|
||||||
|
US: KHPX: Paducah, KY
|
||||||
|
US: KTYX: Burlington, VT
|
||||||
|
US: KGRK: Dallas / Ft. Worth, TX
|
||||||
|
US: KPOE: Lake Charles, LA
|
||||||
|
US: KEOX: Tallahassee, FL
|
||||||
|
US: KHDX: El Paso, TX
|
||||||
|
US: KDFX: San Antonio, TX
|
||||||
|
US: KMXX: Birmingham, AL
|
||||||
|
US: KMBX: Bismarck, ND
|
||||||
|
US: KVAX: Jacksonville, FL
|
||||||
|
US: KJGX: Peachtree City/atlanta, GA
|
||||||
|
US: KVNX: Norman, OK
|
||||||
|
US: KVBX: Vandenberg Afb: Orcutt, CA
|
||||||
|
EU: Europe
|
||||||
|
EU: GB: Great Brittain
|
||||||
|
EU: SCAN: Scandinavia
|
||||||
|
EU: ALPS: The Alps
|
||||||
|
EU: NL: The Netherlands
|
||||||
|
EU: DE: Germany
|
||||||
|
EU: SP: Spain
|
||||||
|
EU: FR: France
|
||||||
|
EU: IT: Italy
|
||||||
|
EU: PL: Poland
|
||||||
|
EU: GR: Greece
|
||||||
|
EU: TU: Turkey
|
||||||
|
EU: RU: Russia
|
||||||
|
EU: BA: Bahrain
|
||||||
|
EU: BC: Botswana
|
||||||
|
EU: SE: Republic of Seychelles
|
||||||
|
EU: HU: Hungary
|
||||||
|
EU: UK: Ukraine
|
||||||
|
AF: AF: Africa
|
||||||
|
AF: WA: West Africa
|
||||||
|
AF: ZA: South Africa
|
||||||
|
AF: DZ: Algeria
|
||||||
|
AF: CE: Canary Islands
|
||||||
|
AF: NG: Nigeria
|
||||||
|
AF: TD: Chad
|
||||||
|
AF: CG: Democratic Republic of Congo
|
||||||
|
AF: EG: Egypt
|
||||||
|
AF: ET: Ethiopia
|
||||||
|
AF: CM: Cameroon
|
||||||
|
AF: IS: Israel
|
||||||
|
AF: LY: Libya
|
||||||
|
AF: MG: Madagascar
|
||||||
|
AF: MO: Morocco
|
||||||
|
AF: BW: Namibia
|
||||||
|
AF: SA: Saudi Arabia
|
||||||
|
AF: SO: Somalia
|
||||||
|
AF: SD: Sudan
|
||||||
|
AF: TZ: Tanzania
|
||||||
|
AF: TN: Tunisia
|
||||||
|
AF: ZM: Zambia
|
||||||
|
AF: KE: Kenya
|
||||||
|
AF: AO: Angola" | dmenu -r -i -l 50 -p "Select a radar to use as default:" | tr "[:lower:]" "[:upper:]")"
|
||||||
|
|
||||||
|
# Set continent code and radar code.
|
||||||
|
continentcode=$(echo "$chosen" | sed "s/:.*//")
|
||||||
|
radarcode=$(echo "$chosen" | sed "s/..: // ; s/:.*//")
|
||||||
|
|
||||||
|
# Sanity check of selection and ensure user did not escape.
|
||||||
|
echo "$radarcode" | grep -q "^[A-Z]\+$" && printf "%s,%s\\n" "$continentcode" "$radarcode" > "$radarloc" ;}
|
||||||
|
|
||||||
|
getdoppler() {
|
||||||
|
cont="$(sed "s/,.*//" "$radarloc")"
|
||||||
|
loc="$(cut -c 4- "$radarloc")"
|
||||||
|
notify-send "🌦️ Doppler RADAR" "Pulling most recent Doppler RADAR for $loc."
|
||||||
|
if [ "$cont" = "US" ] ; then
|
||||||
|
curl -sL "https://radar.weather.gov/ridge/lite/${loc}_loop.gif" > "$doppler" ;
|
||||||
|
elif [ "$cont" = "EU" ] ; then
|
||||||
|
curl -sL "https://api.sat24.com/animated/${loc}/rainTMC/2/" > "$doppler" ;
|
||||||
|
elif [ "$cont" = "AF" ] ; then
|
||||||
|
curl -sL "https://api.sat24.com/animated/${loc}/rain/2/" > "$doppler" ;
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
showdoppler() { setsid -f mpv --no-osc --loop=inf --no-terminal "$doppler" ;}
|
||||||
|
|
||||||
|
case $BLOCK_BUTTON in
|
||||||
|
1) [ ! -f "$radarloc" ] && pickloc && getdoppler
|
||||||
|
[ $(($(date '+%s') - $(stat -c %Y "$doppler"))) -gt "$secs" ] && getdoppler
|
||||||
|
showdoppler ;;
|
||||||
|
2) pickloc && getdoppler && showdoppler ;;
|
||||||
|
3) notify-send "🗺️ Doppler RADAR module" "\- Left click for local Doppler RADAR.
|
||||||
|
- Middle click to update RADAR location.
|
||||||
|
After $secs seconds, new clicks will also automatically update the doppler RADAR." ;;
|
||||||
|
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
echo 🗺️
|
||||||
@ -14,7 +14,7 @@ getforecast() { curl -sf "wttr.in/$LOCATION" > "$weatherreport" || exit 1 ;}
|
|||||||
# display them with coresponding emojis.
|
# display them with coresponding emojis.
|
||||||
showweather() { printf "%s" "$(sed '16q;d' "$weatherreport" |
|
showweather() { printf "%s" "$(sed '16q;d' "$weatherreport" |
|
||||||
grep -wo "[0-9]*%" | sort -rn | sed "s/^/☔/g;1q" | tr -d '\n')"
|
grep -wo "[0-9]*%" | sort -rn | sed "s/^/☔/g;1q" | tr -d '\n')"
|
||||||
sed '13q;d' "$weatherreport" | grep -o "m\\([-+]\\)*[0-9]\\+" | sort -n -t 'm' -k 2n | sed -e 1b -e '$!d' | tr '\n|m' ' ' | awk '{print " 🥶" $1 "°","🌞" $2 "°"}' ;}
|
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 "°"}' ;}
|
||||||
|
|
||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) setsid -f "$TERMINAL" -e less -Srf "$weatherreport" ;;
|
1) setsid -f "$TERMINAL" -e less -Srf "$weatherreport" ;;
|
||||||
|
|||||||
@ -7,6 +7,7 @@
|
|||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) "$TERMINAL" -e nmtui; pkill -RTMIN+4 dwmblocks ;;
|
1) "$TERMINAL" -e nmtui; pkill -RTMIN+4 dwmblocks ;;
|
||||||
3) notify-send "🌐 Internet module" "\- Click to connect
|
3) notify-send "🌐 Internet module" "\- Click to connect
|
||||||
|
❌: wifi disabled
|
||||||
📡: no wifi connection
|
📡: no wifi connection
|
||||||
📶: wifi connection with quality
|
📶: wifi connection with quality
|
||||||
❎: no ethernet
|
❎: no ethernet
|
||||||
@ -16,9 +17,10 @@ case $BLOCK_BUTTON in
|
|||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
case "$(cat /sys/class/net/w*/operstate 2>/dev/null)" in
|
if grep -xq 'up' /sys/class/net/w*/operstate 2>/dev/null ; then
|
||||||
down) wifiicon="📡 " ;;
|
wifiicon="$(awk '/^\s*w/ { print "📶", int($3 * 100 / 70) "% " }' /proc/net/wireless)"
|
||||||
up) 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
|
||||||
esac
|
grep -xq '0x1003' /sys/class/net/w*/flags && wifiicon="📡 " || wifiicon="❌ "
|
||||||
|
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)"
|
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)"
|
||||||
|
|||||||
@ -5,7 +5,7 @@
|
|||||||
|
|
||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) setsid -f "$TERMINAL" -e neomutt ;;
|
1) setsid -f "$TERMINAL" -e neomutt ;;
|
||||||
2) setsid -f mw sync >/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
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
filter() { mpc | sed "/^volume:/d;s/\\&/&/g;s/\\[paused\\].*/⏸/g;/\\[playing\\].*/d" | paste -sd ' ' -;}
|
filter() { mpc | sed "/^volume:/d;s/\\&/&/g;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 &
|
||||||
|
|
||||||
|
|||||||
@ -26,4 +26,4 @@ update() {
|
|||||||
rx=$(update /sys/class/net/[ew]*/statistics/rx_bytes)
|
rx=$(update /sys/class/net/[ew]*/statistics/rx_bytes)
|
||||||
tx=$(update /sys/class/net/[ew]*/statistics/tx_bytes)
|
tx=$(update /sys/class/net/[ew]*/statistics/tx_bytes)
|
||||||
|
|
||||||
printf "🔻%4sB 🔺%4sB\\n" $(numfmt --to=iec $rx) $(numfmt --to=iec $tx)
|
printf "🔻%4sB 🔺%4sB\\n" $(numfmt --to=iec $rx $tx)
|
||||||
|
|||||||
@ -1,19 +1,24 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
# Usage:
|
# Usage:
|
||||||
# price <url> <Name of currency> <icon>
|
# price <url> <Name of currency> <icon> <Price to show in>
|
||||||
# price bat "Basic Attention Token" 🦁
|
# price bat "Basic Attention Token" 🦁
|
||||||
# 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 "$3" ] && exit 1
|
||||||
|
|
||||||
|
# use $4 as currency, if not passed in use "usd" as default
|
||||||
|
currency="${4:-usd}"
|
||||||
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_DATA_HOME:-$HOME/.local/share}/crypto-prices"
|
||||||
pricefile="$dir/$1"
|
pricefile="$dir/$1-$currency"
|
||||||
chartfile="$dir/$1-chart"
|
chartfile="$dir/$1-$currency-chart"
|
||||||
|
|
||||||
updateprice() { ping -q -c 1 example.org >/dev/null 2>&1 &&
|
updateprice() { temp="$(mktemp)"
|
||||||
curl -s "rate.sx/1$1" > "$pricefile" &&
|
curl -s "$currency.rate.sx/1$1" > "$temp" &&
|
||||||
curl -s "rate.sx/$1$interval" > "$chartfile" ;}
|
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"
|
||||||
|
|
||||||
@ -21,7 +26,7 @@ updateprice() { ping -q -c 1 example.org >/dev/null 2>&1 &&
|
|||||||
updateprice "$1"
|
updateprice "$1"
|
||||||
|
|
||||||
case $BLOCK_BUTTON in
|
case $BLOCK_BUTTON in
|
||||||
1) setsid "$TERMINAL" -e less -Sf "$chartfile" ;;
|
1) setsid "$TERMINAL" -e less -Srf "$chartfile" ;;
|
||||||
2) notify-send -u low "$3 Updating..." "Updating $2 price..."
|
2) notify-send -u low "$3 Updating..." "Updating $2 price..."
|
||||||
updateprice "$1" && notify-send "$3 Update complete." "$2 price is now
|
updateprice "$1" && notify-send "$3 Update complete." "$2 price is now
|
||||||
\$$(cat "$pricefile")" ;;
|
\$$(cat "$pricefile")" ;;
|
||||||
@ -35,4 +40,11 @@ case $BLOCK_BUTTON in
|
|||||||
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
6) "$TERMINAL" -e "$EDITOR" "$0" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
printf "$3$%0.2f" "$(cat "$pricefile")"
|
case "$currency" in
|
||||||
|
usd) symb="$" ;;
|
||||||
|
gbp) symb="£" ;;
|
||||||
|
eur) symb="€" ;;
|
||||||
|
btc) symb="₿" ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
printf "$3$symb%0.2f$after" "$(cat "$pricefile")"
|
||||||
|
|||||||
@ -19,10 +19,12 @@ vol="$(pamixer --get-volume)"
|
|||||||
|
|
||||||
if [ "$vol" -gt "70" ]; then
|
if [ "$vol" -gt "70" ]; then
|
||||||
icon="🔊"
|
icon="🔊"
|
||||||
elif [ "$vol" -lt "30" ]; then
|
elif [ "$vol" -gt "30" ]; then
|
||||||
|
icon="🔉"
|
||||||
|
elif [ "$vol" -gt "0" ]; then
|
||||||
icon="🔈"
|
icon="🔈"
|
||||||
else
|
else
|
||||||
icon="🔉"
|
echo 🔇 && exit
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "$icon$vol%"
|
echo "$icon$vol%"
|
||||||
|
|||||||
@ -1,21 +1,18 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
# A dmenu wrapper script for system functions.
|
# A dmenu wrapper script for system functions.
|
||||||
|
|
||||||
# For non-systemd init systems.
|
|
||||||
case "$(readlink -f /sbin/init)" in
|
case "$(readlink -f /sbin/init)" in
|
||||||
*runit*) hib="sudo -A zzz" ;;
|
*systemd*) ctl='systemctl' ;;
|
||||||
*openrc*) reb="sudo -A openrc-shutdown -r"; shut="sudo -A openrc-shutdown -p" ;;
|
*) ctl='loginctl' ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
cmds="\
|
case "$(printf "🔒 lock\n🚪 leave dwm\n♻️ renew dwm\n🐻 hibernate\n🔃 reboot\n🖥️shutdown\n💤 sleep\n📺 display off" | dmenu -i -p 'Action: ')" in
|
||||||
🔒 lock slock
|
'🔒 lock') slock ;;
|
||||||
🚪 leave dwm kill -TERM $(pgrep -u $USER "\bdwm$")
|
'🚪 leave dwm') kill -TERM "$(pgrep -u "$USER" "\bdwm$")" ;;
|
||||||
♻ renew dwm kill -HUP $(pgrep -u $USER "\bdwm$")
|
'♻️ renew dwm') kill -HUP "$(pgrep -u "$USER" "\bdwm$")" ;;
|
||||||
🐻 hibernate slock ${hib:-systemctl suspend-then-hibernate -i}
|
'🐻 hibernate') slock $ctl hibernate ;;
|
||||||
🔃 reboot ${reb:-sudo -A reboot}
|
'💤 sleep') slock $ctl suspend ;;
|
||||||
🖥 shutdown ${shut:-sudo -A shutdown -h now}"
|
'🔃 reboot') $ctl reboot -i ;;
|
||||||
|
'🖥️shutdown') $ctl poweroff -i ;;
|
||||||
choice="$(echo "$cmds" | cut -d' ' -f 1 | dmenu)" || exit 1
|
'📺 display off') xset dpms force off ;;
|
||||||
|
*) exit 1 ;;
|
||||||
`echo "$cmds" | grep "^$choice " | cut -d ' ' -f2-`
|
esac
|
||||||
|
|||||||
@ -7,6 +7,6 @@ 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-da && 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 "tranmission-daemon enabled."
|
[ "$(printf "No\\nYes" | dmenu -i -p "Turn on transmission daemon?")" = "Yes" ] && transmission-daemon && notify-send "transmission-daemon enabled."
|
||||||
fi
|
fi
|
||||||
sleep 3 && pkill -RTMIN+7 "${STATUSBAR:-dwmblocks}"
|
sleep 3 && pkill -RTMIN+7 "${STATUSBAR:-dwmblocks}"
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
ifinstalled tremc-git transmission-cli || exit
|
ifinstalled tremc transmission-cli || exit
|
||||||
|
|
||||||
! pidof transmission-daemon >/dev/null && transmission-daemon && notify-send "Starting torrent daemon..."
|
! pidof transmission-daemon >/dev/null && transmission-daemon && notify-send "Starting torrent daemon..."
|
||||||
|
|
||||||
|
|||||||
@ -5,22 +5,22 @@
|
|||||||
# add/remove videos from this list as I go on.
|
# add/remove videos from this list as I go on.
|
||||||
|
|
||||||
vidlist="
|
vidlist="
|
||||||
dwm (window manager) https://www.youtube.com/watch?v=xnREqY-oyzM
|
dwm (window manager) https://videos.lukesmith.xyz/videos/watch/f6b78db7-b368-4647-bc64-28c08fff1988
|
||||||
pacman (installing/managing programs) https://www.youtube.com/watch?v=-dEuXTMzRKs
|
pacman (installing/managing programs) https://videos.lukesmith.xyz/videos/watch/8e7cadb9-0fed-47ce-a2a8-6635fa48614b
|
||||||
status bar https://www.youtube.com/watch?v=UP2QpHmcgyk
|
status bar https://videos.lukesmith.xyz/videos/watch/a4d5326b-0aac-496e-bfc3-5acd5cee89f0
|
||||||
sxiv (image viewer) https://www.youtube.com/watch?v=GYW9i_u5PYs
|
sxiv (image viewer) https://videos.lukesmith.xyz/videos/watch/ad4c8d85-90c3-4f3d-a1f3-89129e64a3c2
|
||||||
st (terminal) https://www.youtube.com/watch?v=9H75enWM22k
|
st (terminal) https://videos.lukesmith.xyz/videos/watch/efddd39d-bac5-4599-b572-177beb4ce6e8
|
||||||
i3 (old window manager) https://www.youtube.com/watch?v=GKviflL9XeI
|
i3 (old window manager) https://videos.lukesmith.xyz/videos/watch/b861525c-7ada-40ee-a2bb-b5e1ffe0f48b
|
||||||
neomutt (email) https://www.youtube.com/watch?v=2U3vRbF7v5A
|
neomutt (email) https://videos.lukesmith.xyz/videos/watch/83122e83-52d9-4278-ae1a-7d1beeb50c8e
|
||||||
ncmpcpp (music player) https://www.youtube.com/watch?v=sZIEdI9TS2U
|
ncmpcpp (music player) https://videos.lukesmith.xyz/videos/watch/b5ac6f0d-a220-4433-88e3-e98fc791dc0a
|
||||||
newsboat (RSS reader) https://www.youtube.com/watch?v=dUFCRqs822w
|
newsboat (RSS reader) https://videos.lukesmith.xyz/videos/watch/bd2c3fff-40fa-47ea-aa98-5b1ec0c903b6
|
||||||
ranger (file manager) https://www.youtube.com/watch?v=L6Vu7WPkoJo
|
lf (file manager) https://videos.lukesmith.xyz/w/rKeHsF5ZHDNDbR1buUKB1c
|
||||||
zathura (pdf viewer) https://www.youtube.com/watch?v=V_Iz4zdyRM4
|
zathura (pdf viewer) https://videos.lukesmith.xyz/videos/watch/c780f75a-11f6-48a9-a191-d079ebc36ea4
|
||||||
gpg keys https://www.youtube.com/watch?v=DMGIlj7u7Eo
|
gpg keys https://videos.lukesmith.xyz/videos/watch/040f5530-4830-4583-9ddc-2080b421531b
|
||||||
calcurse (calendar) https://www.youtube.com/watch?v=hvc-pHjbhdE
|
calcurse (calendar) https://videos.lukesmith.xyz/videos/watch/4b937e8b-7654-46e3-8d01-79392ec5b3d1
|
||||||
urlview https://www.youtube.com/watch?v=IgzpAjFgbCw
|
urlview https://videos.lukesmith.xyz/videos/watch/31a4918f-633b-4bd6-b08e-956ac75d0324
|
||||||
colorschemes with pywal https://www.youtube.com/watch?v=Es79N_9BblE
|
colorschemes with pywal https://videos.lukesmith.xyz/videos/watch/1b476003-61b2-4609-ac4b-820c3d128643
|
||||||
vi mode in shell https://www.youtube.com/watch?v=GqoJQft5R2E
|
vi mode in shell https://videos.lukesmith.xyz/videos/watch/228aa50c-836f-456f-9f0d-a45157fe4313
|
||||||
pass (password manager) https://www.youtube.com/watch?v=sVkURNfxPd4
|
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
|
||||||
|
|||||||
@ -1,48 +0,0 @@
|
|||||||
_ _____
|
|
||||||
(_)___ /
|
|
||||||
| | |_ \
|
|
||||||
| |___) |
|
|
||||||
|_|____/
|
|
||||||
i3 is the window manager.
|
|
||||||
For a full readme, press super+F1.
|
|
||||||
This is a partial key list.
|
|
||||||
esc left workspace exit i3
|
|
||||||
tab last workspace
|
|
||||||
- - vol -- vol
|
|
||||||
_ - vol -- vol
|
|
||||||
= + vol ++ vol
|
|
||||||
+ + vol ++ vol
|
|
||||||
q kill win kill win
|
|
||||||
w nmtui (wlan) browser
|
|
||||||
e neomutt tutorials
|
|
||||||
r ranger winresize
|
|
||||||
t toggle hor/vert gaps=15px
|
|
||||||
y calcurse resize left
|
|
||||||
u dropdown term resize down
|
|
||||||
i htop resize up
|
|
||||||
o sticky win resize right
|
|
||||||
p pause music pause A/V
|
|
||||||
[ back 10 secs back 2 min
|
|
||||||
] forward 10 secs forward 2 min
|
|
||||||
\ last workspace
|
|
||||||
a calculator audio control
|
|
||||||
s + inner gaps - inner gaps
|
|
||||||
d dmenu remove gaps
|
|
||||||
f fullscreen freeze mode
|
|
||||||
g left workspace GIMP
|
|
||||||
h focus left move win left
|
|
||||||
j focus down move win down
|
|
||||||
k focus up move win up
|
|
||||||
l focus right move win right
|
|
||||||
; right workspace
|
|
||||||
' fast right win
|
|
||||||
z + outer gaps - outer gaps
|
|
||||||
x lock screen shutdown
|
|
||||||
c webcam
|
|
||||||
v open Vimwiki
|
|
||||||
b bar on/off stick/float win (left)
|
|
||||||
n newsboat stick/float win (right)
|
|
||||||
m ncmpcpp mute audio
|
|
||||||
, < previous song restart song
|
|
||||||
. > next song
|
|
||||||
/ ? fast win below kill win
|
|
||||||
@ -1,2 +1,2 @@
|
|||||||
custom: ["https://lukesmith.xyz/donate.html", "https://lukesmith.xyz/crypto.html"]
|
custom: ["https://lukesmith.xyz/donate.html"]
|
||||||
github: lukesmithxyz
|
github: lukesmithxyz
|
||||||
|
|||||||
@ -43,3 +43,7 @@ curl -LO larbs.xyz/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/LukeSmithxyz/LARBS/blob/master/progs.csv).
|
[dependencies](https://github.com/LukeSmithxyz/LARBS/blob/master/progs.csv).
|
||||||
|
|
||||||
|
## Default Desktop Artwork
|
||||||
|
|
||||||
|
Thomas Thiemeyer's *The Road to Samarkand* ([fb](https://www.facebook.com/t.thiemeyer/), [insta](https://www.instagram.com/tthiemeyer/), [shop](https://www.redbubble.com/de/people/TThiemeyer/shop))
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user