diff options
author | John Fultz <jfultz@wolfram.com> | 2014-11-02 19:16:49 -0600 |
---|---|---|
committer | John Fultz <jfultz@wolfram.com> | 2014-11-02 19:16:49 -0600 |
commit | ebc13b2b7cfa9c5c7d3f7762666337bb4fd10d10 (patch) | |
tree | 529b49b3ad71e1376b0bb2d298bc6c63d23a2c56 | |
parent | 727ae380a5de63e7b5856abb1f4dd191e2d5b678 (diff) | |
download | libgit2-ebc13b2b7cfa9c5c7d3f7762666337bb4fd10d10.tar.gz |
Clean up issues include.path issues found during code review.
* Error-handling is cleaned up to only let a file-not-found error
through, not other sorts of errors. And when a file-not-found
error happens, we clean up the error.
* Test now checks that file-not-found introduces no error. And
other minor cleanups.
-rw-r--r-- | src/config_file.c | 11 | ||||
-rw-r--r-- | tests/config/include.c | 7 |
2 files changed, 13 insertions, 5 deletions
diff --git a/src/config_file.c b/src/config_file.c index 195ad90bf..d72e12c56 100644 --- a/src/config_file.c +++ b/src/config_file.c @@ -1280,11 +1280,18 @@ static int config_parse(git_strmap *values, diskfile_backend *cfg_file, struct r r->file_path = git_buf_detach(&path); git_buf_init(&r->buffer, 0); - if (git_futils_readbuffer_updated(&r->buffer, r->file_path, &r->file_mtime, - &r->file_size, NULL) == 0) { + result = git_futils_readbuffer_updated(&r->buffer, r->file_path, &r->file_mtime, + &r->file_size, NULL); + + if (result == 0) { result = config_parse(values, cfg_file, r, level, depth+1); r = git_array_get(cfg_file->readers, index); } + else if (result == GIT_ENOTFOUND) { + giterr_clear(); + result = 0; + } + git_buf_free(&r->buffer); if (result < 0) diff --git a/tests/config/include.c b/tests/config/include.c index b98252d1c..d4af59509 100644 --- a/tests/config/include.c +++ b/tests/config/include.c @@ -92,12 +92,13 @@ void test_config_include__missing(void) git_config *cfg; const char *str; - cl_git_mkfile("included", "[include]\npath = nonexistentfile\n[foo]\nbar = baz"); + cl_git_mkfile("including", "[include]\npath = nonexistentfile\n[foo]\nbar = baz"); - cl_git_pass(git_config_open_ondisk(&cfg, "included")); + giterr_clear(); + cl_git_pass(git_config_open_ondisk(&cfg, "including")); + cl_assert(giterr_last() == NULL); cl_git_pass(git_config_get_string(&str, cfg, "foo.bar")); cl_assert_equal_s(str, "baz"); git_config_free(cfg); - unlink("included"); } |