Initial commit.

This commit is contained in:
Sam Greytalon 2023-04-14 20:50:40 -07:00
commit 6b1ee9f050
54 changed files with 5258 additions and 0 deletions

15
.config/dunst/dunstrc Normal file
View file

@ -0,0 +1,15 @@
[global]
script = ~/.config/dunst/playsound
corner_radius = 5
timeout = 1
[critical]
timeout = 0
[brightness]
summary = "Brightness:*"
history_ignore = yes
[volume]
summary = "Volume:*"
history_ignore = yes

3
.config/dunst/playsound Executable file
View file

@ -0,0 +1,3 @@
#! /bin/sh
play "~/.config/sounds/dunst/$DUNST_STACK_TAG.*" || play "~/.config/sounds/dunst/$DUNST_DESKTOP_ENTRY.*" || play "~/.config/sounds/dunst/$DUNST_URGENCY.*"

102
.config/fish/config.fish Normal file
View file

@ -0,0 +1,102 @@
set -x PATH "$HOME/bin:$PATH"
if not which sh > /dev/null 2>&1
alias which="command -v"
end
if not which hostname > /dev/null 2>&1
alias hostname="cat /etc/hostname"
end
if which doas > /dev/null 2>&1
alias sudo="doas"
else
alias doas="sudo"
end
if which nvim >/dev/null 2>&1
alias vim="nvim"
set -x EDITOR nvim
else
alias nvim="vim -u ~/.config/vim/vimrc"
alias vim="vim -u ~/.config/vim/vimrc"
set -x EDITOR "vim -u ~/.config/vim/vimrc"
end
function please
eval doas $history[1]
end
function x
startx ~/.config/xinitrc
if [ -f "$XDG_RUNTIME_DIR/logout" ]
rm "$XDG_RUNTIME_DIR/logout"
exit
end
end
function pingme
set COMMAND $argv
$COMMAND
notify-send --urgency=normal "Ping!" "Job '$COMMAND' exited with status $status."
end
function nope-syntax --on-event fish_posterror
if [ $status -gt 0 ]
play ~/.config/sounds/nope.mp3 > /dev/null 2>&1 & disown
end
end
function nope-command --on-event fish_postexec
if [ $status -gt 0 ]
play ~/.config/sounds/nope.mp3 > /dev/null 2>&1 & disown
end
end
fish_vi_key_bindings
function fish_mode_prompt; end; funcsave fish_mode_prompt > /dev/null
set fish_cursor_default block blink
set fish_cursor_insert line blink
set fish_cursor_replace_one underscore blink
set fish_cursor_visual block
if which starship >/dev/null 2>&1
export STARSHIP_CONFIG="$HOME/.config/starship/config.toml"
starship init fish | source
end
if status --is-login
echo ""
end
if status --is-interactive
alias la="ls -a --color=always"
alias ll="ls -l --color=always"
alias ls="ls --color=always"
alias g="git"
mkdir -p ~/.local
if [ (expr (date '+%s') - (cat "$HOME/.local/last_shell" 2>/dev/null || echo 0)) -gt "28800" ]
timeout 5 git sit && date '+%s' > "$HOME/.local/last_shell"
echo ""
end
set remind (remind)
if [ ! -z "$remind" ]
echo Reminders:
echo "$remind"
echo ""
end
end

12
.config/git/config Normal file
View file

@ -0,0 +1,12 @@
[init]
defaultBranch = main
[user]
name = Sam Greytalon
email = sam@oaktal.com
[pull]
rebase = false
[alias]
sit = pull --rebase
flush = "git add -A && git commit -a; git push"
unstage = reset HEAD --
sync = !git sit && git flush

37
.config/herbstluftwm/autostart Executable file
View file

@ -0,0 +1,37 @@
#!/usr/bin/env bash
hc() {
cmds="$cmds , $@"
}
hc emit_hook reload
. ~/.config/herbstluftwm/keybinds
hc unrule -F
hc rule focus=on # normally focus new clients
hc rule floatplacement=smart
hc rule windowtype~'_NET_WM_WINDOW_TYPE_(DIALOG|UTILITY|SPLASH)' floating=on
hc rule windowtype='_NET_WM_WINDOW_TYPE_DIALOG' focus=on
hc rule windowtype~'_NET_WM_WINDOW_TYPE_(NOTIFICATION|DOCK|DESKTOP)' manage=off
hc set tree_style '╾│ ├└╼─┐'
. ~/.config/herbstluftwm/theme
herbstclient chain $cmds
#
# STOLEN FLOATING WINDOW CODE:
#
PADDING=$(herbstclient list_padding)
#re-add monitor called 'float' with same padding and dimensions as the monitor under focus in tag 9
herbstclient remove_monitor float
herbstclient add_monitor $(herbstclient list_monitors | grep \[FOCUS\] | grep -oe '[0-9]\+x[0-9]\++[0-9]\++[0-9]\+') "PIN" float
herbstclient lock_tag float
#add same padding:
herbstclient pad float $PADDING
# unlock after everything
hc unlock

89
.config/herbstluftwm/keybinds Executable file
View file

