]> git.ipfire.org Git - thirdparty/git.git/commit - revision.h
rev-list: add commit object support in `--missing` option
authorKarthik Nayak <karthik.188@gmail.com>
Fri, 27 Oct 2023 07:59:29 +0000 (09:59 +0200)
committerJunio C Hamano <gitster@pobox.com>
Wed, 1 Nov 2023 03:07:18 +0000 (12:07 +0900)
commit9830926c7db626e374b887eeecb96515e2956638
tree252371c7783c8217a2e0bbcc57c41d9109f12b47
parentb49529230d512c9a9551e064e3181bc8c1264880
rev-list: add commit object support in `--missing` option

The `--missing` object option in rev-list currently works only with
missing blobs/trees. For missing commits the revision walker fails with
a fatal error.

Let's extend the functionality of `--missing` option to also support
commit objects. This is done by adding a `missing_objects` field to
`rev_info`. This field is an `oidset` to which we'll add the missing
commits as we encounter them. The revision walker will now continue the
traversal and call `show_commit()` even for missing commits. In rev-list
we can then check if the commit is a missing commit and call the
existing code for parsing `--missing` objects.

A scenario where this option would be used is to find the boundary
objects between different object directories. Consider a repository with
a main object directory (GIT_OBJECT_DIRECTORY) and one or more alternate
object directories (GIT_ALTERNATE_OBJECT_DIRECTORIES). In such a
repository, using the `--missing=print` option while disabling the
alternate object directory allows us to find the boundary objects
between the main and alternate object directory.

Helped-by: Patrick Steinhardt <ps@pks.im>
Helped-by: Junio C Hamano <gitster@pobox.com>
Signed-off-by: Karthik Nayak <karthik.188@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/rev-list.c
list-objects.c
revision.c
revision.h
t/t6022-rev-list-missing.sh [new file with mode: 0755]