X-Git-Url: https://glassweightruler.freedombox.rocks/gitweb/xdg-ninja.git/blobdiff_plain/2c4c10ff39288bb476d00211302c5787fc8343f1..f0e4b7f74bd2069ed8739319b588fbd6dfa91cbb:/xdg-ninja.sh diff --git a/xdg-ninja.sh b/xdg-ninja.sh index 602f262..6c8a2f2 100755 --- a/xdg-ninja.sh +++ b/xdg-ninja.sh @@ -87,18 +87,21 @@ 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 -check_not_exists_file() { +# Returns 1 if the path leads to something +check_if_file_exists() { FILE_PATH=$(apply_shell_expansion "$1") - if [ -f "$FILE_PATH" ]; then + if [ -e "$FILE_PATH" ]; then return 1 - elif [ -d "$FILE_PATH" ]; then - return 2 else return 0 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" @@ -127,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 ;; @@ -140,14 +143,12 @@ log() { # Checks that the given file does not exist, otherwise outputs help check_file() { - INPUT="$1" - NAME="$2" - - FILENAME=$(printf "%s" "$INPUT" | jq -r .path) - MOVABLE=$(printf "%s" "$INPUT" | jq -r .movable) - HELP=$(printf "%s" "$INPUT" | jq -r .help) + NAME="$1" + FILENAME="$2" + MOVABLE="$3" + HELP="$4" - check_not_exists_file "$FILENAME" + check_if_file_exists "$FILENAME" case $? in @@ -155,7 +156,7 @@ check_file() { log SUCS "$NAME" "$FILENAME" "$HELP" ;; - 1 | 2) + 1) if "$MOVABLE"; then log ERR "$NAME" "$FILENAME" "$HELP" else @@ -171,30 +172,25 @@ check_file() { esac } -# Reads a file from programs/, calls check_file on each file specified for the program -check_program() { - PROGRAM=$1 - - NAME=$(jq -r .name "$PROGRAM") - - while IFS= read -r file; do - check_file "$file" "$NAME" +# 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 "$name" "$filename" "$movable" "$help" done <