@ -0,0 +1,89 @@
#!/bin/sh
Mod=Mod4
hc keyunbind --all
hc keybind $Mod-Shift-q spawn herbstclient quit
hc keybind $Mod-Shift-r reload
hc keybind $Mod-Shift-c close_or_remove
hc keybind $Mod-q close_or_remove
hc keybind $Mod-Return spawn "${TERMINAL} -d ~"
hc keybind $Mod-space spawn "${MENU}"
hc keybind Print spawn screenshot
hc keybind Shift-Print spawn selscreen
hc keybind $Mod-Left focus left
hc keybind $Mod-Down focus down
hc keybind $Mod-Up focus up
hc keybind $Mod-Right focus right
hc keybind $Mod-h focus left
hc keybind $Mod-j focus down
hc keybind $Mod-k focus up
hc keybind $Mod-l focus right
hc keybind $Mod-Shift-Left shift left
hc keybind $Mod-Shift-Down shift down
hc keybind $Mod-Shift-Up shift up
hc keybind $Mod-Shift-Right shift right
hc keybind $Mod-Shift-h shift left
hc keybind $Mod-Shift-j shift down
hc keybind $Mod-Shift-k shift up
hc keybind $Mod-Shift-l shift right
hc keybind $Mod-Shift-BackSpace shift_to_monitor +1
hc keybind $Mod-u split bottom 0.5
hc keybind $Mod-o split right 0.5
hc keybind $Mod-Control-Space split explode
resizestep=0.02
hc keybind $Mod-Control-h resize left +$resizestep
hc keybind $Mod-Control-j resize down +$resizestep
hc keybind $Mod-Control-k resize up +$resizestep
hc keybind $Mod-Control-l resize right +$resizestep
hc keybind $Mod-Control-Left resize left +$resizestep
hc keybind $Mod-Control-Down resize down +$resizestep
hc keybind $Mod-Control-Up resize up +$resizestep
hc keybind $Mod-Control-Right resize right +$resizestep
hc keybind XF86AudioMute chain '->' spawn vol toggle '->' emit_hook volume_changed
hc keybind XF86AudioLowerVolume chain '->' spawn vol down '->' emit_hook volume_changed
hc keybind XF86AudioRaiseVolume chain '->' spawn vol up '->' emit_hook volume_changed
hc keybind XF86MonBrightnessDown spawn br down
hc keybind XF86MonBrightnessUp spawn br up
hc rename default "1"
for i in $(seq 1 9); do
hc add "$i"
num="$(expr $i - 1)"
hc keybind "$Mod-$i" use_index "$num"
hc keybind "$Mod-Shift-$i" move_index "$num"
done
hc add "PIN"
hc keybind "$Mod-Control-Shift-p" move "PIN"
hc keybind $Mod-period use_index +1 --skip-visible
hc keybind $Mod-comma use_index -1 --skip-visible
hc keybind $Mod-r remove
hc keybind $Mod-s floating toggle
hc keybind $Mod-f fullscreen toggle
hc keybind $Mod-Shift-f set_attr clients.focus.floating toggle
hc keybind $Mod-p pseudotile toggle
hc mouseunbind --all
hc mousebind $Mod-Button1 move
hc mousebind $Mod-Button2 zoom
hc mousebind $Mod-Button3 resize
hc keybind $Mod-BackSpace cycle_monitor
hc keybind $Mod-Tab cycle_all +1
hc keybind $Mod-Shift-Tab cycle_all -1
hc keybind $Mod-c cycle
hc keybind $Mod-i jumpto urgent
hc keybind $Mod-slash cycle_layout +1

3
.config/kitty/kitty.conf Normal file
View file

@ -0,0 +1,3 @@
include theme.conf
shell .

16
.config/mpanel/menus/powermenu Executable file
View file

@ -0,0 +1,16 @@
#! /bin/sh
choice=$(echo " Kill X11\n Logout\n襤 Poweroff" | rofi -dmenu -m -3 -hover-select -me-select-entry '' -me-accept-entry MousePrimary -theme-str ' * { width: 15em; scrollbar: false; } listview { fixed-height: false; } inputbar { enabled: false; }')
case "$choice" in
" Kill X11")
herbstclient quit
;;
" Logout")
touch $XDG_RUNTIME_DIR/logout
herbstclient quit
;;
"襤 Poweroff")
doas poweroff
;;
esac

3
.config/mpanel/menus/windows Executable file
View file

@ -0,0 +1,3 @@
#! /bin/sh
rofi -show window -show-icons -m -3 -hover-select -me-select-entry '' -me-accept-entry MousePrimary -kb-delete-entry MouseSecondary -window-format '{w} {c:10} {t:15}' -theme-str ' * { width: 15em; scrollbar: false; } listview { fixed-height: false; } inputbar { enabled: false; }'

37
.config/mpanel/modules/10vol Executable file
View file

@ -0,0 +1,37 @@
#!/bin/sh
. ../mpanel.subr
align="left"
background="$(color 4)"
foreground="$(color 3)"
clickFunc=click
waitFunc="wait_for volume_changed"
click() {
vol toggle
}
print_volume() {
sleep 0.01
CURRENT_VOLUME="$(vol get)%%"
padding=11
if [ "$CURRENT_VOLUME" = "muted%%" ]; then
symbol=""
CURRENT_VOLUME=""
padding=10
elif [ "$CURRENT_VOLUME" -le "33" ]; then
symbol=""
elif [ "$CURRENT_VOLUME" -le "66" ]; then
symbol=""
else
symbol=""
fi
output="$(pad " $symbol $CURRENT_VOLUME" $padding)"
echo "$output"
}
loop print_volume

30
.config/mpanel/modules/11tags Executable file
View file

@ -0,0 +1,30 @@
#!/bin/sh
. ../mpanel.subr
align="left"
background="$(color 5)"
foreground="$(color 3)"
waitFunc="wait_for tag_changed"
print_tags() {
output=""
for element in $(herbstclient tag_status); do
pref="$(echo "$element" | cut -c1-1)"
tag="$(echo "$element" | cut -c2-)"
if [ "$pref" = "#" ]; then
output="$output%{R}$tag%{R}"
elif [ "$pref" = ":" ]; then
output="$output%{A:herbstclient use_index $(expr $tag - 1):} $tag %{A}"
else
output="$output"
fi
done
echo "$output"
}
loop print_tags

24
.config/mpanel/modules/1focus Executable file
View file

