Skip to content

Commit

Permalink
builtin-prune.c: use parse_options()
Browse files Browse the repository at this point in the history
Using the OPT_DATE() introduced earlier, this updates builtin-prune to
use parse_options().

Signed-off-by: Michele Ballabio <[email protected]>
Signed-off-by: Junio C Hamano <[email protected]>
  • Loading branch information
chunga authored and gitster committed Mar 27, 2008
1 parent 0c62705 commit 629de47
Showing 1 changed file with 16 additions and 22 deletions.
38 changes: 16 additions & 22 deletions builtin-prune.c
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,12 @@
#include "revision.h"
#include "builtin.h"
#include "reachable.h"
#include "parse-options.h"

static const char prune_usage[] = "git-prune [-n]";
static const char * const prune_usage[] = {
"git-prune [-n] [--expire <time>] [--] [<head>...]",
NULL
};
static int show_only;
static unsigned long expire;

Expand Down Expand Up @@ -123,32 +127,22 @@ static void remove_temporary_files(void)

int cmd_prune(int argc, const char **argv, const char *prefix)
{
int i;
struct rev_info revs;

for (i = 1; i < argc; i++) {
const char *arg = argv[i];
if (!strcmp(arg, "-n")) {
show_only = 1;
continue;
}
if (!strcmp(arg, "--expire")) {
if (++i < argc) {
expire = approxidate(argv[i]);
continue;
}
}
else if (!prefixcmp(arg, "--expire=")) {
expire = approxidate(arg + 9);
continue;
}
usage(prune_usage);
}
const struct option options[] = {
OPT_BOOLEAN('n', NULL, &show_only,
"do not remove, show only"),
OPT_DATE(0, "expire", &expire,
"expire objects older than <time>"),
OPT_END()
};

save_commit_buffer = 0;
init_revisions(&revs, prefix);
mark_reachable_objects(&revs, 1);

argc = parse_options(argc, argv, options, prune_usage, 0);
if (argc)
die ("unrecognized argument: %s", name);
mark_reachable_objects(&revs, 1);
prune_object_dir(get_object_directory());

sync();
Expand Down

0 comments on commit 629de47

Please sign in to comment.