diff options
author | Egor Tensin <Egor.Tensin@gmail.com> | 2016-11-13 16:36:44 +0300 |
---|---|---|
committer | Egor Tensin <Egor.Tensin@gmail.com> | 2016-11-13 16:36:44 +0300 |
commit | 5deb74079e78ecb05aa67147fda480b4887e2d90 (patch) | |
tree | 63061733bddcd54c4ffe25a976a97ffabe24cffd /update.sh | |
parent | traverse_path: usage message update (diff) | |
download | config-links-5deb74079e78ecb05aa67147fda480b4887e2d90.tar.gz config-links-5deb74079e78ecb05aa67147fda480b4887e2d90.zip |
bugfix
Diffstat (limited to 'update.sh')
-rwxr-xr-x | update.sh | 33 |
1 files changed, 21 insertions, 12 deletions
@@ -96,6 +96,11 @@ traverse_path() { type_flag=-f type_name="regular file" ;; + -*) + dump "unrecognized parameter: $key" >&2 + exit_with_usage=1 + break + ;; *) paths+=("$key") ;; @@ -103,12 +108,17 @@ traverse_path() { done if [ -n "$exit_with_usage" ]; then - echo "usage: ${FUNCNAME[0]} [-h|--help] [-0|-z|--zero] [-e|--exist] [-f|--file] [-d|--directory] [--] [PATH]..." || true + local destfd=1 + [ "$exit_with_usage" -ne 0 ] && destfd=2 + + echo "usage: ${FUNCNAME[0]} [-h|--help] [-0|-z|--zero] [-e|--exist] [-f|--file] [-d|--directory] [--] [PATH]..." >&"$destfd" || true return "$exit_with_usage" fi paths+=("$@") + [ "${#paths[@]}" -eq 0 ] && return 0 + if is_cygwin; then local i for i in "${!paths[@]}"; do @@ -138,7 +148,7 @@ declare -A cached_paths resolve_variable() { if [ "$#" -ne 1 ]; then - echo "usage: ${FUNCNAME[0]} VAR_NAME" || true + echo "usage: ${FUNCNAME[0]} VAR_NAME" >&2 || true return 1 fi @@ -189,7 +199,7 @@ shared_dir="$( pwd )" update_shared_dir() { if [ "$#" -ne 1 ]; then - echo "usage: ${FUNCNAME[0]} DIR" || true + echo "usage: ${FUNCNAME[0]} DIR" >&2 || true return 1 fi @@ -210,7 +220,7 @@ declare -A database update_database_path() { if [ "$#" -ne 1 ]; then - echo "usage: ${FUNCNAME[0]} PATH" || true + echo "usage: ${FUNCNAME[0]} PATH" >&2 || true return 1 fi @@ -244,7 +254,7 @@ write_database() { delete_obsolete_dirs() { if [ $# -ne 2 ]; then - echo "usage: ${FUNCNAME[0]} BASE_DIR DIR" || true + echo "usage: ${FUNCNAME[0]} BASE_DIR DIR" >&2 || true return 1 fi @@ -310,8 +320,8 @@ delete_obsolete_entries() { local symlink_dir symlink_dir="$( dirname -- "$symlink_path" )" - delete_obsolete_dirs "$symlink_var_dir" "$symlink_dir" || true + continue fi @@ -378,8 +388,11 @@ discover_new_entries() { # Main routines exit_with_usage() { + local destfd=1 + [ "${exit_with_usage:-0}" -ne 0 ] && destfd=2 + local msg - IFS= read -d '' -r msg <<MSG || echo -n "$msg" || true + IFS= read -d '' -r msg <<MSG || echo -n "$msg" >&"$destfd" || true usage: $script_argv0 [-h|--help] [-d|--database PATH] [-s|--shared-dir DIR] [-n|--dry-run] optional parameters: -h,--help show this message and exit @@ -388,6 +401,7 @@ optional parameters: (current working directory by default) -n,--dry-run don't actually do anything intrusive MSG + exit "${exit_with_usage:-0}" } @@ -401,15 +415,12 @@ parse_script_options() { exit_with_usage=0 break ;; - -n|--dry-run) dry_run=1 continue ;; - -d|--database|-s|--shared-dir) ;; - *) dump "unrecognized parameter: $key" >&2 exit_with_usage=1 @@ -430,11 +441,9 @@ parse_script_options() { -d|--database) update_database_path "$value" ;; - -s|--shared-dir) update_shared_dir "$value" ;; - *) dump "unrecognized parameter: $key" >&2 exit_with_usage=1 |