aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSeyi Kufoiji <kuforiji98@gmail.com>2026-03-05 11:05:26 +0100
committerJunio C Hamano <gitster@pobox.com>2026-03-05 11:16:18 -0800
commita98ea50288c9fd39b501710635977478fb1f0a05 (patch)
tree2a4ad863dc8f73fe7265f6f8940e99e977e597d8
parenta06a725c7847840ac56c0e797a829ac13abbe350 (diff)
downloadgit-a98ea50288c9fd39b501710635977478fb1f0a05.tar.xz
builtin/rev-list: migrate missing_objects cleanup to oidmap_clear_with_free()
As part of the conversion away from oidmap_clear(), switch the missing_objects map to use oidmap_clear_with_free(). missing_objects stores struct missing_objects_map_entry instances, which own an xstrdup()'d path string in addition to the container struct itself. Previously, rev-list manually freed entry->path before calling oidmap_clear(&missing_objects, true). Introduce a dedicated free callback and pass it to oidmap_clear_with_free(), consolidating entry teardown into a single place and making cleanup semantics explicit. Signed-off-by: Seyi Kuforiji <kuforiji98@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
-rw-r--r--builtin/rev-list.c15
1 files changed, 12 insertions, 3 deletions
diff --git a/builtin/rev-list.c b/builtin/rev-list.c
index 99f876ba85..3bf30e1467 100644
--- a/builtin/rev-list.c
+++ b/builtin/rev-list.c
@@ -88,9 +88,19 @@ static int arg_print_omitted; /* print objects omitted by filter */
struct missing_objects_map_entry {
struct oidmap_entry entry;
- const char *path;
+ char *path;
unsigned type;
};
+
+static void missing_objects_map_entry_free(void *e)
+{
+ struct missing_objects_map_entry *entry =
+ container_of(e, struct missing_objects_map_entry, entry);
+
+ free(entry->path);
+ free(entry);
+}
+
static struct oidmap missing_objects;
enum missing_action {
MA_ERROR = 0, /* fail if any missing objects are encountered */
@@ -935,10 +945,9 @@ int cmd_rev_list(int argc,
while ((entry = oidmap_iter_next(&iter))) {
print_missing_object(entry, arg_missing_action ==
MA_PRINT_INFO);
- free((void *)entry->path);
}
- oidmap_clear(&missing_objects, true);
+ oidmap_clear_with_free(&missing_objects, missing_objects_map_entry_free);
}
stop_progress(&progress);