keys configurable, multiple keys support, decreasesd fzf processes

This commit is contained in:
2025-08-27 17:38:11 +02:00
parent 9aa1413a51
commit a1ae20fa82
5 changed files with 157 additions and 368 deletions

View File

@@ -14,6 +14,9 @@ set -eu
# Load theme # Load theme
. "sh/theme.sh" . "sh/theme.sh"
# Load keys
. "sh/keys.sh"
# Load AWK scripts # Load AWK scripts
. "sh/awk.sh" . "sh/awk.sh"
@@ -57,9 +60,6 @@ if [ "${1:-}" = "--fzf-reload" ]; then
"$MODE_LIST_ALBUMS") "$MODE_LIST_ALBUMS")
list_local_releasegroups list_local_releasegroups
;; ;;
"$MODE_SELECT_ARTIST")
true
;;
esac esac
exit 0 exit 0
fi fi
@@ -101,9 +101,8 @@ if [ "${1:-}" = "--fzf-load" ]; then
SHOW_PREVIEW=1 SHOW_PREVIEW=1
;; ;;
"$MODE_LIST_ALBUMS") ;; "$MODE_LIST_ALBUMS") ;;
"$MODE_SELECT_ARTIST") ;;
esac esac
[ "${QUERY:-}" ] && printf "+change-query(%s)" "$QUERY" printf "+change-query(%s)" "${QUERY:-}"
printf "+change-prompt(%s)" "${PROMPT:-"$SEARCH_PROMPT"}" printf "+change-prompt(%s)" "${PROMPT:-"$SEARCH_PROMPT"}"
[ "${DISABLE_SEARCH:-}" ] && printf "+disable-search" || printf "+enable-search" [ "${DISABLE_SEARCH:-}" ] && printf "+disable-search" || printf "+enable-search"
[ "${SHOW_PREVIEW:-}" ] && printf "+show-preview" || printf "+hide-preview" [ "${SHOW_PREVIEW:-}" ] && printf "+show-preview" || printf "+hide-preview"
@@ -128,7 +127,7 @@ if [ "${1:-}" = "--fzf-info" ]; then
echo "Search albums" echo "Search albums"
;; ;;
"$MODE_SELECT_ARTIST") "$MODE_SELECT_ARTIST")
echo "Select artist" echo "Select artist (WE SHOULDNT SEE THIS; THIS IS A BUG!)"
;; ;;
*) *)
if [ "$FZF_KEY" ]; then if [ "$FZF_KEY" ]; then
@@ -231,37 +230,18 @@ if [ "${1:-}" = "--fzf-change" ]; then
exit 0 exit 0
fi fi
generate_playlist() {
dir="$(dirname "$2")"
mb_release "$1" |
$JQ -r --slurpfile deco "$2" --arg base "$dir" '$deco[].tracks as $filenames |
.media[] |
.position as $pos |
.tracks |
map({
$pos,
number: .number,
file: $filenames[.id]
}) |
map(
if(.number | type == "string" and test("^[0-9]+$")) then
.number |= tonumber
else
.
end
) |
sort_by([.pos, .number]) |
map($base + "/" + .file)[]'
}
if [ "${1:-}" = "--fzf-key" ]; then if [ "${1:-}" = "--fzf-key" ]; then
foo "KEY: $*"
mbid="${2:-}" mbid="${2:-}"
path="${3:-}" path="${3:-}"
mode=$(cut -d "#" -f 1 "$MODEFILE") mode=$(cut -d "#" -f 1 "$MODEFILE")
args=$(cut -d "#" -f 2- "$MODEFILE") args=$(cut -d "#" -f 2- "$MODEFILE")
if [ "$FZF_KEY" = "enter" ] && [ "$path" ]; then
case "$mode" in case ",$FZF_KEY," in
*",$KEYS_PLAY,"*)
[ "$path" ] && case "$mode" in
"$MODE_RELEASEGROUP") "$MODE_RELEASEGROUP")
tmplist=$(mktemp)
generate_playlist "$mbid" "$path" >"$tmplist" generate_playlist "$mbid" "$path" >"$tmplist"
mpv_play_list "$tmplist" >/dev/null mpv_play_list "$tmplist" >/dev/null
rm -f "$tmplist" rm -f "$tmplist"
@@ -270,62 +250,60 @@ if [ "${1:-}" = "--fzf-key" ]; then
mpv_play_file "$path" >/dev/null mpv_play_file "$path" >/dev/null
;; ;;
esac esac
elif [ "$FZF_KEY" = "alt-enter" ] && [ "$path" ]; then ;;
case "$mode" in *",$KEYS_QUEUE,"*)
[ "$path" ] && case "$mode" in
"$MODE_RELEASEGROUP") "$MODE_RELEASEGROUP")
tmplist=$(mktemp)
generate_playlist "$mbid" "$path" >"$tmplist" generate_playlist "$mbid" "$path" >"$tmplist"
mpv_queue_list "$tmplist" >/dev/null mpv_queue_list "$tmplist" >/dev/null
rm -f "$tmplist" rm -f "$tmplist"
;; ;;
"$MODE_RELEASE") "$MODE_RELEASE")
mpv_queue_file "$path" >/dev/null mpv_play_file "$path" >/dev/null
;; ;;
esac esac
elif [ "$FZF_KEY" = "alt-space" ]; then ;;
mpv_toggle_pause >/dev/null *",$KEYS_TOGGLE_PLAY_PAUSE,"*) mpv_toggle_pause >/dev/null ;;
elif [ "$FZF_KEY" = "ctrl-n" ] && [ "$path" ]; then *",$KEYS_PLAY_NEXT,"*) [ "$path" ] && mpv_next >/dev/null ;;
mpv_next >/dev/null *",$KEYS_PLAY_PREV,"*) [ "$path" ] && mpv_prev >/dev/null ;;
elif [ "$FZF_KEY" = "ctrl-p" ] && [ "$path" ]; then *",$KEYS_SEEK_FORWARD,"*) mpv_seek_forward >/dev/null ;;
mpv_prev >/dev/null *",$KEYS_SEEK_BACKWARD,"*) mpv_seek_backward >/dev/null ;;
elif [ "$FZF_KEY" = "shift-right" ] && [ "$path" ]; then *",$KEYS_HALFPAGE_DOWN,"*) printf "half-page-down" ;;
mpv_seek_forward >/dev/null *",$KEYS_HALFPAGE_UP,"*) printf "half-page-up" ;;
elif [ "$FZF_KEY" = "shift-left" ] && [ "$path" ]; then *",$KEYS_FILTER_LOCAL,"*)
mpv_seek_backward >/dev/null
elif [ "$FZF_KEY" = "ctrl-d" ]; then
printf "half-page-down"
elif [ "$FZF_KEY" = "down" ]; then
printf "preview-half-page-down"
elif [ "$FZF_KEY" = "up" ]; then
printf "preview-half-page-up"
elif [ "$FZF_KEY" = "ctrl-u" ]; then
printf "half-page-up"
elif [ "$FZF_KEY" = "alt-l" ]; then
case "$mode" in case "$mode" in
"$MODE_SEARCH_ARTIST" | "$MODE_SEARCH_ALBUM") ;; "$MODE_SEARCH_ARTIST" | "$MODE_SEARCH_ALBUM") ;;
*) QUERY="$FORMAT_LOCAL " ;; *) QUERY="$FORMAT_LOCAL " ;;
esac esac
elif [ "$FZF_KEY" = "tab" ]; then ;;
*",$KEYS_SWITCH_ARTIST_ALBUM,"*)
case "$mode" in case "$mode" in
"$MODE_SEARCH_ARTIST") MODE_NEXT="$MODE_SEARCH_ALBUM" ;; "$MODE_SEARCH_ARTIST") MODE_NEXT="$MODE_SEARCH_ALBUM" ;;
"$MODE_SEARCH_ALBUM") MODE_NEXT="$MODE_SEARCH_ARTIST" ;; "$MODE_SEARCH_ALBUM") MODE_NEXT="$MODE_SEARCH_ARTIST" ;;
"$MODE_LIST_ARTISTS") MODE_NEXT="$MODE_LIST_ALBUMS" ;; "$MODE_LIST_ARTISTS") MODE_NEXT="$MODE_LIST_ALBUMS" ;;
"$MODE_LIST_ALBUMS") MODE_NEXT="$MODE_LIST_ARTISTS" ;; "$MODE_LIST_ALBUMS") MODE_NEXT="$MODE_LIST_ARTISTS" ;;
esac esac
elif [ "$FZF_KEY" = "ctrl-/" ]; then ;;
*",$KEYS_SWITCH_LOCAL_REMOTE,"*)
case "$mode" in case "$mode" in
"$MODE_SEARCH_ARTIST") MODE_NEXT="$MODE_LIST_ARTISTS" ;; "$MODE_SEARCH_ARTIST") MODE_NEXT="$MODE_LIST_ARTISTS" ;;
"$MODE_SEARCH_ALBUM") MODE_NEXT="$MODE_LIST_ALBUMS" ;; "$MODE_SEARCH_ALBUM") MODE_NEXT="$MODE_LIST_ALBUMS" ;;
"$MODE_LIST_ARTISTS") MODE_NEXT="$MODE_SEARCH_ARTIST" ;; "$MODE_LIST_ARTISTS") MODE_NEXT="$MODE_SEARCH_ARTIST" ;;
"$MODE_LIST_ALBUMS") MODE_NEXT="$MODE_SEARCH_ALBUM" ;; "$MODE_LIST_ALBUMS") MODE_NEXT="$MODE_SEARCH_ALBUM" ;;
esac esac
elif [ "$FZF_KEY" = "alt-b" ] && [ "$mbid" ]; then ;;
*",$KEYS_BROWSE,"*)
[ "$mbid" ] || exit 0
case "$mode" in case "$mode" in
"$MODE_SEARCH_ARTIST" | "$MODE_LIST_ARTISTS") urltype="artist" ;;
"$MODE_ARTIST") urltype="release-group" ;; "$MODE_ARTIST") urltype="release-group" ;;
"$MODE_RELEASEGROUP") urltype="release" ;; "$MODE_RELEASEGROUP") urltype="release" ;;
"$MODE_RELEASE") urltype="track" ;; "$MODE_RELEASE") urltype="track" ;;
esac esac
printf "esecute-silent(xdg-open \"https://musicbrainz.org/%s/%s\" &)" "$urltype" "$mbid" printf "execute-silent(xdg-open \"https://musicbrainz.org/%s/%s\" &)" "$urltype" "$mbid"
elif [ "$FZF_KEY" = "ctrl-h" ]; then ;;
*",$KEYS_OUT,"*)
case "$mode" in case "$mode" in
"$MODE_ARTIST") "$MODE_ARTIST")
MODE_NEXT="$MODE_LIST_ARTISTS" MODE_NEXT="$MODE_LIST_ARTISTS"
@@ -333,13 +311,16 @@ if [ "${1:-}" = "--fzf-key" ]; then
"$MODE_RELEASEGROUP") "$MODE_RELEASEGROUP")
MODE_NEXT="$MODE_SELECT_ARTIST" MODE_NEXT="$MODE_SELECT_ARTIST"
MODE_NEXT_ARGS="$(mb_releasegroup "$args" | $JQ -r --compact-output '."artist-credit"')" MODE_NEXT_ARGS="$(mb_releasegroup "$args" | $JQ -r --compact-output '."artist-credit"')"
ACCEPT=1
;; ;;
"$MODE_RELEASE") "$MODE_RELEASE")
MODE_NEXT="$MODE_RELEASEGROUP" MODE_NEXT="$MODE_RELEASEGROUP"
MODE_NEXT_ARGS="$(mb_release "$args" | $JQ -r --compact-output '."release-group".id')" MODE_NEXT_ARGS="$(mb_release "$args" | $JQ -r --compact-output '."release-group".id')"
;; ;;
esac esac
elif [ "$FZF_KEY" = "ctrl-l" ] && [ "$mbid" ]; then ;;
*",$KEYS_IN,"*)
[ "$mbid" ] || exit 0
MODE_NEXT_ARGS="$mbid" MODE_NEXT_ARGS="$mbid"
case "$mode" in case "$mode" in
"$MODE_LIST_ARTISTS" | "$MODE_SEARCH_ARTIST") "$MODE_LIST_ARTISTS" | "$MODE_SEARCH_ARTIST")
@@ -352,40 +333,40 @@ if [ "${1:-}" = "--fzf-key" ]; then
MODE_NEXT="$MODE_RELEASE" MODE_NEXT="$MODE_RELEASE"
;; ;;
esac esac
elif [ "$FZF_KEY" = "ctrl-a" ] && [ "$mbid" ]; then ;;
*",$KEYS_SELECT_ARTIST,"*)
[ "$mbid" ] || exit 0
case "$mode" in case "$mode" in
"$MODE_ARTIST" | "$MODE_SEARCH_ARTIST" | "$MODE_LIST_ARTISTS") "$MODE_ARTIST" | "$MODE_SEARCH_ARTIST" | "$MODE_LIST_ARTISTS")
MODE_NEXT_ARGS="$(mb_releasegroup "$mbid" | $JQ -r --compact-output '."artist-credit"')" MODE_NEXT_ARGS="$(mb_releasegroup "$mbid" | $JQ -r --compact-output '."artist-credit"')"
ACCEPT=1
;; ;;
"$MODE_RELEASEGROUP" | "$MODE_SEARCH_ALBUM" | "$MODE_LIST_ALBUMS") "$MODE_RELEASEGROUP" | "$MODE_SEARCH_ALBUM" | "$MODE_LIST_ALBUMS")
MODE_NEXT_ARGS="$(mb_release "$mbid" | $JQ -r --compact-output '."artist-credit"')" MODE_NEXT_ARGS="$(mb_release "$mbid" | $JQ -r --compact-output '."artist-credit"')"
ACCEPT=1
;; ;;
"$MODE_RELEASE") "$MODE_RELEASE")
MODE_NEXT_ARGS="$(mb_release "$args" | $JQ -r --compact-output '."artist-credit"')" MODE_NEXT_ARGS="$(mb_release "$args" | $JQ -r --compact-output '."artist-credit"')"
ACCEPT=1
;; ;;
esac esac
[ "$MODE_NEXT_ARGS" ] && MODE_NEXT="$MODE_SELECT_ARTIST" [ "$MODE_NEXT_ARGS" ] && MODE_NEXT="$MODE_SELECT_ARTIST"
else ;;
# View specific commands *",$KEYS_FILTER_PRIMARY,"*)
case "$mode" in [ "$mode" = "$MODE_ARTIST" ] || exit 0
"$MODE_ARTIST") secsymb="$(printf "$FORMAT_TYPE_HAS_SECONDARY" "")"
case "$FZF_KEY" in QUERY="!$secsymb "
"alt-1") ;;
secsymb="$(printf "$FORMAT_TYPE_HAS_SECONDARY" "")" *",$KEYS_FILTER_SECONDARY,"*)
QUERY="!$secsymb " [ "$mode" = "$MODE_ARTIST" ] || exit 0
;; secsymb="$(printf "$FORMAT_TYPE_HAS_SECONDARY" "")"
"alt-2") QUERY="$secsymb "
secsymb="$(printf "$FORMAT_TYPE_HAS_SECONDARY" "")" ;;
QUERY="$secsymb " esac
;;
esac
;;
esac
fi
[ "${QUERY:-}" ] && printf "+change-query(%s)" "$QUERY" [ "${QUERY:-}" ] && printf "+change-query(%s)" "$QUERY"
if [ "$MODE_NEXT" ]; then if [ "$MODE_NEXT" ]; then
printf "%s#%s" "$MODE_NEXT" "${MODE_NEXT_ARGS:-}" >"$MODEFILE" printf "%s#%s" "$MODE_NEXT" "${MODE_NEXT_ARGS:-}" >"$MODEFILE"
printf "+clear-query+reload:%s" "$0 --fzf-reload" [ "${ACCEPT:-}" ] && printf "+accept" || printf "+reload:%s" "$0 --fzf-reload"
fi fi
exit 0 exit 0
fi fi
@@ -433,7 +414,7 @@ GENERAL OPTIONS:
MANAGE LOCAL MUSIC: MANAGE LOCAL MUSIC:
--decorate <path> Decorate directory containing a tagged release --decorate <path> Decorate directory containing a tagged release
--reload <path> Populate database with decorated local music from <path> --reload <path> Populate da$KEYS_SWITCH_ARTIST_ALBUMase with decorated local music from <path>
EOF EOF
exit 0 exit 0
fi fi
@@ -469,8 +450,10 @@ MODE_SEARCH_ALBUM="search-album"
MODE_LIST_ARTISTS="list-artists" MODE_LIST_ARTISTS="list-artists"
MODE_LIST_ALBUMS="list-albums" MODE_LIST_ALBUMS="list-albums"
MODE_SELECT_ARTIST="select-artist" MODE_SELECT_ARTIST="select-artist"
MODE_PLAYLIST="playlist"
export MODE_ARTIST MODE_RELEASEGROUP MODE_RELEASE MODE_SEARCH_ARTIST \ export MODE_ARTIST MODE_RELEASEGROUP MODE_RELEASE MODE_SEARCH_ARTIST \
MODE_SEARCH_ALBUM MODE_LIST_ARTISTS MODE_LIST_ALBUMS MODE_SELECT_ARTIST MODE_SEARCH_ALBUM MODE_LIST_ARTISTS MODE_LIST_ALBUMS MODE_SELECT_ARTIST \
MODE_PLAYLIST
case "${1:-}" in case "${1:-}" in
"--artist") "--artist")
@@ -506,134 +489,14 @@ esac
# Start mpv # Start mpv
mpv_start mpv_start
$FZF \ # $KEYS_PLAY main loop
--bind="start:reload:$0 --fzf-reload" \
--bind="load:transform:$0 --fzf-load" \
--bind="change:execute-silent($0 --fzf-change &)+reload:$0 --fzf-change-reload" \
--bind="ctrl-d:transform:$0 --fzf-key" \
--bind="ctrl-u:transform:$0 --fzf-key" \
--bind="alt-b:transform:$0 --fzf-key {2}" \
--bind="ctrl-h:transform:$0 --fzf-key {2}" \
--bind="ctrl-l:transform:$0 --fzf-key {2}" \
--bind="ctrl-a:transform:$0 --fzf-key {2}" \
--bind="alt-l:transform:$0 --fzf-key" \
--bind="alt-1:transform:$0 --fzf-key" \
--bind="alt-2:transform:$0 --fzf-key" \
--bind="tab:transform:$0 --fzf-key" \
--bind="ctrl-/:transform:$0 --fzf-key" \
--bind="enter:transform:$0 --fzf-key {2} {3}" \
--bind="alt-enter:transform:$0 --fzf-key {2} {3}" \
--bind="alt-space:transform:$0 --fzf-key" \
--bind="alt-space:transform:$0 --fzf-key" \
--bind="ctrl-n:transform:$0 --fzf-key" \
--bind="ctrl-p:transform:$0 --fzf-key" \
--bind="shift-right:transform:$0 --fzf-key" \
--bind="shift-left:transform:$0 --fzf-key" \
--info="inline-right" \
--info-command="$0 --fzf-info" \
--preview-window="right,25%,border-left,wrap,<30(hidden)" \
--preview="$0 --internal-preview-artist {2}" \
--delimiter="\t" \
--with-nth="{1}" \
--accept-nth="{2}"
while true; do while true; do
case "${1:-}" in mode=$(cut -d "#" -f 1 "$MODEFILE")
"--releasegroup") args=$(cut -d "#" -f 2- "$MODEFILE")
title="$(mb_releasegroup "$2" | case "$mode" in
$JQ -r '.title')" "$MODE_SELECT_ARTIST")
artist="$(mb_releasegroup "$2" |
$JQ -r '."artist-credit" | map(([.name, .joinphrase]|join(""))) | join("")')"
sel=$( sel=$(
$0 --internal-list-releases "$2" | echo "$args" |
$FZF \
--no-clear \
--ansi \
--reverse \
--cycle \
--no-sort \
--query="$FORMAT_STATUS_OFFICIAL " \
--delimiter="\t" \
--prompt="$(printf "$FULL_PROMPT" "$artist" "$title")" \
--accept-nth="{2}" \
--with-nth="{1}" \
--expect="ctrl-h,ctrl-a" \
--bind="alt-l:change-query($FORMAT_LOCAL )" \
--bind="load:transform:[ \"\$FZF_TOTAL_COUNT\" -gt 0 ] && echo \"rebind:ctrl-l\" || echo \"unbind:ctrl-l\"" \
--bind="enter:execute-silent:$0 --play-release {2} {3}" \
--bind="alt-enter:execute-silent:$0 --play-release {2} {3} q" \
--bind="alt-space:execute-silent:$0 --play-toggle" \
--bind="ctrl-n:execute-silent:$0 --play-next" \
--bind="ctrl-p:execute-silent:$0 --play-previous" \
--bind="shift-right:execute-silent:$0 --seek-forward" \
--bind="shift-left:execute-silent:$0 --seek-backward" \
--bind="focus:transform:
[ {3} ] && c=rebind || c=unbind
for key in enter alt-enter alt-space ctrl-n ctrl-p shift-right shift-left; do
printf \"+%s(%s)\" \"\$c\" \"\$key\"
done
" \
--bind="ctrl-l:accept" \
--bind="alt-b:execute-silent:xdg-open 'https://musicbrainz.org/release/{r2}' &" \
--bind="ctrl-d:half-page-down,ctrl-u:half-page-up"
)
lns=$(echo "$sel" | wc -l)
key=$(echo "$sel" | head -1 | tail -1)
mid=$(echo "$sel" | head -2 | tail -1)
[ "$lns" -eq 2 ] && [ ! "$key" ] && [ "$mid" ] && set -- "--release" "$mid"
[ "$lns" -eq 2 ] && [ "$key" = "ctrl-h" ] && set -- "--select-artist" "$(mb_releasegroup "$2" | $JQ -r -c '."artist-credit"')"
[ "$lns" -eq 2 ] && [ "$key" = "ctrl-a" ] && set -- "--select-artist" "$(mb_release "$mid" | $JQ -r -c '."artist-credit"')"
;;
"--release")
title="$(mb_release "$2" |
$JQ -r '.title')"
artist="$(mb_release "$2" |
$JQ -r '."artist-credit" | map(([.name, .joinphrase]|join(""))) | join("")')"
sel=$(
$0 --internal-list-recordings "$2" |
$FZF \
--no-clear \
--ansi \
--reverse \
--cycle \
--no-sort \
--delimiter="\t" \
--prompt="$(printf "$FULL_PROMPT" "$artist" "$title")" \
--accept-nth="{2}" \
--with-nth="{1}" \
--expect="ctrl-h,ctrl-a" \
--bind="alt-l:change-query($FORMAT_LOCAL )" \
--bind="enter:execute-silent:$0 --play-recording {3}" \
--bind="alt-enter:execute-silent:$0 --play-recording {3} q" \
--bind="alt-space:execute-silent:$0 --play-toggle" \
--bind="ctrl-n:execute-silent:$0 --play-next" \
--bind="ctrl-p:execute-silent:$0 --play-previous" \
--bind="shift-right:execute-silent:$0 --seek-forward" \
--bind="shift-left:execute-silent:$0 --seek-backward" \
--bind="focus:transform:
[ {3} ] && c=rebind || c=unbind
for key in enter alt-enter alt-space ctrl-n ctrl-p shift-right shift-left; do
printf \"+%s(%s)\" \"\$c\" \"\$key\"
done
" \
--bind="alt-b:execute-silent:xdg-open 'https://musicbrainz.org/track/{r2}' &" \
--bind="ctrl-d:half-page-down,ctrl-u:half-page-up"
)
lns=$(echo "$sel" | wc -l)
key=$(echo "$sel" | head -1 | tail -1)
mid=$(echo "$sel" | head -2 | tail -1)
[ "$lns" -eq 2 ] && [ "$key" = "ctrl-h" ] && set -- "--releasegroup" "$(mb_release "$2" | $JQ -r -c '."release-group".id')"
[ "$lns" -eq 2 ] && [ "$key" = "ctrl-a" ] && set -- "--select-artist" "$(mb_release "$2" | $JQ -r -c ".media[].tracks[] | select(.id==\"$mid\") | .\"artist-credit\"")"
;;
"--playlist")
count=$(mpv_playlist_count)
echo "Playlist: count=$count" >>/tmp/foo
set -- ""
;;
"--select-artist")
tput rmcup
sel=$(
echo "$2" |
$JQ -r 'map([.artist.id, .artist.type, .name] | join("\t")) | join("\n")' | $JQ -r 'map([.artist.id, .artist.type, .name] | join("\t")) | join("\n")' |
awk \ awk \
-F "\t" \ -F "\t" \
@@ -646,177 +509,53 @@ while true; do
column -t -s "$(printf '\t')" | column -t -s "$(printf '\t')" |
sed 's| \+\([0-9a-f-]\+\)$|\t\1|' | sed 's| \+\([0-9a-f-]\+\)$|\t\1|' |
$FZF \ $FZF \
--no-clear \ --bind="$KEYS_HALFPAGE_DOWN:transform:$0 --fzf-key" \
--bind="$KEYS_HALFPAGE_UP:transform:$0 --fzf-key" \
--bind="$KEYS_BROWSE:transform:$0 --fzf-key {2}" \
--bind="$KEYS_FILTER_LOCAL:transform:$0 --fzf-key" \
--bind="$KEYS_TOGGLE_PLAY_PAUSE:transform:$0 --fzf-key" \
--bind="$KEYS_PLAY_NEXT:transform:$0 --fzf-key" \
--bind="$KEYS_PLAY_PREV:transform:$0 --fzf-key" \
--bind="$KEYS_SEEK_FORWARD:transform:$0 --fzf-key" \
--bind="$KEYS_SEEK_BACKWARD:transform:$0 --fzf-key" \
-1 \ -1 \
--ansi \
--cycle \
--no-sort \
--border="bold" \ --border="bold" \
--border-label="Select artist" \ --border-label="Select artist" \
--delimiter="\t" \ --delimiter="\t" \
--prompt="$SEARCH_PROMPT" \ --prompt="$SEARCH_PROMPT" \
--margin="5%,20%" \ --margin="5%,20%" \
--bind="alt-l:change-query($FORMAT_LOCAL )" \ --bind="$KEYS_FILTER_LOCAL:change-query($FORMAT_LOCAL )" \
--accept-nth="{2}" \ --accept-nth="{2}" \
--with-nth="{1}" --with-nth="{1}"
) )
[ "$sel" ] && set -- "--artist" "$sel" printf "%s#%s" "$MODE_ARTIST" "$sel" >"$MODEFILE"
;; ;;
"--search-album") "$MODE_PLAYLIST")
sel=$( count=$(mpv_playlist_count)
printf "" | foo "Playlist: count=$count"
$FZF \ printf "%s#%s" "$MODE_LIST_ARTISTS" "" >"$MODEFILE"
--no-clear \
--ansi \
--reverse \
--no-sort \
--disabled \
--cycle \
--delimiter="\t" \
--prompt="$SEARCH_PROMPT" \
--info="inline-right" \
--info-command="echo \"Search album on MusicBrainz\"" \
--color='input-fg:#ba478f' \
--accept-nth="{2}" \
--with-nth="{1}" \
--expect="ctrl-c,ctrl-q,tab" \
--expect="ctrl-/" \
--bind="alt-l:change-query($FORMAT_LOCAL )" \
--bind="start:transform:[ \"${2:-}\" ] && echo \"change-query:${2:-}\"" \
--bind="load:unbind(enter)+unbind(alt-enter)+transform:[ \"\$FZF_TOTAL_COUNT\" -gt 0 ] && echo \"rebind:ctrl-l\" || echo \"unbind:ctrl-l\"" \
--bind="ctrl-l:accept" \
--bind="ctrl-d:half-page-down,ctrl-u:half-page-up" \
--bind="alt-b:execute-silent:xdg-open 'https://musicbrainz.org/release-group/{r2}' &" \
--bind="change:execute-silent($0 --internal-search releasegroup \$FZF_QUERY &)+reload($0 --internal-reload)" || true
)
lns=$(echo "$sel" | wc -l)
key=$(echo "$sel" | head -1 | tail -1)
mid=$(echo "$sel" | head -2 | tail -1)
[ "$key" = "ctrl-c" ] && tput rmcup && exit 0
[ "$key" = "ctrl-q" ] && tput rmcup && exit 0
[ "$key" = "tab" ] && set -- "--search-artist"
[ "$key" = "ctrl-/" ] && set -- "--albums"
[ "$lns" -eq 2 ] && [ ! "$key" ] && [ "$mid" ] && set -- "--releasegroup" "$mid"
;; ;;
"--search-artist") *) # Main instance
sel=$( $FZF \
printf "" | --reverse \
$FZF \ --bind="start:reload:$0 --fzf-reload" \
--no-clear \ --bind="load:transform:$0 --fzf-load" \
--ansi \ --bind="change:execute-silent($0 --fzf-change &)+reload:$0 --fzf-change-reload" \
--reverse \ --bind="$KEYS_HALFPAGE_DOWN,$KEYS_HALFPAGE_UP,\
--no-sort \ $KEYS_BROWSE,\
--disabled \ $KEYS_IN,$KEYS_OUT,\
--cycle \ $KEYS_SELECT_ARTIST,\
--delimiter="\t" \ $KEYS_FILTER_LOCAL,$KEYS_FILTER_PRIMARY,$KEYS_FILTER_SECONDARY,\
--prompt="$SEARCH_PROMPT" \ $KEYS_SWITCH_ARTIST_ALBUM,$KEYS_SWITCH_LOCAL_REMOTE,\
--info="inline-right" \ $KEYS_PLAY,$KEYS_QUEUE,$KEYS_TOGGLE_PLAY_PAUSE,\
--info-command="echo \"Search music artist on MusicBrainz\"" \ $KEYS_PLAY_NEXT,$KEYS_PLAY_PREV,\
--color='input-fg:#ba478f' \ $KEYS_SEEK_FORWARD,$KEYS_SEEK_BACKWARD:transform:$0 --fzf-key {2} {3}" \
--accept-nth="{2}" \ --info="inline-right" \
--with-nth="{1}" \ --info-command="$0 --fzf-info" \
--preview-window="right,25%,border-left,wrap,<30(hidden)" \ --preview-window="right,25%,border-left,wrap,<30(hidden)" \
--preview="$0 --internal-preview-artist {2}" \ --preview="$0 --internal-preview-artist {2}" \
--expect="ctrl-c,ctrl-q,tab" \ --delimiter="\t" \
--expect="ctrl-/" \ --with-nth="{1}" >/dev/null
--bind="alt-l:change-query($FORMAT_LOCAL )" \
--bind="start:transform:[ \"${2:-}\" ] && echo \"change-query:${2:-}\"" \
--bind="load:unbind(enter)+unbind(alt-enter)+transform:[ \"\$FZF_TOTAL_COUNT\" -gt 0 ] && echo \"rebind:ctrl-l\" || echo \"unbind:ctrl-l\"" \
--bind="ctrl-l:accept" \
--bind="ctrl-d:half-page-down,ctrl-u:half-page-up" \
--bind="down:preview-half-page-down,up:preview-half-page-up" \
--bind="alt-b:execute-silent:xdg-open 'https://musicbrainz.org/artist/{r2}' &" \
--bind="change:execute-silent($0 --internal-search artist \$FZF_QUERY &)+reload($0 --internal-reload)" || true
)
lns=$(echo "$sel" | wc -l)
key=$(echo "$sel" | head -1 | tail -1)
mid=$(echo "$sel" | head -2 | tail -1)
[ "$key" = "ctrl-c" ] && tput rmcup && exit 0
[ "$key" = "ctrl-q" ] && tput rmcup && exit 0
[ "$key" = "tab" ] && set -- "--search-album"
[ "$key" = "ctrl-/" ] && set -- "--artists"
[ "$lns" -eq 2 ] && [ ! "$key" ] && [ "$mid" ] && set -- "--artist" "$mid"
;;
"--albums")
sel=$(
$0 --internal-list-local-releasegroups |
$FZF \
--no-clear \
--ansi \
--reverse \
--cycle \
--delimiter="\t" \
--prompt="$SEARCH_PROMPT" \
--info="inline-right" \
--info-command="echo \"Search albums\"" \
--accept-nth="{2}" \
--with-nth="{1}" \
--expect="ctrl-h,ctrl-a" \
--expect="ctrl-c,ctrl-q,tab" \
--expect="ctrl-/" \
--bind="alt-l:change-query($FORMAT_LOCAL )" \
--bind="load:transform:[ \"\$FZF_TOTAL_COUNT\" -gt 0 ] && echo \"rebind:ctrl-l\" || echo \"unbind:ctrl-l\"" \
--bind="enter:execute-silent:$0 --play-release {2} {3}" \
--bind="alt-enter:execute-silent:$0 --play-release {2} {3} q" \
--bind="alt-space:execute-silent:$0 --play-toggle" \
--bind="ctrl-n:execute-silent:$0 --play-next" \
--bind="ctrl-p:execute-silent:$0 --play-previous" \
--bind="shift-right:execute-silent:$0 --seek-forward" \
--bind="shift-left:execute-silent:$0 --seek-backward" \
--bind="focus:transform:
[ {3} ] && c=rebind || c=unbind
for key in enter alt-enter alt-space ctrl-n ctrl-p shift-right shift-left; do
printf \"+%s(%s)\" \"\$c\" \"\$key\"
done
" \
--bind="ctrl-l:accept" \
--bind="alt-b:execute-silent:xdg-open 'https://musicbrainz.org/release/{r2}' &" \
--bind="ctrl-d:half-page-down,ctrl-u:half-page-up" || true
)
lns=$(echo "$sel" | wc -l)
key=$(echo "$sel" | head -1 | tail -1)
mid=$(echo "$sel" | head -2 | tail -1)
[ "$lns" -eq 2 ] && [ ! "$key" ] && [ "$mid" ] && set -- "--releasegroup" "$mid"
[ "$lns" -eq 2 ] && [ "$key" = "ctrl-h" ] && set -- "--albums"
[ "$lns" -eq 2 ] && [ "$key" = "ctrl-a" ] && set -- "--select-artist" "$(mb_releasegroup "$mid" | $JQ -r -c '."artist-credit"')"
[ "$key" = "ctrl-c" ] && tput rmcup && exit 0
[ "$key" = "ctrl-q" ] && tput rmcup && exit 0
[ "$key" = "ctrl-/" ] && set -- "--search-album"
[ "$key" = "tab" ] && set -- "--artists"
;;
*)
sel=$(
$0 --internal-list-local-artists |
$FZF \
--no-clear \
--ansi \
--reverse \
--cycle \
--delimiter="\t" \
--prompt="$SEARCH_PROMPT" \
--info="inline-right" \
--info-command="echo \"Search music artist\"" \
--accept-nth="{2}" \
--with-nth="{1}" \
--preview-window="right,25%,border-left,wrap,<30(hidden)" \
--preview="$0 --internal-preview-artist {2}" \
--expect="ctrl-c,ctrl-q,tab" \
--expect="ctrl-/" \
--bind="alt-l:change-query($FORMAT_LOCAL )" \
--bind="load:unbind(enter)+unbind(alt-enter)+transform:[ \"\$FZF_TOTAL_COUNT\" -gt 0 ] && echo \"rebind:ctrl-l\" || echo \"unbind:ctrl-l\"" \
--bind="ctrl-l:accept" \
--bind="ctrl-d:half-page-down,ctrl-u:half-page-up" \
--bind="down:preview-half-page-down,up:preview-half-page-up" \
--bind="alt-b:execute-silent:xdg-open 'https://musicbrainz.org/artist/{r2}' &" || true
)
lns=$(echo "$sel" | wc -l)
key=$(echo "$sel" | head -1 | tail -1)
mid=$(echo "$sel" | head -2 | tail -1)
[ "$key" = "ctrl-c" ] && tput rmcup && exit 0
[ "$key" = "ctrl-q" ] && tput rmcup && exit 0
[ "$key" = "tab" ] && set -- "--albums"
[ "$key" = "ctrl-/" ] && set -- "--search-artist"
[ "$lns" -eq 2 ] && [ ! "$key" ] && [ "$mid" ] && set -- "--artist" "$mid"
;; ;;
esac esac
done done

