__PRINT() { local COLOR="$1" local MESSAGE="$2" local LINE_END [ $3 ] && LINE_END='' || LINE_END='\n' printf "${COLOR}${MESSAGE}${__COLOR_RESET}${LINE_END}" } __ERROR() { __PRINT $__RED "ERROR ✖ : $@" >&2; ((ERRORS+=1)); } __SUCCESS() { __PRINT $__GREEN "SUCCESS ✔ : $@" >&2; } __WARNING() { __PRINT $__ORANGE "WARNING  : $@" >&2; } __STATUS() { __PRINT $__BLUE "STATUS : $@" >&2; } __REMINDER() { __PRINT $__PURPLE "REMINDER  : $@" >&2; } __INFO() { __PRINT $__WHITE "INFO  : $@" >&2; } __PROMPT() { __PRINT $__CYAN "PROMPT  : $@" >&2 __PRINT $__CYAN "USER  : " --no-end >&2 } __FAIL() { __ERROR "${@:2}"; exit $1; } __ABORT() { __FAIL 69 'user abort'; } __ERROR_CHECK() { [ ! $ERRORS ] && ERRORS=0 [[ $ERRORS -ne 0 ]] && __USAGE [[ $ERRORS -eq 0 ]] || exit $ERRORS } __USAGE() { [ ! $USAGE ] && return 0 USAGE=$(echo $USAGE | sed "s/^\t\+//; s/\s\+$//") local USAGE_LINE=$(\ echo $USAGE \ | grep -i '^ *usage *:' \ | sed "s;^[^:]*:;& scwrypts -- $SCWRYPT_NAME;" \ | sed 's/ \{2,\}/ /g; s/scwrypts -- scwrypts/scwrypts/' \ ) local THE_REST=$(echo $USAGE | grep -vi '^ *usage *:' | sed 'N;/^\n$/D;P;D;') { echo; __PRINT $__DARK_BLUE "$USAGE_LINE"; echo $THE_REST; echo } >&2 } __INPUT() { __PROMPT "${@:2}" __READ $1 local VALUE=$(eval echo '$'$1) [ $VALUE ] } __Yn() { __PROMPT "$@ [Yn]" [ $CI ] && { echo y; return 0; } local Yn; __READ -k Yn; echo [[ $Yn =~ [nN] ]] && return 1 || return 0 } __yN() { __PROMPT "$@ [yN]" [ $CI ] && { echo y; return 0; } local yN; __READ -k yN; echo [[ $yN =~ [yY] ]] && return 0 || return 1 } ##################################################################### __GETSUDO() { echo "\\033[1;36mPROMPT  : checking sudo password...\\033[0m" >&2 sudo echo hi >/dev/null 2>&1 /dev/tty; } __FZF() { [ $CI ] && { __ERROR 'currently in CI, but __FZF requires user input' exit 1 } fzf -i --height=30% --layout=reverse --prompt "$1 : " ${@:2} } __FZF_HEAD() { __FZF $@ --print-query | sed '/^$/d' | head -n1; } # prefer user input over selected __FZF_TAIL() { __FZF $@ --print-query | sed '/^$/d' | tail -n1; } # prefer selected over user input __READ() { [ $CI ] && { __ERROR 'currently in CI, but __READ explicitly requires terminal input' return 1 } read $@ /dev/tty __SUCCESS "finished editing '$1'!" }