From: Junio C Hamano Date: Fri, 15 Jun 2012 22:00:53 +0000 (-0700) Subject: Merge branch 'as/diff-shortstat-ignore-binary' X-Git-Tag: v1.7.11~3 X-Git-Url: https://git.lorimer.id.au/gitweb.git/diff_plain/0b6e913c8be236ba801b49d21490409f13af7cd9?hp=1fd8f97f6e2c5f928e7399adb59b6d87ac82eb08 Merge branch 'as/diff-shortstat-ignore-binary' # By Alexander Strasser * as/diff-shortstat-ignore-binary: diff: Only count lines in show_shortstats --- diff --git a/diff.c b/diff.c index 77edd5086f..1a594df4f4 100644 --- a/diff.c +++ b/diff.c @@ -1700,7 +1700,7 @@ static void show_shortstats(struct diffstat_t *data, struct diff_options *option continue; if (!data->files[i]->is_renamed && (added + deleted == 0)) { total_files--; - } else { + } else if (!data->files[i]->is_binary) { /* don't count bytes */ adds += added; dels += deleted; } diff --git a/t/t4012-diff-binary.sh b/t/t4012-diff-binary.sh index 8b4e80de96..6cebb3951b 100755 --- a/t/t4012-diff-binary.sh +++ b/t/t4012-diff-binary.sh @@ -36,6 +36,18 @@ test_expect_success '"apply --stat" output for binary file change' ' test_i18ncmp expected current ' +test_expect_success 'diff --shortstat output for binary file change' ' + echo " 4 files changed, 2 insertions(+), 2 deletions(-)" >expected && + git diff --shortstat >current && + test_i18ncmp expected current +' + +test_expect_success 'diff --shortstat output for binary file change only' ' + echo " 1 file changed, 0 insertions(+), 0 deletions(-)" >expected && + git diff --shortstat -- b >current && + test_i18ncmp expected current +' + test_expect_success 'apply --numstat notices binary file change' ' git diff >diff && git apply --numstat current &&