View File

@@ -37,7 +37,7 @@ mpv_quit() {
mpv_start() { mpv_start() {
MPV_SOCKET="$(mktemp --suffix=.sock)" MPV_SOCKET="$(mktemp --suffix=.sock)"
trap 'mpv_quit; rm -f "$MPV_SOCKET"' EXIT INT trap 'mpv_quit >/dev/null; rm -f "$MPV_SOCKET"' EXIT INT
$MPV --no-config --no-terminal --input-ipc-server="$MPV_SOCKET" --idle --no-osc --no-input-default-bindings & $MPV --no-config --no-terminal --input-ipc-server="$MPV_SOCKET" --idle --no-osc --no-input-default-bindings &
} }

24
src/sh/keys.sh Normal file
View File

@@ -0,0 +1,24 @@
KEYS_HALFPAGE_DOWN="${KEYS_HALFPAGE_DOWN:-"ctrl-d"}"
KEYS_HALFPAGE_UP="${KEYS_HALFPAGE_UP:-"ctrl-u"}"
KEYS_BROWSE="${KEYS_BROWSE:-"alt-b"}"
KEYS_OUT="${KEYS_OUT:-"ctrl-h"}"
KEYS_IN="${KEYS_IN:-"ctrl-l"}"
KEYS_SELECT_ARTIST="${KEYS_SELECT_ARTIST:-"ctrl-a"}"
KEYS_FILTER_LOCAL="${KEYS_FILTER_LOCAL:-"alt-l"}"
KEYS_FILTER_PRIMARY="${KEYS_FILTER_PRIMARY:-"alt-1"}"
KEYS_FILTER_SECONDARY="${KEYS_FILTER_SECONDARY:-"alt-2"}"
KEYS_SWITCH_ARTIST_ALBUM="${KEYS_SWITCH_ARTIST_ALBUM:-"tab"}"
KEYS_SWITCH_LOCAL_REMOTE="${KEYS_SWITCH_LOCAL_REMOTE:-"ctrl-/"}"
KEYS_PLAY="${KEYS_PLAY:-"enter"}"
KEYS_QUEUE="${KEYS_QUEUE:-"alt-enter"}"
KEYS_TOGGLE_PLAY_PAUSE="${KEYS_TOGGLE_PLAY_PAUSE:-"space"}"
KEYS_PLAY_NEXT="${KEYS_PLAY_NEXT:-"l"}"
KEYS_PLAY_PREV="${KEYS_PLAY_PREV:-"h"}"
KEYS_SEEK_FORWARD="${KEYS_SEEK_FORWARD:-"shift-right"}"
KEYS_SEEK_BACKWARD="${KEYS_SEEK_BACKWARD:-"shift-left"}"
export KEYS_HALFPAGE_DOWN KEYS_HALFPAGE_UP KEYS_BROWSE KEYS_OUT KEYS_IN \
KEYS_SELECT_ARTIST KEYS_FILTER_LOCAL KEYS_FILTER_PRIMARY KEYS_FILTER_SECONDARY \
KEYS_SWITCH_ARTIST_ALBUM KEYS_SWITCH_LOCAL_REMOTE KEYS_PLAY KEYS_QUEUE \
KEYS_TOGGLE_PLAY_PAUSE KEYS_PLAY_NEXT KEYS_PLAY_PREV KEYS_SEEK_FORWARD \
KEYS_SEEK_BACKWARD

View File

@@ -139,3 +139,29 @@ list_local_releasegroups() {
list_local_releases() { list_local_releases() {
cat "$LOCALDATA_RELEASES_VIEW" 2>/dev/null cat "$LOCALDATA_RELEASES_VIEW" 2>/dev/null
} }
# Generate playlist from MB release ID and path to decoration
# @argument $1: MusicBrainz Release ID
# @argument $2: Path to decoration file
generate_playlist() {
dir="$(dirname "$2")"
mb_release "$1" |
$JQ -r --slurpfile deco "$2" --arg base "$dir" '$deco[].tracks as $filenames |
.media[] |
.position as $pos |
.tracks |
map({
$pos,
number: .number,
file: $filenames[.id]
}) |
map(
if(.number | type == "string" and test("^[0-9]+$")) then
.number |= tonumber
else
.
end
) |
sort_by([.pos, .number]) |
map($base + "/" + .file)[]'
}

View File

@@ -1,5 +1,5 @@
if command -v "fzf" >/dev/null; then if command -v "fzf" >/dev/null; then
FZF="fzf --black --ansi --reverse --cycle" FZF="fzf --black --ansi --cycle"
else else
err "Did not find the command-line fuzzy finder fzf." err "Did not find the command-line fuzzy finder fzf."
exit 1 exit 1