From: Taylor Blau <me@ttaylorr.com>
To: git@vger.kernel.org
Cc: Elijah Newren <newren@gmail.com>, Jeff King <peff@peff.net>,
Junio C Hamano <gitster@pobox.com>
Subject: [PATCH v3 0/9] repack: avoid MIDX'ing cruft pack(s) where possible
Date: Tue, 15 Apr 2025 18:46:45 -0400 [thread overview]
Message-ID: <cover.1744757204.git.me@ttaylorr.com> (raw)
In-Reply-To: <cover.1744413969.git.me@ttaylorr.com>
Here is a small-ish reroll of my series to explore creating MIDXs while
repacking that don't include the cruft pack.
The bulk of the series is unchanged, save for a few minor points that
I'll call out here (as usual, a complete range-diff is below for
convenience):
* Dropped the patch adding a warning about using designated
initializers. I think that we should resurrect this patch soon and
update the CodingGuidelines, but I'd rather disentangle that from
this series.
* Dropped the designated initializer component of the "limit scope"
patch.
* Swapped ordering on one of the die_for_incompatible_opt2() checks.
* Various wording tweaks.
* Split out some code movement changes into their own patches to make
substantive patches easier to read/review.
* Test updates and cleanup.
These changes are all thanks to helpful review from Junio and Elijah.
Thanks, both!
Otherwise the series is unchanged. I still need to deploy it to GitHub's
infrastructure and try it out on some internal repos, but I should be
able to do that tomorrow and report back on my findings a few days after
that.
Thanks in advance for any review :-).
Taylor Blau (9):
pack-objects: use standard option incompatibility functions
pack-objects: limit scope in 'add_object_entry_from_pack()'
pack-objects: factor out handling '--stdin-packs'
pack-objects: declare 'rev_info' for '--stdin-packs' earlier
pack-objects: perform name-hash traversal for unpacked objects
pack-objects: fix typo in 'show_object_pack_hint()'
pack-objects: swap 'show_{object,commit}_pack_hint'
pack-objects: introduce '--stdin-packs=follow'
repack: exclude cruft pack(s) from the MIDX where possible
Documentation/config/repack.adoc | 7 +
Documentation/git-pack-objects.adoc | 10 +-
builtin/pack-objects.c | 192 ++++++++++++++++++----------
builtin/repack.c | 163 ++++++++++++++++++++---
t/t5331-pack-objects-stdin.sh | 84 +++++++++++-
t/t7704-repack-cruft.sh | 90 +++++++++++++
6 files changed, 456 insertions(+), 90 deletions(-)
Range-diff against v2:
1: 65bc7e4630 ! 1: f8b31c6a8d pack-objects: use standard option incompatibility functions
@@ builtin/pack-objects.c: int cmd_pack_objects(int argc,
- if (stdin_packs && filter_options.choice)
- die(_("cannot use --filter with --stdin-packs"));
-+ die_for_incompatible_opt2(filter_options.choice, "--filter",
-+ stdin_packs, "--stdin-packs");
++ die_for_incompatible_opt2(stdin_packs, "--stdin-packs",
++ filter_options.choice, "--filter");
++
if (stdin_packs && use_internal_rev_list)
die(_("cannot use internal rev list with --stdin-packs"));
@@ t/t5331-pack-objects-stdin.sh: test_expect_success '--stdin-packs is incompatibl
test_must_fail git pack-objects --stdin-packs --stdout \
--filter=blob:none </dev/null 2>err &&
- test_grep "cannot use --filter with --stdin-packs" err
-+ test_grep "options .--filter. and .--stdin-packs. cannot be used together" err
++ test_grep "options .--stdin-packs. and .--filter. cannot be used together" err
)
'
2: 920c91eb1e < -: ---------- object-store-ll.h: add note about designated initializers
3: f8ac36b110 ! 2: 986bef29b5 pack-objects: limit scope in 'add_object_entry_from_pack()'
@@ Metadata
## Commit message ##
pack-objects: limit scope in 'add_object_entry_from_pack()'
- add_object_entry_from_pack() handles objects from identified packs by
- checking their type, before adding commit objects as pending in the
- subsequent traversal used by `--stdin-packs`.
-
- There are a couple of quality-of-life refactorings that I noticed while
- working in this area:
-
- - We declare 'revs' (given to us through the miscellaneous context
- argument) earlier in the "if (p)" conditional than is necessary.
-
- - The 'struct object_info' can use a designated initializer to fill in
- the structures type pointer, since that is the only field that we
- care about.
+ In add_object_entry_from_pack() we declare 'revs' (given to us through
+ the miscellaneous context argument) earlier in the "if (p)" conditional
+ than is necessary. Move it down as far as it can go to reduce its
+ scope.
Signed-off-by: Taylor Blau <me@ttaylorr.com>
@@ builtin/pack-objects.c: static int add_object_entry_from_pack(const struct objec
if (p) {
- struct rev_info *revs = _data;
-- struct object_info oi = OBJECT_INFO_INIT;
+ struct object_info oi = OBJECT_INFO_INIT;
-
-- oi.typep = &type;
-+ struct object_info oi = { .typep = &type };
+ oi.typep = &type;
++
if (packed_object_info(the_repository, p, ofs, &oi) < 0) {
die(_("could not get type of object %s in pack %s"),
oid_to_hex(oid), p->pack_name);
4: 5e03b482ba = 3: 6f8fe8a4e1 pack-objects: factor out handling '--stdin-packs'
5: bccbac2ec5 = 4: 2a235461a6 pack-objects: declare 'rev_info' for '--stdin-packs' earlier
6: 0bc2183dc3 ! 5: 240e90b68d pack-objects: perform name-hash traversal for unpacked objects
@@ Commit message
pack (`add_unreachable_loose_objects()`) did not have access to the
'rev_info' struct found in `read_packs_list_from_stdin()`.
- Excluding unpacked objects from that traversal doesn't effect the
+ Excluding unpacked objects from that traversal doesn't affect the
correctness of the resulting pack, but it does make it harder to
discover good deltas for loose objects.
-: ---------- > 6: 9a18fa2e52 pack-objects: fix typo in 'show_object_pack_hint()'
-: ---------- > 7: 6c997853f1 pack-objects: swap 'show_{object,commit}_pack_hint'
7: 697a337cb1 ! 8: 0ff699f056 pack-objects: introduce '--stdin-packs=follow'
@@ Documentation/git-pack-objects.adoc: base-name::
included packs (those not beginning with `^`), excluding any
objects listed in the excluded packs (beginning with `^`).
+
-+When `mode` is "follow", pack objects which are reachable from objects
-+in the included packs, but appear in packs that are not listed.
-+Reachable objects which appear in excluded packs are not packed. Useful
-+for resurrecting once-cruft objects to generate packs which are closed
-+under reachability up to the excluded packs.
++When `mode` is "follow", objects from packs not listed on stdin receive
++special treatment. Objects within unlisted packs will be included if
++those objects are (1) reachable from the included packs, and (2) not
++found in any excluded packs. This mode is useful, for example, to
++resurrect once-unreachable objects found in cruft packs to generate
++packs which are closed under reachability up to the boundary set by the
++excluded packs.
++
Incompatible with `--revs`, or options that imply `--revs` (such as
`--all`), with the exception of `--unpacked`, which is compatible.
@@ builtin/pack-objects.c: static struct oidmap configured_exclusions;
* Check whether the name_hash_version chosen by user input is appropriate,
* and also validate whether it is compatible with other features.
@@ builtin/pack-objects.c: static int add_object_entry_from_pack(const struct object_id *oid,
- return 0;
}
--static void show_commit_pack_hint(struct commit *commit UNUSED,
-- void *data UNUSED)
--{
-- /* nothing to do; commits don't have a namehash */
--}
--
static void show_object_pack_hint(struct object *object, const char *name,
- void *data UNUSED)
+ void *data)
{
- struct object_entry *oe = packlist_find(&to_pack, &object->oid);
- if (!oe)
+- return;
+ enum stdin_packs_mode mode = *(enum stdin_packs_mode *)data;
+ if (mode == STDIN_PACKS_MODE_FOLLOW) {
+ add_object_entry(&object->oid, object->type, name, 0);
@@ builtin/pack-objects.c: static int add_object_entry_from_pack(const struct objec
+ struct object_entry *oe = packlist_find(&to_pack, &object->oid);
+ if (!oe)
+ return;
-+
-+ /*
-+ * Our 'to_pack' list was constructed by iterating all
-+ * objects packed in included packs, and so doesn't
-+ * have a non-zero hash field that you would typically
-+ * pick up during a reachability traversal.
-+ *
-+ * Make a best-effort attempt to fill in the ->hash
-+ * and ->no_try_delta here using a now in order to
-+ * perhaps improve the delta selection process.
-+ */
-+ oe->hash = pack_name_hash_fn(name);
-+ oe->no_try_delta = name && no_try_delta(name);
-+
-+ stdin_packs_hints_nr++;
-+ }
-+}
-+
-+static void show_commit_pack_hint(struct commit *commit, void *data)
-+{
-+ enum stdin_packs_mode mode = *(enum stdin_packs_mode *)data;
-+ if (mode == STDIN_PACKS_MODE_FOLLOW) {
-+ show_object_pack_hint((struct object *)commit, "", data);
- return;
-+ }
-+ /* nothing to do; commits don't have a namehash */
- /*
- * Our 'to_pack' list was constructed by iterating all objects packed in
@@ builtin/pack-objects.c: static int add_object_entry_from_pack(const struct objec
- * would typically pick up during a reachability traversal.
- *
- * Make a best-effort attempt to fill in the ->hash and ->no_try_delta
-- * here using a now in order to perhaps improve the delta selection
+- * fields here in order to perhaps improve the delta selection
- * process.
- */
- oe->hash = pack_name_hash_fn(name);
- oe->no_try_delta = name && no_try_delta(name);
--
++ /*
++ * Our 'to_pack' list was constructed by iterating all
++ * objects packed in included packs, and so doesn't have
++ * a non-zero hash field that you would typically pick
++ * up during a reachability traversal.
++ *
++ * Make a best-effort attempt to fill in the ->hash and
++ * ->no_try_delta fields here in order to perhaps
++ * improve the delta selection process.
++ */
++ oe->hash = pack_name_hash_fn(name);
++ oe->no_try_delta = name && no_try_delta(name);
+
- stdin_packs_hints_nr++;
++ stdin_packs_hints_nr++;
++ }
+ }
+
+-static void show_commit_pack_hint(struct commit *commit UNUSED,
+- void *data UNUSED)
++static void show_commit_pack_hint(struct commit *commit, void *data)
+ {
++ enum stdin_packs_mode mode = *(enum stdin_packs_mode *)data;
++
++ if (mode == STDIN_PACKS_MODE_FOLLOW) {
++ show_object_pack_hint((struct object *)commit, "", data);
++ return;
++ }
++
+ /* nothing to do; commits don't have a namehash */
++
}
static int pack_mtime_cmp(const void *_a, const void *_b)
@@ t/t5331-pack-objects-stdin.sh: test_expect_success 'pack-objects --stdin with pa
+ rm -f objects.raw
+}
+
-+test_expect_success 'setup for --stdin-packs=follow' '
-+ git init stdin-packs--follow &&
-+ (
-+ cd stdin-packs--follow &&
-+
-+ for c in A B C D
-+ do
-+ test_commit "$c" || return 1
-+ done &&
-+
-+ A="$(echo A | git pack-objects --revs $packdir/pack)" &&
-+ B="$(echo A..B | git pack-objects --revs $packdir/pack)" &&
-+ C="$(echo B..C | git pack-objects --revs $packdir/pack)" &&
-+ D="$(echo C..D | git pack-objects --revs $packdir/pack)" &&
-+
-+ git prune-packed
-+ )
-+'
-+
+test_expect_success '--stdin-packs=follow walks into unknown packs' '
+ test_when_finished "rm -fr repo" &&
+
@@ t/t5331-pack-objects-stdin.sh: test_expect_success 'pack-objects --stdin with pa
+ B="$(echo A..B | git pack-objects --revs $packdir/pack)" &&
+ C="$(echo B..C | git pack-objects --revs $packdir/pack)" &&
+ D="$(echo C..D | git pack-objects --revs $packdir/pack)" &&
++ test_commit E &&
+
+ git prune-packed &&
+
@@ t/t5331-pack-objects-stdin.sh: test_expect_success 'pack-objects --stdin with pa
+ objects_in_packs $P >actual &&
+ test_cmp expect actual &&
+
-+ test_commit E &&
+ # And with --unpacked, we will pick up objects from unknown
+ # packs that are reachable from loose objects. Loose object E
+ # reaches objects in pack A, but there are three excluded packs
8: a2ec1b826c ! 9: 58891101f3 repack: exclude cruft pack(s) from the MIDX where possible
@@ Commit message
MIDX with '--write-midx' to ensure that the resulting MIDX was always
closed under reachability in order to generate reachability bitmaps.
- Suppose you have a once-unreachable object packed in a cruft pack, which
- later on becomes reachable from one or more objects in a geometrically
- repacked pack. That once-unreachable object *won't* appear in the new
- pack, since the cruft pack was specified as neither included nor
- excluded to 'pack-objects --stdin-packs'. If the bitmap selection
- process picks one or more commits which reach the once-unreachable
- objects, commit ddee3703b3 ensures that the MIDX will be closed under
- reachability. Without it, we would fail to generate a MIDX bitmap.
+ Suppose (prior to this patch) you have a once-unreachable object packed
+ in a cruft pack, which later on becomes reachable from one or more
+ objects in a geometrically repacked pack. That once-unreachable object
+ *won't* appear in the new pack, since the cruft pack was specified as
+ neither included nor excluded to 'pack-objects --stdin-packs'. If the
+ new pack is included in a MIDX without the cruft pack, then trying to
+ generate bitmaps for that MIDX may fail. This happens when the bitmap
+ selection process picks one or more commits which reach the
+ once-unreachable objects, commit ddee3703b3 ensures that the MIDX will
+ be closed under reachability. Without it, we would fail to generate a
+ MIDX bitmap.
ddee3703b3 alludes to the fact that this is sub-optimal by saying
@@ Commit message
and slows down object lookup.
This is doubly unfortunate because the vast majority of objects in cruft
- pack(s) are unlikely to be read, but object reads that go through the
- MIDX have to search through them anyway.
+ pack(s) are unlikely to be read. But any object lookups that go through
+ the MIDX must binary search over them anyway, slowing down object
+ lookups using the MIDX.
This patch causes geometrically-repacked packs to contain a copy of any
once-unreachable object(s) with 'git pack-objects --stdin-packs=follow',
@@ Commit message
be closed under reachability.
Note that you cannot guarantee that a collection of packs is closed
- under reachability if not all of them were generated with following as
+ under reachability if not all of them were generated with "following" as
above. One tell-tale sign that not all geometrically-repacked packs in
- the MIDX were generated with following is to see if there is a pack in
+ the MIDX were generated with "following" is to see if there is a pack in
the existing MIDX that is not going to be somehow represented (either
verbatim or as part of a geometric rollup) in the new MIDX.
- If there is, then starting to generate packs with following during
+ If there is, then starting to generate packs with "following" during
geometric repacking won't work, since it's open to the same race as
described above.
@@ builtin/repack.c: static void midx_included_packs(struct string_list *include,
- * repack).
+ * For example, a cruft pack can be required to form a
+ * reachability closure if the MIDX is bitmapped and one
-+ * or more of its selected commits reaches a once-cruft
-+ * object that was later made reachable.
++ * or more of the bitmap's selected commits reaches a
++ * once-cruft object that was later made reachable.
*/
- if (pack_is_marked_for_deletion(item))
- continue;
@@ builtin/repack.c: static void midx_included_packs(struct string_list *include,
+ }
+ } else {
+ /*
-+ * Modern versions of Git will write new copies of
++ * Modern versions of Git (with the appropriate
++ * configuration setting) will write new copies of
+ * once-cruft objects when doing a --geometric repack.
+ *
+ * If the MIDX has no cruft pack, new packs written
base-commit: 485f5f863615e670fd97ae40af744e14072cfe18
--
2.49.0.230.ga662d77f78
next prev parent reply other threads:[~2025-04-15 22:46 UTC|newest]
Thread overview: 105+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-04-11 23:26 [RFC PATCH 0/8] repack: avoid MIDX'ing cruft pack(s) where possible Taylor Blau
2025-04-11 23:26 ` [RFC PATCH 1/8] pack-objects: use standard option incompatibility functions Taylor Blau
2025-04-11 23:26 ` [RFC PATCH 2/8] pack-objects: limit scope in 'add_object_entry_from_pack()' Taylor Blau
2025-04-11 23:26 ` [RFC PATCH 3/8] pack-objects: factor out handling '--stdin-packs' Taylor Blau
2025-04-11 23:26 ` [RFC PATCH 4/8] pack-objects: declare 'rev_info' for '--stdin-packs' earlier Taylor Blau
2025-04-11 23:26 ` [RFC PATCH 5/8] pack-objects: perform name-hash traversal for unpacked objects Taylor Blau
2025-04-11 23:26 ` [RFC PATCH 6/8] pack-objects: introduce '--stdin-packs=follow' Taylor Blau
2025-04-11 23:26 ` [RFC PATCH 7/8] repack: keep track of existing MIDX'd packs Taylor Blau
2025-04-11 23:26 ` [RFC PATCH 8/8] repack: exclude cruft pack(s) from the MIDX where possible Taylor Blau
2025-04-14 20:06 ` [PATCH v2 0/8] repack: avoid MIDX'ing cruft pack(s) " Taylor Blau
2025-04-14 20:06 ` [PATCH v2 1/8] pack-objects: use standard option incompatibility functions Taylor Blau
2025-04-14 20:41 ` Junio C Hamano
2025-04-15 19:32 ` Taylor Blau
2025-04-15 19:48 ` Junio C Hamano
2025-04-15 22:27 ` Taylor Blau
2025-04-14 20:06 ` [PATCH v2 2/8] object-store-ll.h: add note about designated initializers Taylor Blau
2025-04-14 21:07 ` Junio C Hamano
2025-04-15 19:51 ` Taylor Blau
2025-04-15 2:57 ` Elijah Newren
2025-04-15 19:47 ` Taylor Blau
2025-04-14 20:06 ` [PATCH v2 3/8] pack-objects: limit scope in 'add_object_entry_from_pack()' Taylor Blau
2025-04-15 3:10 ` Elijah Newren
2025-04-14 20:06 ` [PATCH v2 4/8] pack-objects: factor out handling '--stdin-packs' Taylor Blau
2025-04-14 20:06 ` [PATCH v2 5/8] pack-objects: declare 'rev_info' for '--stdin-packs' earlier Taylor Blau
2025-04-14 20:06 ` [PATCH v2 6/8] pack-objects: perform name-hash traversal for unpacked objects Taylor Blau
2025-04-15 3:10 ` Elijah Newren
2025-04-15 19:57 ` Taylor Blau
2025-04-14 20:06 ` [PATCH v2 7/8] pack-objects: introduce '--stdin-packs=follow' Taylor Blau
2025-04-15 3:11 ` Elijah Newren
2025-04-15 20:45 ` Taylor Blau
2025-04-16 5:26 ` Elijah Newren
2025-04-14 20:06 ` [PATCH v2 8/8] repack: exclude cruft pack(s) from the MIDX where possible Taylor Blau
2025-04-15 3:11 ` Elijah Newren
2025-04-15 20:51 ` Taylor Blau
2025-04-15 2:57 ` [PATCH v2 0/8] repack: avoid MIDX'ing cruft pack(s) " Elijah Newren
2025-04-15 22:05 ` Taylor Blau
2025-04-15 22:46 ` Taylor Blau [this message]
2025-04-15 22:46 ` [PATCH v3 1/9] pack-objects: use standard option incompatibility functions Taylor Blau
2025-04-15 22:46 ` [PATCH v3 2/9] pack-objects: limit scope in 'add_object_entry_from_pack()' Taylor Blau
2025-04-16 0:58 ` Junio C Hamano
2025-04-16 22:07 ` Taylor Blau
2025-04-16 5:31 ` Elijah Newren
2025-04-16 22:07 ` Taylor Blau
2025-04-15 22:46 ` [PATCH v3 3/9] pack-objects: factor out handling '--stdin-packs' Taylor Blau
2025-04-16 0:59 ` Junio C Hamano
2025-04-15 22:46 ` [PATCH v3 4/9] pack-objects: declare 'rev_info' for '--stdin-packs' earlier Taylor Blau
2025-04-15 22:47 ` [PATCH v3 5/9] pack-objects: perform name-hash traversal for unpacked objects Taylor Blau
2025-04-16 9:21 ` Junio C Hamano
2025-04-15 22:47 ` [PATCH v3 6/9] pack-objects: fix typo in 'show_object_pack_hint()' Taylor Blau
2025-04-16 5:36 ` Elijah Newren
2025-04-15 22:47 ` [PATCH v3 7/9] pack-objects: swap 'show_{object,commit}_pack_hint' Taylor Blau
2025-04-15 22:47 ` [PATCH v3 8/9] pack-objects: introduce '--stdin-packs=follow' Taylor Blau
2025-04-15 22:47 ` [PATCH v3 9/9] repack: exclude cruft pack(s) from the MIDX where possible Taylor Blau
2025-04-16 5:56 ` Elijah Newren
2025-04-16 22:16 ` Taylor Blau
2025-05-13 3:34 ` Elijah Newren
2025-05-28 23:20 ` [PATCH v4 0/9] repack: avoid MIDX'ing cruft pack(s) " Taylor Blau
2025-05-28 23:20 ` [PATCH v4 1/9] pack-objects: use standard option incompatibility functions Taylor Blau
2025-05-28 23:20 ` [PATCH v4 2/9] pack-objects: limit scope in 'add_object_entry_from_pack()' Taylor Blau
2025-05-28 23:20 ` [PATCH v4 3/9] pack-objects: factor out handling '--stdin-packs' Taylor Blau
2025-05-28 23:20 ` [PATCH v4 4/9] pack-objects: declare 'rev_info' for '--stdin-packs' earlier Taylor Blau
2025-05-28 23:20 ` [PATCH v4 5/9] pack-objects: perform name-hash traversal for unpacked objects Taylor Blau
2025-05-28 23:20 ` [PATCH v4 6/9] pack-objects: fix typo in 'show_object_pack_hint()' Taylor Blau
2025-05-28 23:20 ` [PATCH v4 7/9] pack-objects: swap 'show_{object,commit}_pack_hint' Taylor Blau
2025-05-28 23:20 ` [PATCH v4 8/9] pack-objects: introduce '--stdin-packs=follow' Taylor Blau
2025-05-28 23:20 ` [PATCH v4 9/9] repack: exclude cruft pack(s) from the MIDX where possible Taylor Blau
2025-06-19 11:33 ` Carlo Marcelo Arenas Belón
2025-06-19 13:08 ` [PATCH] fixup! " Carlo Marcelo Arenas Belón
2025-06-19 17:07 ` Junio C Hamano
2025-06-19 23:26 ` Taylor Blau
2025-05-29 0:07 ` [PATCH v4 0/9] repack: avoid MIDX'ing cruft pack(s) " Taylor Blau
2025-05-29 0:15 ` Elijah Newren
2025-06-19 23:30 ` [PATCH v5 " Taylor Blau
2025-06-19 23:30 ` [PATCH v5 1/9] pack-objects: use standard option incompatibility functions Taylor Blau
2025-06-19 23:30 ` [PATCH v5 2/9] pack-objects: limit scope in 'add_object_entry_from_pack()' Taylor Blau
2025-06-19 23:30 ` [PATCH v5 3/9] pack-objects: factor out handling '--stdin-packs' Taylor Blau
2025-06-19 23:30 ` [PATCH v5 4/9] pack-objects: declare 'rev_info' for '--stdin-packs' earlier Taylor Blau
2025-06-19 23:30 ` [PATCH v5 5/9] pack-objects: perform name-hash traversal for unpacked objects Taylor Blau
2025-06-19 23:30 ` [PATCH v5 6/9] pack-objects: fix typo in 'show_object_pack_hint()' Taylor Blau
2025-06-19 23:30 ` [PATCH v5 7/9] pack-objects: swap 'show_{object,commit}_pack_hint' Taylor Blau
2025-06-19 23:30 ` [PATCH v5 8/9] pack-objects: introduce '--stdin-packs=follow' Taylor Blau
2025-06-20 15:27 ` Junio C Hamano
2025-06-19 23:30 ` [PATCH v5 9/9] repack: exclude cruft pack(s) from the MIDX where possible Taylor Blau
2025-06-21 4:35 ` Jeff King
2025-06-23 18:47 ` Taylor Blau
2025-06-24 10:54 ` Jeff King
2025-06-24 16:05 ` Taylor Blau
2025-06-23 22:32 ` [PATCH v6 0/9] repack: avoid MIDX'ing cruft pack(s) " Taylor Blau
2025-06-23 22:32 ` [PATCH v6 1/9] pack-objects: use standard option incompatibility functions Taylor Blau
2025-06-24 15:52 ` Junio C Hamano
2025-06-24 16:06 ` Taylor Blau
2025-06-23 22:32 ` [PATCH v6 2/9] pack-objects: limit scope in 'add_object_entry_from_pack()' Taylor Blau
2025-06-23 22:49 ` Junio C Hamano
2025-06-23 22:32 ` [PATCH v6 3/9] pack-objects: factor out handling '--stdin-packs' Taylor Blau
2025-06-23 22:32 ` [PATCH v6 4/9] pack-objects: declare 'rev_info' for '--stdin-packs' earlier Taylor Blau
2025-06-23 22:59 ` Junio C Hamano
2025-06-23 22:32 ` [PATCH v6 5/9] pack-objects: perform name-hash traversal for unpacked objects Taylor Blau
2025-06-23 23:08 ` Junio C Hamano
2025-06-24 16:08 ` Taylor Blau
2025-06-23 22:32 ` [PATCH v6 6/9] pack-objects: fix typo in 'show_object_pack_hint()' Taylor Blau
2025-06-23 22:32 ` [PATCH v6 7/9] pack-objects: swap 'show_{object,commit}_pack_hint' Taylor Blau
2025-06-23 22:32 ` [PATCH v6 8/9] pack-objects: introduce '--stdin-packs=follow' Taylor Blau
2025-06-23 23:35 ` Junio C Hamano
2025-06-24 16:10 ` Taylor Blau
2025-06-23 22:32 ` [PATCH v6 9/9] repack: exclude cruft pack(s) from the MIDX where possible Taylor Blau
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=cover.1744757204.git.me@ttaylorr.com \
--to=me@ttaylorr.com \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
--cc=newren@gmail.com \
--cc=peff@peff.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.