X-Git-Url: https://glassweightruler.freedombox.rocks/gitweb/xdg-ninja.git/blobdiff_plain/9125c23023c8edb7f62eea198894cb78ef5aaf32..b6d3bc4e2f25365294a4bcd2ecebee64b919770c:/xdg-ninja.sh diff --git a/xdg-ninja.sh b/xdg-ninja.sh index d52c6a3..aa751bd 100755 --- a/xdg-ninja.sh +++ b/xdg-ninja.sh @@ -1,10 +1,11 @@ -#!/bin/bash +#!/usr/bin/env sh +# shellcheck disable=SC2016 USE_GLOW=true -if ! command -v glow &>/dev/null; then - echo "Glow not found, markdown rendering not available." - echo "Output will be raw markdown and might look weird." - echo "Install glow for easier reading & copy-paste." +if ! command -v glow >/dev/null 2>/dev/null; then + printf "Glow not found, markdown rendering not available." + printf "Output will be raw markdown and might look weird." + printf "Install glow for easier reading & copy-paste." USE_GLOW=false fi @@ -31,29 +32,52 @@ HELPSTRING="""\ SKIP_OK=true for i in "$@"; do - if [[ $i == "--help" ]] || [[ $i == "-h" ]]; then - echo -e "$HELPSTRING" + if [ "$i" = "--help" ] || [ "$i" = "-h" ]; then + printf "%b" "$HELPSTRING" exit - elif [[ $i == "--skip-ok" ]]; then + elif [ "$i" = "--skip-ok" ]; then SKIP_OK=true - elif [[ $i == "--no-skip-ok" ]]; then + elif [ "$i" = "--no-skip-ok" ]; then SKIP_OK=false - elif [[ $i == "-v" ]]; then + elif [ "$i" = "-v" ]; then SKIP_OK=false fi done -if ! command -v jq &>/dev/null; then - echo "jq is needed to run this script, but it wasn't found. Please install it to be able to use this script." +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' +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' +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' +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' +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' +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." exit fi -# Function to expand enviornment variables in string +printf "\n" + +# Function to expand environment variables in string # https://stackoverflow.com/a/20316582/11110290 apply_shell_expansion() { - declare data="$1" - declare delimiter="__apply_shell_expansion_delimiter__" - declare command="cat <<$delimiter"$'\n'"$data"$'\n'"$delimiter" + data="$1" + delimiter="__apply_shell_expansion_delimiter__" + command=$(printf "cat <<%s\n%s\n%s" "$delimiter" "$data" "$delimiter") eval "$command" } @@ -80,28 +104,27 @@ log() { case "$MODE" in ERR) - printf "[\e[1;31m$NAME\e[1;0m]: \e[1;3m$FILENAME\e[1;0m\n" + printf '[\e[1;31m%s\e[1;0m]: \e[1;3m%s\e[1;0m\n' "$NAME" "$FILENAME" ;; WARN) - printf "[\e[1;33m$NAME\e[1;0m]: \e[1;3m$FILENAME\e[1;0m\n" + printf '[\e[1;33m%s\e[1;0m]: \e[1;3m%s\e[1;0m\n' "$NAME" "$FILENAME" ;; INFO) - printf "[\e[1;36m$NAME\e[1;0m]: \e[1;3m$FILENAME\e[1;0m\n" + printf '[\e[1;36m%s\e[1;0m]: \e[1;3m%s\e[1;0m\n' "$NAME" "$FILENAME" ;; SUCS) - if [ "$SKIP_OK" = false ]; then - printf "[\e[1;32m$NAME\e[1;0m]: \e[1;3m$FILENAME\e[1;0m\n" - fi + [ "$SKIP_OK" = false ] && + printf '[\e[1;32m%s\e[1;0m]: \e[1;3m%s\e[1;0m\n' "$NAME" "$FILENAME" ;; HELP) if $USE_GLOW; then - echo "$HELP" | glow - + printf "%s" "$HELP" | glow - else - echo "$HELP" + printf "%s" "$HELP" fi ;; @@ -113,9 +136,9 @@ check_file() { INPUT="$1" NAME="$2" - FILENAME=$(echo -E "$INPUT" | jq -r .path) - MOVABLE=$(echo -E "$INPUT" | jq -r .movable) - HELP=$(echo -E "$INPUT" | jq -r .help) + FILENAME=$(printf "%s" "$INPUT" | jq -r .path) + MOVABLE=$(printf "%s" "$INPUT" | jq -r .movable) + HELP=$(printf "%s" "$INPUT" | jq -r .help) check_not_exists_file "$FILENAME" @@ -131,7 +154,7 @@ check_file() { else log WARN "$NAME" "$FILENAME" "$HELP" fi - if ! [ -z "$HELP" ]; then + if [ "$HELP" ]; then log HELP "$NAME" "$FILENAME" "$HELP" else log HELP "$NAME" "$FILENAME" "_No help available._" @@ -145,24 +168,26 @@ check_file() { check_program() { INPUT=$1 - NAME=$(echo "$INPUT" | jq -r .name) + NAME=$(printf "%s" "$INPUT" | jq -r .name) while IFS= read -r file; do check_file "$file" "$NAME" - done <<<"$(echo "$INPUT" | jq -rc '.files[]')" + done <