contrib/mrss.sh: made changes
- mrss select is no longer here (rip), no reason to support it - you can now make meta-feeds by making folders of directory symlinks - jq: sub -> gsub
This commit is contained in:
parent
8e46602e19
commit
1959be7ffd
102
contrib/mrss.sh
102
contrib/mrss.sh
@ -23,13 +23,12 @@ sub_help() {
|
|||||||
echo
|
echo
|
||||||
echo "commands:"
|
echo "commands:"
|
||||||
echo " update updates feeds"
|
echo " update updates feeds"
|
||||||
echo " select show each new article and prompt for an action;"
|
|
||||||
echo " you can run 'select new/feed' for a specific feed"
|
|
||||||
echo " or 'select watch-later'."
|
|
||||||
echo " fzf show articles using fzf"
|
echo " fzf show articles using fzf"
|
||||||
echo " use the commands /read (enter), /purge (ctrl-d), /purge-all (ctrl-alt-d),"
|
echo " use the commands /read (enter), /purge (ctrl-d), /purge-all (ctrl-alt-d),"
|
||||||
echo " /watch-later (ctrl-w) and /queue (ctrl-e)"
|
echo " /watch-later (ctrl-w) and /queue (ctrl-e)"
|
||||||
echo " you can also run 'fzf feed' for a specific feed."
|
echo " you can also 'fzf feed' for a specific feed,"
|
||||||
|
echo " or 'fzf new/feed' for new articles in the feed,"
|
||||||
|
echo " or 'fzf watch-later' for articles marked watch-later."
|
||||||
echo " 'fzf -s' shuffles the feed."
|
echo " 'fzf -s' shuffles the feed."
|
||||||
echo
|
echo
|
||||||
echo "article commands (pass files as arguments):"
|
echo "article commands (pass files as arguments):"
|
||||||
@ -77,7 +76,7 @@ list_purge() {
|
|||||||
sub_purge() {
|
sub_purge() {
|
||||||
if [ -z "$@" ]; then
|
if [ -z "$@" ]; then
|
||||||
cd "$MRSS_DIR"/new
|
cd "$MRSS_DIR"/new
|
||||||
find . -type l -or -type f | list_purge
|
find . -type f | list_purge
|
||||||
else
|
else
|
||||||
for art in "$@"; do
|
for art in "$@"; do
|
||||||
printf "%s\n" "$art"
|
printf "%s\n" "$art"
|
||||||
@ -186,64 +185,6 @@ sub_watchlater() {
|
|||||||
done | list_watchlater
|
done | list_watchlater
|
||||||
}
|
}
|
||||||
|
|
||||||
sub_select() {
|
|
||||||
if [ -z "$1" ]; then
|
|
||||||
DIR="$MRSS_NEWDIR"
|
|
||||||
else
|
|
||||||
DIR="$MRSS_DIR/$1"
|
|
||||||
fi
|
|
||||||
NEWARTS="$(find "$DIR" -type l -or -type f)"
|
|
||||||
TOTAL_COUNT="$(printf "%s" "$NEWARTS" | wc -l)"
|
|
||||||
printf "%s" "$NEWARTS" | (
|
|
||||||
|
|
||||||
INDEX=0
|
|
||||||
while read -r ARTICLE; do
|
|
||||||
if [ -n "$SKIPALL" ]; then
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
|
|
||||||
INDEX=$((INDEX+1))
|
|
||||||
clear
|
|
||||||
printf "\nItem %s/%s\n" "$INDEX" "$TOTAL_COUNT"
|
|
||||||
sub_preview "$ARTICLE"
|
|
||||||
|
|
||||||
printf "\n\n-----------------\n"
|
|
||||||
printf "\nq quit, r read, e queue article, f full summary, d purge (mark read),\n"
|
|
||||||
printf "s skip, S skip all, w watch later\n"
|
|
||||||
|
|
||||||
while true; do
|
|
||||||
printf "\n> "
|
|
||||||
read ans </dev/tty
|
|
||||||
case "$ans" in
|
|
||||||
q ) exit;;
|
|
||||||
r ) sub_read "$ARTICLE"; break;;
|
|
||||||
e )
|
|
||||||
if [ -n "$QUEUE" ]; then
|
|
||||||
QUEUE=$(printf "%s\n%s" "$QUEUE" "$ARTICLE")
|
|
||||||
else
|
|
||||||
QUEUE="$ARTICLE"
|
|
||||||
fi
|
|
||||||
break;;
|
|
||||||
f )
|
|
||||||
cat "$ARTICLE" | jq -r '.description // ""' | w3m -o confirm_qq=false -T text/html
|
|
||||||
;;
|
|
||||||
d )
|
|
||||||
sub_purge "$ARTICLE"
|
|
||||||
break;;
|
|
||||||
s ) break;;
|
|
||||||
S ) SKIPALL="y"; break;;
|
|
||||||
w ) sub_watchlater "$ARTICLE"
|
|
||||||
break;;
|
|
||||||
* ) break;;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
done &&
|
|
||||||
if [ -n "$QUEUE" ]; then
|
|
||||||
printf "%s\n" "$QUEUE" | list_read
|
|
||||||
fi
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
list_fzf_filename() {
|
list_fzf_filename() {
|
||||||
# searches entry in index and returns its filename
|
# searches entry in index and returns its filename
|
||||||
while read -r ENTRY; do
|
while read -r ENTRY; do
|
||||||
@ -259,6 +200,37 @@ sub_fzf_preview() {
|
|||||||
sub_preview "$(echo "$ENTRY" | list_fzf_filename "$INDXFILE")"
|
sub_preview "$(echo "$ENTRY" | list_fzf_filename "$INDXFILE")"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mrss_find() {
|
||||||
|
# a meta-feed should only have directory links
|
||||||
|
# if there is a file link, use the way faster approach to list files
|
||||||
|
if [ -f "$(realpath "$(ls | head -n 1)")" ]; then
|
||||||
|
find . -mindepth 1 -maxdepth 1 -or -type f -or -type l
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
# follow directory links, but not file links
|
||||||
|
# this means you can make your own tag folders that link to specific feeds
|
||||||
|
# we don't follow file links because mrss purge only deletes links from new/
|
||||||
|
|
||||||
|
find . -mindepth 1 -maxdepth 1 -type d -or -type f -or -type l | \
|
||||||
|
(while read -r f; do
|
||||||
|
# this loop finds directories (symlink or real)
|
||||||
|
# regular files go through this pipeline unaffected
|
||||||
|
# symlink files are discarded
|
||||||
|
if [ -f "$f" ] || [ -d "$f" ]; then
|
||||||
|
printf "%s\n" "$f"
|
||||||
|
elif [ -h "$f" ]; then
|
||||||
|
if [ -d "$(realpath "$f")" ]; then
|
||||||
|
printf "%s\n" "$f"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done) | \
|
||||||
|
(while read -r f; do
|
||||||
|
# this loop lists directories
|
||||||
|
find -H "$f" -type f -or -type l
|
||||||
|
done)
|
||||||
|
}
|
||||||
|
|
||||||
sub_fzf() {
|
sub_fzf() {
|
||||||
while getopts ":s" flag; do
|
while getopts ":s" flag; do
|
||||||
case "$flag" in
|
case "$flag" in
|
||||||
@ -278,14 +250,14 @@ sub_fzf() {
|
|||||||
INDXFILE=`mktemp --suffix=mrss`
|
INDXFILE=`mktemp --suffix=mrss`
|
||||||
|
|
||||||
COUNTER="1"
|
COUNTER="1"
|
||||||
find . -type l -or -type f \
|
mrss_find \
|
||||||
| ([ -n "$MRSS_SHUF" ] && shuf || cat) \
|
| ([ -n "$MRSS_SHUF" ] && shuf || cat) \
|
||||||
| nl -ba -d'' -n'rz' -s': ' -w1 \
|
| nl -ba -d'' -n'rz' -s': ' -w1 \
|
||||||
> "$INDXFILE"
|
> "$INDXFILE"
|
||||||
|
|
||||||
cat "$INDXFILE" | sed "s/^[0-9]*: //" \
|
cat "$INDXFILE" | sed "s/^[0-9]*: //" \
|
||||||
| xargs -rd "\n" cat \
|
| xargs -rd "\n" cat \
|
||||||
| jq -r '[.feedname?, .title] | map(select(. != null)) | join(" - ") | sub("\n"; " ")' \
|
| jq -r '[.feedname?, .title] | map(select(. != null)) | join(" - ") | gsub("\n"; " ")' \
|
||||||
| nl -ba -d'' -n'rz' -s': ' -w1 \
|
| nl -ba -d'' -n'rz' -s': ' -w1 \
|
||||||
> "$LISTFILE"
|
> "$LISTFILE"
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user