@ -0,0 +1,24 @@
#!/bin/sh
. ../mpanel.subr
align="left"
background="$(color 6)"
foreground="$(color 3)"
waitFunc="wait_for focus_changed tag_changed window_title_changed"
clickFunc="../menus/windows"
print_focus() {
title="$(herbstclient attr clients.focus.title)"
output="$(trim "$title" 25)"
if [ "$?" = "3" ]; then
echo " $output... "
else
echo " $output "
fi
}
loop print_focus

22
.config/mpanel/modules/21time Executable file
View file

@ -0,0 +1,22 @@
#!/bin/sh
. ../mpanel.subr
align="center"
background="$(color 7)"
foreground="$(color 3)"
clickFunc="toggle flag"
waitFunc="sleep 1"
flag="true"
print_time() {
if [ "$flag" = "true" ]; then
echo " $(date "+%b. %d, %H:%M") "
else
echo " $(date "+%H:%M") "
fi
}
loop print_time

11
.config/mpanel/modules/2user Executable file
View file

@ -0,0 +1,11 @@
#!/bin/sh
. ../mpanel.subr
align="center"
background="$(color 8)"
foreground="$(color 3)"
echo "$module_name/$align!$background!$foreground/%{A:./menus/powermenu:} $(whoami)@$(hostname) %{A}"
sleep infinity

71
.config/mpanel/modules/31batt Executable file
View file

@ -0,0 +1,71 @@
#!/bin/sh
. ../mpanel.subr
align="right"
background="$(color 9)"
foreground="$(color 3)"
clickFunc="toggle flag"
waitFunc="sleep 5"
notify=""
flag=true
print_batt() {
level="$(cat /sys/class/power_supply/BAT1/capacity)"
if [ "$level" -ge "100" ]; then
SYMBOL=""
elif [ "$level" -ge "90" ]; then
SYMBOL=""
elif [ "$level" -ge "80" ]; then
SYMBOL=""
elif [ "$level" -ge "70" ]; then
SYMBOL=""
elif [ "$level" -ge "60" ]; then
SYMBOL=""
elif [ "$level" -ge "50" ]; then
SYMBOL=""
elif [ "$level" -ge "40" ]; then
SYMBOL=""
elif [ "$level" -ge "30" ]; then
SYMBOL=""
elif [ "$level" -ge "20" ]; then
SYMBOL=""
notify=""
elif [ "$level" -ge "10" ]; then
SYMBOL=""
if [ "$notify" = "" ]; then
notify-send --urgency=normal "Battery Low!"
fi
notify="low"
elif [ "$level" -ge "0" ]; then
SYMBOL=""
if [ "$notify" = "" ] || [ "$notify" = "low" ]; then
notify-send --urgency=critical "Battery Critically Low!"
fi
notify="critical"
fi
if [ "$(cat /sys/class/power_supply/BAT1/status)" = "Charging" ]; then
SYMBOL="$SYMBOL"
else
SYMBOL="$SYMBOL"
fi
if [ "$flag" = "true" ]; then
output=" $SYMBOL $(cat /sys/class/power_supply/BAT1/capacity)% "
else
output=" $SYMBOL "
fi
echo "$output"
}
loop print_batt

34
.config/mpanel/modules/321cpu Executable file
View file

@ -0,0 +1,34 @@
#! /bin/sh
. ../mpanel.subr
align="right"
background="$(color 10)"
foreground="$(color 3)"
waitFunc="sleep 1"
clickFunc='toggle flag; [ "$flag" = "true" ] && waitFunc="sleep 1" || waitFunc="sleep infinity"'
flag="true"
STORE_FILE="$XDG_RUNTIME_DIR/stats-cpu.tmp"
SYMBOL="﬙"
INTERVAL=""
store_stats() {
cpu="$(vmstat 1 2 | tail -1 | awk '{printf "%3.0f", 100-$15}')"
echo "$cpu" | atomic_write "$STORE_FILE"
}
print_stats() {
if [ "$flag" = "true" ]; then
echo " $SYMBOL$(cat "$STORE_FILE")%"
else
echo " $SYMBOL"
fi
}
kickoff store_stats $INTERVAL &
loop print_stats

35
.config/mpanel/modules/322mem Executable file
View file

@ -0,0 +1,35 @@
#! /bin/sh
. ../mpanel.subr
align="right"
background="$(color 10)"
foreground="$(color 3)"
waitFunc="sleep 1"
clickFunc='toggle flag; [ "$flag" = "true" ] && waitFunc="sleep 1" || waitFunc="sleep infinity"'
flag="true"
STORE_FILE="$XDG_RUNTIME_DIR/stats-mem.tmp"
SYMBOL=""
INTERVAL="1"
store_stats() {
memTotal="$(cat /proc/meminfo | grep MemTotal | awk '{print $2}')"
memFree="$(cat /proc/meminfo | grep MemFree | awk '{print $2}')"
awk "BEGIN {printf \"%3.0f\", 100*(($memTotal-$memFree)/$memTotal)}" | atomic_write "$STORE_FILE"
}
print_stats() {
if [ "$flag" = "true" ]; then
echo "$SYMBOL$(cat "$STORE_FILE")%"
else
echo "$SYMBOL"
fi
}
kickoff store_stats $INTERVAL &
loop print_stats

34
.config/mpanel/modules/323diskr Executable file
View file

