diff options
author | Russell Belfer <rb@github.com> | 2012-08-24 13:41:45 -0700 |
---|---|---|
committer | Russell Belfer <rb@github.com> | 2012-08-24 13:41:45 -0700 |
commit | 1168410426293aef8ce33becb277ff225595e183 (patch) | |
tree | 745ef945dd714903ebe81f58e9e846d340954f09 /src/ignore.c | |
parent | 2eb4edf5f269f60b188ff72d350ee321d1cbaf79 (diff) | |
download | libgit2-1168410426293aef8ce33becb277ff225595e183.tar.gz |
Fix crash with adding internal ignores
Depending on what you had done before adding new items to the
internal ignores list, it was possible for the cache of ignore
data to be uninitialized.
Diffstat (limited to 'src/ignore.c')
-rw-r--r-- | src/ignore.c | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/src/ignore.c b/src/ignore.c index 1ac8afdf3..3c2f19ab9 100644 --- a/src/ignore.c +++ b/src/ignore.c @@ -205,6 +205,16 @@ cleanup: return 0; } +static int get_internal_ignores(git_attr_file **ign, git_repository *repo) +{ + int error; + + if (!(error = git_attr_cache__init(repo))) + error = git_attr_cache__internal_file(repo, GIT_IGNORE_INTERNAL, ign); + + return error; +} + int git_ignore_add_rule( git_repository *repo, const char *rules) @@ -212,10 +222,7 @@ int git_ignore_add_rule( int error; git_attr_file *ign_internal; - error = git_attr_cache__internal_file( - repo, GIT_IGNORE_INTERNAL, &ign_internal); - - if (!error && ign_internal != NULL) + if (!(error = get_internal_ignores(&ign_internal, repo))) error = parse_ignore_file(repo, rules, ign_internal); return error; @@ -227,10 +234,7 @@ int git_ignore_clear_internal_rules( int error; git_attr_file *ign_internal; - error = git_attr_cache__internal_file( - repo, GIT_IGNORE_INTERNAL, &ign_internal); - - if (!error && ign_internal != NULL) + if (!(error = get_internal_ignores(&ign_internal, repo))) git_attr_file__clear_rules(ign_internal); return error; |