Revision e4cb3693a45a74ac9fdd142ab6392832b0a895d3 authored by Junio C Hamano on 30 August 2021, 23:06:05 UTC, committed by Johannes Schindelin on 22 March 2023, 17:00:36 UTC
"git range-diff" code clean-up. Needed to pacify modern GCC versions.

* jk/range-diff-fixes:
  range-diff: use ssize_t for parsed "len" in read_patches()
  range-diff: handle unterminated lines in read_patches()
  range-diff: drop useless "offset" variable from read_patches()
2 parent s 3c7896e + c025b4b
Raw File
multi-pack-index.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 [<options>] (write|verify|expire|repack --batch-size=<size>)"),
	NULL
};

static struct opts_multi_pack_index {
	const char *object_dir;
	unsigned long batch_size;
	int progress;
} opts;

int cmd_multi_pack_index(int argc, const char **argv,
			 const char *prefix)
{
	unsigned flags = 0;

	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_BOOL(0, "progress", &opts.progress, N_("force progress reporting")),
		OPT_MAGNITUDE(0, "batch-size", &opts.batch_size,
		  N_("during repack, collect pack-files of smaller size into a batch that is larger than this size")),
		OPT_END(),
	};

	git_config(git_default_config, NULL);

	opts.progress = isatty(2);
	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 (opts.progress)
		flags |= MIDX_PROGRESS;

	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], "repack"))
		return midx_repack(the_repository, opts.object_dir,
			(size_t)opts.batch_size, flags);
	if (opts.batch_size)
		die(_("--batch-size option is only for 'repack' subcommand"));

	if (!strcmp(argv[0], "write"))
		return write_midx_file(opts.object_dir, flags);
	if (!strcmp(argv[0], "verify"))
		return verify_midx_file(the_repository, opts.object_dir, flags);
	if (!strcmp(argv[0], "expire"))
		return expire_midx_packs(the_repository, opts.object_dir, flags);

	die(_("unrecognized subcommand: %s"), argv[0]);
}
back to top