summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorCarlos Martín Nieto <cmn@dwim.me>2014-10-23 18:58:39 +0200
committerCarlos Martín Nieto <cmn@dwim.me>2014-10-23 18:58:39 +0200
commit4bb6ffb6bb8ad9d49eb173350be965183cd09c96 (patch)
tree6e5a2d0cb8df338e5359c7342e845e31e9d9fa65 /src
parentd676af43da6603f1b31fb6d2d3eb02793b260ad0 (diff)
parentad5adacb1d1913620f022d7bb6c9b877ff3a4faf (diff)
downloadlibgit2-4bb6ffb6bb8ad9d49eb173350be965183cd09c96.tar.gz
Merge pull request #2622 from libgit2/refresh-config-snapshot
Refresh git configuration before looking for the tracking branch redux.
Diffstat (limited to 'src')
-rw-r--r--src/config_file.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/config_file.c b/src/config_file.c
index 8f55c42f3..1f73e7e11 100644
--- a/src/config_file.c
+++ b/src/config_file.c
@@ -767,12 +767,17 @@ static int config_readonly_open(git_config_backend *cfg, git_config_level_t leve
{
diskfile_readonly_backend *b = (diskfile_readonly_backend *) cfg;
diskfile_backend *src = b->snapshot_from;
+ diskfile_header *src_header = &src->header;
refcounted_strmap *src_map;
+ int error;
+
+ if (!src_header->readonly && (error = config_refresh(&src_header->parent)) < 0)
+ return error;
/* We're just copying data, don't care about the level */
GIT_UNUSED(level);
- src_map = refcounted_strmap_take(&src->header);
+ src_map = refcounted_strmap_take(src_header);
b->header.values = src_map;
return 0;