Skip to content

Commit

Permalink
Remove absolute pathnames to binaries and rely on PATH
Browse files Browse the repository at this point in the history
 Fixes issues with distributions that use non-standard binary paths (e.g., in
 isolated build environments). Scripts rely on PATH for other programs, anyway.

 Use /usr/bin/env to find the pwd binary avoiding the shell built-in.
  • Loading branch information
spacefrogg authored and Michael Raitza committed Aug 7, 2020
1 parent b08b5ef commit 5977e99
Show file tree
Hide file tree
Showing 7 changed files with 14 additions and 14 deletions.
2 changes: 1 addition & 1 deletion do
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ usage() {
}

mydir=$(dirname "$0")
cd "$(/bin/pwd)" && cd "$mydir" || die "can't find self in dir: $mydir"
cd "$(/usr/bin/env pwd)" && cd "$mydir" || die "can't find self in dir: $mydir"

args=
while [ "$1" != "${1#-}" ]; do
Expand Down
6 changes: 3 additions & 3 deletions minimal/do
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ qdirname() (
)

_dirsplit "$0"
REDO=$(cd "$(pwd -P)" &&
REDO=$(cd "$(/usr/bin/env pwd -P)" &&
cd "${_dirsplit_dir:-.}" &&
echo "$PWD/$_dirsplit_base")
export REDO
Expand Down Expand Up @@ -89,7 +89,7 @@ if [ -z "$DO_BUILT" -a "$_cmd" != "redo-whichdo" ]; then
if [ "$#" -eq 0 ] && [ "$_cmd" = "do" -o "$_cmd" = "redo" ]; then
set all # only toplevel redo has a default target
fi
export DO_STARTDIR="$(pwd -P)"
export DO_STARTDIR="$(/usr/bin/env pwd -P)"
# If starting /bin/pwd != $PWD, this will fix it.
# That can happen when $PWD contains symlinks that the shell is
# trying helpfully (but unsuccessfully) to hide from the user.
Expand Down Expand Up @@ -228,7 +228,7 @@ _realpath()
#echo "Trying: $PWD--$path" >&2
if cd -P "$path" 2>/dev/null; then
# success
pwd=$(pwd -P)
pwd=$(/usr/bin/env pwd -P)
#echo " chdir ok: $pwd--$rest" >&2
np=$(_normpath "${pwd%/}/$rest" "$relto")
if [ -n "$isabs" ]; then
Expand Down
4 changes: 2 additions & 2 deletions minimal/do.test
Original file line number Diff line number Diff line change
Expand Up @@ -136,9 +136,9 @@ mkdir y
ln -s . y/x
check "/usr/__does_not/b" _realpath "/usr/__does_not/a/../b" "$x"
check "foo" _realpath "y/x/x/x/x/x/../foo" "$PWD"
check "$(/bin/pwd)/foo" _realpath "$PWD/y/x/x/x/x/x/../foo" "$PWD"
check "$(/usr/bin/env pwd)/foo" _realpath "$PWD/y/x/x/x/x/x/../foo" "$PWD"
check "foo/blam" _realpath "y/x/x/x/x/x/../foo/spam/../blam" "$PWD"
check "$(/bin/pwd)/foo/blam" _realpath "$PWD/y/x/x/../foo/spam/../blam" "$PWD"
check "$(/usr/bin/env pwd)/foo/blam" _realpath "$PWD/y/x/x/../foo/spam/../blam" "$PWD"


SECTION _find_dofile
Expand Down
4 changes: 2 additions & 2 deletions t/105-sympath/all.do
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,10 @@ for iter in 10 20; do
cd y/x/x/x/x/x
IFS=$(printf '\n')
redo-ifchange static x/x/x/static $PWD/static \
$(/bin/pwd)/static /etc/passwd
$(/usr/bin/env pwd)/static /etc/passwd
redo-ifchange $PWD/../static 2>/dev/null && exit 35
redo-ifchange 1.dyn x/x/x/2.dyn $PWD/3.dyn \
$PWD/../4.dyn $(/bin/pwd)/5.dyn
$PWD/../4.dyn $(/usr/bin/env pwd)/5.dyn
)
[ -e y/1.dyn ] || exit $((iter + 1))
[ -e y/2.dyn ] || exit $((iter + 2))
Expand Down
6 changes: 3 additions & 3 deletions t/all.do
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,13 @@ fi

# builds 1xx*/all to test for basic/dangerous functionality.
# We don't want to run more advanced tests if the basics don't work.
/bin/ls 1[0-9][0-9]*/all.do |
ls 1[0-9][0-9]*/all.do |
sed 's/\.do$//' |
xargs redo
110-compile/hello >&2

# builds most of the rest in parallel
/bin/ls [2-9][0-9][0-9]*/all.do |
ls [2-9][0-9][0-9]*/all.do |
sed 's/\.do$//' |
xargs redo

Expand All @@ -25,7 +25,7 @@ xargs redo
# are checking for unnecessary extra rebuilds of some targets, which
# might happen after flush-cache.
# FIXME: a better solution might be to make flush-cache less destructive!
/bin/ls [s][0-9][0-9]*/all.do |
ls [s][0-9][0-9]*/all.do |
sed 's/\.do$//' | {
while read d; do
redo "$d"
Expand Down
2 changes: 1 addition & 1 deletion t/clean.do
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/bin/ls [0-9s][0-9][0-9]*/clean.do |
ls [0-9s][0-9][0-9]*/clean.do |
sed 's/\.do$//' |
xargs redo

Expand Down
4 changes: 2 additions & 2 deletions t/shelltest.od
Original file line number Diff line number Diff line change
Expand Up @@ -526,8 +526,8 @@ rm -f shlink ../shlink
ln -s . shlink
(quiet_stderr cd -L shlink/shlink/shlink/../shlink) || fail 120
(quiet_stderr cd -P shlink/shlink/shlink/../shlink) && fail 121
x1=$(cd shlink && basename "$(pwd -P)")
x2=$(cd shlink && basename "$(pwd -L)")
x1=$(cd shlink && basename "$(/usr/bin/env pwd -P)")
x2=$(cd shlink && basename "$(/usr/bin/env pwd -L)")
[ "$x1" = "t" ] || fail 122
[ "$x2" = "shlink" ] || fail 123

Expand Down

0 comments on commit 5977e99

Please sign in to comment.