Commit 11684104 by Russell Belfer

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.
parent 2eb4edf5
...@@ -205,6 +205,16 @@ cleanup: ...@@ -205,6 +205,16 @@ cleanup:
return 0; 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( int git_ignore_add_rule(
git_repository *repo, git_repository *repo,
const char *rules) const char *rules)
...@@ -212,10 +222,7 @@ int git_ignore_add_rule( ...@@ -212,10 +222,7 @@ int git_ignore_add_rule(
int error; int error;
git_attr_file *ign_internal; git_attr_file *ign_internal;
error = git_attr_cache__internal_file( if (!(error = get_internal_ignores(&ign_internal, repo)))
repo, GIT_IGNORE_INTERNAL, &ign_internal);
if (!error && ign_internal != NULL)
error = parse_ignore_file(repo, rules, ign_internal); error = parse_ignore_file(repo, rules, ign_internal);
return error; return error;
...@@ -227,10 +234,7 @@ int git_ignore_clear_internal_rules( ...@@ -227,10 +234,7 @@ int git_ignore_clear_internal_rules(
int error; int error;
git_attr_file *ign_internal; git_attr_file *ign_internal;
error = git_attr_cache__internal_file( if (!(error = get_internal_ignores(&ign_internal, repo)))
repo, GIT_IGNORE_INTERNAL, &ign_internal);
if (!error && ign_internal != NULL)
git_attr_file__clear_rules(ign_internal); git_attr_file__clear_rules(ign_internal);
return error; return error;
......
...@@ -199,3 +199,18 @@ void test_status_ignore__adding_internal_ignores(void) ...@@ -199,3 +199,18 @@ void test_status_ignore__adding_internal_ignores(void)
cl_git_pass(git_status_should_ignore(&ignored, g_repo, "two.bar")); cl_git_pass(git_status_should_ignore(&ignored, g_repo, "two.bar"));
cl_assert(ignored); cl_assert(ignored);
} }
void test_status_ignore__add_internal_as_first_thing(void)
{
int ignored;
const char *add_me = "\n#################\n## Eclipse\n#################\n\n*.pydevproject\n.project\n.metadata\nbin/\ntmp/\n*.tmp\n\n";
g_repo = cl_git_sandbox_init("empty_standard_repo");
cl_git_pass(git_ignore_add_rule(g_repo, add_me));
cl_git_pass(git_status_should_ignore(&ignored, g_repo, "one.tmp"));
cl_assert(ignored);
cl_git_pass(git_status_should_ignore(&ignored, g_repo, "two.bar"));
cl_assert(!ignored);
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment