diff options
author | Nguyễn Thái Ngọc Duy <pclouds@gmail.com> | 2011-12-15 20:47:23 +0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2011-12-15 11:35:10 -0800 |
commit | 37576c14439a4dfa43bec5a5c953fea1cc436bbf (patch) | |
tree | ab64240830bfce6d1308787f193ff8f0f77c21c0 /t | |
parent | Convert commit_tree() to take strbuf as message (diff) | |
download | tgif-37576c14439a4dfa43bec5a5c953fea1cc436bbf.tar.xz |
commit_tree(): refuse commit messages that contain NULs
Current implementation sees NUL as terminator. If users give a message
with NUL byte in it (e.g. editor set to save as UTF-16), the new commit
message will have NULs. However following operations (displaying or
amending a commit for example) will not keep anything after the first NUL.
Stop user right when they do this. If NUL is added by mistake, they have
their chance to fix. Otherwise, log messages will no longer be text "git
log" and friends would grok.
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't')
-rwxr-xr-x | t/t3900-i18n-commit.sh | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/t/t3900-i18n-commit.sh b/t/t3900-i18n-commit.sh index 1f62c151b0..d48a7c002d 100755 --- a/t/t3900-i18n-commit.sh +++ b/t/t3900-i18n-commit.sh @@ -34,6 +34,12 @@ test_expect_success 'no encoding header for base case' ' test z = "z$E" ' +test_expect_failure 'UTF-16 refused because of NULs' ' + echo UTF-16 >F && + git commit -a -F "$TEST_DIRECTORY"/t3900/UTF-16.txt +' + + for H in ISO8859-1 eucJP ISO-2022-JP do test_expect_success "$H setup" ' |