diff options
author | Vicent Marti <vicent@github.com> | 2014-07-16 13:07:17 -0700 |
---|---|---|
committer | Vicent Marti <vicent@github.com> | 2014-07-16 13:07:17 -0700 |
commit | ec813d83e757df2c4c8d7984e9ac993e7518fad6 (patch) | |
tree | f6894f28f0d56e41f2199f21cd886213a999fb32 | |
parent | 8baeb8a4801ca44b3d383eb824e779b96da026f5 (diff) | |
parent | 693748694bf3e404d09d7099527ea9f4b105f74c (diff) | |
download | libgit2-ec813d83e757df2c4c8d7984e9ac993e7518fad6.tar.gz |
Merge pull request #2476 from linquize/config-lf-eof
When adding new config section, handle config file not ending with LF
-rw-r--r-- | src/config_file.c | 6 | ||||
-rw-r--r-- | tests/config/write.c | 16 |
2 files changed, 19 insertions, 3 deletions
diff --git a/src/config_file.c b/src/config_file.c index 56271144b..393a0b547 100644 --- a/src/config_file.c +++ b/src/config_file.c @@ -1522,6 +1522,9 @@ static int config_write(diskfile_backend *cfg, const char *key, const regex_t *p git_filebuf_write(&file, reader->buffer.ptr, reader->buffer.size); + if (reader->buffer.size > 0 && *(reader->buffer.ptr + reader->buffer.size - 1) != '\n') + git_filebuf_write(&file, "\n", 1); + /* And now if we just need to add a variable */ if (!section_matches && write_section(&file, section) < 0) goto rewrite_fail; @@ -1536,9 +1539,6 @@ static int config_write(diskfile_backend *cfg, const char *key, const regex_t *p } /* If we are here, there is at least a section line */ - if (reader->buffer.size > 0 && *(reader->buffer.ptr + reader->buffer.size - 1) != '\n') - git_filebuf_write(&file, "\n", 1); - q = quotes_for_value(value); git_filebuf_printf(&file, "\t%s = %s%s%s\n", name, q, value, q); } diff --git a/tests/config/write.c b/tests/config/write.c index 402be9317..0f11ae8da 100644 --- a/tests/config/write.c +++ b/tests/config/write.c @@ -229,6 +229,22 @@ void test_config_write__add_value_at_file_with_no_clrf_at_the_end(void) git_config_free(cfg); } +void test_config_write__add_section_at_file_with_no_clrf_at_the_end(void) +{ + git_config *cfg; + int i; + + cl_git_pass(git_config_open_ondisk(&cfg, "config17")); + cl_git_pass(git_config_set_int32(cfg, "diff.context", 10)); + git_config_free(cfg); + + cl_git_pass(git_config_open_ondisk(&cfg, "config17")); + cl_git_pass(git_config_get_int32(&i, cfg, "diff.context")); + cl_assert_equal_i(10, i); + + git_config_free(cfg); +} + void test_config_write__add_value_which_needs_quotes(void) { git_config *cfg; |