diff options
author | Junio C Hamano <gitster@pobox.com> | 2011-08-16 11:23:26 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2011-08-16 11:23:26 -0700 |
commit | d5c756e99ed7aa07427295b1011edf4718ea80b0 (patch) | |
tree | 5891cf85b913b5f363cfce727cef7f99a972b488 | |
parent | 824f4a93890b06d47d46f87b146022266977b2a9 (diff) | |
parent | 4dca1aa6502a46f8d7b6ecc8e7812c5c23ad0923 (diff) | |
download | git-d5c756e99ed7aa07427295b1011edf4718ea80b0.tar.gz git-d5c756e99ed7aa07427295b1011edf4718ea80b0.tar.xz |
Merge branch 'bc/submodule-foreach-stdin-fix-1.7.4' into maint
* bc/submodule-foreach-stdin-fix-1.7.4:
git-submodule.sh: preserve stdin for the command spawned by foreach
t/t7407: demonstrate that the command called by 'submodule foreach' loses stdin
-rwxr-xr-x | git-submodule.sh | 6 | ||||
-rwxr-xr-x | t/t7407-submodule-foreach.sh | 18 |
2 files changed, 23 insertions, 1 deletions
diff --git a/git-submodule.sh b/git-submodule.sh index d189a24c7..9c6dca5a1 100755 --- a/git-submodule.sh +++ b/git-submodule.sh @@ -300,6 +300,10 @@ cmd_foreach() toplevel=$(pwd) + # dup stdin so that it can be restored when running the external + # command in the subshell (and a recursive call to this function) + exec 3<&0 + module_list | while read mode sha1 stage path do @@ -316,7 +320,7 @@ cmd_foreach() then cmd_foreach "--recursive" "$@" fi - ) || + ) <&3 3<&- || die "Stopping at '$path'; script returned non-zero status." fi done diff --git a/t/t7407-submodule-foreach.sh b/t/t7407-submodule-foreach.sh index e5be13c27..835a50624 100755 --- a/t/t7407-submodule-foreach.sh +++ b/t/t7407-submodule-foreach.sh @@ -292,4 +292,22 @@ test_expect_success 'use "update --recursive nested1" to checkout all submodules ) ' +test_expect_success 'command passed to foreach retains notion of stdin' ' + ( + cd super && + git submodule foreach echo success >../expected && + yes | git submodule foreach "read y && test \"x\$y\" = xy && echo success" >../actual + ) && + test_cmp expected actual +' + +test_expect_success 'command passed to foreach --recursive retains notion of stdin' ' + ( + cd clone2 && + git submodule foreach --recursive echo success >../expected && + yes | git submodule foreach --recursive "read y && test \"x\$y\" = xy && echo success" >../actual + ) && + test_cmp expected actual +' + test_done |