"Johannes Schindelin via GitGitGadget" <[email protected]>
writes:

> @@ -442,6 +442,18 @@ static enum get_oid_result get_short_oid(const char 
> *name, int len,
>       find_short_packed_object(&ds);
>       status = finish_object_disambiguation(&ds, oid);
>  
> +     /*
> +      * If we didn't find it, do the usual reprepare() slow-path,
> +      * since the object may have recently been added to the repository
> +      * or migrated from loose to packed.
> +      */
> +     if (status == MISSING_OBJECT) {
> +             reprepare_packed_git(the_repository);
> +             find_short_object_filename(&ds);
> +             find_short_packed_object(&ds);
> +             status = finish_object_disambiguation(&ds, oid);
> +     }
> +

This looks obviously correct, but two things that made me wonder
briefly were:

 1. is reprepare_packed_git() a bit too heavy-weight, if the only
    thing we are addressing is the loose-object cache going stale?

 2. is there a way to cleanly avoid the three-line duplicate?

My tentative answers are (1) even if it is, but get_short_oid() is
already heavy-weight enough; it won't be worth restructuring the
code to make it possible to clear only the loose-object cache, and
(2) a loop that runs twice when the first result is MISSING_OBJECT
and otherwise leaves after once would need an extra variable, its
iniialization, check and increment, which is more than what we might
save with such a restructuring, so it won't be worth pursuing.

But others may have better ideas, as always ;-)

Reply via email to