summaryrefslogtreecommitdiff
path: root/src/config_file.c
diff options
context:
space:
mode:
authorCarlos Martín Nieto <cmn@dwim.me>2013-09-06 20:51:35 +0200
committerCarlos Martín Nieto <cmn@dwim.me>2013-09-07 20:51:26 +0200
commita9fb79896e59f4e58cd7d174e7835e8a9c850a33 (patch)
tree7b68f32e3b0447ad75c82e6bdeccb1534804ade0 /src/config_file.c
parent19be0692b40f7ba8583ea96b1d0f382e45c13071 (diff)
downloadlibgit2-a9fb79896e59f4e58cd7d174e7835e8a9c850a33.tar.gz
config: refresh included files
We need to refresh the variables from the included files if they are changed, so loop over all included files and re-parse the files if any of them has changed.
Diffstat (limited to 'src/config_file.c')
-rw-r--r--src/config_file.c21
1 files changed, 16 insertions, 5 deletions
diff --git a/src/config_file.c b/src/config_file.c
index 3732fd15c..c83576524 100644
--- a/src/config_file.c
+++ b/src/config_file.c
@@ -197,14 +197,25 @@ static int config_open(git_config_backend *cfg, git_config_level_t level)
static int config_refresh(git_config_backend *cfg)
{
- int res, updated = 0;
+ int res = 0, updated = 0, any_updated = 0;
diskfile_backend *b = (diskfile_backend *)cfg;
git_strmap *old_values;
- struct reader *reader = git_array_get(b->readers, 0);
+ struct reader *reader;
+ uint32_t i;
- res = git_futils_readbuffer_updated(
- &reader->buffer, b->file_path, &reader->file_mtime, &reader->file_size, &updated);
- if (res < 0 || !updated)
+ for (i = 0; i < git_array_size(b->readers); i++) {
+ reader = git_array_get(b->readers, i);
+ res = git_futils_readbuffer_updated(
+ &reader->buffer, reader->file_path, &reader->file_mtime, &reader->file_size, &updated);
+
+ if (res < 0)
+ return (res == GIT_ENOTFOUND) ? 0 : res;
+
+ if (updated)
+ any_updated = 1;
+ }
+
+ if (!any_updated)
return (res == GIT_ENOTFOUND) ? 0 : res;
/* need to reload - store old values and prep for reload */