blob: drop unused parts of parse_blob_buffer()

Our parse_blob_buffer() takes a ptr/len combo, just like
parse_tree_buffer(), etc, and returns success or failure. But it doesn't
actually do anything with them; we just set the "parsed" flag in the
object and return success, without even looking at the contents.

There could be some value to keeping these unused parameters:

  - it's consistent with the parse functions for other object types. But
    we already lost that consistency in 837d395a5c (Replace parse_blob()
    with an explanatory comment, 2010-01-18).

  - As the comment from 837d395a5c explains, callers are supposed to
    make sure they have the object content available. So in theory
    asking for these parameters could serve as a signal. But there are
    only two callers, and one of them always passes NULL (after doing a
    streaming check of the object hash).

    This shows that there aren't likely to be a lot of callers (since
    everyone either uses the type-generic parse functions, or handles
    blobs individually), and that they need to take special care anyway
    (because we usually want to avoid loading whole blobs in memory if
    we can avoid it).

So let's just drop these unused parameters, and likewise the useless
return value. While we're touching the header file, let's move the
declaration of parse_blob_buffer() right below that explanatory comment,
where it's more likely to be seen by people looking for the function.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2022-12-13 06:11:57 -05:00 committed by Junio C Hamano
parent 91e2ab1587
commit c1166ca0e2
3 changed files with 4 additions and 7 deletions

3
blob.c
View File

@ -13,8 +13,7 @@ struct blob *lookup_blob(struct repository *r, const struct object_id *oid)
return object_as_type(obj, OBJ_BLOB, 0); return object_as_type(obj, OBJ_BLOB, 0);
} }
int parse_blob_buffer(struct blob *item, void *buffer, unsigned long size) void parse_blob_buffer(struct blob *item)
{ {
item->object.parsed = 1; item->object.parsed = 1;
return 0;
} }

3
blob.h
View File

@ -11,8 +11,6 @@ struct blob {
struct blob *lookup_blob(struct repository *r, const struct object_id *oid); struct blob *lookup_blob(struct repository *r, const struct object_id *oid);
int parse_blob_buffer(struct blob *item, void *buffer, unsigned long size);
/** /**
* Blobs do not contain references to other objects and do not have * Blobs do not contain references to other objects and do not have
* structured data that needs parsing. However, code may use the * structured data that needs parsing. However, code may use the
@ -21,5 +19,6 @@ int parse_blob_buffer(struct blob *item, void *buffer, unsigned long size);
* parse_blob_buffer() is used (by object.c) to flag that the object * parse_blob_buffer() is used (by object.c) to flag that the object
* has been read successfully from the database. * has been read successfully from the database.
**/ **/
void parse_blob_buffer(struct blob *item);
#endif /* BLOB_H */ #endif /* BLOB_H */

View File

@ -212,8 +212,7 @@ struct object *parse_object_buffer(struct repository *r, const struct object_id
if (type == OBJ_BLOB) { if (type == OBJ_BLOB) {
struct blob *blob = lookup_blob(r, oid); struct blob *blob = lookup_blob(r, oid);
if (blob) { if (blob) {
if (parse_blob_buffer(blob, buffer, size)) parse_blob_buffer(blob);
return NULL;
obj = &blob->object; obj = &blob->object;
} }
} else if (type == OBJ_TREE) { } else if (type == OBJ_TREE) {
@ -292,7 +291,7 @@ struct object *parse_object_with_flags(struct repository *r,
error(_("hash mismatch %s"), oid_to_hex(oid)); error(_("hash mismatch %s"), oid_to_hex(oid));
return NULL; return NULL;
} }
parse_blob_buffer(lookup_blob(r, oid), NULL, 0); parse_blob_buffer(lookup_blob(r, oid));
return lookup_object(r, oid); return lookup_object(r, oid);
} }