@ -0,0 +1,34 @@
#! /bin/sh
. ../mpanel.subr
align="right"
background="$(color 10)"
foreground="$(color 3)"
waitFunc="sleep 1"
clickFunc='toggle flag; [ "$flag" = "true" ] && waitFunc="sleep 1" || waitFunc="sleep infinity"'
flag="true"
STORE_FILE="$XDG_RUNTIME_DIR/stats-diskr.tmp"
SYMBOL=""
INTERVAL=""
store_stats() {
disk="$(zpool iostat -Hp 1 2 | tail -1 | awk '{r=$6 ; rSuf="B " ; if (r >= 1000) {r=r/1000; rSuf="KB";} if (r >= 1000) {r=r/1000; rSuf="MB";} if (r >= 1000) {r=r/1000; rSuf="GB";} printf "%3.0f", r; printf rSuf;}')"
echo "$disk" | atomic_write "$STORE_FILE"
}
print_stats() {
if [ "$flag" = "true" ]; then
echo "$SYMBOL$(cat "$STORE_FILE")"
else
echo "$SYMBOL"
fi
}
kickoff store_stats $INTERVAL &
loop print_stats

34
.config/mpanel/modules/324diskw Executable file
View file

@ -0,0 +1,34 @@
#! /bin/sh
. ../mpanel.subr
align="right"
background="$(color 10)"
foreground="$(color 3)"
waitFunc="sleep 1"
clickFunc='toggle flag; [ "$flag" = "true" ] && waitFunc="sleep 1" || waitFunc="sleep infinity"'
flag="true"
STORE_FILE="$XDG_RUNTIME_DIR/stats-diskw.tmp"
SYMBOL=""
INTERVAL=""
store_stats() {
disk="$(zpool iostat -Hp 1 2 | tail -1 | awk '{w=$7 ; wSuf="B " ; if (w >= 1000) {w=w/1000; wSuf="KB";} if (w >= 1000) {w=w/1000; wSuf="MB";} if (w >= 1000) {w=w/1000; wSuf="GB";} printf "%3.0f", w; printf wSuf;}')"
echo "$disk" | atomic_write "$STORE_FILE"
}
print_stats() {
if [ "$flag" = "true" ]; then
echo "$SYMBOL$(cat "$STORE_FILE")"
else
echo "$SYMBOL"
fi
}
kickoff store_stats $INTERVAL &
loop print_stats

34
.config/mpanel/modules/325temp Executable file
View file

@ -0,0 +1,34 @@
#! /bin/sh
. ../mpanel.subr
align="right"
background="$(color 10)"
foreground="$(color 3)"
waitFunc="sleep 1"
clickFunc='toggle flag; [ "$flag" = "true" ] && waitFunc="sleep 1" || waitFunc="sleep infinity"'
flag="true"
warn=""
SYMBOL=""
print_stats() {
temp="$(cat /sys/class/thermal/thermal_zone4/temp | awk '{printf "%3.0f", $1/1000}')"
if [ "$(echo "$temp" | head -c2)" -gt "80" ]; then
[ "$warn" != "urgent" ] && notify-send --urgency=critical "CPU Temperature High!"
warn="urgent"
else
warn=""
fi
if [ "$flag" = "true" ]; then
echo "$SYMBOL$temp°C "
else
echo "$SYMBOL "
fi
}
loop print_stats

91
.config/mpanel/modules/33wifi Executable file
View file

@ -0,0 +1,91 @@
#!/bin/sh
. ../mpanel.subr
. ../aux/secrets
align="right"
background="$(color 11)"
foreground="$(color 3)"
waitFunc="sleep 1"
clickFunc="toggle flag"
flag="true"
connected() {
state="$(iwctl station $wifi_if show | grep State | awk '{print $2}')"
[ "$state" = "connected" ] && return 0
return 1
}
internet() {
if nc -zw1 google.com 443; then
return 0
fi
return 1
}
vpn() {
if ping -c 1 -w 5 $vpn_ip >/dev/null 2>&1; then
return 0
fi
return 1
}
home() {
if ping -c 1 -w 5 $home_ip >/dev/null 2>&1; then
return 0
fi
return 1
}
store_speeds() {
R1="$(cat /sys/class/net/$wifi_if/statistics/rx_bytes)"
T1="$(cat /sys/class/net/$wifi_if/statistics/tx_bytes)"
sleep 1
R2="$(cat /sys/class/net/$wifi_if/statistics/rx_bytes)"
T2="$(cat /sys/class/net/$wifi_if/statistics/tx_bytes)"
r="$(echo $R1 $R2 | awk '{r=$2-$1 ; rSuf="B " ; if (r >= 1000) {r=r/1000; rSuf="KB";} if (r >= 1000) {r=r/1000; rSuf="MB";} printf "%3.0f", r; printf rSuf;}')"
t="$(echo $T1 $T2 | awk '{t=$2-$1 ; tSuf="B " ; if (t >= 1000) {t=t/1000; tSuf="KB";} if (t >= 1000) {t=t/1000; tSuf="MB";} printf "%3.0f", t; printf tSuf;}')"
echo " $r 祝$t" | atomic_write "$XDG_RUNTIME_DIR/wifi-speeds.tmp"
}
store_symbol() {
if connected; then
if internet; then
if vpn; then
out="直"
elif home; then
out=""
else
out=""
fi
else
out=""
fi
else
out="睊"
fi
echo "$out" | atomic_write "$XDG_RUNTIME_DIR/wifi-symbol.tmp"
}
print_stats() {
if [ "$flag" = "true" ]; then
echo " $(cat "$XDG_RUNTIME_DIR/wifi-symbol.tmp")$(cat "$XDG_RUNTIME_DIR/wifi-speeds.tmp") "
else
echo " $(cat "$XDG_RUNTIME_DIR/wifi-symbol.tmp") "
fi
}
kickoff store_speeds &
kickoff store_symbol 5 &
loop print_stats

96
.config/mpanel/mpanel.subr Executable file
View file

