summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarlos Martín Nieto <cmn@dwim.me>2015-02-13 08:56:01 +0100
committerCarlos Martín Nieto <cmn@dwim.me>2015-02-13 08:56:01 +0100
commit0b2ee7c07c7b494b432ad5b2a870f6378e191f25 (patch)
treee1e082e7d9a70960279fe1d842db88ca94b1fd3c
parent3ca91107fcf0097bb6b67e81fd80d6dd612ac7db (diff)
parent1713653883c3dfd199a18b51a1e2b37def183101 (diff)
downloadlibgit2-0b2ee7c07c7b494b432ad5b2a870f6378e191f25.tar.gz
Merge pull request #2883 from urkud/reget-reader-pointer
Reinit `reader` pointer after reading included config file
-rw-r--r--src/config_file.c1
-rw-r--r--tests/config/include.c22
2 files changed, 23 insertions, 0 deletions
diff --git a/src/config_file.c b/src/config_file.c
index 4f041e7e3..268cced09 100644
--- a/src/config_file.c
+++ b/src/config_file.c
@@ -1284,6 +1284,7 @@ static int config_parse(git_strmap *values, diskfile_backend *cfg_file, struct r
if (result == 0) {
result = config_parse(values, cfg_file, r, level, depth+1);
r = git_array_get(cfg_file->readers, index);
+ reader = git_array_get(cfg_file->readers, reader_idx);
}
else if (result == GIT_ENOTFOUND) {
giterr_clear();
diff --git a/tests/config/include.c b/tests/config/include.c
index 0a931342a..8232af489 100644
--- a/tests/config/include.c
+++ b/tests/config/include.c
@@ -102,3 +102,25 @@ void test_config_include__missing(void)
git_config_free(cfg);
}
+
+#define replicate10(s) s s s s s s s s s s
+void test_config_include__depth2(void)
+{
+ git_config *cfg;
+ const char *str;
+ const char *content = "[include]\n" replicate10(replicate10("path=bottom\n"));
+
+ cl_git_mkfile("top-level", "[include]\npath = middle\n[foo]\nbar = baz");
+ cl_git_mkfile("middle", content);
+ cl_git_mkfile("bottom", "[foo]\nbar2 = baz2");
+
+ cl_git_pass(git_config_open_ondisk(&cfg, "top-level"));
+
+ cl_git_pass(git_config_get_string(&str, cfg, "foo.bar"));
+ cl_assert_equal_s(str, "baz");
+
+ cl_git_pass(git_config_get_string(&str, cfg, "foo.bar2"));
+ cl_assert_equal_s(str, "baz2");
+
+ git_config_free(cfg);
+}