diff options
| author | Bruce Hill <bruce@bruce-hill.com> | 2019-11-11 12:29:40 -0800 |
|---|---|---|
| committer | Bruce Hill <bruce@bruce-hill.com> | 2019-11-11 12:29:40 -0800 |
| commit | b7ad0e93a243da19e39fc750054afcfa3c6bb9b0 (patch) | |
| tree | 33295fb95c09d02e9d3afed9e68ef28c3a415107 /bindings.bb | |
| parent | af3f6421500dfeb58b8ac251edf639552e48b762 (diff) | |
Refactored `bb +...` to `bbcmd ...` within bb bindings. This makes
things a lot less ambiguous. Also removed the default marks created in
bbstartup.sh and ensured that `$XDG_DATA_HOME` and `$XDG_CONFIG_HOME`
always get set as environment variables.
Diffstat (limited to 'bindings.bb')
| -rw-r--r-- | bindings.bb | 131 |
1 files changed, 68 insertions, 63 deletions
diff --git a/bindings.bb b/bindings.bb index f63aa91..42b8e25 100644 --- a/bindings.bb +++ b/bindings.bb @@ -2,9 +2,9 @@ # The format is: <key>(,<key>)*:[ ]*#<description>(\n[ ]+script)+ Section: BB Commands ?,F1: # Show Help menu - bb +help + bbcmd help q,Q: # Quit - bb +quit + bbcmd quit Ctrl-c: # Send interrupt signal kill -INT $PPID Ctrl-z: # Suspend @@ -14,92 +14,97 @@ Ctrl-\: # Quit and generate core dump Section: File Navigation j,Down: # Next file - bb +move:+1 + bbcmd move:+1 k,Up: # Previous file - bb +move:-1 + bbcmd move:-1 h,Left: # Parent directory - bb +cd:.. + bbcmd cd:.. l,Right: # Enter directory - if [ -d "$BBCURSOR" ]; then bb +cd:"$BBCURSOR"; fi + if [ -d "$BBCURSOR" ]; then bbcmd cd:"$BBCURSOR"; fi Ctrl-f: # Search for file file="$( if [ $BBDOTFILES ]; then find -mindepth 1 -printf '%P\0'; else find -mindepth 1 ! -path '*/.*' -printf '%P\0'; fi | pick "Find: " - )" && bb +goto:"$file" + )" && bbcmd goto:"$file" /: # Pick a file file="$(find -mindepth 1 -maxdepth 1 -printf '%P\0' | pick "Pick: ")" || exit - expr "$file" : "\..*" >/dev/null && ! [ "$BBDOTFILES" ] && bb +dotfiles - bb +goto:"$file" + expr "$file" : "\..*" >/dev/null && ! [ "$BBDOTFILES" ] && bbcmd dotfiles + bbcmd goto:"$file" Ctrl-g: # Go to directory - ask goto "Go to directory: " && bb +cd:"$goto" + ask goto "Go to directory: " && bbcmd cd:"$goto" m: # Mark this directory - ask mark "Mark: " && ln -s "$PWD" ~/.config/bb/marks/"$mark" + mkdir -p "$XDG_CONFIG_HOME/bb/marks" + ln -sT "$2" "$XDG_CONFIG_HOME/bb/marks/$1" 2>/dev/null + ask mark "Mark: " && ln -s "$PWD" "$XDG_CONFIG_HOME"/bb/marks/"$mark" ': # Go to a marked directory - mark="$(find ~/.config/bb/marks/ -mindepth 1 -printf '%P\0' | pick "Jump to: ")" && - bb +cd:"$(readlink -f ~/.config/bb/marks/"$mark")" + [ -d "$XDG_CONFIG_HOME"/bb/marks ] || exit + mark="$(find "$XDG_CONFIG_HOME"/bb/marks/ -mindepth 1 -type l -printf '%P\0' | pick "Jump to: ")" && + bbcmd cd:"$(readlink -f "$XDG_CONFIG_HOME"/bb/marks/"$mark")" -,Backspace: # Go to previous directory - [ "$BBPREVPATH" ] && bb +cd:"$BBPREVPATH" + [ "$BBPREVPATH" ] && bbcmd cd:"$BBPREVPATH" ;: # Show selected files - bb +cd:'<selection>' + bbcmd cd:'<selection>' 0: # Go to intitial directory - bb +cd:"$BBINITIALPATH" + bbcmd cd:"$BBINITIALPATH" g,Home: # Go to first file - bb +move:0 + bbcmd move:0 G,End: # Go to last file - bb +move:100%n + bbcmd move:100%n PgDn: # Page down - bb +scroll:+100% + bbcmd scroll:+100% PgUp: # Page up - bb +scroll:-100% + bbcmd scroll:-100% Ctrl-d: # Half page down - bb +scroll:+50% + bbcmd scroll:+50% Ctrl-u: # Half page up - bb +scroll:-50% + bbcmd scroll:-50% Mouse wheel down: # Scroll down - bb +scroll:+3 + bbcmd scroll:+3 Mouse wheel up: # Scroll up - bb +scroll:-3 + bbcmd scroll:-3 Section: File Selection v,V,Space: # Toggle selection at cursor - bb +toggle + bbcmd toggle Escape: # Clear selection - bb +deselect + bbcmd deselect S: # Select pattern - ask patt "Select: " && eval bb +select: "$patt" + ask patt "Select: " && eval bbcmd select: "$patt" U: # Unselect pattern - ask patt "Unselect: " && eval bb +deselect: "$patt" + ask patt "Unselect: " && eval bbcmd deselect: "$patt" Ctrl-s: # Save the selection [ $# -gt 0 ] && ask savename "Save selection as: " || exit 1 + mkdir -p "$XDG_DATA_HOME"/bb if ! expr "$savename" : ".*\.sel" >/dev/null; then savename="$savename.sel"; fi - printf '%s\0' "$@" > ~/.config/bb/"$savename" + printf '%s\0' "$@" > "$XDG_DATA_HOME"/bb/"$savename" Ctrl-o: # Open a saved selection + [ -d "$XDG_DATA_HOME"/bb ] || exit [ $# -gt 0 ] && ! confirm "The current selection will be discarded. " && exit 1 - loadpath="$(find ~/.config/bb/ -mindepth 1 -name '*.sel' -printf '%P\0' | pick "Load selection: ")" && - cat ~/.config/bb/"$loadpath" | bb +deselect +select: + loadpath="$(find "$XDG_DATA_HOME"/bb/ -mindepth 1 -name '*.sel' -printf '%P\0' | pick "Load selection: ")" && + cat "$XDG_DATA_HOME"/bb/"$loadpath" | bbcmd deselect select: J: # Spread selection down - bb +spread:+1 + bbcmd spread:+1 K: # Spread selection up - bb +spread:-1 + bbcmd spread:-1 Shift-Home: # Spread the selection to the top - bb +spread:0 + bbcmd spread:0 Shift-End: # Spread the selection to the bottom - bb +spread:100%n + bbcmd spread:100%n Ctrl-a: # Select all files here - bb +select + bbcmd select Section: File Actions Left click: # Move cursor to file if [ "$BBCLICKED" = "<column label>" ]; then - bb +sort:"~$BBMOUSECOL" + bbcmd sort:"~$BBMOUSECOL" elif [ "$BBCLICKED" -a "$BBMOUSECOL" = "*" ]; then - bb +toggle:"$BBCLICKED" + bbcmd toggle:"$BBCLICKED" elif [ "$BBCLICKED" ]; then - bb +goto:"$BBCLICKED" + bbcmd goto:"$BBCLICKED" fi Enter,Double left click: # Open file/directory - if [ -d "$BBCURSOR" ]; then bb +cd:"$BBCURSOR"; + if [ -d "$BBCURSOR" ]; then bbcmd cd:"$BBCURSOR"; elif [ "$(uname)" = "Darwin" ]; then if expr "$(file -bI "$BBCURSOR")" : '\(text/\|inode/empty\)' >/dev/null; then $EDITOR "$BBCURSOR"; else open "$BBCURSOR"; fi @@ -111,23 +116,23 @@ e: # Edit file in $EDITOR $EDITOR "$BBCURSOR" || pause d,Delete: # Delete a file printf "\033[1mDeleting \033[33m$BBCURSOR\033[0;1m...\033[0m " && confirm && - rm -rf "$BBCURSOR" && bb +deselect:"$BBCURSOR" +refresh + rm -rf "$BBCURSOR" && bbcmd deselect:"$BBCURSOR" refresh D: # Delete all selected files [ $# -gt 0 ] && printf "\033[1mDeleting the following:\n\033[33m$(printf ' %s\n' "$@")\033[0m" | unscroll | more && - confirm && rm -rf "$@" && bb +deselect +refresh + confirm && rm -rf "$@" && bbcmd deselect refresh Ctrl-v: # Move files here printf "\033[1mMoving the following to here:\n\033[33m$(printf ' %s\n' "$@")\033[0m" | unscroll | more && confirm && printf "\033[1G\033[KMoving..." && mv -i "$@" . && printf "done." && - bb +deselect +refresh && for f; do bb +sel:"$(basename "$f")"; done + bbcmd deselect refresh && for f; do bbcmd sel:"$(basename "$f")"; done c: # Copy a file printf "\033[1mCreating copy of \033[33m$BBCURSOR\033[0;1m...\033[0m " && - confirm && cp -ri "$BBCURSOR" "$BBCURSOR.copy" && bb +refresh + confirm && cp -ri "$BBCURSOR" "$BBCURSOR.copy" && bbcmd refresh C: # Copy all selected files here [ $# -gt 0 ] && printf "\033[1mCopying the following to here:\n\033[33m$(printf ' %s\n' "$@")\033[0m" | unscroll | more && confirm && printf "\033[1G\033[KCopying..." && for f; do if [ "./$(basename "$f")" -ef "$f" ]; then cp -ri "$f" "$f.copy" || break; - else cp -ri "$f" . || break; fi; done; printf 'done.' && bb +refresh + else cp -ri "$f" . || break; fi; done; printf 'done.' && bbcmd refresh Ctrl-n: # New file/directory case "$(printf '%s\0' File Directory | pick "Create new: ")" in File) @@ -140,7 +145,7 @@ Ctrl-n: # New file/directory ;; *) exit ;; - esac && bb +goto:"$name" +refresh || pause + esac && bbcmd goto:"$name" refresh || pause p: # Page through a file with `less` less -XK "$BBCURSOR" r,F2: # Rename a file @@ -149,9 +154,9 @@ r,F2: # Rename a file [ "$r" = "$BBCURSOR" ] && exit [ -e "$r" ] && printf "\033[31;1m$r already exists! It will be overwritten.\033[0m " && confirm && { rm -rf "$r" || { pause; exit; }; } - mv "$BBCURSOR" "$r" && bb +refresh && - while [ $# -gt 0 ]; do "$1" = "$BBCURSOR" && bb +deselect:"$BBCURSOR" +select:"$r"; shift; done && - bb +goto:"$r" || { pause; exit; } + mv "$BBCURSOR" "$r" && bbcmd refresh && + while [ $# -gt 0 ]; do "$1" = "$BBCURSOR" && bbcmd deselect:"$BBCURSOR" select:"$r"; shift; done && + bbcmd goto:"$r" || { pause; exit; } R: # Rename all selected files for f; do ask newname "Rename $(printf "\033[33m%s\033[39m" "$(basename "$f")"): " "$(basename "$f")" || break; @@ -160,10 +165,10 @@ R: # Rename all selected files [ -e "$r" ] && printf "\033[31;1m$r already exists! It will be overwritten.\033[0m " && confirm && { rm -rf "$r" || { pause; exit; }; } mv "$f" "$r" || { pause; exit; } - bb +deselect:"$f" +select:"$r"; - [ "$f" = "$BBCURSOR" ] && bb +goto:"$r"; + bbcmd deselect:"$f" select:"$r"; + [ "$f" = "$BBCURSOR" ] && bbcmd goto:"$r"; done; - bb +refresh + bbcmd refresh Ctrl-r: # Regex rename files command -v rename >/dev/null || { printf '\033[31;1mThe `rename` command is not installed. Please install it to use this key binding.\033[0m\n'; pause; exit; }; @@ -172,33 +177,33 @@ Ctrl-r: # Regex rename files confirm || exit 1 if [ $# -eq 0 ]; then set -- *; ! [ -e "$1" ] && exit; fi rename -i "$patt" "$rep" "$@" - bb +deselect +refresh + bbcmd deselect refresh Section: Shell Commands :: # Run a command - ask cmd ':' && sh -c "$BBSHELLFUNC$cmd" -- "$@"; bb +r; pause + ask cmd ':' && sh -c "$BBSHELLFUNC$cmd" -- "$@"; bbcmd refresh; pause |: # Pipe selected files to a command - ask cmd '|' && printf '%s\n' "$@" | sh -c "$BBSHELLFUNC$cmd"; bb +r; pause + ask cmd '|' && printf '%s\n' "$@" | sh -c "$BBSHELLFUNC$cmd"; bbcmd refresh; pause >: # Open a shell - tput rmcup; tput cvvis; $SHELL; bb +r + tput rmcup; tput cvvis; $SHELL; bbcmd refresh f: # Resume suspended process - bb +fg + bbcmd fg Section: Viewing Options s: # Sort by... ask1 sort "Sort (n)ame (s)ize (m)odification (c)reation (a)ccess (r)andom (p)ermissions: " && - bb +sort:"~$sort" + bbcmd sort:"~$sort" ---,#: # Set columns ask columns "Set columns (*)selected (a)ccessed (c)reated (m)odified (n)ame (p)ermissions (r)andom (s)ize: " && - bb +col:"$columns" + bbcmd col:"$columns" .: # Toggle dotfile visibility - bb +dotfiles + bbcmd dotfiles i: # Toggle interleaving files and directories - bb +interleave + bbcmd interleave F5: # Refresh view - bb +refresh + bbcmd refresh Ctrl-b: # Bind a key to a script ask1 key "Press key to bind..." && echo && ask script "Bind script: " && - bb +bind:"$key":"{ $script; } || pause" || pause + bbcmd bind:"$key":"{ $script; } || pause" || pause Section: User Bindings |
