From: Bryan Donlan Date: Sun, 4 May 2008 05:37:54 +0000 (-0400) Subject: test-lib.sh: Add a test_set_editor function to safely set $VISUAL X-Git-Tag: v1.5.6-rc0~57^2~6 X-Git-Url: https://git.tokkee.org/?a=commitdiff_plain;h=02b35660031e1da4036559fb928589ca8c3844bd;p=git.git test-lib.sh: Add a test_set_editor function to safely set $VISUAL In particular, this function correctly handles cases where the pwd contains spaces, quotes, and other troublesome metacharacters. Signed-off-by: Bryan Donlan Signed-off-by: Junio C Hamano --- diff --git a/t/test-lib.sh b/t/test-lib.sh index 7c2a8ba77..d7ad13b95 100644 --- a/t/test-lib.sh +++ b/t/test-lib.sh @@ -160,6 +160,22 @@ die () { trap 'die' exit +# The semantics of the editor variables are that of invoking +# sh -c "$EDITOR \"$@\"" files ... +# +# If our trash directory contains shell metacharacters, they will be +# interpreted if we just set $EDITOR directly, so do a little dance with +# environment variables to work around this. +# +# In particular, quoting isn't enough, as the path may contain the same quote +# that we're using. +test_set_editor () { + FAKE_EDITOR="$1" + export FAKE_EDITOR + VISUAL='"$FAKE_EDITOR"' + export VISUAL +} + test_tick () { if test -z "${test_tick+set}" then