X-Git-Url: https://glassweightruler.freedombox.rocks/gitweb/xdg-ninja.git/blobdiff_plain/18d848aaf63e169f92602686cd59ad17c0b3c6de..7fd93c796799385fb4f5f953cd2c54bfb2122f22:/xdg-ninja.sh diff --git a/xdg-ninja.sh b/xdg-ninja.sh index d873df2..8fe952f 100755 --- a/xdg-ninja.sh +++ b/xdg-ninja.sh @@ -1,5 +1,4 @@ #!/usr/bin/env sh -# shellcheck disable=SC2016 USE_GLOW=false USE_BAT=false @@ -20,19 +19,19 @@ unalias -a HELPSTRING="""\ - \e[37;45;1mxdg-ninja\e[0m + \033[37;45;1mxdg-ninja\033[0m - \e[1;3mCheck your \$HOME for unwanted files.\e[1;0m + \033[1;3mCheck your \$HOME for unwanted files.\033[1;0m ──────────────────────────────────── - \e[3m--help\e[0m \e[1mThis help menu\e[0m - \e[3m-h\e[0m + \033[3m--help\033[0m \033[1mThis help menu\033[0m + \033[3m-h\033[0m - \e[3m--no-skip-ok\e[0m \e[1mDisplay messages for all files checked (verbose)\e[0m - \e[3m-v\e[0m + \033[3m--no-skip-ok\033[0m \033[1mDisplay messages for all files checked (verbose)\033[0m + \033[3m-v\033[0m - \e[3m--skip-ok\e[0m \e[1mDon't display anything for files that do not exist (default)\e[0m + \033[3m--skip-ok\033[0m \033[1mDon't display anything for files that do not exist (default)\033[0m """ @@ -51,28 +50,28 @@ for i in "$@"; do done if [ -z "${XDG_DATA_HOME}" ]; then - printf '\e[1;36m%s\e[1;0m\n' "The \$XDG_DATA_HOME environment variable is not set, make sure to add it to your shell's configuration before setting any of the other environment variables!" - printf '\e[1;36m ⤷ \e[1mThe recommended value is: \e[1;3m$HOME/.local/share\e[1;0m\n' + printf '\033[1;36m%s\033[1;0m\n' "The \$XDG_DATA_HOME environment variable is not set, make sure to add it to your shell's configuration before setting any of the other environment variables!" + printf "\033[1;36m ⤷ \033[1mThe recommended value is: \033[1;3m\$HOME/.local/share\033[1;0m\n" fi if [ -z "${XDG_CONFIG_HOME}" ]; then - printf '\e[1;36m%s\e[1;0m\n' "The \$XDG_CONFIG_HOME environment variable is not set, make sure to add it to your shell's configuration before setting any of the other environment variables!" - printf '\e[1;36m ⤷ \e[1mThe recommended value is: \e[1;3m$HOME/.config\e[1;0m\n' + printf '\033[1;36m%s\033[1;0m\n' "The \$XDG_CONFIG_HOME environment variable is not set, make sure to add it to your shell's configuration before setting any of the other environment variables!" + printf "\033[1;36m ⤷ \033[1mThe recommended value is: \033[1;3m\$HOME/.config\033[1;0m\n" fi if [ -z "${XDG_STATE_HOME}" ]; then - printf '\e[1;36m%s\e[1;0m\n' "The \$XDG_STATE_HOME environment variable is not set, make sure to add it to your shell's configuration before setting any of the other environment variables!" - printf '\e[1;36m ⤷ \e[1mThe recommended value is: \e[1;3m$HOME/.local/state\e[1;0m\n' + printf '\033[1;36m%s\033[1;0m\n' "The \$XDG_STATE_HOME environment variable is not set, make sure to add it to your shell's configuration before setting any of the other environment variables!" + printf "\033[1;36m ⤷ \033[1mThe recommended value is: \033[1;3m\$HOME/.local/state\033[1;0m\n" fi if [ -z "${XDG_CACHE_HOME}" ]; then - printf '\e[1;36m%s\e[1;0m\n' "The \$XDG_CACHE_HOME environment variable is not set, make sure to add it to your shell's configuration before setting any of the other environment variables!" - printf '\e[1;36m ⤷ \e[1mThe recommended value is: \e[1;3m$HOME/.cache\e[1;0m\n' + printf '\033[1;36m%s\033[1;0m\n' "The \$XDG_CACHE_HOME environment variable is not set, make sure to add it to your shell's configuration before setting any of the other environment variables!" + printf "\033[1;36m ⤷ \033[1mThe recommended value is: \033[1;3m\$HOME/.cache\033[1;0m\n" fi if [ -z "${XDG_RUNTIME_DIR}" ]; then - printf '\e[1;36m%s\e[1;0m\n' "The \$XDG_RUNTIME_DIR environment variable is not set, make sure to add it to your shell's configuration before setting any of the other environment variables!" - printf '\e[1;36m ⤷ \e[1mThe recommended value is: \e[1;3m/run/user/$UID\e[1;0m\n' + printf '\033[1;36m%s\033[1;0m\n' "The \$XDG_RUNTIME_DIR environment variable is not set, make sure to add it to your shell's configuration before setting any of the other environment variables!" + printf "\033[1;36m ⤷ \033[1mThe recommended value is: \033[1;3m/run/user/\$UID\033[1;0m\n" fi if ! command -v jq >/dev/null 2>/dev/null; then - printf "jq is needed to run this script, but it wasn't found. Please install it to be able to use this script." + printf "jq is needed to run this script, but it wasn't found. Please install it to be able to use this script.\n" exit fi @@ -89,12 +88,10 @@ 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() { +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 @@ -110,27 +107,27 @@ log() { case "$MODE" in ERR) - printf '[\e[1;31m%s\e[1;0m]: \e[1;3m%s\e[1;0m\n' "$NAME" "$FILENAME" + printf '[\033[1;31m%s\033[1;0m]: \033[1;3m%s\033[1;0m\n' "$NAME" "$FILENAME" ;; WARN) - printf '[\e[1;33m%s\e[1;0m]: \e[1;3m%s\e[1;0m\n' "$NAME" "$FILENAME" + printf '[\033[1;33m%s\033[1;0m]: \033[1;3m%s\033[1;0m\n' "$NAME" "$FILENAME" ;; INFO) - printf '[\e[1;36m%s\e[1;0m]: \e[1;3m%s\e[1;0m\n' "$NAME" "$FILENAME" + printf '[\033[1;36m%s\033[1;0m]: \033[1;3m%s\033[1;0m\n' "$NAME" "$FILENAME" ;; SUCS) [ "$SKIP_OK" = false ] && - printf '[\e[1;32m%s\e[1;0m]: \e[1;3m%s\e[1;0m\n' "$NAME" "$FILENAME" + printf '[\033[1;32m%s\033[1;0m]: \033[1;3m%s\033[1;0m\n' "$NAME" "$FILENAME" ;; HELP) if $USE_GLOW; then printf "%s\n" "$HELP" | glow - elif $USE_BAT; then - printf "%s\n" "$HELP" | bat -pp -f --language markdown + printf "%s\n" "$HELP" | bat -pp --decorations=always --color=always --language markdown else printf "%s\n" "$HELP" fi @@ -141,14 +138,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 @@ -156,7 +151,7 @@ check_file() { log SUCS "$NAME" "$FILENAME" "$HELP" ;; - 1 | 2) + 1) if "$MOVABLE"; then log ERR "$NAME" "$FILENAME" "$HELP" else @@ -172,29 +167,35 @@ 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() { - INPUT=$1 - - NAME=$(printf "%s" "$INPUT" | jq -r .name) + PROGRAM=$1 - while IFS= read -r file; do - check_file "$file" "$NAME" + 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")" done <