@ -0,0 +1,96 @@
#! /bin/sh
module_name="$(basename "$0")"
align="left"
color() {
sed "$1!d" ../colors
}
background="$(color 1)"
foreground="$(color 2)"
trap "echo "$module_name//!DEAD" && trap - TERM && kill -- -$$" INT TERM EXIT
loop() {
echo "$module_name/$align!$background!$foreground/"
if [ ! -z "$clickFunc" ]; then
trap "$clickFunc" 10
prefix="%{A:kill -10 $$:}"
suffix="%{A}"
fi
while :; do
data="$($1)"
if [ "$?" = "1" ]; then
sleep 0.01
continue
fi
echo "$module_name//$prefix$data$suffix"
$waitFunc &
wait $!
done
}
wait_for() {
[ "$1" = "" ] && exit
if [ "$2" = "" ]; then
herbstclient --wait $1 > /dev/null &
wait
else
list=""
for arg in $@; do
list="$list|$arg"
done
herbstclient --wait "$list" > /dev/null &
wait
fi
}
kickoff() {
if [ "$2" = "" ]; then
while :; do
$1
done
else
while :; do
$1
sleep $2
done
fi
}
pad() {
len="$(echo -n "$1" | wc -c)"
padding="$(expr $2 - $len)"
if [ "$padding" -lt 1 ]; then
echo "$1"
return
fi
printf "$1%*s\n" $padding ''
}
trim() {
len="$(echo -n "$1" | wc -c)"
echo "$1" | colrm $2
[ "$len" -gt "$2" ] && return 3
}
toggle() {
eval "[ \"\$$1\" = \"true\" ] && $1=false || $1=true"
}
atomic_write() {
cat - > "$1.atom"
mv "$1.atom" "$1"
}

View file

@ -0,0 +1,3 @@
module oaktal.com/parser
go 1.20

View file

