Skip to content

Commit

Permalink
mergetool: Remove explicit references to /dev/tty
Browse files Browse the repository at this point in the history
mergetool used /dev/tty to switch back to receiving input from the user
via inside a block with a redirected stdin.

This harms testability, so change mergetool to save its original stdin
to an alternative fd in this block and restore it for those sub-commands
that need the original stdin.

Includes additional compatibility fix from Jonathan Nieder.

Tested-by: Jonathan Nieder <jrnieder@gmail.com>
Signed-off-by: Charles Bailey <charles@hashpling.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Charles Bailey authored and Junio C Hamano committed Aug 20, 2010
1 parent 64fdc08 commit af31471
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 3 deletions.
2 changes: 1 addition & 1 deletion git-mergetool--lib.sh
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ check_unchanged () {
while true; do
echo "$MERGED seems unchanged."
printf "Was the merge successful? [y/n] "
read answer < /dev/tty
read answer
case "$answer" in
y*|Y*) status=0; break ;;
n*|N*) status=1; break ;;
Expand Down
8 changes: 6 additions & 2 deletions git-mergetool.sh
Original file line number Diff line number Diff line change
Expand Up @@ -271,17 +271,21 @@ if test $# -eq 0 ; then
echo "No files need merging"
exit 0
fi

# Save original stdin
exec 3<&0

echo Merging the files: "$files"
git ls-files -u |
sed -e 's/^[^ ]* //' |
sort -u |
while IFS= read i
do
if test $last_status -ne 0; then
prompt_after_failed_merge < /dev/tty || exit 1
prompt_after_failed_merge <&3 || exit 1
fi
printf "\n"
merge_file "$i" < /dev/tty > /dev/tty
merge_file "$i" <&3
last_status=$?
if test $last_status -ne 0; then
rollup_status=1
Expand Down

0 comments on commit af31471

Please sign in to comment.