diff options
author | Junio C Hamano <gitster@pobox.com> | 2015-02-18 11:45:01 -0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2015-02-18 11:45:01 -0800 |
commit | de15bdb0583a1a65bf1bab47b7bec9bdc03f727a (patch) | |
tree | 36d6f1b6626f57b3a0fcfd93958e29b2aa4fcf4d | |
parent | 2c1f554d0ca2c35c213d68d94baf30f11180f4ce (diff) | |
parent | 1d0655c15ebf7dfb460466d058daab790ed285b2 (diff) | |
download | git-de15bdb0583a1a65bf1bab47b7bec9bdc03f727a.tar.gz git-de15bdb0583a1a65bf1bab47b7bec9bdc03f727a.tar.xz |
Merge branch 'jk/config-no-ungetc-eof'
Reading configuration from a blob object, when it ends with a lone
CR, use to confuse the configuration parser.
* jk/config-no-ungetc-eof:
config_buf_ungetc: warn when pushing back a random character
config: do not ungetc EOF
-rw-r--r-- | config.c | 11 | ||||
-rwxr-xr-x | t/t1307-config-blob.sh | 9 |
2 files changed, 17 insertions, 3 deletions
@@ -73,8 +73,12 @@ static int config_buf_fgetc(struct config_source *conf) static int config_buf_ungetc(int c, struct config_source *conf) { - if (conf->u.buf.pos > 0) - return conf->u.buf.buf[--conf->u.buf.pos]; + if (conf->u.buf.pos > 0) { + conf->u.buf.pos--; + if (conf->u.buf.buf[conf->u.buf.pos] != c) + die("BUG: config_buf can only ungetc the same character"); + return c; + } return EOF; } @@ -235,7 +239,8 @@ static int get_next_char(void) /* DOS like systems */ c = cf->do_fgetc(cf); if (c != '\n') { - cf->do_ungetc(c, cf); + if (c != EOF) + cf->do_ungetc(c, cf); c = '\r'; } } diff --git a/t/t1307-config-blob.sh b/t/t1307-config-blob.sh index fdc257e66..3c6791e6b 100755 --- a/t/t1307-config-blob.sh +++ b/t/t1307-config-blob.sh @@ -67,4 +67,13 @@ test_expect_success 'parse errors in blobs are properly attributed' ' grep "HEAD:config" err ' +test_expect_success 'can parse blob ending with CR' ' + printf "[some]key = value\\r" >config && + git add config && + git commit -m CR && + echo value >expect && + git config --blob=HEAD:config some.key >actual && + test_cmp expect actual +' + test_done |