From d2c11a38c476bdfa3dd2387a0d933b8c00e4dfe3 Mon Sep 17 00:00:00 2001 From: Junio C Hamano Date: Wed, 27 Dec 2006 16:41:33 -0800 Subject: UTF-8: introduce i18n.logoutputencoding. It is plausible for somebody to want to view the commit log in a different encoding from i18n.commitencoding -- the project's policy may be UTF-8 and the user may be using a commit message hook to run iconv to conform to that policy (and either not have i18n.commitencoding to default to UTF-8 or have it explicitly set to UTF-8). Even then, Latin-1 may be more convenient for the usual pager and the terminal the user uses. The new variable i18n.logoutputencoding is used in preference to i18n.commitencoding to decide what encoding to recode the log output in when git-log and friends formats the commit log message. Signed-off-by: Junio C Hamano --- t/t3900-i18n-commit.sh | 104 +++++++++++++++++++++++++++++++++++++++++++++++++ t/t3900/1-UTF-8.txt | 3 ++ t/t3900/2-UTF-8.txt | 4 ++ t/t3900/EUCJP.txt | 4 ++ t/t3900/ISO-8859-1.txt | 3 ++ t/t3900/ISO2022JP.txt | 4 ++ 6 files changed, 122 insertions(+) create mode 100755 t/t3900-i18n-commit.sh create mode 100644 t/t3900/1-UTF-8.txt create mode 100644 t/t3900/2-UTF-8.txt create mode 100644 t/t3900/EUCJP.txt create mode 100644 t/t3900/ISO-8859-1.txt create mode 100644 t/t3900/ISO2022JP.txt (limited to 't') diff --git a/t/t3900-i18n-commit.sh b/t/t3900-i18n-commit.sh new file mode 100755 index 0000000000..3606ed2efa --- /dev/null +++ b/t/t3900-i18n-commit.sh @@ -0,0 +1,104 @@ +#!/bin/sh +# +# Copyright (c) 2006 Junio C Hamano +# + +test_description='commit and log output encodings' + +. ./test-lib.sh + +compare_with () { + git-show -s "$1" | sed -e '1,/^$/d' -e 's/^ //' -e '$d' >current && + diff -u current "$2" +} + +test_expect_success setup ' + : >F && + git-add F && + T=$(git-write-tree) && + C=$(git-commit-tree $T <../t3900/1-UTF-8.txt) && + git-update-ref HEAD $C && + git-tag C0 +' + +test_expect_success 'no encoding header for base case' ' + E=$(git-cat-file commit C0 | sed -ne "s/^encoding //p") && + test z = "z$E" +' + +for H in ISO-8859-1 EUCJP ISO2022JP +do + test_expect_success "$H setup" ' + git-repo-config i18n.commitencoding $H && + git-checkout -b $H C0 && + echo $H >F && + git-commit -a -F ../t3900/$H.txt + ' +done + +for H in ISO-8859-1 EUCJP ISO2022JP +do + test_expect_success "check encoding header for $H" ' + E=$(git-cat-file commit '$H' | sed -ne "s/^encoding //p") && + test "z$E" = "z'$H'" + ' +done + +test_expect_success 'repo-config to remove customization' ' + git-repo-config --unset-all i18n.commitencoding && + if Z=$(git-repo-config --get-all i18n.commitencoding) + then + echo Oops, should have failed. + false + else + test z = "z$Z" + fi && + git-repo-config i18n.commitencoding utf-8 +' + +test_expect_success 'ISO-8859-1 should be shown in UTF-8 now' ' + compare_with ISO-8859-1 ../t3900/1-UTF-8.txt +' + +for H in EUCJP ISO2022JP +do + test_expect_success "$H should be shown in UTF-8 now" ' + compare_with '$H' ../t3900/2-UTF-8.txt + ' +done + +test_expect_success 'repo-config to add customization' ' + git-repo-config --unset-all i18n.commitencoding && + if Z=$(git-repo-config --get-all i18n.commitencoding) + then + echo Oops, should have failed. + false + else + test z = "z$Z" + fi +' + +for H in ISO-8859-1 EUCJP ISO2022JP +do + test_expect_success "$H should be shown in itself now" ' + git-repo-config i18n.commitencoding '$H' && + compare_with '$H' ../t3900/'$H'.txt + ' +done + +test_expect_success 'repo-config to tweak customization' ' + git-repo-config i18n.logoutputencoding utf-8 +' + +test_expect_success 'ISO-8859-1 should be shown in UTF-8 now' ' + compare_with ISO-8859-1 ../t3900/1-UTF-8.txt +' + +for H in EUCJP ISO2022JP +do + test_expect_success "$H should be shown in UTF-8 now" ' + compare_with '$H' ../t3900/2-UTF-8.txt + ' +done + +test_done diff --git a/t/t3900/1-UTF-8.txt b/t/t3900/1-UTF-8.txt new file mode 100644 index 0000000000..ee31e19738 --- /dev/null +++ b/t/t3900/1-UTF-8.txt @@ -0,0 +1,3 @@ +ÄËÑÏÖ + +Ábçdèfg diff --git a/t/t3900/2-UTF-8.txt b/t/t3900/2-UTF-8.txt new file mode 100644 index 0000000000..63f4f8f121 --- /dev/null +++ b/t/t3900/2-UTF-8.txt @@ -0,0 +1,4 @@ +はれひほふ + +しているのが、いるので。 +濱浜ほれぷりぽれまびぐりろへ。 diff --git a/t/t3900/EUCJP.txt b/t/t3900/EUCJP.txt new file mode 100644 index 0000000000..546f2aac01 --- /dev/null +++ b/t/t3900/EUCJP.txt @@ -0,0 +1,4 @@ +ϤҤۤ + +ƤΤΤǡ +ͤۤפݤޤӤء diff --git a/t/t3900/ISO-8859-1.txt b/t/t3900/ISO-8859-1.txt new file mode 100644 index 0000000000..7cbef0ee6f --- /dev/null +++ b/t/t3900/ISO-8859-1.txt @@ -0,0 +1,3 @@ + + +bdfg diff --git a/t/t3900/ISO2022JP.txt b/t/t3900/ISO2022JP.txt new file mode 100644 index 0000000000..74b533042f --- /dev/null +++ b/t/t3900/ISO2022JP.txt @@ -0,0 +1,4 @@ +$B$O$l$R$[$U(B + +$B$7$F$$$k$N$,!"$$$k$N$G!#(B +$B_@IM$[$l$W$j$]$l$^$S$0$j$m$X!#(B -- cgit v1.2.1 From 46e35a6cb9914ebb839249ecf2154c48b044c5cd Mon Sep 17 00:00:00 2001 From: Junio C Hamano Date: Wed, 27 Dec 2006 17:38:02 -0800 Subject: Rename t3900 test vector file It appears ISO-2022-JP is more widely accepted than ISO2022JP, so rename it that way. We probably would need to have a way to skip this test altogether in locale-challenged environments. Signed-off-by: Junio C Hamano --- t/t3900-i18n-commit.sh | 10 +++++----- t/t3900/ISO-2022-JP.txt | 4 ++++ t/t3900/ISO2022JP.txt | 4 ---- 3 files changed, 9 insertions(+), 9 deletions(-) create mode 100644 t/t3900/ISO-2022-JP.txt delete mode 100644 t/t3900/ISO2022JP.txt (limited to 't') diff --git a/t/t3900-i18n-commit.sh b/t/t3900-i18n-commit.sh index 3606ed2efa..879b69793c 100755 --- a/t/t3900-i18n-commit.sh +++ b/t/t3900-i18n-commit.sh @@ -26,7 +26,7 @@ test_expect_success 'no encoding header for base case' ' test z = "z$E" ' -for H in ISO-8859-1 EUCJP ISO2022JP +for H in ISO-8859-1 EUCJP ISO-2022-JP do test_expect_success "$H setup" ' git-repo-config i18n.commitencoding $H && @@ -36,7 +36,7 @@ do ' done -for H in ISO-8859-1 EUCJP ISO2022JP +for H in ISO-8859-1 EUCJP ISO-2022-JP do test_expect_success "check encoding header for $H" ' E=$(git-cat-file commit '$H' | sed -ne "s/^encoding //p") && @@ -60,7 +60,7 @@ test_expect_success 'ISO-8859-1 should be shown in UTF-8 now' ' compare_with ISO-8859-1 ../t3900/1-UTF-8.txt ' -for H in EUCJP ISO2022JP +for H in EUCJP ISO-2022-JP do test_expect_success "$H should be shown in UTF-8 now" ' compare_with '$H' ../t3900/2-UTF-8.txt @@ -78,7 +78,7 @@ test_expect_success 'repo-config to add customization' ' fi ' -for H in ISO-8859-1 EUCJP ISO2022JP +for H in ISO-8859-1 EUCJP ISO-2022-JP do test_expect_success "$H should be shown in itself now" ' git-repo-config i18n.commitencoding '$H' && @@ -94,7 +94,7 @@ test_expect_success 'ISO-8859-1 should be shown in UTF-8 now' ' compare_with ISO-8859-1 ../t3900/1-UTF-8.txt ' -for H in EUCJP ISO2022JP +for H in EUCJP ISO-2022-JP do test_expect_success "$H should be shown in UTF-8 now" ' compare_with '$H' ../t3900/2-UTF-8.txt diff --git a/t/t3900/ISO-2022-JP.txt b/t/t3900/ISO-2022-JP.txt new file mode 100644 index 0000000000..74b533042f --- /dev/null +++ b/t/t3900/ISO-2022-JP.txt @@ -0,0 +1,4 @@ +$B$O$l$R$[$U(B + +$B$7$F$$$k$N$,!"$$$k$N$G!#(B +$B_@IM$[$l$W$j$]$l$^$S$0$j$m$X!#(B diff --git a/t/t3900/ISO2022JP.txt b/t/t3900/ISO2022JP.txt deleted file mode 100644 index 74b533042f..0000000000 --- a/t/t3900/ISO2022JP.txt +++ /dev/null @@ -1,4 +0,0 @@ -$B$O$l$R$[$U(B - -$B$7$F$$$k$N$,!"$$$k$N$G!#(B -$B_@IM$[$l$W$j$]$l$^$S$0$j$m$X!#(B -- cgit v1.2.1 From 7255ff0446217ad723dad6088504a18f6afb15db Mon Sep 17 00:00:00 2001 From: Junio C Hamano Date: Thu, 28 Dec 2006 17:36:35 -0800 Subject: t3900: test conversion to non UTF-8 as well Signed-off-by: Junio C Hamano --- t/t3900-i18n-commit.sh | 11 +++++++++++ 1 file changed, 11 insertions(+) (limited to 't') diff --git a/t/t3900-i18n-commit.sh b/t/t3900-i18n-commit.sh index 879b69793c..46fd47cb0f 100755 --- a/t/t3900-i18n-commit.sh +++ b/t/t3900-i18n-commit.sh @@ -101,4 +101,15 @@ do ' done +for J in EUCJP ISO-2022-JP +do + git-repo-config i18n.logoutputencoding $J + for H in EUCJP ISO-2022-JP + do + test_expect_success "$H should be shown in $J now" ' + compare_with '$H' ../t3900/'$J'.txt + ' + done +done + test_done -- cgit v1.2.1