aboutsummaryrefslogtreecommitdiffstats
path: root/Library
diff options
context:
space:
mode:
authorMike McQuaid2016-08-24 10:22:55 +0100
committerMike McQuaid2016-08-25 11:12:22 +0100
commit408ac6088f0cdb32c6c033df4f4c18b8ce7829c1 (patch)
tree0a9d7009c777be6d727ba12e3cc567e3ed9e66c6 /Library
parentea069936bfbe64f5c3efe80e84b10efef389d807 (diff)
downloadbrew-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-xLibrary/Homebrew/shims/scm/git25
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 "$@"