From: Layerex Date: Mon, 23 May 2022 12:48:11 +0000 (+0300) Subject: Call jq only once and optimize string decoding (#58) X-Git-Tag: v0.2.0.0~21 X-Git-Url: https://glassweightruler.freedombox.rocks/gitweb/xdg-ninja.git/commitdiff_plain/0e4ada6e9f469f9eafe61f8335fc3cd01927f878 Call jq only once and optimize string decoding (#58) * Fix comment * Call jq only once * Optimize string decoding --- diff --git a/xdg-ninja.sh b/xdg-ninja.sh index 8fe952f..6c8a2f2 100755 --- a/xdg-ninja.sh +++ b/xdg-ninja.sh @@ -87,7 +87,7 @@ apply_shell_expansion() { } # Returns 0 if the path doesn't lead anywhere -# Return 1 if the path points to a file, 2 if it points to a directory +# Returns 1 if the path leads to something check_if_file_exists() { FILE_PATH=$(apply_shell_expansion "$1") if [ -e "$FILE_PATH" ]; then @@ -97,6 +97,11 @@ check_if_file_exists() { fi } +decode_string() { + printf "%s\n" "$1" | sed -e 's/\\n/\ +/g' -e 's/\\\"/\"/g' # Replace \n with literal newline and \" with " +} + # Function to handle the formatting of output log() { MODE="$1" @@ -125,11 +130,11 @@ log() { HELP) if $USE_GLOW; then - printf "%s\n" "$HELP" | glow - + decode_string "$HELP" | glow - elif $USE_BAT; then - printf "%s\n" "$HELP" | bat -pp --decorations=always --color=always --language markdown + decode_string "$HELP" | bat -pp --decorations=always --color=always --language markdown else - printf "%s\n" "$HELP" + decode_string "$HELP" fi ;; @@ -167,36 +172,25 @@ check_file() { esac } -decode_string() { - tmp="${1#\"}" # Trim leading quote - tmp="${tmp%\"}" # Trim traling quote - printf "%s" "$(echo "$tmp" | sed -e 's/\\n/\ -/g' -e 's/\\\"/\"/g')" # Replace \n with literal newline and \" with " -} - -# Reads a file from programs/, calls check_file on each file specified for the program -check_program() { - PROGRAM=$1 - +# Reads files from programs/, calls check_file on each file specified for each program +do_check_programs() { while IFS=" " read -r name; read -r filename; read -r movable; read -r help; do - check_file "$(decode_string "$name")" "$(decode_string "$filename")" "$movable" "$(decode_string "$help")" + check_file "$name" "$filename" "$movable" "$help" done <