From a542b3894da05c9377beadfe13d68bd7387ebcc9 Mon Sep 17 00:00:00 2001 From: Andreas Schwab Date: Fri, 2 Nov 2012 18:33:33 +0100 Subject: Make cross-test-ssh.sh compatible with a remote POSIX sh --- scripts/cross-test-ssh.sh | 26 +++++++------------------- 1 file changed, 7 insertions(+), 19 deletions(-) (limited to 'scripts') diff --git a/scripts/cross-test-ssh.sh b/scripts/cross-test-ssh.sh index f09c98ec11..51b0da924a 100755 --- a/scripts/cross-test-ssh.sh +++ b/scripts/cross-test-ssh.sh @@ -108,37 +108,25 @@ bourne_quote () done } -# Remove unnecessary newlines from a Bourne shell command sequence. -remove_newlines () -{ - sed -n \ - -e '1h' \ - -e '2,$H' \ - -e '${g - s/\([^\]\)\n/\1; /g - p - }' -} - # Unset all variables from the blacklist. Then echo all exported -# variables. The 'export -p' command adds backslashes for environment -# variables which contain newlines. +# variables. blacklist_exports () { - (unset ${env_blacklist}; export -p) | remove_newlines + (unset ${env_blacklist}; export -p) | sed 's/^declare -x/export/' } -# Produce properly quoted Bourne shell arguments for 'env' to carry -# over the current environment, less blacklisted variables. +# Produce commands to carry over the current environment, less blacklisted +# variables. exports="$(blacklist_exports)" -exports="${exports:+${exports}; }" # Transform the current argument list into a properly quoted Bourne shell # command string. command="$(bourne_quote "$@")" # Add commands to set environment variables and the current directory. -command="${exports}cd $PWD; ${command}" +command="${exports} +cd $(bourne_quote "$PWD") +${command}" # HOST's sshd simply concatenates its arguments with spaces and # passes them to some shell. We want to force the use of /bin/sh, -- cgit 1.4.1