diff options
author | Vicent Martà <tanoku@gmail.com> | 2011-11-25 21:31:35 -0800 |
---|---|---|
committer | Vicent Martà <tanoku@gmail.com> | 2011-11-25 21:31:35 -0800 |
commit | 880b6f0c22153db164ecb3a18c362ba8337365d3 (patch) | |
tree | 8f7a5a9efd16a2f80f629389a1dc9c6447b39eec /src | |
parent | e42ea1f488ae50655f31b8f09413a543b0fab9b7 (diff) | |
parent | 533fda3b83d757d7689880e67a19fd8a55e9fc55 (diff) | |
download | libgit2-880b6f0c22153db164ecb3a18c362ba8337365d3.tar.gz |
Merge pull request #497 from carlosmn/config
Don't fail when opening a new config file
Diffstat (limited to 'src')
-rw-r--r-- | src/config_file.c | 26 |
1 files changed, 21 insertions, 5 deletions
diff --git a/src/config_file.c b/src/config_file.c index 87a430759..5e862d487 100644 --- a/src/config_file.c +++ b/src/config_file.c @@ -256,7 +256,11 @@ static int config_open(git_config_file *cfg) diskfile_backend *b = (diskfile_backend *)cfg; error = git_futils_readbuffer(&b->reader.buffer, b->file_path); - if(error < GIT_SUCCESS) + /* It's fine if the file doesn't exist */ + if (error == GIT_ENOTFOUND) + return GIT_SUCCESS; + + if (error < GIT_SUCCESS) goto cleanup; error = config_parse(b); @@ -714,6 +718,9 @@ static int skip_bom(diskfile_backend *cfg) { static const char *utf8_bom = "\xef\xbb\xbf"; + if (cfg->reader.buffer.len < sizeof(utf8_bom)) + return GIT_SUCCESS; + if (memcmp(cfg->reader.read_ptr, utf8_bom, sizeof(utf8_bom)) == 0) cfg->reader.read_ptr += sizeof(utf8_bom); @@ -882,14 +889,23 @@ static int config_write(diskfile_backend *cfg, cvar_t *var) /* We need to read in our own config file */ error = git_futils_readbuffer(&cfg->reader.buffer, cfg->file_path); - if (error < GIT_SUCCESS) { + if (error < GIT_SUCCESS && error != GIT_ENOTFOUND) { return git__rethrow(error, "Failed to read existing config file %s", cfg->file_path); } /* Initialise the reading position */ - cfg->reader.read_ptr = cfg->reader.buffer.data; - cfg->reader.eof = 0; - data_start = cfg->reader.read_ptr; + if (error == GIT_ENOTFOUND) { + error = GIT_SUCCESS; + cfg->reader.read_ptr = NULL; + cfg->reader.eof = 1; + data_start = NULL; + cfg->reader.buffer.len = 0; + cfg->reader.buffer.data = NULL; + } else { + cfg->reader.read_ptr = cfg->reader.buffer.data; + cfg->reader.eof = 0; + data_start = cfg->reader.read_ptr; + } /* Lock the file */ error = git_filebuf_open(&file, cfg->file_path, 0); |