Merge branch 'jk/optim-in-pack-idx-conversion'
Code clean-up. * jk/optim-in-pack-idx-conversion: pack-objects: avoid pointless oe_map_new_pack() calls
This commit is contained in:
@@ -119,7 +119,10 @@ void oe_map_new_pack(struct packing_data *pack)
|
|||||||
{
|
{
|
||||||
uint32_t i;
|
uint32_t i;
|
||||||
|
|
||||||
REALLOC_ARRAY(pack->in_pack, pack->nr_alloc);
|
if (pack->in_pack)
|
||||||
|
BUG("packing_data has already been converted to pack array");
|
||||||
|
|
||||||
|
ALLOC_ARRAY(pack->in_pack, pack->nr_alloc);
|
||||||
|
|
||||||
for (i = 0; i < pack->nr_objects; i++)
|
for (i = 0; i < pack->nr_objects; i++)
|
||||||
pack->in_pack[i] = oe_in_pack(pack, pack->objects + i);
|
pack->in_pack[i] = oe_in_pack(pack, pack->objects + i);
|
||||||
|
|||||||
@@ -251,12 +251,21 @@ static inline void oe_set_in_pack(struct packing_data *pack,
|
|||||||
struct object_entry *e,
|
struct object_entry *e,
|
||||||
struct packed_git *p)
|
struct packed_git *p)
|
||||||
{
|
{
|
||||||
if (!p->index)
|
if (pack->in_pack_by_idx) {
|
||||||
|
if (p->index) {
|
||||||
|
e->in_pack_idx = p->index;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
/*
|
||||||
|
* We're accessing packs by index, but this pack doesn't have
|
||||||
|
* an index (e.g., because it was added since we created the
|
||||||
|
* in_pack_by_idx array). Bail to oe_map_new_pack(), which
|
||||||
|
* will convert us to using the full in_pack array, and then
|
||||||
|
* fall through to our in_pack handling.
|
||||||
|
*/
|
||||||
oe_map_new_pack(pack);
|
oe_map_new_pack(pack);
|
||||||
if (pack->in_pack_by_idx)
|
}
|
||||||
e->in_pack_idx = p->index;
|
pack->in_pack[e - pack->objects] = p;
|
||||||
else
|
|
||||||
pack->in_pack[e - pack->objects] = p;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline struct object_entry *oe_delta(
|
static inline struct object_entry *oe_delta(
|
||||||
|
|||||||
@@ -77,6 +77,7 @@ do
|
|||||||
# actual pack generation, without smudging the on-disk setup
|
# actual pack generation, without smudging the on-disk setup
|
||||||
# between trials.
|
# between trials.
|
||||||
test_perf "repack ($nr_packs)" '
|
test_perf "repack ($nr_packs)" '
|
||||||
|
GIT_TEST_FULL_IN_PACK_ARRAY=1 \
|
||||||
git pack-objects --keep-true-parents \
|
git pack-objects --keep-true-parents \
|
||||||
--honor-pack-keep --non-empty --all \
|
--honor-pack-keep --non-empty --all \
|
||||||
--reflog --indexed-objects --delta-base-offset \
|
--reflog --indexed-objects --delta-base-offset \
|
||||||
|
|||||||
Reference in New Issue
Block a user