From 7e812c03dde31434f05de16d75520ba4f1e5ee92 Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Fri, 3 Apr 2020 14:25:06 -0500 Subject: [PATCH 01/56] remove cruft fonts breaking st --- .config/fontconfig/fonts.conf | 8 -------- 1 file changed, 8 deletions(-) diff --git a/.config/fontconfig/fonts.conf b/.config/fontconfig/fonts.conf index 8bfaaa2a..dd614184 100755 --- a/.config/fontconfig/fonts.conf +++ b/.config/fontconfig/fonts.conf @@ -5,32 +5,24 @@ serif Source Code Pro - Joy Pixels - Noto Color Emoji sans-serif Source Code Pro - Joy Pixels - Noto Color Emoji sans Source Code Pro - Joy Pixels - Noto Color Emoji monospace Source Code Pro - Joy Pixels - Noto Color Emoji From a6cefe52fc0c725713410dc7f9a98544a929c641 Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Fri, 3 Apr 2020 15:11:31 -0500 Subject: [PATCH 02/56] added .screenlayout/ to dotfiles --- .screenlayout/dual_screens.sh | 2 ++ .screenlayout/dual_screens_nashville.sh | 2 ++ 2 files changed, 4 insertions(+) create mode 100755 .screenlayout/dual_screens.sh create mode 100755 .screenlayout/dual_screens_nashville.sh diff --git a/.screenlayout/dual_screens.sh b/.screenlayout/dual_screens.sh new file mode 100755 index 00000000..ed6133b0 --- /dev/null +++ b/.screenlayout/dual_screens.sh @@ -0,0 +1,2 @@ +#!/bin/sh +xrandr --output eDP-1 --off --output DP-1 --off --output DP-2 --off --output DP-1-1 --primary --mode 1920x1080 --pos 0x0 --rotate normal --output DP-1-2 --mode 1920x1080 --pos 1920x0 --rotate normal --output DP-1-3 --off diff --git a/.screenlayout/dual_screens_nashville.sh b/.screenlayout/dual_screens_nashville.sh new file mode 100755 index 00000000..5058a6c7 --- /dev/null +++ b/.screenlayout/dual_screens_nashville.sh @@ -0,0 +1,2 @@ +#!/bin/sh +xrandr --output eDP-1 --mode 1366x768 --pos 1920x156 --rotate normal --output DP-1 --off --output HDMI-1 --mode 1920x1080 --pos 0x0 --rotate normal --output DP-2 --off --output HDMI-2 --off From b1966bec715a259e584a188c9e6babe3c78a428c Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Fri, 3 Apr 2020 17:23:48 -0500 Subject: [PATCH 03/56] Updated display select to allow you to load screen layout from dmenu --- .config/dunst/dunstrc | 2 +- .local/bin/displayselect | 27 +++++++++++++++++++++------ 2 files changed, 22 insertions(+), 7 deletions(-) diff --git a/.config/dunst/dunstrc b/.config/dunst/dunstrc index abf55860..56cb908b 100644 --- a/.config/dunst/dunstrc +++ b/.config/dunst/dunstrc @@ -1,7 +1,7 @@ [global] monitor = 0 follow = keyboard - geometry = "350x5-0+24" + geometry = "400x5-0+24" indicate_hidden = yes shrink = yes transparency = 20 diff --git a/.local/bin/displayselect b/.local/bin/displayselect index c0e34795..cba424f8 100755 --- a/.local/bin/displayselect +++ b/.local/bin/displayselect @@ -1,4 +1,5 @@ #!/bin/sh +set -e # A UI for detecting and selecting all displays. Probes xrandr for connected # displays and lets user select one to use. User may also select "manual @@ -48,25 +49,39 @@ morescreen() { # If multi-monitor is selected and there are more than two screen multimon() { # Multi-monitor handler. case "$(echo "$screens" | wc -l)" in - 1) xrandr $(echo "$allposs" | grep -v "$screens" | awk '{print "--output", $1, "--off"}' | tr '\n' ' ') ;; - 2) twoscreen ;; - *) morescreen ;; + *) xrandr $(echo "$allposs" | grep -v "$screens" | awk '{print "--output", $1, "--off"}' | tr '\n' ' ') ;; esac ;} +load_screen_layout() { # ~/.screenlayout loader + # Get all screen configurations in ~.screenlayout/ + if [[ $(echo $screen_layouts | wc -l) -eq 2 ]]; then + notify-send --urgency=critical "~/.screenlayout seems to be empty" + else + layout_name=$(echo "$screen_layouts" | dmenu -i -p "Screen layouts:") + chosen_layout=$(find ~/.screenlayout -type f | grep $layout_name) + echo "$chosen_layout" + arandr $chosen_layout 2>/dev/null || notify-send --urgency=critical "Error loading screen layout: ~/.screenlayout/$layout_name" && exit + fi + } + # Get all possible displays allposs=$(xrandr -q | grep "connected") -# Get all connected screens. +# Get all connected screens screens=$(echo "$allposs" | grep " connected" | awk '{print $1}') +# Get all screen layouts +screen_layouts=$(find ~/.screenlayout -type f -exec basename {} \;) + # Get user choice including multi-monitor and manual selection: -chosen=$(printf "%s\\nmulti-monitor\\nmanual selection" "$screens" | dmenu -i -p "Select display arangement:") && +chosen=$(printf "%s\\nlayouts\\nmulti-monitor\\nmanual selection" "$screens" | dmenu -i -p "Select display arangement:") && case "$chosen" in "manual selection") arandr ; exit ;; "multi-monitor") multimon ;; + "layouts") load_screen_layout;; *) xrandr --output "$chosen" --auto --scale 1.0x1.0 $(echo "$allposs" | grep -v "$chosen" | awk '{print "--output", $1, "--off"}' | tr '\n' ' ') ;; esac setbg # Fix background if screen size/arangement has changed. remaps # Re-remap keys if keyboard added (for laptop bases) -pgrep -x dunst >/dev/null && killall dunst && setsid dunst & # Restart dunst to ensure proper location on screen +pgrep -x dunst >/dev/null && killall dunst && setsid dunst & # Restart dunst to ensure proper location on screen \ No newline at end of file From f156cb1e3223607fdc994577fa5075aaf7eab74c Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Fri, 3 Apr 2020 17:43:21 -0500 Subject: [PATCH 04/56] Added new dmenu script and renamed them to be easier to pick out --- .config/i3/config | 2 +- .local/bin/{displayselect => dmenu_displayselect} | 0 .local/bin/{dmenuhandler => dmenu_handler} | 0 .local/bin/{dmenumount => dmenu_mount} | 0 .local/bin/dmenu_openmusic | 9 +++++++++ .local/bin/{dmenupass => dmenu_pass} | 0 .local/bin/{dmenurecord => dmenu_record} | 0 .local/bin/{dmenuumount => dmenu_umount} | 0 .local/bin/{dmenuunicode => dmenu_unicode} | 0 9 files changed, 10 insertions(+), 1 deletion(-) rename .local/bin/{displayselect => dmenu_displayselect} (100%) rename .local/bin/{dmenuhandler => dmenu_handler} (100%) rename .local/bin/{dmenumount => dmenu_mount} (100%) create mode 100755 .local/bin/dmenu_openmusic rename .local/bin/{dmenupass => dmenu_pass} (100%) rename .local/bin/{dmenurecord => dmenu_record} (100%) rename .local/bin/{dmenuumount => dmenu_umount} (100%) rename .local/bin/{dmenuunicode => dmenu_unicode} (100%) diff --git a/.config/i3/config b/.config/i3/config index ffb73d72..5cd3eb55 100644 --- a/.config/i3/config +++ b/.config/i3/config @@ -92,7 +92,7 @@ bindsym $mod+l focus right bindsym $mod+Shift+l move right 30 bindsym $mod+Ctrl+l move workspace to output right # M -bindsym $mod+m exec spotify +bindsym $mod+m exec open_music_source bindsym $mod+Shift+m exec --no-startup-id amixer sset Master toggle # N bindsym $mod+n exec nautilus diff --git a/.local/bin/displayselect b/.local/bin/dmenu_displayselect similarity index 100% rename from .local/bin/displayselect rename to .local/bin/dmenu_displayselect diff --git a/.local/bin/dmenuhandler b/.local/bin/dmenu_handler similarity index 100% rename from .local/bin/dmenuhandler rename to .local/bin/dmenu_handler diff --git a/.local/bin/dmenumount b/.local/bin/dmenu_mount similarity index 100% rename from .local/bin/dmenumount rename to .local/bin/dmenu_mount diff --git a/.local/bin/dmenu_openmusic b/.local/bin/dmenu_openmusic new file mode 100755 index 00000000..0918baec --- /dev/null +++ b/.local/bin/dmenu_openmusic @@ -0,0 +1,9 @@ +#!/bin/sh + +# Allow you to choose which music source you want to launch + +chosen=$(printf "%s\\nGoogle Music\\Spotify| dmenu -i -p "Select music provider:") && +case "$chosen" in + "nGoogle Music") google-chrome-stable https://music.google.com ;; + "Spotify") spotify & ;; +esac \ No newline at end of file diff --git a/.local/bin/dmenupass b/.local/bin/dmenu_pass similarity index 100% rename from .local/bin/dmenupass rename to .local/bin/dmenu_pass diff --git a/.local/bin/dmenurecord b/.local/bin/dmenu_record similarity index 100% rename from .local/bin/dmenurecord rename to .local/bin/dmenu_record diff --git a/.local/bin/dmenuumount b/.local/bin/dmenu_umount similarity index 100% rename from .local/bin/dmenuumount rename to .local/bin/dmenu_umount diff --git a/.local/bin/dmenuunicode b/.local/bin/dmenu_unicode similarity index 100% rename from .local/bin/dmenuunicode rename to .local/bin/dmenu_unicode From b48eb2a78786d283aeba6ee793642b099c6f2940 Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Fri, 3 Apr 2020 17:44:52 -0500 Subject: [PATCH 05/56] Updated references to renames scripts --- .config/i3/config | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/.config/i3/config b/.config/i3/config index 5cd3eb55..b19513ee 100644 --- a/.config/i3/config +++ b/.config/i3/config @@ -17,7 +17,7 @@ gaps outer $outer_gap set $term --no-startup-id $TERMINAL set $mod Mod4 set $netrefresh --no-startup-id sudo -A systemctl restart NetworkManager -set $stoprec --no-startup-id dmenurecord kill +set $stoprec --no-startup-id dmenu_record kill # #---Gaps---# # for_window [class="^.*"] border pixel 2 @@ -46,7 +46,7 @@ bindsym $mod+Shift+Return exec --no-startup-id samedir bindsym $mod+space focus mode_toggle bindsym $mod+Shift+space floating toggle bindsym $mod+Escape workspace prev -bindsym $mod+grave exec --no-startup-id dmenuunicode +bindsym $mod+grave exec --no-startup-id dmenu_unicode bindsym $mod+Insert exec --no-startup-id showclip # #---Power Bindings---# # @@ -202,8 +202,8 @@ for_window [title="Default - Wine desktop"] floating enable bindsym $mod+F2 restart bindsym $mod+F3 exec --no-startup-id displayselect bindsym $mod+F5 exec --no-startup-id $netrefresh -bindsym $mod+F9 exec --no-startup-id dmenumount -bindsym $mod+F10 exec --no-startup-id dmenuumount +bindsym $mod+F9 exec --no-startup-id dmenu_mount +bindsym $mod+F10 exec --no-startup-id dmenu_umount # #---Arrow Keys---# # bindsym $mod+Left focus left @@ -222,7 +222,7 @@ bindsym $mod+Ctrl+Right move workspace to output right # #---Screenshots/Recording---# # bindsym Print exec --no-startup-id maim pic-full-"$(date '+%y%m%d-%H%M-%S').png" bindsym Shift+Print exec --no-startup-id maimpick -bindsym $mod+Print exec --no-startup-id dmenurecord +bindsym $mod+Print exec --no-startup-id dmenu_record bindsym $mod+Scroll_Lock exec --no-startup-id "killall screenkey || screenkey" bindsym $mod+Delete exec $stoprec From fe7afd7cbf011a1b5cd239d747a1ca7182343838 Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Fri, 3 Apr 2020 18:12:14 -0500 Subject: [PATCH 06/56] Added file to reload ~/.local/bin to $PATH --- .local/bin/add_local_bin_to_path | 6 ++++++ 1 file changed, 6 insertions(+) create mode 100755 .local/bin/add_local_bin_to_path diff --git a/.local/bin/add_local_bin_to_path b/.local/bin/add_local_bin_to_path new file mode 100755 index 00000000..a18d2351 --- /dev/null +++ b/.local/bin/add_local_bin_to_path @@ -0,0 +1,6 @@ +#!/bin/sh + +export PATH="$PATH:$(du "$HOME/.local/bin/" | cut -f2 | tr '\n' ':' | sed 's/:*$//')" + +notify-send "Added ~/.local/bin/ to $PATH" + From 641c3b8c68a58ee11cb8049f88a128d8af5d9d75 Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Fri, 3 Apr 2020 21:11:20 -0500 Subject: [PATCH 07/56] Added some things to bin and made it easier to select music source, reset $PATH and added ~/.local/bin shortcut --- .config/directories | 2 +- .config/i3/config | 14 ++++++-------- .local/bin/add_local_bin_to_path | 4 ++-- .local/bin/dmenu_openmusic | 12 +++++++----- .local/bin/refbar | 5 ----- 5 files changed, 16 insertions(+), 21 deletions(-) delete mode 100755 .local/bin/refbar diff --git a/.config/directories b/.config/directories index ab756235..f4cb1212 100644 --- a/.config/directories +++ b/.config/directories @@ -3,7 +3,7 @@ cf ~/.config d ~/downloads gh ~/github h ~/ -l ~/.local/bin +lb ~/.local/bin mn /mnt psc ~/.local/bin/polybar_scripts pp ~/pictures diff --git a/.config/i3/config b/.config/i3/config index b19513ee..3012d54f 100644 --- a/.config/i3/config +++ b/.config/i3/config @@ -35,9 +35,7 @@ for_window [instance="dropdown_dropdowncalc"] resize set 800 300 for_window [instance="dropdown_tmuxdd"] border pixel 3 for_window [instance="dropdown_dropdowncalc"] border pixel 2 for_window [instance="dropdown_*"] move position center -for_window [class="Spotify"] move to workspace $ws10 for_window [class="discord"] move to workspace $ws10 -for_window [class="Slack"] move to workspace $ws10 for_window [class="Pulse"] move to workspace $ws9 # #---Basic Bindings---# # @@ -57,7 +55,7 @@ bindsym $mod+Ctrl+x exec --no-startup-id prompt "Shutdown computer?" "$shutdown # #---Letter Key Bindings---# # # A bindsym $mod+a exec --no-startup-id ddspawn dropdowncalc -f mono:pixelsize=24 -bindsym $mod+shift +a exec $term -e alsamixer +bindsym $mod+shift+a exec $term -e alsamixer # B bindsym $mod+b exec --no-startup-id polybar_msg cmd toggle bindsym $mod+Shift+b floating toggle; sticky toggle; exec --no-startup-id hover left @@ -92,7 +90,7 @@ bindsym $mod+l focus right bindsym $mod+Shift+l move right 30 bindsym $mod+Ctrl+l move workspace to output right # M -bindsym $mod+m exec open_music_source +bindsym $mod+m exec dmenu_openmusic bindsym $mod+Shift+m exec --no-startup-id amixer sset Master toggle # N bindsym $mod+n exec nautilus @@ -152,10 +150,10 @@ bindsym $mod+Shift+slash exec --no-startup-id xkill bindsym $mod+backslash workspace back_and_forth # #---Volume Bindings---# # -bindsym $mod+plus exec --no-startup-id amixer sset Master 5%+ && pkill -RTMIN+10 i3blocks -bindsym $mod+Shift+plus exec --no-startup-id amixer sset Master 15%+ && pkill -RTMIN+10 i3blocks -bindsym $mod+minus exec --no-startup-id amixer sset Master 5%- && pkill -RTMIN+10 i3blocks -bindsym $mod+Shift+minus exec --no-startup-id amixer sset Master 15%- && pkill -RTMIN+10 i3blocks +bindsym $mod+plus exec --no-startup-id amixer sset Master 5%+ +bindsym $mod+Shift+plus exec --no-startup-id amixer sset Master 15%+ +bindsym $mod+minus exec --no-startup-id amixer sset Master 5%- +bindsym $mod+Shift+minus exec --no-startup-id amixer sset Master 15%- set $ws1 "1" set $ws2 "2" diff --git a/.local/bin/add_local_bin_to_path b/.local/bin/add_local_bin_to_path index a18d2351..5ccf7184 100755 --- a/.local/bin/add_local_bin_to_path +++ b/.local/bin/add_local_bin_to_path @@ -1,6 +1,6 @@ #!/bin/sh -export PATH="$PATH:$(du "$HOME/.local/bin/" | cut -f2 | tr '\n' ':' | sed 's/:*$//')" +. ~/.profile -notify-send "Added ~/.local/bin/ to $PATH" +notify-send "Added ~/.local/bin/ to \$PATH" diff --git a/.local/bin/dmenu_openmusic b/.local/bin/dmenu_openmusic index 0918baec..dccde07b 100755 --- a/.local/bin/dmenu_openmusic +++ b/.local/bin/dmenu_openmusic @@ -2,8 +2,10 @@ # Allow you to choose which music source you want to launch -chosen=$(printf "%s\\nGoogle Music\\Spotify| dmenu -i -p "Select music provider:") && -case "$chosen" in - "nGoogle Music") google-chrome-stable https://music.google.com ;; - "Spotify") spotify & ;; -esac \ No newline at end of file +music_service=$(printf "Google Music\nSpotify" | dmenu -i -p "Select music service: ") +case "$music_service" in + "Google Music") notify-send "Opened $music_service" && google-chrome-stable https://music.google.com 2>/dev/null & ;; + "Spotify") notify-send "Opened $music_service" && firefox https://open.spotify.com/browse/ 2>/dev/null & ;; +esac + + diff --git a/.local/bin/refbar b/.local/bin/refbar deleted file mode 100755 index 78b50188..00000000 --- a/.local/bin/refbar +++ /dev/null @@ -1,5 +0,0 @@ -#!/bin/sh - -# Refresh the dwmbar. -# Send SIGTRAP signal to dwmbar script, which will handle it with a trap. -pkill -SIGTRAP dwmbar From 5302db26a79a9f2d1cbf8acc1b0ef0f8c03925dd Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Sat, 4 Apr 2020 02:19:27 -0500 Subject: [PATCH 08/56] Fixed polybar toggle bug and switched back to chrome for both google music and spotify --- .config/i3/config | 2 +- .local/bin/dmenu_openmusic | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.config/i3/config b/.config/i3/config index 3012d54f..7460a6d4 100644 --- a/.config/i3/config +++ b/.config/i3/config @@ -57,7 +57,7 @@ bindsym $mod+Ctrl+x exec --no-startup-id prompt "Shutdown computer?" "$shutdown bindsym $mod+a exec --no-startup-id ddspawn dropdowncalc -f mono:pixelsize=24 bindsym $mod+shift+a exec $term -e alsamixer # B -bindsym $mod+b exec --no-startup-id polybar_msg cmd toggle +bindsym $mod+b exec --no-startup-id polybar-msg cmd toggle bindsym $mod+Shift+b floating toggle; sticky toggle; exec --no-startup-id hover left # C bindsym $mod+c exec code diff --git a/.local/bin/dmenu_openmusic b/.local/bin/dmenu_openmusic index dccde07b..ef221f18 100755 --- a/.local/bin/dmenu_openmusic +++ b/.local/bin/dmenu_openmusic @@ -4,8 +4,8 @@ music_service=$(printf "Google Music\nSpotify" | dmenu -i -p "Select music service: ") case "$music_service" in - "Google Music") notify-send "Opened $music_service" && google-chrome-stable https://music.google.com 2>/dev/null & ;; - "Spotify") notify-send "Opened $music_service" && firefox https://open.spotify.com/browse/ 2>/dev/null & ;; + "Google Music") notify-send "Opened $music_service" && google-chrome-stable https://play.google.com/music/listen\#/artists 2>/dev/null & ;; + "Spotify") notify-send "Opened $music_service" && google-chrome-stable https://open.spotify.com/browse/ 2>/dev/null & ;; esac From 85db095156375f55c696185e54bf258ac532c4ba Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Sat, 4 Apr 2020 02:22:27 -0500 Subject: [PATCH 09/56] point to correct dmenu script --- .config/i3/config | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.config/i3/config b/.config/i3/config index 7460a6d4..801bd55a 100644 --- a/.config/i3/config +++ b/.config/i3/config @@ -198,7 +198,7 @@ for_window [title="Default - Wine desktop"] floating enable # #---Function Buttons---# # bindsym $mod+F2 restart -bindsym $mod+F3 exec --no-startup-id displayselect +bindsym $mod+F3 exec --no-startup-id dmenu_displayselect bindsym $mod+F5 exec --no-startup-id $netrefresh bindsym $mod+F9 exec --no-startup-id dmenu_mount bindsym $mod+F10 exec --no-startup-id dmenu_umount From 7e0a0e63a74e2281a7c4b25669d6f518848dddfb Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Sat, 4 Apr 2020 16:33:57 -0500 Subject: [PATCH 10/56] added lf icons --- .xprofile | 62 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) diff --git a/.xprofile b/.xprofile index 0e97a743..1bb686b8 100644 --- a/.xprofile +++ b/.xprofile @@ -12,3 +12,65 @@ xcompmgr & # xcompmgr for transparency dunst & # dunst for notifications xset r rate 300 50 & # Speed xrate up unclutter & # Remove mouse when idle + +# lf icons +export LF_ICONS="di=📁:\ +fi=📃:\ +tw=🤝:\ +ow=📂:\ +ln=⛓:\ +or=❌:\ +ex=🎯:\ +*.txt=✍:\ +*.mom=✍:\ +*.me=✍:\ +*.ms=✍:\ +*.png=🖼:\ +*.ico=🖼:\ +*.jpg=📸:\ +*.jpeg=📸:\ +*.gif=🖼:\ +*.svg=🗺:\ +*.xcf=🖌:\ +*.html=🌎:\ +*.xml=📰:\ +*.gpg=🔒:\ +*.css=🎨:\ +*.pdf=📚:\ +*.djvu=📚:\ +*.epub=📚:\ +*.csv=📓:\ +*.xlsx=📓:\ +*.tex=📜:\ +*.md=📘:\ +*.r=📊:\ +*.R=📊:\ +*.rmd=📊:\ +*.Rmd=📊:\ +*.mp3=🎵:\ +*.opus=🎵:\ +*.ogg=🎵:\ +*.m4a=🎵:\ +*.flac=🎼:\ +*.mkv=🎥:\ +*.mp4=🎥:\ +*.webm=🎥:\ +*.mpeg=🎥:\ +*.zip=📦:\ +*.rar=📦:\ +*.7z=📦:\ +*.tar.gz=📦:\ +*.z64=🎮:\ +*.v64=🎮:\ +*.n64=🎮:\ +*.1=ℹ:\ +*.nfo=ℹ:\ +*.info=ℹ:\ +*.log=📙:\ +*.iso=📀:\ +*.img=📀:\ +*.bib=🎓:\ +*.ged=👪:\ +*.part=💔:\ +*.torrent=🔽:\ +" From 64e2f0a5a0550c4373a20d8e633f96b234734e7a Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Sat, 4 Apr 2020 16:37:24 -0500 Subject: [PATCH 11/56] dont use mpd --- .local/bin/mpd-module-update | 7 ------- 1 file changed, 7 deletions(-) delete mode 100755 .local/bin/mpd-module-update diff --git a/.local/bin/mpd-module-update b/.local/bin/mpd-module-update deleted file mode 100755 index da8d9fc8..00000000 --- a/.local/bin/mpd-module-update +++ /dev/null @@ -1,7 +0,0 @@ -#!/bin/sh - -# This loop will update the mpd statusbar module whenever a command changes the -# music player's status. mpd must be running on X's start for this to work. -while : ; do - mpc idle >/dev/null && pkill -RTMIN+11 "${STATUSBAR:?}" || break -done From 2d325fcb44af174ca2a73c4ddf1c7ec6d299f9ab Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Sat, 4 Apr 2020 16:37:42 -0500 Subject: [PATCH 12/56] dont use mpv --- .local/bin/pauseallmpv | 10 ---------- 1 file changed, 10 deletions(-) delete mode 100755 .local/bin/pauseallmpv diff --git a/.local/bin/pauseallmpv b/.local/bin/pauseallmpv deleted file mode 100755 index 85a7032c..00000000 --- a/.local/bin/pauseallmpv +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh - -# You might notice all mpv commands are aliased to have this input-ipc-server -# thing. That's just for this particular command, which allows us to pause -# every single one of them with one command! This is bound to super + shift + p -# (with other things) by default and is used in some other places. - -for i in $(ls /tmp/mpvsoc*); do - echo '{ "command": ["set_property", "pause", true] }' | socat - $i; -done From 83d12e466df154db621e358e6d1d5192b3755bb6 Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Sat, 4 Apr 2020 16:39:09 -0500 Subject: [PATCH 13/56] dont need welcome message --- .local/bin/i3cmds/toggle-welcome | 10 ---------- 1 file changed, 10 deletions(-) delete mode 100755 .local/bin/i3cmds/toggle-welcome diff --git a/.local/bin/i3cmds/toggle-welcome b/.local/bin/i3cmds/toggle-welcome deleted file mode 100755 index 715db09e..00000000 --- a/.local/bin/i3cmds/toggle-welcome +++ /dev/null @@ -1,10 +0,0 @@ -#!/bin/sh - -# Toggles the LARBS welcome message. - -PIC="$HOME/.local/share/larbs/larbs.png" - -grep LARBSWELCOME "$HOME/.xprofile" && - ( sed -i "/LARBSWELCOME/d" ~/.xprofile && notify-send -i "$PIC" "LARBS welcome message" "Welcome message disabled. Press Super+Shift+F1 again to reverse." ) || - ( echo "notify-send -i \"$PIC\" \"Welcome to LARBS\" \"Press super+F1 for the help menu.\" # LARBSWELCOME" >> ~/.xprofile && - notify-send -i "$PIC" "LARBS welcome message" "Welcome message re-enabled." ) From d86cd73be9bcde5e2d0f745acfcce89cd18d0160 Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Sat, 4 Apr 2020 16:50:51 -0500 Subject: [PATCH 14/56] change from ranger to lf --- .profile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.profile b/.profile index 87ca0a23..11dd9c5a 100644 --- a/.profile +++ b/.profile @@ -8,7 +8,7 @@ export EDITOR="nvim" export TERMINAL="st" export BROWSER="google-chrome-stable" export READER="zathura" -export FILE="ranger" +export FILE="lf" export STATUSBAR="polybar" # ~/ Clean-up: From 0de55bfd0677b17c9f15c30838d77bb5a112a693 Mon Sep 17 00:00:00 2001 From: Vlad Doster Date: Sat, 4 Apr 2020 17:14:12 -0500 Subject: [PATCH 15/56] Moved from ranger to lf and remove lf configs --- .config/lf/lfrc | 74 --- .config/lf/scope | 58 --- .config/ranger/ranger/commands.py | 208 ++++++++ .config/ranger/ranger/luke_ranger_readme.md | 85 ++++ .config/ranger/ranger/rc.conf | 508 ++++++++++++++++++++ .config/ranger/ranger/rifle.conf | 236 +++++++++ .config/ranger/ranger/scope.sh | 120 +++++ .config/ranger/ranger/shortcuts.conf | 0 .profile | 2 +- 9 files changed, 1158 insertions(+), 133 deletions(-) delete mode 100644 .config/lf/lfrc delete mode 100644 .config/lf/scope create mode 100755 .config/ranger/ranger/commands.py create mode 100644 .config/ranger/ranger/luke_ranger_readme.md create mode 100644 .config/ranger/ranger/rc.conf create mode 100644 .config/ranger/ranger/rifle.conf create mode 100755 .config/ranger/ranger/scope.sh create mode 100644 .config/ranger/ranger/shortcuts.conf diff --git a/.config/lf/lfrc b/.config/lf/lfrc deleted file mode 100644 index 8f892363..00000000 --- a/.config/lf/lfrc +++ /dev/null @@ -1,74 +0,0 @@ -# lf settings - -# Basic vars -set shell sh -set previewer ~/.config/lf/scope -set shellopts '-eu' -set ifs "\n" -set scrolloff 10 -set color256 -set icons # Enable icons. Requires nerd fonts and LF_ICONS variable. - -# cmds/functions -cmd open ${{ - case $(file --mime-type $f -b) in - text/troff) man ./ $f;; - text/*) $EDITOR $fx;; - image/x-xcf|image/svg+xml) setsid gimp $f >/dev/null 2>&1 & ;; - image/*) rotdir $f | setsid sxiv -aio 2>/dev/null | lf-select & ;; - audio/*) mpv --input-ipc-server=/tmp/mpvsoc$(date +%%s) $f ;; - video/*) setsid mpv --input-ipc-server=/tmp/mpvsoc$(date +%%s) $f -quiet >/dev/null 2>&1 & ;; - application/pdf) setsid zathura $fx >/dev/null 2>&1 & ;; - *) for f in $fx; do setsid $OPENER $f >/dev/null 2>&1 & done;; - esac -}} - -cmd rename %[ -e $1 ] && printf "file exists" || mv $f $1 - -cmd delete ${{ - set -f - printf "%s\n\t" "$fx" - printf "delete?[y/N]" - read ans - [ $ans = "y" ] && rm -rf $fx -}} - -cmd moveto ${{ - set -f - clear; echo "Move to where?" - dest="$(cut -d' ' -f2- ~/.config/directories | fzf)" && - eval mv -iv $fx $dest && - notify-send "🚚 File(s) moved." "File(s) moved to $dest." -}} - -cmd copyto ${{ - set -f - clear; echo "Copy to where?" - dest="$(cut -d' ' -f2- ~/.config/directories | fzf)" && - eval cp -ivr $fx $dest && - notify-send "📋 File(s) copied." "File(s) copies to $dest." -}} - -cmd bulkrename ${{ - vidir -}} - -# Bindings -map c $lf -remote "send $id cd $(cut -d' ' -f2 ~/.config/directories | fzf)" -map $lf -remote "send $id select '$(fzf)'" -map J $lf -remote "send $id cd $(cut -d' ' -f2 ~/.config/directories | fzf)" -map gh -map g top -map D delete -map C copyto -map M moveto -map a push %mkdir -map r push :rename -map R $lf -remote "send $id push :rename$f" -map b bulkrename -map reload -map shell -map x $$f -map X !$f -map o &mimeopen "$f" -map O $mimeopen --ask "$f" diff --git a/.config/lf/scope b/.config/lf/scope deleted file mode 100644 index 45f9f338..00000000 --- a/.config/lf/scope +++ /dev/null @@ -1,58 +0,0 @@ -#!/bin/bash - -set -C -f -u -#IFS=$'\n' -IFS="$(printf '%b_' '\n')"; IFS="${IFS%_}" - -# ANSI color codes are supported. -# STDIN is disabled, so interactive scripts won't work properly - -# This script is considered a configuration file and must be updated manually. - -# Meanings of exit codes: -# 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}" )" -handle_mime "${MIMETYPE}" -exit 1 diff --git a/.config/ranger/ranger/commands.py b/.config/ranger/ranger/commands.py new file mode 100755 index 00000000..71fd2a24 --- /dev/null +++ b/.config/ranger/ranger/commands.py @@ -0,0 +1,208 @@ +# This is a sample commands.py. You can add your own commands here. +# +# Please refer to commands_full.py for all the default commands and a complete +# documentation. Do NOT add them all here, or you may end up with defunct +# commands when upgrading ranger. + +# You always need to import ranger.api.commands here to get the Command class: +from ranger.api.commands import * +from ranger.core.loader import CommandLoader + +# A simple command for demonstration purposes follows. +#------------------------------------------------------------------------------ + +# You can import any python module as needed. +import os + +# Any class that is a subclass of "Command" will be integrated into ranger as a +# command. Try typing ":my_edit" in ranger! +class my_edit(Command): + # The so-called doc-string of the class will be visible in the built-in + # help that is accessible by typing "?c" inside ranger. + """:my_edit + + A sample command for demonstration purposes that opens a file in an editor. + """ + + # The execute method is called when you run this command in ranger. + def execute(self): + # self.arg(1) is the first (space-separated) argument to the function. + # This way you can write ":my_edit somefilename". + if self.arg(1): + # self.rest(1) contains self.arg(1) and everything that follows + target_filename = self.rest(1) + else: + # self.fm is a ranger.core.filemanager.FileManager object and gives + # you access to internals of ranger. + # self.fm.thisfile is a ranger.container.file.File object and is a + # reference to the currently selected file. + target_filename = self.fm.thisfile.path + + # This is a generic function to print text in ranger. + self.fm.notify("Let's edit the file " + target_filename + "!") + + # Using bad=True in fm.notify allows you to print error messages: + if not os.path.exists(target_filename): + self.fm.notify("The given file does not exist!", bad=True) + return + + # This executes a function from ranger.core.acitons, a module with a + # variety of subroutines that can help you construct commands. + # Check out the source, or run "pydoc ranger.core.actions" for a list. + self.fm.edit_file(target_filename) + + # The tab method is called when you press tab, and should return a list of + # suggestions that the user will tab through. + def tab(self): + # This is a generic tab-completion function that iterates through the + # content of the current directory. + return self._tab_directory_content() + + +# https://github.com/ranger/ranger/wiki/Integrating-File-Search-with-fzf +# Now, simply bind this function to a key, by adding this to your ~/.config/ranger/rc.conf: map fzf_select +class fzf_select(Command): + """ + :fzf_select + + Find a file using fzf. + + With a prefix argument select only directories. + + See: https://github.com/junegunn/fzf + """ + def execute(self): + import subprocess + if self.quantifier: + # match only directories + command="find -L . \( -path '*/\.*' -o -fstype 'dev' -o -fstype 'proc' \) -prune \ + -o -type d -print 2> /dev/null | sed 1d | cut -b3- | fzf +m" + else: + # match files and directories + command="find -L . \( -path '*/\.*' -o -fstype 'dev' -o -fstype 'proc' \) -prune \ + -o -print 2> /dev/null | sed 1d | cut -b3- | fzf +m" + fzf = self.fm.execute_command(command, stdout=subprocess.PIPE) + stdout, stderr = fzf.communicate() + if fzf.returncode == 0: + fzf_file = os.path.abspath(stdout.decode('utf-8').rstrip('\n')) + if os.path.isdir(fzf_file): + self.fm.cd(fzf_file) + else: + self.fm.select_file(fzf_file) + + +# fzf_locate +class fzf_locate(Command): + """ + :fzf_locate + + Find a file using fzf. + + With a prefix argument select only directories. + + See: https://github.com/junegunn/fzf + """ + def execute(self): + import subprocess + if self.quantifier: + command="locate home media | fzf -e -i" + else: + command="locate home media | fzf -e -i" + fzf = self.fm.execute_command(command, stdout=subprocess.PIPE) + stdout, stderr = fzf.communicate() + if fzf.returncode == 0: + fzf_file = os.path.abspath(stdout.decode('utf-8').rstrip('\n')) + if os.path.isdir(fzf_file): + self.fm.cd(fzf_file) + else: + self.fm.select_file(fzf_file) + + +class fzf_bring(Command): + """ + :fzf_bring + + Find a file using fzf and bring it to the current directory. + + See: https://github.com/junegunn/fzf + """ + def execute(self): + import subprocess + import shutil + if self.quantifier: + # match only directories + command="find -L . \( -path '*/\.*' -o -fstype 'dev' -o -fstype 'proc' \) -prune \ + -o -type d -print 2> /dev/null | sed 1d | cut -b3- | fzf +m" + else: + # match files and directories + command="find -L . \( -path '*/\.*' -o -fstype 'dev' -o -fstype 'proc' \) -prune \ + -o -print 2> /dev/null | sed 1d | cut -b3- | fzf +m" + fzf = self.fm.execute_command(command, stdout=subprocess.PIPE) + stdout, stderr = fzf.communicate() + if fzf.returncode == 0: + fzf_file = os.path.abspath(stdout.decode('utf-8').rstrip('\n')) + shutil.move(fzf_file, self.fm.thisdir.path) + + +class compress(Command): + def execute(self): + """ Compress marked files to current directory """ + cwd = self.fm.thisdir + marked_files = cwd.get_selection() + + if not marked_files: + return + + def refresh(_): + cwd = self.fm.get_directory(original_path) + cwd.load_content() + + original_path = cwd.path + parts = self.line.split() + au_flags = parts[1:] + + descr = "compressing files in: " + os.path.basename(parts[1]) + obj = CommandLoader(args=['apack'] + au_flags + \ + [os.path.relpath(f.path, cwd.path) for f in marked_files], descr=descr) + + obj.signal_bind('after', refresh) + self.fm.loader.add(obj) + + def tab(self): + """ Complete with current folder name """ + + extension = ['.zip', '.tar.gz', '.rar', '.7z'] + return ['compress ' + os.path.basename(self.fm.thisdir.path) + ext for ext in extension] + + +class extracthere(Command): + def execute(self): + """ Extract copied files to current directory """ + copied_files = tuple(self.fm.copy_buffer) + + if not copied_files: + return + + def refresh(_): + cwd = self.fm.get_directory(original_path) + cwd.load_content() + + one_file = copied_files[0] + cwd = self.fm.thisdir + original_path = cwd.path + au_flags = ['-X', cwd.path] + au_flags += self.line.split()[1:] + au_flags += ['-e'] + + self.fm.copy_buffer.clear() + self.fm.cut_buffer = False + if len(copied_files) == 1: + descr = "extracting: " + os.path.basename(one_file.path) + else: + descr = "extracting files from: " + os.path.basename(one_file.dirname) + obj = CommandLoader(args=['aunpack'] + au_flags \ + + [f.path for f in copied_files], descr=descr) + + obj.signal_bind('after', refresh) + self.fm.loader.add(obj) + diff --git a/.config/ranger/ranger/luke_ranger_readme.md b/.config/ranger/ranger/luke_ranger_readme.md new file mode 100644 index 00000000..51c5dd10 --- /dev/null +++ b/.config/ranger/ranger/luke_ranger_readme.md @@ -0,0 +1,85 @@ +# Luke's ranger setup + +## Basic Ranger shortcuts + +These are the basic key binds in ranger, even outside of my configs. Note that they are mostly vim-based. + ++ h/j/k/l -- Move left/down/up/right (where left moves up in the directory structure, right moves into a folder) ++ Space -- select/highlight file ++ dd -- cut selected files ++ yy -- copy/yank selected files ++ pp -- paste/move cut/copied files ++ / -- search, when (n/N) next/previos result ++ zh or CTRL-h -- show hidden files ++ Renaming files: + + cw -- rename file from scratch + + A -- rename file adding to the end + + aa -- rename file appending before the extension + + I -- rename file adding at the beginning + +## Shortcuts + +As I say in the main readme, there are shortcut commands generated for ranger +based on what bookmarked directories and files you give it. For directory +shortcuts, here are the "verbs": + ++ g -- "go or cd" ++ t -- "new tab" ++ m -- "move file" ++ Y -- "yank or copy file" + +These "verbs" take "nouns" or "arguments," like these: + ++ d -- "~/Documents" ++ D -- "~/Downloads" ++ cf -- "~/.config" ++ And many others, including those you add to `~/.bmdirs`. + +Press any "verb" followed by any "argument" to perform a folder operation. "gd" will cd to ~/Documents, for example. "mD" will move the selected file(s) to ~/Downloads. "tcf" will create a new tab in ~/.config, etc. etc. + +## Many little additions! + ++ Basic additions: + + V -- Make a new file and edit it in vim + + cW -- rename *all* selected files, editing in your text editor + + mkd -- Make a directory/folder + + sc -- Makes a link/shortcut (ln -sT) + + D -- delete selected file + + X -- Extract a zip/rar/tar.gz, whatever. Runs a script that picks the right command for the right archive. + + Z -- zips a folder up into a .tar.gz archive. + + CTRL-f -- Fuzzy find a file + + CTRL-l -- Fuzzy locate a file ++ Document manipulation: + + p1s -- print this file on the default printer, one-sided (lpr) + + p2s -- print this file on the default printer, double-sided (lpr) + + MP -- convert to a .pdf with pandoc (I use this to convert markdown, etc.) + + MX -- compile selected document in XeLaTeX + + ML -- compile selected document in LaTeX + + TC -- clear all non-visible TeX build files in this directory + + Txa -- copy article template to new file + + Txs -- copy slideshow/beamer template to new file + + Txh -- copy handout template to new file ++ Image commands: + + bg -- (for i3 users) makes an image your background (assuming i3 is looking at ~/.config/wall.png for your background) + + bw -- runs Pywal on the selected image, making it your background and generating a color scheme based off of it. + + C -- rotates an image (requires imagemagick) + + F -- flips an image (requires imagemagick) + + TR -- add transparency to image file ++ mpd/mpc shortcuts + + MS -- Start mpd + + MK -- kill mpd + + MN -- Start playing selected song/folder now + + Ma -- Enqueue selected song/folder + + Mp -- Pause + + Mn -- Next track + + Mb -- Previous track + + Mo -- Restart track ++ Audio tagging with eye3D: + + Ta -- change artist name + + TA -- change album name + + Tb -- change album artist + + Tt -- change title + + Tn -- change track number ++ Downloading: + + ytv -- Download online video (paste in url) (requires youtube-dl) + + yta -- Download audio of online video (paste in url) (requires youtube-dl) diff --git a/.config/ranger/ranger/rc.conf b/.config/ranger/ranger/rc.conf new file mode 100644 index 00000000..89b4b8c2 --- /dev/null +++ b/.config/ranger/ranger/rc.conf @@ -0,0 +1,508 @@ +###SETTINGS### + +set column_ratios 1,3,4 +#set hidden_filter ^\.|\.(?:pyc|pyo|bak|swp)$|^lost\+found$|^__(py)?cache__$ +set hidden_filter ^\.|\.(?:pyc|vrb|pyo|lof|bak|swp|aux|log|nav|out|snm|toc|bcf|run\.xml|synctex\.gz|blg|bbl)$|^lost\+found$|^__(py)?cache__$ +set show_hidden false +set confirm_on_delete multiple +set preview_script ~/.config/ranger/scope.sh +set use_preview_script true +set automatically_count_files true +set open_all_images true +set vcs_aware false +set vcs_backend_git enabled +set vcs_backend_hg disabled +set vcs_backend_bzr disabled +set preview_images true +set preview_images_method ueberzug +set unicode_ellipsis false +set show_hidden_bookmarks false +set colorscheme default +set preview_files true +set preview_directories true +set collapse_preview true +set save_console_history false +set status_bar_on_top false +set draw_progress_bar_in_status_bar true +set draw_borders true +set dirname_in_tabs true +set mouse_enabled true +set display_size_in_main_column true +set display_size_in_status_bar true +set display_tags_in_all_columns true +set update_title false +set update_tmux_title true +set shorten_title 3 +set tilde_in_titlebar true +set max_history_size 20 +set max_console_history_size 50 +set scroll_offset 8 +set flushinput true +set padding_right true +set autosave_bookmarks false +set autoupdate_cumulative_size false +set show_cursor false +set sort natural +set sort_reverse false +set sort_case_insensitive true +set sort_directories_first true +set sort_unicode false +set xterm_alt_key false +set cd_bookmarks false +set preview_max_size 0 +set show_selection_in_titlebar true +set idle_delay 2000 +set metadata_deep_search false + +###ALIASES### +alias e edit +alias q quit +alias q! quitall +alias qa quitall +alias qall quitall +alias setl setlocal + +alias filter scout -prt +alias find scout -aeit +alias mark scout -mr +alias unmark scout -Mr +alias search scout -rs +alias search_inc scout -rts +alias travel scout -aefiklst + +###BASIC KEYS### + +#BASIC +map Q quit! +map q quit +copymap q ZZ ZQ + +#map R reload_cwd +map reset +#map redraw_window +map abort +map change_mode normal + +map i display_file +map ? help +#map W display_log +map w taskview_open +map S shell $SHELL + +map : console +map ; console +map ! console shell%space +map @ console -p6 shell %s +map # console shell -p%space +#map s console shell%space +map r chain draw_possible_programs; console open_with%%space +map f console find%space +map cd console cd%space + +# Change the line mode +#map Mf linemode filename +#map Mi linemode fileinfo +#map Mp linemode permissions +#map Mt linemode metatitle + +#moc +#map Mc shell mocp -c +#map Ma shell mocp -a %s +#map Ms shell mocp -p +#map MS shell mocp -S +#map Mp shell mocp -G +#map Mn shell mocp -f +#map Mb shell mocp -r +#map MN shell mocp -s && mocp -c && mocp -a %s && mocp -p +#map Mo shell mocp -j 0%% +#map MK shell killall mocp + +# Tagging / Marking +map at tag_toggle +map ut tag_remove +map " tag_toggle tag=%any +map mark_files toggle=True +map va mark_files all=True toggle=True +map uv mark_files all=True val=False +map vs toggle_visual_mode +map uV toggle_visual_mode reverse=True + +# For the nostalgics: Midnight Commander bindings +map help +map display_file +map edit +map copy +map console shell echo "require(rmarkdown); render_site()" | R --vanilla +map cut +map console mkdir%space +map console delete +map exit + +# In case you work on a keyboard with dvorak layout +map move up=1 +map move down=1 +map move left=1 +map move right=1 +map move to=0 +map move to=-1 +map move down=1 pages=True +map move up=1 pages=True +map move right=1 +map console delete +map console touch%space + +# VIM-like +copymap k +copymap j +copymap h +copymap l +copymap gg +copymap G +copymap +copymap + +map J move down=0.5 pages=True +map K move up=0.5 pages=True +copymap J +copymap K + +# Jumping around +map H history_go -1 +map L history_go 1 +map ] move_parent 1 +map [ move_parent -1 +map } traverse + +#DEFAULT MOVEMENT +map ge cd /etc +map gu cd /usr +#map gl cd -r . +map gL cd -r %f +#map gv cd /var +map gM cd /mnt +map gr cd / +map gR eval fm.cd(ranger.RANGERDIR) +map g? cd /usr/share/doc/ranger + +# Tabs +map tab_new ~ +map tab_close +map tab_move 1 +map tab_move -1 +map tab_move 1 +map tab_move -1 +#map gt tab_move 1 +#map gT tab_move -1 +map gn tab_new ~ +#map gc tab_close +map tt tab_close +map uq tab_restore +map tab_open 1 +map tab_open 2 +map tab_open 3 +map tab_open 4 +map tab_open 5 +map tab_open 6 +map tab_open 7 +map tab_open 8 +map tab_open 9 + + +# External Programs +map E edit +map du shell -p du --max-depth=1 -h --apparent-size +map dU shell -p du --max-depth=1 -h --apparent-size | sort -rh +map yp shell -f echo -n %%d/%%f | xsel -i; xsel -o | xsel -i -b +map yd shell -f echo -n %%d | xsel -i; xsel -o | xsel -i -b +map yn shell -f echo -n %%f | xsel -i; xsel -o | xsel -i -b + + +# Filesystem Operations +map = chmod +map cw console rename%space +map aa rename_append +map A eval fm.open_console('rename ' + fm.thisfile.relative_path) +map I eval fm.open_console('rename ' + fm.thisfile.relative_path, position=7) +map pp paste +map po paste overwrite=True +map pP paste append=True +map pO paste overwrite=True append=True +map pl paste_symlink relative=False +map pL paste_symlink relative=True +map phl paste_hardlink +map pht paste_hardlinked_subtree + +map dD console delete + +map dd cut +map ud uncut +map da cut mode=add +map dr cut mode=remove + +map yy copy +map uy uncut +map ya copy mode=add +map yr copy mode=remove + + +# Temporary workarounds +map dgg eval fm.cut(dirarg=dict(to=0), narg=quantifier) +map dG eval fm.cut(dirarg=dict(to=-1), narg=quantifier) +map dj eval fm.cut(dirarg=dict(down=1), narg=quantifier) +map dk eval fm.cut(dirarg=dict(up=1), narg=quantifier) +map ygg eval fm.copy(dirarg=dict(to=0), narg=quantifier) +map yG eval fm.copy(dirarg=dict(to=-1), narg=quantifier) +map yj eval fm.copy(dirarg=dict(down=1), narg=quantifier) +map yk eval fm.copy(dirarg=dict(up=1), narg=quantifier) + + +# Searching +map / console search%space +map n search_next +map N search_next forward=False +map ct search_next order=tag +map cs search_next order=size +map ci search_next order=mimetype +map cc search_next order=ctime +map cm search_next order=mtime +map ca search_next order=atime + + +# Sorting +map or toggle_option sort_reverse +map oz set sort=random +map os chain set sort=size; set sort_reverse=False +map ob chain set sort=basename; set sort_reverse=False +map on chain set sort=natural; set sort_reverse=False +map om chain set sort=mtime; set sort_reverse=False +map oc chain set sort=ctime; set sort_reverse=False +map oa chain set sort=atime; set sort_reverse=False +map ot chain set sort=type; set sort_reverse=False +map oe chain set sort=extension; set sort_reverse=False + +map oS chain set sort=size; set sort_reverse=True +map oB chain set sort=basename; set sort_reverse=True +map oN chain set sort=natural; set sort_reverse=True +map oM chain set sort=mtime; set sort_reverse=True +map oC chain set sort=ctime; set sort_reverse=True +map oA chain set sort=atime; set sort_reverse=True +map oT chain set sort=type; set sort_reverse=True +map oE chain set sort=extension; set sort_reverse=True + +map dc get_cumulative_size + + +# Settings +map zc toggle_option collapse_preview +map zd toggle_option sort_directories_first +map zh toggle_option show_hidden +map toggle_option show_hidden +map zi toggle_option flushinput +map zm toggle_option mouse_enabled +map zp toggle_option preview_files +map zP toggle_option preview_directories +map zs toggle_option sort_case_insensitive +map zu toggle_option autoupdate_cumulative_size +map zv toggle_option use_preview_script +map zf console filter%space + + +# Bookmarks +#map ` enter_bookmark %any +#map ' enter_bookmark %any +#map mm set_bookmark %any +#map um unset_bookmark %any + +#map m draw_bookmarks +#copymap m um ` ' + + +# Generate all the chmod bindings with some python help: +eval for arg in "rwxXst": cmd("map +u{0} shell -f chmod u+{0} %s".format(arg)) +eval for arg in "rwxXst": cmd("map +g{0} shell -f chmod g+{0} %s".format(arg)) +eval for arg in "rwxXst": cmd("map +o{0} shell -f chmod o+{0} %s".format(arg)) +eval for arg in "rwxXst": cmd("map +a{0} shell -f chmod a+{0} %s".format(arg)) +eval for arg in "rwxXst": cmd("map +{0} shell -f chmod u+{0} %s".format(arg)) + +eval for arg in "rwxXst": cmd("map -u{0} shell -f chmod u-{0} %s".format(arg)) +eval for arg in "rwxXst": cmd("map -g{0} shell -f chmod g-{0} %s".format(arg)) +eval for arg in "rwxXst": cmd("map -o{0} shell -f chmod o-{0} %s".format(arg)) +eval for arg in "rwxXst": cmd("map -a{0} shell -f chmod a-{0} %s".format(arg)) +eval for arg in "rwxXst": cmd("map -{0} shell -f chmod u-{0} %s".format(arg)) + + +###CONSOLE KEYS### +# Basic +cmap eval fm.ui.console.tab() +cmap eval fm.ui.console.tab(-1) +cmap eval fm.ui.console.close() +cmap eval fm.ui.console.execute() +#cmap redraw_window + +copycmap +copycmap + + +# Move around +cmap eval fm.ui.console.history_move(-1) +cmap eval fm.ui.console.history_move(1) +cmap eval fm.ui.console.move(left=1) +cmap eval fm.ui.console.move(right=1) +cmap eval fm.ui.console.move(right=0, absolute=True) +cmap eval fm.ui.console.move(right=-1, absolute=True) + + +# Line Editing +cmap eval fm.ui.console.delete(-1) +cmap eval fm.ui.console.delete(0) +cmap eval fm.ui.console.delete_word() +cmap eval fm.ui.console.delete_word(backward=False) +cmap eval fm.ui.console.delete_rest(1) +cmap eval fm.ui.console.delete_rest(-1) +cmap eval fm.ui.console.paste() + +# And of course the emacs way +#copycmap +#copycmap +#copycmap +#copycmap +#copycmap +#copycmap +#copycmap +#copycmap + + +# Note: There are multiple ways to express backspaces. (code 263) +# and (code 127). To be sure, use both. +copycmap + +# This special expression allows typing in numerals: +cmap false + + + +###PAGER KEYS### +# Movement +pmap pager_move down=1 +pmap pager_move up=1 +pmap pager_move left=4 +pmap pager_move right=4 +pmap pager_move to=0 +pmap pager_move to=-1 +pmap pager_move down=1.0 pages=True +pmap pager_move up=1.0 pages=True +pmap pager_move down=0.5 pages=True +pmap pager_move up=0.5 pages=True + +copypmap k +copypmap j +copypmap h +copypmap l +copypmap g +copypmap G +copypmap d +copypmap u +copypmap n f +copypmap p b + + +# Basic +#pmap redraw_window +pmap pager_close +copypmap q Q i +pmap E edit_file + +# =================================================================== +# == Taskview Keybindings +# =================================================================== + +# Movement +tmap taskview_move up=1 +tmap taskview_move down=1 +tmap taskview_move to=0 +tmap taskview_move to=-1 +tmap taskview_move down=1.0 pages=True +tmap taskview_move up=1.0 pages=True +tmap taskview_move down=0.5 pages=True +tmap taskview_move up=0.5 pages=True + +copytmap k +copytmap j +copytmap g +copytmap G +copytmap u +copytmap n f +copytmap p b + +# Changing priority and deleting tasks +tmap J eval -q fm.ui.taskview.task_move(-1) +tmap K eval -q fm.ui.taskview.task_move(0) +tmap dd eval -q fm.ui.taskview.task_remove() +tmap eval -q fm.ui.taskview.task_move(-1) +tmap eval -q fm.ui.taskview.task_move(0) +tmap eval -q fm.ui.taskview.task_remove() + +# Basic +#tmap redraw_window +tmap taskview_close +copytmap q Q w + + +map sp console shell bash speedvid.sh %f%space +map x shell chmod -x %s + +#General +map V console shell vim%space +map cW bulkrename %s +map mkd console mkdir%space +map sc console shell ln -sT%space +map D console delete +map X shell atool -x %f +map Z shell tar -cvzf %f.tar.gz %s +map fzf_select +map fzf_locate + +#Document Manipulation +map p1s shell lpr -o sides=one-sided %f +map p2s shell lpr -o sides=two-sided-long-edge %f +map MP shell pandoc %f -o %f.pdf +map MX shell xelatex %f +map ML shell latex %f +map TC shell texclear +map Txa console shell cp ~/Documents/LaTeX/article.tex%space +map Txs console shell cp ~/Documents/LaTeX/beamer.tex%space +map Txh console shell cp ~/Documents/LaTeX/handout.tex%space + +#Image commands +map bg shell setbg %f +map bw shell wal -i %f && setbg %f +map C shell killall w3mimgdisplay && convert -rotate 90 %s %s +map F shell killall w3mimgdisplay && convert -flop %s %s +map bl shell killall w3mimgdisplay && convert %s -resize 1440x1080\> bl_%s +map TR shell convert %s -transparent white %s + +#Music (mpd) shortcuts +map MS shell mpd +map MK shell killall mpd +map Ma shell mpc add "%s" +map Ms shell mpc play +map Mp shell mpc toggle +map Mn shell mpc next +map Mb shell mpc prev +map MN shell mpc stop && mpc clear && mpc add "%s" +map Mo shell mpc seek 0% + +#Audio tagging (Requires eyeD3) +map Ta eval fm.open_console('shell eyeD3 -a ' + fm.thisfile.relative_path, position=15) +#Artist +map TA eval fm.open_console('shell eyeD3 -A ' + fm.thisfile.relative_path, position=15) +#Album +map Tb eval fm.open_console('shell eyeD3 -b ' + fm.thisfile.relative_path, position=15) +#Album artist +map Tt eval fm.open_console('shell eyeD3 -t "" ' + fm.thisfile.relative_path, position=16) +map Tn eval fm.open_console('shell eyeD3 -n "" ' + fm.thisfile.relative_path, position=16) + +#Downloading +map ytv console shell youtube-dl -ic%space +map yta console shell youtube-dl -xic%space +source ~/.config/ranger/shortcuts.conf diff --git a/.config/ranger/ranger/rifle.conf b/.config/ranger/ranger/rifle.conf new file mode 100644 index 00000000..97410d99 --- /dev/null +++ b/.config/ranger/ranger/rifle.conf @@ -0,0 +1,236 @@ +# vim: ft=cfg +# +# This is the configuration file of "rifle", ranger's file executor/opener. +# Each line consists of conditions and a command. For each line the conditions +# are checked and if they are met, the respective command is run. +# +# Syntax: +# , , ... = command +# +# The command can contain these environment variables: +# $1-$9 | The n-th selected file +# $@ | All selected files +# +# If you use the special command "ask", rifle will ask you what program to run. +# +# Prefixing a condition with "!" will negate its result. +# These conditions are currently supported: +# match | The regexp matches $1 +# ext | The regexp matches the extension of $1 +# mime | The regexp matches the mime type of $1 +# name | The regexp matches the basename of $1 +# path | The regexp matches the absolute path of $1 +# has | The program is installed (i.e. located in $PATH) +# env | The environment variable "variable" is non-empty +# file | $1 is a file +# directory | $1 is a directory +# number | change the number of this command to n +# terminal | stdin, stderr and stdout are connected to a terminal +# X | $DISPLAY is not empty (i.e. Xorg runs) +# +# There are also pseudo-conditions which have a "side effect": +# flag | Change how the program is run. See below. +# label