diff options
| author | Junio C Hamano <gitster@pobox.com> | 2025-11-08 10:05:35 -0800 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2025-11-08 10:05:37 -0800 |
| commit | f2414e11feb8833fd51dc7dee11b1c99c0a54821 (patch) | |
| tree | 8075b2f96403a9277f4f17ae6f8d697df4aad800 /refs/files-backend.c | |
| parent | Merge branch 'en/ort-rename-another-fix' into jch (diff) | |
| parent | maintenance: add 'is-needed' subcommand (diff) | |
| download | git-f2414e11feb8833fd51dc7dee11b1c99c0a54821.tar.gz git-f2414e11feb8833fd51dc7dee11b1c99c0a54821.zip | |
Merge branch 'kn/maintenance-is-needed' into jch
"git maintenance" command learned "is-needed" subcommand to tell if
it is necessary to perform various maintenance tasks.
* kn/maintenance-is-needed:
maintenance: add 'is-needed' subcommand
maintenance: add checking logic in `pack_refs_condition()`
refs: add a `optimize_required` field to `struct ref_storage_be`
reftable/stack: add function to check if optimization is required
reftable/stack: return stack segments directly
Diffstat (limited to 'refs/files-backend.c')
| -rw-r--r-- | refs/files-backend.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/refs/files-backend.c b/refs/files-backend.c index 6c501edebe..6f6f76a8d8 100644 --- a/refs/files-backend.c +++ b/refs/files-backend.c @@ -1512,6 +1512,16 @@ static int files_optimize(struct ref_store *ref_store, return 0; } +static int files_optimize_required(struct ref_store *ref_store, + struct refs_optimize_opts *opts, + bool *required) +{ + struct files_ref_store *refs = files_downcast(ref_store, REF_STORE_READ, + "optimize_required"); + *required = should_pack_refs(refs, opts); + return 0; +} + /* * People using contrib's git-new-workdir have .git/logs/refs -> * /some/other/path/.git/logs/refs, and that may live on another device. @@ -3982,6 +3992,7 @@ struct ref_storage_be refs_be_files = { .transaction_abort = files_transaction_abort, .optimize = files_optimize, + .optimize_required = files_optimize_required, .rename_ref = files_rename_ref, .copy_ref = files_copy_ref, |
