aboutsummaryrefslogtreecommitdiffstats
path: root/builtin/cat-file.c
diff options
context:
space:
mode:
authorPatrick Steinhardt <ps@pks.im>2025-04-02 13:13:40 +0200
committerJunio C Hamano <gitster@pobox.com>2025-04-07 14:43:50 -0700
commitdbe1b32d59699092d549150e2db7af07e3cbfaf3 (patch)
treeeeff6083d28695e8d7ede13e3e4d91184043e8c5 /builtin/cat-file.c
parentbuiltin/cat-file: support "blob:none" objects filter (diff)
downloadgit-dbe1b32d59699092d549150e2db7af07e3cbfaf3.tar.gz
git-dbe1b32d59699092d549150e2db7af07e3cbfaf3.zip
builtin/cat-file: support "blob:limit=" objects filter
Implement support for the "blob:limit=" filter in git-cat-file(1), which causes us to omit all blobs that are bigger than a certain size. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'builtin/cat-file.c')
-rw-r--r--builtin/cat-file.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/builtin/cat-file.c b/builtin/cat-file.c
index bcceb646f8..629c6cddcb 100644
--- a/builtin/cat-file.c
+++ b/builtin/cat-file.c
@@ -483,8 +483,11 @@ static void batch_object_write(const char *obj_name,
int ret;
if (use_mailmap ||
- opt->objects_filter.choice == LOFC_BLOB_NONE)
+ opt->objects_filter.choice == LOFC_BLOB_NONE ||
+ opt->objects_filter.choice == LOFC_BLOB_LIMIT)
data->info.typep = &data->type;
+ if (opt->objects_filter.choice == LOFC_BLOB_LIMIT)
+ data->info.sizep = &data->size;
if (pack)
ret = packed_object_info(the_repository, pack, offset,
@@ -509,6 +512,15 @@ static void batch_object_write(const char *obj_name,
return;
}
break;
+ case LOFC_BLOB_LIMIT:
+ if (data->type == OBJ_BLOB &&
+ data->size >= opt->objects_filter.blob_limit_value) {
+ if (!opt->all_objects)
+ report_object_status(opt, obj_name,
+ &data->oid, "excluded");
+ return;
+ }
+ break;
default:
BUG("unsupported objects filter");
}
@@ -1049,6 +1061,7 @@ int cmd_cat_file(int argc,
case LOFC_DISABLED:
break;
case LOFC_BLOB_NONE:
+ case LOFC_BLOB_LIMIT:
if (!batch.enabled)
usage(_("objects filter only supported in batch mode"));
break;