mirror of
https://github.com/git/git.git
synced 2025-12-12 20:36:24 +01:00
bundle: support fsck message configuration
If the `VERIFY_BUNDLE_FLAG` is set during `unbundle()`, the git-index-pack(1) spawned is configured with the `--fsck-options` flag to perform fsck verification. With this flag enabled, there is not a way to configure fsck message severity though. Extend the `unbundle_opts` type to store fsck message severity configuration and update `unbundle()` to conditionally append it to the `--fsck-objects` flag if provided. This enables `unbundle()` call sites to support optionally setting the severity for specific fsck messages. Signed-off-by: Justin Tobler <jltobler@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
committed by
Junio C Hamano
parent
87c01003cd
commit
187574ce86
13
bundle.c
13
bundle.c
@@ -631,12 +631,12 @@ int unbundle(struct repository *r, struct bundle_header *header,
|
|||||||
struct unbundle_opts *opts)
|
struct unbundle_opts *opts)
|
||||||
{
|
{
|
||||||
struct child_process ip = CHILD_PROCESS_INIT;
|
struct child_process ip = CHILD_PROCESS_INIT;
|
||||||
enum verify_bundle_flags flags = 0;
|
struct unbundle_opts opts_fallback = { 0 };
|
||||||
|
|
||||||
if (opts)
|
if (!opts)
|
||||||
flags = opts->flags;
|
opts = &opts_fallback;
|
||||||
|
|
||||||
if (verify_bundle(r, header, flags))
|
if (verify_bundle(r, header, opts->flags))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
strvec_pushl(&ip.args, "index-pack", "--fix-thin", "--stdin", NULL);
|
strvec_pushl(&ip.args, "index-pack", "--fix-thin", "--stdin", NULL);
|
||||||
@@ -645,8 +645,9 @@ int unbundle(struct repository *r, struct bundle_header *header,
|
|||||||
if (header->filter.choice)
|
if (header->filter.choice)
|
||||||
strvec_push(&ip.args, "--promisor=from-bundle");
|
strvec_push(&ip.args, "--promisor=from-bundle");
|
||||||
|
|
||||||
if (flags & VERIFY_BUNDLE_FSCK)
|
if (opts->flags & VERIFY_BUNDLE_FSCK)
|
||||||
strvec_push(&ip.args, "--fsck-objects");
|
strvec_pushf(&ip.args, "--fsck-objects%s",
|
||||||
|
opts->fsck_msg_types ? opts->fsck_msg_types : "");
|
||||||
|
|
||||||
if (extra_index_pack_args)
|
if (extra_index_pack_args)
|
||||||
strvec_pushv(&ip.args, extra_index_pack_args->v);
|
strvec_pushv(&ip.args, extra_index_pack_args->v);
|
||||||
|
|||||||
7
bundle.h
7
bundle.h
@@ -41,6 +41,13 @@ int verify_bundle(struct repository *r, struct bundle_header *header,
|
|||||||
|
|
||||||
struct unbundle_opts {
|
struct unbundle_opts {
|
||||||
enum verify_bundle_flags flags;
|
enum verify_bundle_flags flags;
|
||||||
|
/*
|
||||||
|
* fsck_msg_types may optionally contain fsck message severity
|
||||||
|
* configuration. If present, this configuration gets directly appended
|
||||||
|
* to a '--fsck-objects' option and therefore must be prefixed with '='.
|
||||||
|
* (E.g. "=missingEmail=ignore,gitmodulesUrl=ignore")
|
||||||
|
*/
|
||||||
|
const char *fsck_msg_types;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
Reference in New Issue
Block a user