@ -0,0 +1,373 @@
package main
import (
"bufio"
"os"
"strings"
"errors"
"fmt"
"sort"
)
const LEFT = 0
const CENTER = 1
const RIGHT = 2
const GLOBAL_PREFIX = ""
const GLOBAL_SUFFIX = "%{B-}%{F-}"
const LEFT_BORDER_CHAR = ""
const RIGHT_BORDER_CHAR = ""
const RIGHT_ALIGN_PREFIX = "%%{B%s}%%{F%s}"
const LEFT_FACING_BORDER = "%%{B%s}%%{F%s}" + LEFT_BORDER_CHAR + "%%{B%s}%%{F%s}"
const RIGHT_ALIGN_SUFFIX = ""
const LEFT_ALIGN_PREFIX = "%%{B%s}%%{F%s}"
const RIGHT_FACING_BORDER = "%%{B%s}%%{F%s}" + RIGHT_BORDER_CHAR + "%%{B%s}%%{F%s}"
const LEFT_ALIGN_SUFFIX = ""
const LEFT_HANGING_BORDER = "%%{F%s}" + LEFT_BORDER_CHAR
const RIGHT_HANGING_BORDER = "%%{B-}%%{F%s}" + RIGHT_BORDER_CHAR
const CENTER_PREFIX = "%%{B%s}%%{F%s}"
const CENTER_BORDER = ""
const CENTER_SUFFIX = ""
type block struct {
tag string
align int
back string
fore string
content string
}
func main() {
blocks := make([]block, 0, 16)
reader := bufio.NewReader(os.Stdin)
for {
line, _ := reader.ReadString('\n')
if (line == "") {
os.Exit(0)
}
var err error = nil
new_blocks, err := runCommandOnSlice(line, blocks)
if (err != nil) {
continue
} else {
blocks = new_blocks
}
output := generateStringFromSlice(blocks)
if (err != nil) {
fmt.Printf("Fatal error! %w\n", err)
os.Exit(1)
}
fmt.Println(GLOBAL_PREFIX + output + GLOBAL_SUFFIX)
}
}
func runCommandOnSlice(command string, targetSlice []block) ([]block, error) {
tag, format, content, err := extractFieldsFromCommand(command)
if (err != nil) {
return nil, err
}
if (len(content) > 0) {
if (content == "!DEAD") {
return removeBlockFromSliceWithTag(targetSlice, tag), nil
}
if (content[0] == '\\') {
content = content[1:]
}
}
align, back, fore := parseFormatString(format)
curBlock := block {tag: tag, align: align, back: back, fore: fore, content: content}
newSlice, err := mergeBlockToSlice(curBlock, targetSlice)
if (err != nil) {
return nil, fmt.Errorf("runCommandOnSlice: %v", err)
}
newSlice = sortSliceOfBlocks(newSlice)
return newSlice, nil
}
func extractFieldsFromCommand(command string) (string, string, string, error) {
trimmedCommand := strings.TrimRight(command, " \n")
tag := ""
format := ""
content := ""
splitCommand := strings.SplitN(trimmedCommand, "/", 3)
tag = splitCommand[0]
if (len(splitCommand) == 3) {
format = splitCommand[1]
content = splitCommand[2]
} else if (len(splitCommand) == 2) {
format = ""
content = splitCommand[1]
} else {
return "", "", "", fmt.Errorf("Malformed command: %v", command)
}
if (content == "NULL") {
content = ""
}
return tag, format, content, nil
}
func removeBlockFromSliceWithTag(targetSlice []block, tag string) ([]block) {
outputSlice := make([]block, len(targetSlice), cap(targetSlice))
index := -1
copy(outputSlice, targetSlice)
for i, v := range outputSlice {
if v.tag == tag {
index = i
break
}
}
if (index != -1) {
outputSlice = removeIndexFromSlice(outputSlice, index)
}
return outputSlice
}
func removeIndexFromSlice(targetSlice []block, index int) []block {
outputSlice := make([]block, len(targetSlice), cap(targetSlice))
copy(outputSlice, targetSlice)
outputSlice[index] = outputSlice[len(outputSlice) - 1]
return outputSlice[:len(outputSlice) - 1]
}
func parseFormatString(format string) (int, string, string) {
align := LEFT
back := ""
fore := ""
splitFormat := strings.Split(format, "!")
align = parseAlignString(splitFormat[0])
if (len(splitFormat) > 1) {
back = splitFormat[1]
}
if (len(splitFormat) > 2) {
fore = splitFormat[2]
}
return align, back, fore
}
func parseAlignString(align string) int {
switch align {
case "left":
return LEFT
case "center":
return CENTER
case "right":
return RIGHT
default:
return -1
}
}
func mergeBlockToSlice(newBlock block, targetSlice []block) ([]block, error) {
targetBlock, index := getBlockAndIndexFromSliceWithTag(targetSlice, newBlock.tag)
outputSlice := make([]block, len(targetSlice), cap(targetSlice))
copy(outputSlice, targetSlice)
if (index == -1) {
outputSlice = append(outputSlice, newBlock)
return outputSlice, nil
}
mergedBlock, err := mergeTwoBlocks(newBlock, targetBlock)
if (err != nil) {
return nil, fmt.Errorf("mergeBlockToSlice: %v", err)
}
outputSlice[index] = mergedBlock
return outputSlice, nil
}
func getBlockAndIndexFromSliceWithTag(targetSlice []block, tag string) (block, int) {
for i, curBlock := range targetSlice {
if (curBlock.tag == tag) {
return curBlock, i
}
}
return block {tag: "", align: -1, back: "", fore: ""}, -1
}
func mergeTwoBlocks(newBlock block, oldBlock block) (block, error) {
if (newBlock.tag != "") {
oldBlock.tag = newBlock.tag
}
if (newBlock.align != -1) {
oldBlock.align = newBlock.align
}
if (newBlock.back != "") {
oldBlock.back = newBlock.back
}
if (newBlock.fore != "") {
oldBlock.fore = newBlock.fore
}
if (newBlock.content != "") {
oldBlock.content = newBlock.content
}
if (oldBlock.tag == "") {
return block {tag: "", align: -1, back: "", fore: ""}, errors.New("No tag given for new block!")
}
if (oldBlock.align == -1) {
oldBlock.align = LEFT
}
if (oldBlock.back == "") {
oldBlock.back = "-"
}
if (oldBlock.fore == "") {
oldBlock.fore = "-"
}
if (oldBlock.content == "") {
oldBlock.content = ""
}
return oldBlock, nil
}
func sortSliceOfBlocks(targetSlice []block) []block {
outputSlice := make([]block, len(targetSlice), cap(targetSlice))
copy(outputSlice, targetSlice)
sort.Slice(outputSlice, func (i, j int) bool {
if (outputSlice[i].align < outputSlice[j].align) {
return true
}
return outputSlice[i].tag < outputSlice[j].tag
})
return outputSlice
}
func generateStringFromSlice(sourceSlice []block) string {
if (len(sourceSlice) == 0) {
return ""
}
outputString := ""
mode := LEFT
index := 0
prevBlock := block {
tag: "",
align: sourceSlice[0].align,
back: sourceSlice[0].back,
fore: sourceSlice[0].fore,
content: "" }
nextBlock := block {
tag: "",
align: -1,
back: "",
fore: "",
content: "" }
for _, curBlock := range sourceSlice {
if (index == len(sourceSlice) - 1) {
nextBlock = block {
tag: "",
align: sourceSlice[0].align,
back: sourceSlice[0].back,
fore: sourceSlice[0].fore,
content: "" }
} else {
nextBlock = sourceSlice[index + 1]
}
index = index + 1
alignSegment := ""
if (curBlock.align != mode) {
switch curBlock.align {
case LEFT:
alignSegment = "%{l}"
case CENTER:
alignSegment = "%{c}"
case RIGHT:
alignSegment = "%{r}"
}
mode = curBlock.align
}
blockString := ""
switch curBlock.align {
case LEFT:
if (nextBlock.align == curBlock.align) {
blockString = fmt.Sprintf(LEFT_ALIGN_PREFIX, curBlock.back, curBlock.fore) + curBlock.content + fmt.Sprintf(RIGHT_FACING_BORDER, nextBlock.back, curBlock.back, nextBlock.back, nextBlock.fore)
} else {
blockString = fmt.Sprintf(LEFT_ALIGN_PREFIX, curBlock.back, curBlock.fore) + curBlock.content + fmt.Sprintf(RIGHT_HANGING_BORDER, curBlock.back)
}
case CENTER:
prefix := fmt.Sprintf(CENTER_PREFIX, curBlock.back, curBlock.fore)
suffix := ""
if (prevBlock.align != curBlock.align) {
prefix = fmt.Sprintf(LEFT_HANGING_BORDER, curBlock.back) + prefix
} else {
prefix = CENTER_BORDER + prefix
}
if (nextBlock.align != curBlock.align) {
suffix = suffix + fmt.Sprintf(RIGHT_HANGING_BORDER, curBlock.back)
}
blockString = prefix + curBlock.content + suffix
case RIGHT:
if (prevBlock.align == curBlock.align) {
blockString = fmt.Sprintf(LEFT_FACING_BORDER, prevBlock.back, curBlock.back, curBlock.back, curBlock.fore) + curBlock.content
} else {
blockString = fmt.Sprintf(LEFT_HANGING_BORDER, curBlock.back) + fmt.Sprintf(RIGHT_ALIGN_PREFIX, curBlock.back, curBlock.fore) + curBlock.content
}
}
outputString = outputString + alignSegment + blockString
prevBlock = curBlock
}
return outputString
}

31
.config/mpanel/start Executable file
View file

