strbuf_addstr(&desc, _("no branch"));
strbuf_addch(&desc, ')');
- free(state.branch);
- free(state.onto);
- free(state.detached_from);
+ wt_status_state_free_buffers(&state);
return strbuf_detach(&desc, NULL);
}
used_atom_cnt = 0;
if (ref_to_worktree_map.worktrees) {
- hashmap_free_entries(&(ref_to_worktree_map.map),
+ hashmap_clear_and_free(&(ref_to_worktree_map.map),
struct ref_to_worktree_entry, ent);
free_worktrees(ref_to_worktree_map.worktrees);
ref_to_worktree_map.worktrees = NULL;
}
}
-static void do_merge_filter(struct ref_filter_cbdata *ref_cbdata, int reachable)
+#define EXCLUDE_REACHED 0
+#define INCLUDE_REACHED 1
+static void reach_filter(struct ref_array *array,
+ struct commit_list *check_reachable,
+ int include_reached)
{
struct rev_info revs;
int i, old_nr;
- struct ref_array *array = ref_cbdata->array;
- struct commit **to_clear = xcalloc(sizeof(struct commit *), array->nr);
- struct commit_list *rl;
+ struct commit **to_clear;
+ struct commit_list *cr;
- struct commit_list *check_reachable_list = reachable ?
- ref_cbdata->filter->reachable_from :
- ref_cbdata->filter->unreachable_from;
-
- if (!check_reachable_list)
+ if (!check_reachable)
return;
+ to_clear = xcalloc(sizeof(struct commit *), array->nr);
+
repo_init_revisions(the_repository, &revs, NULL);
for (i = 0; i < array->nr; i++) {
to_clear[i] = item->commit;
}
- for (rl = check_reachable_list; rl; rl = rl->next) {
- struct commit *merge_commit = rl->item;
+ for (cr = check_reachable; cr; cr = cr->next) {
+ struct commit *merge_commit = cr->item;
merge_commit->object.flags |= UNINTERESTING;
add_pending_object(&revs, &merge_commit->object, "");
}
int is_merged = !!(commit->object.flags & UNINTERESTING);
- if (is_merged == reachable)
+ if (is_merged == include_reached)
array->items[array->nr++] = array->items[i];
else
free_array_item(item);
clear_commit_marks_many(old_nr, to_clear, ALL_REV_FLAGS);
- while (check_reachable_list) {
- struct commit *merge_commit = pop_commit(&check_reachable_list);
+ while (check_reachable) {
+ struct commit *merge_commit = pop_commit(&check_reachable);
clear_commit_marks(merge_commit, ALL_REV_FLAGS);
}
clear_contains_cache(&ref_cbdata.no_contains_cache);
/* Filters that need revision walking */
- do_merge_filter(&ref_cbdata, DO_MERGE_FILTER_REACHABLE);
- do_merge_filter(&ref_cbdata, DO_MERGE_FILTER_UNREACHABLE);
+ reach_filter(array, filter->reachable_from, INCLUDE_REACHED);
+ reach_filter(array, filter->unreachable_from, EXCLUDE_REACHED);
return ret;
}