64404a24cf
Much of the multi-pack-index code focuses on the multi_pack_index struct, and so we only pass a pointer to the current one. However, we will insert a dependency on the packed_git linked list in a future change, so we will need a repository reference. Inserting these parameters is a significant enough change to split out. Signed-off-by: Derrick Stolee <dstolee@microsoft.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
53 lines
1.2 KiB
C
53 lines
1.2 KiB
C
#include "builtin.h"
|
|
#include "cache.h"
|
|
#include "config.h"
|
|
#include "parse-options.h"
|
|
#include "midx.h"
|
|
#include "trace2.h"
|
|
|
|
static char const * const builtin_multi_pack_index_usage[] = {
|
|
N_("git multi-pack-index [--object-dir=<dir>] (write|verify)"),
|
|
NULL
|
|
};
|
|
|
|
static struct opts_multi_pack_index {
|
|
const char *object_dir;
|
|
} opts;
|
|
|
|
int cmd_multi_pack_index(int argc, const char **argv,
|
|
const char *prefix)
|
|
{
|
|
static struct option builtin_multi_pack_index_options[] = {
|
|
OPT_FILENAME(0, "object-dir", &opts.object_dir,
|
|
N_("object directory containing set of packfile and pack-index pairs")),
|
|
OPT_END(),
|
|
};
|
|
|
|
git_config(git_default_config, NULL);
|
|
|
|
argc = parse_options(argc, argv, prefix,
|
|
builtin_multi_pack_index_options,
|
|
builtin_multi_pack_index_usage, 0);
|
|
|
|
if (!opts.object_dir)
|
|
opts.object_dir = get_object_directory();
|
|
|
|
if (argc == 0)
|
|
usage_with_options(builtin_multi_pack_index_usage,
|
|
builtin_multi_pack_index_options);
|
|
|
|
if (argc > 1) {
|
|
die(_("too many arguments"));
|
|
return 1;
|
|
}
|
|
|
|
trace2_cmd_mode(argv[0]);
|
|
|
|
if (!strcmp(argv[0], "write"))
|
|
return write_midx_file(opts.object_dir);
|
|
if (!strcmp(argv[0], "verify"))
|
|
return verify_midx_file(the_repository, opts.object_dir);
|
|
|
|
die(_("unrecognized verb: %s"), argv[0]);
|
|
}
|