Compare commits
5 Commits
af8c7efae9
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| 38c5f9e6fa | |||
| 2c92313509 | |||
| aa25dc2530 | |||
| ce9f16e293 | |||
| ea16fb03d5 |
@@ -7,15 +7,16 @@ NAME="nmf"
|
||||
SRC="./src/main.sh"
|
||||
|
||||
tmpdir=$(mktemp -d)
|
||||
echo "🥚 ${GREEN}Internalize sourced files${OFF}"
|
||||
[ "${1:-}" ] || echo "🥚 ${GREEN}Internalize sourced files${OFF}"
|
||||
sed -E 's|\. "([^$].+)"$|cat src/\1|e' "$SRC" >"$tmpdir/1.sh"
|
||||
echo "🐔 ${GREEN}Internalize awk scripts${OFF}"
|
||||
[ "${1:-}" ] || echo "🐔 ${GREEN}Internalize awk scripts${OFF}"
|
||||
sed -E 's|@@include (.+)$|cat src/\1|e' "$tmpdir/1.sh" >"$tmpdir/2.sh"
|
||||
echo "🥚 ${GREEN}Internalize awk libraries${OFF}"
|
||||
[ "${1:-}" ] || echo "🥚 ${GREEN}Internalize awk libraries${OFF}"
|
||||
sed -E 's|@include "(.+)"$|cat src/\1|e' "$tmpdir/2.sh" >"$tmpdir/3.sh"
|
||||
echo "🐔 ${GREEN}Strip comments${OFF}"
|
||||
[ "${1:-}" ] || echo "🐔 ${GREEN}Strip comments${OFF}"
|
||||
grep -v "^ *# " "$tmpdir/3.sh" | grep -v "^ *#$" >"$NAME"
|
||||
echo "🥚 ${GREEN}Make executable and cleanup${OFF}"
|
||||
[ "${1:-}" ] || echo "🥚 ${GREEN}Make executable and cleanup${OFF}"
|
||||
chmod +x "$NAME"
|
||||
rm -rf "$tmpdir"
|
||||
echo "🍳 ${GREEN}Done:${OFF} Sucessfully built ${BOLD}${GREEN}$NAME${OFF}"
|
||||
[ "${1:-}" ] || echo "🍳 ${GREEN}Done:${OFF} Sucessfully built ${BOLD}${GREEN}$NAME${OFF}"
|
||||
[ "${1:-}" ] && shellcheck -f gcc "$NAME"
|
||||
|
||||
42
src/main.sh
42
src/main.sh
@@ -136,7 +136,7 @@ if [ "${1:-}" = "--archive" ]; then
|
||||
[ "$1" = "thread" ] && thread=1
|
||||
shift
|
||||
[ "${thread:-}" ] && field="thread" || field="id"
|
||||
query="$(echo " $@" | sed "s/\s\(\S\)/ $field:\1/g")"
|
||||
query="$(echo " $*" | sed "s/\s\(\S\)/ $field:\1/g")"
|
||||
tagmod="$(echo " $TAG_INBOX $TAGS_NEW" | sed "s/\s\(\S\)/ -\1/g")"
|
||||
$NOTMUCH tag $tagmod "$query"
|
||||
exit
|
||||
@@ -147,14 +147,14 @@ if [ "${1:-}" = "--delete" ]; then
|
||||
[ "$1" = "thread" ] && thread=1
|
||||
shift
|
||||
[ "${thread:-}" ] && field="thread" || field="id"
|
||||
query="$(echo " $@" | sed "s/\s\(\S\)/ $field:\1/g")"
|
||||
query="$(echo " $*" | sed "s/\s\(\S\)/ $field:\1/g")"
|
||||
$NOTMUCH tag -$TAG_INBOX +$TAG_DEL "$query"
|
||||
exit
|
||||
fi
|
||||
|
||||
if [ "${1:-}" = "--undelete" ]; then
|
||||
shift
|
||||
query="$(echo " $@" | sed "s/\s\(\S\)/ thread:\1/g")"
|
||||
query="$(echo " $*" | sed "s/\s\(\S\)/ thread:\1/g")"
|
||||
$NOTMUCH tag -$TAG_DEL "$query"
|
||||
exit
|
||||
fi
|
||||
@@ -164,7 +164,7 @@ if [ "${1:-}" = "--flag" ]; then
|
||||
[ "$1" = "thread" ] && thread=1
|
||||
shift
|
||||
[ "${thread:-}" ] && field="thread" || field="id"
|
||||
query="$(echo " $@" | sed "s/\s\(\S\)/ $field:\1/g")"
|
||||
query="$(echo " $*" | sed "s/\s\(\S\)/ $field:\1/g")"
|
||||
$NOTMUCH tag +"$TAG_FLAGGED" "$query"
|
||||
exit
|
||||
fi
|
||||
@@ -174,7 +174,7 @@ if [ "${1:-}" = "--unflag" ]; then
|
||||
[ "$1" = "thread" ] && thread=1
|
||||
shift
|
||||
[ "${thread:-}" ] && field="thread" || field="id"
|
||||
query="$(echo " $@" | sed "s/\s\(\S\)/ $field:\1/g")"
|
||||
query="$(echo " $*" | sed "s/\s\(\S\)/ $field:\1/g")"
|
||||
$NOTMUCH tag -"$TAG_FLAGGED" "$query"
|
||||
exit
|
||||
fi
|
||||
@@ -182,11 +182,10 @@ fi
|
||||
|
||||
if [ "${1:-}" = "--purge" ]; then
|
||||
shift
|
||||
# query="$(echo " $@" | sed "s/\s\(\S*\)/ (thread:\1 and tag:del)/g" | sed 's/)\(\s\+\)(/) or (/g')"
|
||||
query="tag:$TAG_DEL and ("$(echo " $@" | sed "s/\s\(\S\)/ thread:\1/g")")"
|
||||
query="tag:$TAG_DEL and ($(echo " $*" | sed "s/\s\(\S\)/ thread:\1/g"))"
|
||||
files=$(nm_files_all "$query")
|
||||
if ynprompt "Are you sure you want to purge these files?" "$files"; then
|
||||
echo -n "$files" | xargs -d "\n" rm
|
||||
printf '%s' "$files" | xargs -d "\n" rm
|
||||
nm_new
|
||||
fi
|
||||
exit
|
||||
@@ -199,7 +198,7 @@ if [ "${1:-}" = "--tag-modify" ]; then
|
||||
[ "$1" = "add" ] && sign=+ || sign=-
|
||||
shift
|
||||
[ "${thread:-}" ] && field="thread" || field="id"
|
||||
query="$(echo " $@" | sed "s/\s\(\S\)/ $field:\1/g")"
|
||||
query="$(echo " $*" | sed "s/\s\(\S\)/ $field:\1/g")"
|
||||
if [ "$sign" = "+" ]; then
|
||||
tagquery=""
|
||||
label_text="Add tag"
|
||||
@@ -220,7 +219,7 @@ if [ "${1:-}" = "--tag-modify" ]; then
|
||||
--border=double \
|
||||
--border-label=" $label_text " | head -1 || true)
|
||||
[ "$res" ] || exit
|
||||
$NOTMUCH tag $sign$res "$query"
|
||||
$NOTMUCH tag "$sign$res" "$query"
|
||||
exit
|
||||
fi
|
||||
|
||||
@@ -240,6 +239,7 @@ if [ "${1:-}" = "--show-thread" ]; then
|
||||
--bind="$KEYS_PREVIEW_UP:preview-up" \
|
||||
--bind="$KEYS_PREVIEW_DOWN_HP:preview-half-page-down" \
|
||||
--bind="$KEYS_PREVIEW_UP_HP:preview-half-page-up" \
|
||||
--bind="$KEYS_PREVIEW_TOGGLE_WRAP:toggle-preview-wrap-word" \
|
||||
--bind="$KEYS_CYCLE_DISPLAY:change-with-nth({1} {2} {3} ({4})|$FZF_DEFAULT_THREAD_LINE)" \
|
||||
--bind="$KEYS_DOWN_HP:half-page-down" \
|
||||
--bind="$KEYS_UP_HP:half-page-up" \
|
||||
@@ -255,7 +255,7 @@ if [ "${1:-}" = "--show-thread" ]; then
|
||||
--bind="$KEYS_OPEN:execute:$0 --open-part {5}" \
|
||||
--bind="$KEYS_FLAG:execute($0 --flag message {+5})+reload:$0 --list-messages-in-thread \"$thread\"" \
|
||||
--bind="$KEYS_UNFLAG:execute($0 --unflag message {+5})+reload:$0 --list-messages-in-thread \"$thread\"" \
|
||||
--bind="$KEYS_REPLY:execute:$0 --reply {5}" \
|
||||
--bind="$KEYS_REPLY:execute:$0 --reply message {5}" \
|
||||
--bind="$KEYS_VIEW_LOGS:execute:$0 --view-logs" \
|
||||
--bind="$KEYS_COMPOSE:execute:$0 --compose" \
|
||||
--bind="focus:change-preview($0 --preview-message {5})+transform-footer:printf '\033[4mMesssage parts\033[0m\n';$0 --show-message-parts {5}" \
|
||||
@@ -310,6 +310,7 @@ if [ "${1:-}" = "--compose" ]; then
|
||||
echo "From: $PRIMARY_NAME <$PRIMARY_EMAIL>"
|
||||
echo "To: $address"
|
||||
echo "Cc: "
|
||||
[ "$BCC_TO_SELF" ] && echo "Bcc: $PRIMARY_NAME <$PRIMARY_EMAIL>"
|
||||
echo "Subject: "
|
||||
echo ""
|
||||
echo "Message body goes here"
|
||||
@@ -323,9 +324,16 @@ fi
|
||||
|
||||
if [ "${1:-}" = "--reply" ]; then
|
||||
shift
|
||||
messageid="$1"
|
||||
[ "$1" = "thread" ] && thread=1
|
||||
shift
|
||||
[ ! "${thread:-}" ] && messageid="$1" || messageid="$(nm_last_message_in_thread "$1")"
|
||||
tmpfile=$(mktemp --suffix='.eml')
|
||||
if [ "$BCC_TO_SELF" ]; then
|
||||
$NOTMUCH reply id:"$messageid" |
|
||||
awk '!f && /^From:/ { print "Bcc: "substr($0, 7); f=1 } {print}' > "$tmpfile"
|
||||
else
|
||||
$NOTMUCH reply id:"$messageid" > "$tmpfile"
|
||||
fi
|
||||
$EDITOR "$tmpfile"
|
||||
# Confirm and send
|
||||
send "$tmpfile"
|
||||
@@ -343,6 +351,7 @@ if [ "${1:-}" = "--send-test-email" ]; then
|
||||
{
|
||||
echo "From: $PRIMARY_NAME <$PRIMARY_EMAIL>"
|
||||
echo "To: $PRIMARY_NAME <$PRIMARY_EMAIL>"
|
||||
[ "$BCC_TO_SELF" ] && echo "Bcc: $PRIMARY_NAME <$PRIMARY_EMAIL>"
|
||||
echo "Subject: Test E-Mail from $APP_NAME version $APP_VERSION"
|
||||
echo ""
|
||||
echo "This is a test email sent from from [$APP_NAME]($APP_WEBSITE)."
|
||||
@@ -413,6 +422,7 @@ while true; do
|
||||
--bind="$KEYS_PREVIEW_UP:preview-up" \
|
||||
--bind="$KEYS_PREVIEW_DOWN_HP:preview-half-page-down" \
|
||||
--bind="$KEYS_PREVIEW_UP_HP:preview-half-page-up" \
|
||||
--bind="$KEYS_PREVIEW_TOGGLE_WRAP:toggle-preview-wrap-word" \
|
||||
--bind="$KEYS_CANCEL:clear-multi" \
|
||||
--bind="$KEYS_ENTER:execute($0 --show-thread {4})+reload:$0 --list-threads \"$nmquery\"" \
|
||||
--bind="$KEYS_DOWN_HP:half-page-down" \
|
||||
@@ -430,8 +440,10 @@ while true; do
|
||||
--bind="$KEYS_SEARCH_UNREAD:print($CMD_GOTO_UNREAD)+accept" \
|
||||
--bind="$KEYS_SEARCH_FLAGGED:print($CMD_GOTO_FLAGGED)+accept" \
|
||||
--bind="$KEYS_VIEW_LOGS:execute:$0 --view-logs" \
|
||||
--bind="$KEYS_REPLY:execute:$0 --reply thread {4}" \
|
||||
--bind="$KEYS_SYNC:execute($0 --sync)+reload:$0 --list-threads \"$nmquery\"" \
|
||||
--bind="$KEYS_COMPOSE:execute:$0 --compose" \
|
||||
--bind="$KEYS_GOTO_FIRST:first" \
|
||||
--bind="focus:change-preview:$0 --preview-thread {4}" \
|
||||
--preview="$0 --preview-thread {4}" \
|
||||
--preview-window="$FZF_DEFAULT_PREVIEW_WINDOW" | head -1 || true)
|
||||
@@ -503,9 +515,9 @@ while true; do
|
||||
--border=double \
|
||||
--border-label=' Query history ' | head -1 || true)
|
||||
;;
|
||||
$CMD_GOTO_INBOX) nmquery="tag:$TAG_INBOX" ;;
|
||||
$CMD_GOTO_UNREAD) nmquery="tag:$TAG_UNREAD" ;;
|
||||
$CMD_GOTO_FLAGGED) nmquery="tag:$TAG_FLAGGED" ;;
|
||||
"$CMD_GOTO_INBOX") nmquery="tag:$TAG_INBOX" ;;
|
||||
"$CMD_GOTO_UNREAD") nmquery="tag:$TAG_UNREAD" ;;
|
||||
"$CMD_GOTO_FLAGGED") nmquery="tag:$TAG_FLAGGED" ;;
|
||||
*)
|
||||
;;
|
||||
esac
|
||||
|
||||
@@ -14,13 +14,14 @@ if [ ! "${CONFIG_LOADED:-}" ]; then
|
||||
|
||||
PRIMARY_NAME=${PRIMARY_NAME:-$($NOTMUCH config get user.name)}
|
||||
PRIMARY_EMAIL=${PRIMARY_EMAIL:-$($NOTMUCH config get user.primary_email)}
|
||||
BCC_TO_SELF=${BCC_TO_SELF:-}
|
||||
|
||||
if [ ! "${SMTPLOGFILE:-}" ]; then
|
||||
SMTPLOGFILE=$(mktemp)
|
||||
trap 'rm -f "$SMTPLOGFILE"' EXIT INT
|
||||
fi
|
||||
|
||||
export PRIMARY_NAME PRIMARY_EMAIL SET_TERMINAL_TITLE SMTPLOGFILE
|
||||
export PRIMARY_NAME PRIMARY_EMAIL BCC_TO_SELF SET_TERMINAL_TITLE SMTPLOGFILE
|
||||
|
||||
export CONFIG_LOADED=1
|
||||
fi
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
if [ ! "${HISTORY_LOADED:-}" ]; then
|
||||
export NMFHIST=$(mktemp)
|
||||
NMFHIST="$(mktemp)"
|
||||
export NMFHIST
|
||||
touch "$NMFHIST"
|
||||
trap 'rm -f "$NMFHIST"' EXIT INT
|
||||
|
||||
|
||||
@@ -3,61 +3,52 @@ if [ ! "${KEYS_LOADED:-}" ]; then
|
||||
# The keys are comma separated. See `fzf --man` for the possible keys.
|
||||
|
||||
# List
|
||||
KEYS_DOWN_HP="ctrl-d"
|
||||
KEYS_UP_HP="ctrl-u"
|
||||
KEYS_BACK="ctrl-h"
|
||||
KEYS_ENTER="enter,ctrl-l"
|
||||
KEYS_CANCEL="esc"
|
||||
KEYS_ENTER_ALTERNATIVE="alt-enter"
|
||||
KEYS_CYCLE_DISPLAY="ctrl-space"
|
||||
export KEYS_DOWN_HP="ctrl-d"
|
||||
export KEYS_UP_HP="ctrl-u"
|
||||
export KEYS_BACK="ctrl-h"
|
||||
export KEYS_ENTER="enter,ctrl-l"
|
||||
export KEYS_CANCEL="esc"
|
||||
export KEYS_ENTER_ALTERNATIVE="alt-enter"
|
||||
export KEYS_CYCLE_DISPLAY="ctrl-space"
|
||||
|
||||
KEYS_VIEW_SOURCE="alt-v"
|
||||
KEYS_HTML_PREVIEW="alt-h"
|
||||
KEYS_TAG_ADD="alt-+"
|
||||
KEYS_TAG_REMOVE="alt--"
|
||||
KEYS_ARCHIVE="ctrl-a"
|
||||
KEYS_DELETE="ctrl-delete"
|
||||
KEYS_FLAG="ctrl-x"
|
||||
KEYS_UNFLAG="ctrl-alt-x"
|
||||
KEYS_OPEN="ctrl-o"
|
||||
KEYS_REPLY="ctrl-r"
|
||||
KEYS_COMPOSE="ctrl-n"
|
||||
KEYS_VIEW_LOGS="alt-0"
|
||||
KEYS_SYNC="ctrl-s"
|
||||
export KEYS_VIEW_SOURCE="alt-v"
|
||||
export KEYS_HTML_PREVIEW="alt-h"
|
||||
export KEYS_TAG_ADD="alt-+"
|
||||
export KEYS_TAG_REMOVE="alt--"
|
||||
export KEYS_ARCHIVE="ctrl-a"
|
||||
export KEYS_DELETE="ctrl-delete"
|
||||
export KEYS_FLAG="ctrl-x"
|
||||
export KEYS_UNFLAG="ctrl-alt-x"
|
||||
export KEYS_OPEN="ctrl-o"
|
||||
export KEYS_REPLY="ctrl-r"
|
||||
export KEYS_COMPOSE="ctrl-n"
|
||||
export KEYS_VIEW_LOGS="alt-0"
|
||||
export KEYS_SYNC="ctrl-s"
|
||||
export KEYS_GOTO_FIRST="home"
|
||||
|
||||
# Preview window
|
||||
KEYS_PREVIEW_DOWN="alt-j"
|
||||
KEYS_PREVIEW_UP="alt-k"
|
||||
KEYS_PREVIEW_DOWN_HP="page-up"
|
||||
KEYS_PREVIEW_UP_HP="page-down"
|
||||
KEYS_PREVIEW_TOGGLE_SIZE="alt-/"
|
||||
export KEYS_PREVIEW_DOWN="alt-j"
|
||||
export KEYS_PREVIEW_UP="alt-k"
|
||||
export KEYS_PREVIEW_DOWN_HP="page-down"
|
||||
export KEYS_PREVIEW_UP_HP="page-up"
|
||||
export KEYS_PREVIEW_TOGGLE_SIZE="alt-/"
|
||||
export KEYS_PREVIEW_TOGGLE_WRAP="alt-w"
|
||||
|
||||
# Keys specific to purge window
|
||||
KEYS_PURGE_ALL="ctrl-alt-d"
|
||||
export KEYS_PURGE_ALL="ctrl-alt-d"
|
||||
|
||||
# Change main views
|
||||
KEYS_SEARCH_TAG_REPLCE="alt-t"
|
||||
KEYS_SEARCH_TAG_APPEND="alt-T"
|
||||
KEYS_SEARCH_FROM_REPLCE="alt-s"
|
||||
KEYS_SEARCH_FROM_APPEND="alt-S"
|
||||
KEYS_SEARCH_TO_REPLCE="alt-r"
|
||||
KEYS_SEARCH_TO_APPEND="alt-R"
|
||||
KEYS_SEARCH_EDIT_QUERY="alt-q"
|
||||
KEYS_SEARCH_DELETED="alt-d"
|
||||
KEYS_SEARCH_INBOX="alt-1"
|
||||
KEYS_SEARCH_UNREAD="alt-2"
|
||||
KEYS_SEARCH_FLAGGED="alt-3"
|
||||
|
||||
export KEYS_DOWN_HP KEYS_UP_HP KEYS_BACK KEYS_ENTER KEYS_CANCEL \
|
||||
KEYS_ENTER_ALTERNATIVE KEYS_CYCLE_DISPLAY KEYS_VIEW_SOURCE \
|
||||
KEYS_HTML_PREVIEW KEYS_TAG_ADD KEYS_TAG_REMOVE KEYS_ARCHIVE KEYS_DELETE \
|
||||
KEYS_FLAG KEYS_UNFLAG KEYS_OPEN KEYS_REPLY KEYS_COMPOSE KEYS_VIEW_LOGS \
|
||||
KEYS_SYNC KEYS_PREVIEW_DOWN KEYS_PREVIEW_UP KEYS_PREVIEW_DOWN_HP \
|
||||
KEYS_PREVIEW_UP_HP KEYS_PREVIEW_TOGGLE_SIZE KEYS_SEARCH_TAG_REPLCE \
|
||||
KEYS_SEARCH_TAG_APPEND KEYS_SEARCH_FROM_REPLCE KEYS_SEARCH_FROM_APPEND \
|
||||
KEYS_SEARCH_TO_REPLCE KEYS_SEARCH_TO_APPEND KEYS_SEARCH_EDIT_QUERY \
|
||||
KEYS_SEARCH_DELETED KEYS_SEARCH_INBOX KEYS_SEARCH_UNREAD \
|
||||
KEYS_SEARCH_FLAGGED
|
||||
export KEYS_SEARCH_TAG_REPLCE="alt-t"
|
||||
export KEYS_SEARCH_TAG_APPEND="alt-T"
|
||||
export KEYS_SEARCH_FROM_REPLCE="alt-s"
|
||||
export KEYS_SEARCH_FROM_APPEND="alt-S"
|
||||
export KEYS_SEARCH_TO_REPLCE="alt-r"
|
||||
export KEYS_SEARCH_TO_APPEND="alt-R"
|
||||
export KEYS_SEARCH_EDIT_QUERY="alt-q"
|
||||
export KEYS_SEARCH_DELETED="alt-d"
|
||||
export KEYS_SEARCH_INBOX="alt-1"
|
||||
export KEYS_SEARCH_UNREAD="alt-2"
|
||||
export KEYS_SEARCH_FLAGGED="alt-3"
|
||||
|
||||
export KEYS_LOADED=1
|
||||
fi
|
||||
|
||||
@@ -9,8 +9,7 @@ nm_new() {
|
||||
# Print the message id of the last message within a thread.
|
||||
# @argument $1: thread id
|
||||
nm_last_message_in_thread() {
|
||||
# TODO: We may be smarter here that just incorporating excluded messages
|
||||
$NOTMUCH search --output=messages --sort=oldest-first --offset=-1 thread:"$1" | sed 's/^...//'
|
||||
$NOTMUCH search --output=messages --sort=newest-first --limit=1 thread:"$1" | sed 's/^...//'
|
||||
}
|
||||
|
||||
# Print the header of a message (with trailing empty line)
|
||||
|
||||
@@ -11,7 +11,6 @@
|
||||
# @argument #3: if set, then the HTML messages will be taken
|
||||
preview_message() {
|
||||
[ "$1" = "id" ] && messageid="$2" || messageid="$(nm_last_message_in_thread "$2")"
|
||||
parts="$(nm_message_parts "$messageid")"
|
||||
html="${3:-}"
|
||||
nr="$(nm_message_part_nr "$messageid" "$html")"
|
||||
[ ! "$nr" ] && [ ! "$html" ] && html="html" && nr="$(nm_message_part_nr "$messageid" "html")"
|
||||
|
||||
@@ -2,12 +2,12 @@
|
||||
# @argument $1: Path to email file
|
||||
# @argument $2: if set, don't prompt the user (optional)
|
||||
send() {
|
||||
if [ ! "${2:-}" ] && ! ynprompt "Do you want to send this email?" "$($CATEMAIL $tmpfile)"; then
|
||||
if [ ! "${2:-}" ] && ! ynprompt "Do you want to send this email?" "$($CATEMAIL "$tmpfile")"; then
|
||||
return
|
||||
fi
|
||||
$MSMTP -t --read-envelope-from -X "$SMTPLOGFILE" < "$1" >/dev/null 2>&1 || true
|
||||
log=$(tail -1 "$SMTPLOGFILE")
|
||||
if [ "${2:-}" ] || echo -n "$log" | grep -q '\bsmtpstatus=250\b'; then
|
||||
if [ "${2:-}" ] || printf '%s' "$log" | grep -q '\bsmtpstatus=250\b'; then
|
||||
return
|
||||
fi
|
||||
# Handle errors
|
||||
|
||||
@@ -9,7 +9,7 @@ if [ ! "${THEME_LOADED:-}" ]; then
|
||||
COLCNTS="$(printf '\033[38;5;%sm' "$ANSICOLORCNTS")"
|
||||
COLFROM="$(printf '\033[38;5;%sm' "$ANSICOLORFROM")"
|
||||
COLSUBJ="$(printf '\033[38;5;%sm\033[3m' "$ANSICOLORSUBJ")"
|
||||
COLTAGS="$(printf '\033[38;5;%sm\033[2m' "$ANSICOLORTAGS")"
|
||||
COLTAGS="$(printf '\033[38;5;%sm' "$ANSICOLORTAGS")"
|
||||
COLRESET="$(printf '\033[0m')"
|
||||
|
||||
export ANSICOLORDATE ANSICOLORCNTS ANSICOLORFROM ANSICOLORSUBJ ANSICOLORTAGS
|
||||
|
||||
@@ -5,7 +5,7 @@
|
||||
# @argument $2: Content to show in preview window
|
||||
# @return: 0 if the user answered "yes" and 1 otherwise.
|
||||
ynprompt() {
|
||||
return $(printf '0 \033[32myes\033[0m\n1 \033[31mno\033[0m\n' |
|
||||
return "$(printf '0 \033[32myes\033[0m\n1 \033[31mno\033[0m\n' |
|
||||
$FZF \
|
||||
--sync \
|
||||
--bind='start:pos(2)' \
|
||||
@@ -19,7 +19,7 @@ ynprompt() {
|
||||
--with-nth=2.. \
|
||||
--accept-nth=1 \
|
||||
--header-border='line' \
|
||||
--color='border:yellow,header:yellow')
|
||||
--color='border:yellow,header:yellow')"
|
||||
}
|
||||
|
||||
# This prompts the user for a series of options.
|
||||
@@ -43,17 +43,3 @@ multiprompt() {
|
||||
--bind="ctrl-c,esc,ctrl-q:" \
|
||||
--color='border:yellow,header:yellow' | head -1 || true
|
||||
}
|
||||
|
||||
# ASCII-encode address
|
||||
# asciiaddress() {
|
||||
# firstword=1
|
||||
# for word in $*; do
|
||||
# [ "${firstword:-}" ] || echo -n ' ' && firstword=
|
||||
# case $word in
|
||||
# *[![:cntrl:][:print:]]*) echo -n $word ;;
|
||||
# *) return 0 ;;
|
||||
# esac
|
||||
# isascii "$word" && echo -n "$word" || echo -n "=?UTF-8?B?$(echo -n "$word" | base64)?="
|
||||
# done
|
||||
# }
|
||||
|
||||
|
||||
Reference in New Issue
Block a user