From 2b74f68ca0553afcab3bed4b6971cf3bfd1fa7b2 Mon Sep 17 00:00:00 2001 From: René Scharfe Date: Fri, 9 Jan 2026 22:30:13 +0100 Subject: tree: add repo_parse_tree*() MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Add variants of parse_tree(), parse_tree_gently() and parse_tree_indirect() that allow using an arbitrary repository. Signed-off-by: René Scharfe Signed-off-by: Junio C Hamano --- tree.c | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) (limited to 'tree.c') diff --git a/tree.c b/tree.c index 2a677234d6..036f56ca29 100644 --- a/tree.c +++ b/tree.c @@ -186,6 +186,12 @@ int parse_tree_buffer(struct tree *item, void *buffer, unsigned long size) } int parse_tree_gently(struct tree *item, int quiet_on_missing) +{ + return repo_parse_tree_gently(the_repository, item, quiet_on_missing); +} + +int repo_parse_tree_gently(struct repository *r, struct tree *item, + int quiet_on_missing) { enum object_type type; void *buffer; @@ -193,8 +199,7 @@ int parse_tree_gently(struct tree *item, int quiet_on_missing) if (item->object.parsed) return 0; - buffer = odb_read_object(the_repository->objects, &item->object.oid, - &type, &size); + buffer = odb_read_object(r->objects, &item->object.oid, &type, &size); if (!buffer) return quiet_on_missing ? -1 : error("Could not read %s", @@ -216,7 +221,12 @@ void free_tree_buffer(struct tree *tree) struct tree *parse_tree_indirect(const struct object_id *oid) { - struct repository *r = the_repository; + return repo_parse_tree_indirect(the_repository, oid); +} + +struct tree *repo_parse_tree_indirect(struct repository *r, + const struct object_id *oid) +{ struct object *obj = parse_object(r, oid); return (struct tree *)repo_peel_to_type(r, NULL, 0, obj, OBJ_TREE); } -- cgit v1.3