X-Git-Url: https://git.madduck.net/code/vcsh.git/blobdiff_plain/2dcbc4d6ccedf064aaec330b585652900cc2c061..519af748f900277d8ecac0594f70b24423deef98:/vcsh?ds=sidebyside diff --git a/vcsh b/vcsh index 9a4f4aa..594368d 100755 --- a/vcsh +++ b/vcsh @@ -29,31 +29,48 @@ while getopts "c:dv" flag; do elif [ "$1" = '-v' ];then VCSH_VERBOSE=1 elif [ "$1" = '-c' ];then - # Source $OPTARG if it can be read and has an absolute or relative - # path or is in $PATH - if [ -r "$OPTARG" ]; then - . "$OPTARG" - else - fatal "Can not read configuration file '$OPTARG'" 1 - fi + VCSH_OPTION_CONFIG=$OPTARG fi done +source_all() { + # Source file even if it's in $PWD and does not have any slashes in it + case "$1" in + */*) . "$1";; + *) . "$PWD/$1";; + esac; +} + +# Read configuration and set defaults if anything's not set [ -n "$VCSH_DEBUG" ] && set -vx [ -z "$XDG_CONFIG_HOME" ] && XDG_CONFIG_HOME="$HOME/.config" + +# Read configuration files if there are any +[ -r "/etc/vcsh/config" ] && . "/etc/vcsh/config" [ -r "$XDG_CONFIG_HOME/vcsh/config" ] && . "$XDG_CONFIG_HOME/vcsh/config" +if [ -n "$VCSH_OPTION_CONFIG" ]; then + # Source $VCSH_OPTION_CONFIG if it can be read and is in $PWD of $PATH + if [ -r "$VCSH_OPTION_CONFIG" ]; then + source_all "$VCSH_OPTION_CONFIG" + else + fatal "Can not read configuration file '$VCSH_OPTION_CONFIG'" 1 + fi +fi [ -n "$VCSH_DEBUG" ] && set -vx + +# Read defaults [ -z "$VCSH_REPO_D" ] && VCSH_REPO_D="$XDG_CONFIG_HOME/vcsh/repo.d" [ -z "$VCSH_HOOK_D" ] && VCSH_HOOK_D="$XDG_CONFIG_HOME/vcsh/hooks-enabled" [ -z "$VCSH_BASE" ] && VCSH_BASE="$HOME" [ -z "$VCSH_GITIGNORE" ] && VCSH_GITIGNORE='exact' + help() { echo "usage: $SELF options: - -c Source file prior to other configuration files + -c Source file -d Enable debug mode -d Enable verbose mode