@ -0,0 +1,31 @@
#!/bin/sh
[ -z "$MPANEL_FONT" ] && MPANEL_FONT="JetBrainsMono Nerd Font Mono"
[ -z "$MPANEL_MAX_LINKS" ] && MPANEL_MAX_LINKS="25"
PIPE="$XDG_RUNTIME_DIR/mpanel.fifo"
if [ -p "$PIPE" ] || [ -f "$PIPE" ]; then
rm -f "$PIPE"
[ -p "$PIPE" ] && exit 1
[ -f "$PIPE" ] && exit 1
fi
mkfifo -m 0660 "$PIPE" || exit 1
cd "$(dirname "$0")" || exit 1
./parser < "$PIPE" | lemonbar \
-f "$MPANEL_FONT" \
-B "$(sed '1!d' ./colors)" \
-F "$(sed '2!d' ./colors)" \
-a "$MPANEL_MAX_LINKS" | sh &
trap "trap - TERM && kill -- -$$" INT TERM EXIT
cd "modules" || exit 1
for module in $(ls); do
"./$module" > "$PIPE" &
done
wait

File diff suppressed because it is too large Load diff

1
.config/nvim/init.vim Normal file
View file

@ -0,0 +1 @@
source ~/.config/vim/vimrc

759
.config/ranger/rc.conf Normal file
View file

