diff options
| author | Mike McQuaid | 2016-08-24 10:22:55 +0100 |
|---|---|---|
| committer | Mike McQuaid | 2016-08-25 11:12:22 +0100 |
| commit | 408ac6088f0cdb32c6c033df4f4c18b8ce7829c1 (patch) | |
| tree | 0a9d7009c777be6d727ba12e3cc567e3ed9e66c6 /Library | |
| parent | ea069936bfbe64f5c3efe80e84b10efef389d807 (diff) | |
| download | brew-408ac6088f0cdb32c6c033df4f4c18b8ce7829c1.tar.bz2 | |
scm/git: make --homebrew=print-path absolute.
This ensures that the output is always a fully-resolved path.
Diffstat (limited to 'Library')
| -rwxr-xr-x | Library/Homebrew/shims/scm/git | 25 |
1 files changed, 17 insertions, 8 deletions
diff --git a/Library/Homebrew/shims/scm/git b/Library/Homebrew/shims/scm/git index 2a95b0181..eedca486b 100755 --- a/Library/Homebrew/shims/scm/git +++ b/Library/Homebrew/shims/scm/git @@ -9,15 +9,23 @@ quiet_safe_cd() { cd "$1" >/dev/null || { echo "Error: failed to cd to $1" >&2; exit 1; } } +absdir() { + quiet_safe_cd "${1%/*}/" && pwd -P +} + +dirbasepath() { + local dir="$1" + local base="${2##*/}" + echo "$dir/$base" +} + realpath() { local path="$1" local dir - local base local dest - dir="$(quiet_safe_cd "${path%/*}/" && pwd -P)" - base="${path##*/}" - path="$dir/$base" + dir="$(absdir "$path")" + path="$(dirbasepath "$dir" "$path")" while [[ -L "$path" ]] do @@ -28,9 +36,8 @@ realpath() { else path="$dir/$dest" fi - dir="$(quiet_safe_cd "${path%/*}/" && pwd -P)" - base="${path##*/}" - path="$dir/$base" + dir="$(absdir "$path")" + path="$(dirbasepath "$dir" "$path")" done echo "$path" @@ -58,7 +65,9 @@ safe_exec() { fi if [[ "$HOMEBREW" = "print-path" ]] then - echo "$arg0" + local dir="$(quiet_safe_cd "${arg0%/*}/" && pwd)" + local path="$(dirbasepath "$dir" "$arg0")" + echo "$path" exit fi exec "$@" |