@ -0,0 +1,759 @@
# ===================================================================
# This file contains the default startup commands for ranger.
# To change them, it is recommended to create either /etc/ranger/rc.conf
# (system-wide) or ~/.config/ranger/rc.conf (per user) and add your custom
# commands there.
#
# If you copy this whole file there, you may want to set the environment
# variable RANGER_LOAD_DEFAULT_RC to FALSE to avoid loading it twice.
#
# The purpose of this file is mainly to define keybindings and settings.
# For running more complex python code, please create a plugin in "plugins/" or
# a command in "commands.py".
#
# Each line is a command that will be run before the user interface
# is initialized. As a result, you can not use commands which rely
# on the UI such as :delete or :mark.
# ===================================================================
# ===================================================================
# == Options
# ===================================================================
# Which viewmode should be used? Possible values are:
# miller: Use miller columns which show multiple levels of the hierarchy
# multipane: Midnight-commander like multipane view showing all tabs next
# to each other
set viewmode miller
#set viewmode multipane
# How many columns are there, and what are their relative widths?
set column_ratios 1,3,4
# Which files should be hidden? (regular expression)
set hidden_filter ^\.|\.(?:pyc|pyo|bak|swp)$|^lost\+found$|^__(py)?cache__$
# Show hidden files? You can toggle this by typing 'zh'
set show_hidden false
# Ask for a confirmation when running the "delete" command?
# Valid values are "always", "never", "multiple" (default)
# With "multiple", ranger will ask only if you delete multiple files at once.
set confirm_on_delete multiple
# Use non-default path for file preview script?
# ranger ships with scope.sh, a script that calls external programs (see
# README.md for dependencies) to preview images, archives, etc.
#set preview_script ~/.config/ranger/scope.sh
# Use the external preview script or display simple plain text or image previews?
set use_preview_script true
# Automatically count files in the directory, even before entering them?
set automatically_count_files true
# Open all images in this directory when running certain image viewers
# like feh or sxiv? You can still open selected files by marking them.
set open_all_images true
# Be aware of version control systems and display information.
set vcs_aware false
# State of the four backends git, hg, bzr, svn. The possible states are
# disabled, local (only show local info), enabled (show local and remote
# information).
set vcs_backend_git enabled
set vcs_backend_hg disabled
set vcs_backend_bzr disabled
set vcs_backend_svn disabled
# Truncate the long commit messages to this length when shown in the statusbar.
set vcs_msg_length 50
# Use one of the supported image preview protocols
set preview_images true
# Set the preview image method. Supported methods:
#
# * w3m (default):
# Preview images in full color with the external command "w3mimgpreview"?
# This requires the console web browser "w3m" and a supported terminal.
# It has been successfully tested with "xterm" and "urxvt" without tmux.
#
# * iterm2:
# Preview images in full color using iTerm2 image previews
# (http://iterm2.com/images.html). This requires using iTerm2 compiled
# with image preview support.
#
# This feature relies on the dimensions of the terminal's font. By default, a
# width of 8 and height of 11 are used. To use other values, set the options
# iterm2_font_width and iterm2_font_height to the desired values.
#
# * terminology:
# Previews images in full color in the terminology terminal emulator.
# Supports a wide variety of formats, even vector graphics like svg.
#
# * urxvt:
# Preview images in full color using urxvt image backgrounds. This
# requires using urxvt compiled with pixbuf support.
#
# * urxvt-full:
# The same as urxvt but utilizing not only the preview pane but the
# whole terminal window.
#
# * kitty:
# Preview images in full color using kitty image protocol.
# Requires python PIL or pillow library.
# If ranger does not share the local filesystem with kitty
# the transfer method is changed to encode the whole image;
# while slower, this allows remote previews,
# for example during an ssh session.
# Tmux is unsupported.
#
# * ueberzug:
# Preview images in full color with the external command "ueberzug".
# Images are shown by using a child window.
# Only for users who run X11 in GNU/Linux.
set preview_images_method kitty
# Delay in seconds before displaying an image with the w3m method.
# Increase it in case of experiencing display corruption.
set w3m_delay 0.02
# Manually adjust the w3mimg offset when using a terminal which needs this
set w3m_offset 0
# Default iTerm2 font size (see: preview_images_method: iterm2)
set iterm2_font_width 8
set iterm2_font_height 11
# Use a unicode "..." character to mark cut-off filenames?
set unicode_ellipsis false
# BIDI support - try to properly display file names in RTL languages (Hebrew, Arabic).
# Requires the python-bidi pip package
set bidi_support false
# Show dotfiles in the bookmark preview box?
set show_hidden_bookmarks true
# Which colorscheme to use? These colorschemes are available by default:
# default, jungle, snow, solarized
set colorscheme default
# Preview files on the rightmost column?
# And collapse (shrink) the last column if there is nothing to preview?
set preview_files true
set preview_directories true
set collapse_preview true
# Wrap long lines in plain text previews?
set wrap_plaintext_previews false
# Save the console history on exit?
set save_console_history true
# Draw the status bar on top of the browser window (default: bottom)
set status_bar_on_top false
# Draw a progress bar in the status bar which displays the average state of all
# currently running tasks which support progress bars?
set draw_progress_bar_in_status_bar true
# Draw borders around columns? (separators, outline, both, or none)
# Separators are vertical lines between columns.
# Outline draws a box around all the columns.
# Both combines the two.
set draw_borders both
# Display the directory name in tabs?
set dirname_in_tabs false
# Enable the mouse support?
set mouse_enabled true
# Display the file size in the main column or status bar?
set display_size_in_main_column true
set display_size_in_status_bar true
# Display the free disk space in the status bar?
set display_free_space_in_status_bar true
# Display files tags in all columns or only in main column?
set display_tags_in_all_columns true
# Set a title for the window? Updates both `WM_NAME` and `WM_ICON_NAME`
set update_title false
# Set the tmux/screen window-name to "ranger"?
set update_tmux_title true
# Shorten the title if it gets long? The number defines how many
# directories are displayed at once, 0 turns off this feature.
set shorten_title 3
# Show hostname in titlebar?
set hostname_in_titlebar true
# Abbreviate $HOME with ~ in the titlebar (first line) of ranger?
set tilde_in_titlebar false
# How many directory-changes or console-commands should be kept in history?
set max_history_size 20
set max_console_history_size 50
# Try to keep so much space between the top/bottom border when scrolling:
set scroll_offset 8
# Flush the input after each key hit? (Noticeable when ranger lags)
set flushinput true
# Padding on the right when there's no preview?
# This allows you to click into the space to run the file.
set padding_right true
# Save bookmarks (used with mX and `X) instantly?
# This helps to synchronize bookmarks between multiple ranger
# instances but leads to *slight* performance loss.
# When false, bookmarks are saved when ranger is exited.
set autosave_bookmarks true
# Save the "`" bookmark to disk. This can be used to switch to the last
# directory by typing "``".
set save_backtick_bookmark true
# You can display the "real" cumulative size of directories by using the
# command :get_cumulative_size or typing "dc". The size is expensive to
# calculate and will not be updated automatically. You can choose
# to update it automatically though by turning on this option:
set autoupdate_cumulative_size false
# Turning this on makes sense for screen readers:
set show_cursor false
# One of: size, natural, basename, atime, ctime, mtime, type, random
set sort natural
# Additional sorting options
set sort_reverse false
set sort_case_insensitive true
set sort_directories_first true
set sort_unicode false
# Enable this if key combinations with the Alt Key don't work for you.
# (Especially on xterm)
set xterm_alt_key false
# Whether to include bookmarks in cd command
set cd_bookmarks true
# Changes case sensitivity for the cd command tab completion
set cd_tab_case sensitive
# Use fuzzy tab completion with the "cd" command. For example,
# ":cd /u/lo/b<tab>" expands to ":cd /usr/local/bin".
set cd_tab_fuzzy false
# Avoid previewing files larger than this size, in bytes. Use a value of 0 to
# disable this feature.
set preview_max_size 0
# The key hint lists up to this size have their sublists expanded.
# Otherwise the submaps are replaced with "...".
set hint_collapse_threshold 10
# Add the highlighted file to the path in the titlebar
set show_selection_in_titlebar true
# The delay that ranger idly waits for user input, in milliseconds, with a
# resolution of 100ms. Lower delay reduces lag between directory updates but
# increases CPU load.
set idle_delay 2000
# When the metadata manager module looks for metadata, should it only look for
# a ".metadata.json" file in the current directory, or do a deep search and
# check all directories above the current one as well?
set metadata_deep_search false
# Clear all existing filters when leaving a directory
set clear_filters_on_dir_change false
# Disable displaying line numbers in main column.
# Possible values: false, absolute, relative.
set line_numbers false
# When line_numbers=relative show the absolute line number in the
# current line.
set relative_current_zero false
# Start line numbers from 1 instead of 0
set one_indexed false
# Save tabs on exit
set save_tabs_on_exit false
# Enable scroll wrapping - moving down while on the last item will wrap around to
# the top and vice versa.
set wrap_scroll false
# Set the global_inode_type_filter to nothing. Possible options: d, f and l for
# directories, files and symlinks respectively.
set global_inode_type_filter
# This setting allows to freeze the list of files to save I/O bandwidth. It
# should be 'false' during start-up, but you can toggle it by pressing F.
set freeze_files false
# Print file sizes in bytes instead of the default human-readable format.
set size_in_bytes false
# Warn at startup if RANGER_LEVEL env var is greater than 0, in other words
# give a warning when you nest ranger in a subshell started by ranger.
# Special value "error" makes the warning more visible.
set nested_ranger_warning true
# ===================================================================
# == Local Options
# ===================================================================
# You can set local options that only affect a single directory.
# Examples:
# setlocal path=~/downloads sort mtime
# ===================================================================
# == Command Aliases in the Console
# ===================================================================
alias e edit
alias q quit
alias q! quit!
alias qa quitall
alias qa! quitall!
alias qall quitall
alias qall! quitall!
alias setl setlocal
alias filter scout -prts
alias find scout -aets
alias mark scout -mr
alias unmark scout -Mr
alias search scout -rs
alias search_inc scout -rts
alias travel scout -aefklst
# ===================================================================
# == Define keys for the browser
# ===================================================================
# Basic
map Q quitall
map q quit
copymap q ZZ ZQ
map R reload_cwd
map F set freeze_files!
map <C-r> reset
map <C-l> redraw_window
map <C-c> abort
map <esc> change_mode normal
map ~ set viewmode!
map i display_file
map <A-j> scroll_preview 1
map <A-k> scroll_preview -1
map ? help