Skip to content

Commit

Permalink
builtin-remote.c: Split out prune_remote as a separate function.
Browse files Browse the repository at this point in the history
prune_remote will be used in update(), so this function was split
out to avoid code duplication.

Signed-off-by: Finn Arne Gangstad <finnag@pvv.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Finn Arne Gangstad authored and Junio C Hamano committed Apr 5, 2009
1 parent e96f368 commit b92c5f2
Showing 1 changed file with 30 additions and 26 deletions.
56 changes: 30 additions & 26 deletions builtin-remote.c
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ static const char * const builtin_remote_usage[] = {
static int verbose;

static int show_all(void);
static int prune_remote(const char *remote, int dry_run);

static inline int postfixcmp(const char *string, const char *postfix)
{
Expand Down Expand Up @@ -1128,46 +1129,49 @@ static int prune(int argc, const char **argv)
OPT__DRY_RUN(&dry_run),
OPT_END()
};
struct ref_states states;
const char *dangling_msg;

argc = parse_options(argc, argv, options, builtin_remote_usage, 0);

if (argc < 1)
usage_with_options(builtin_remote_usage, options);

dangling_msg = (dry_run
? " %s will become dangling!\n"
: " %s has become dangling!\n");
for (; argc; argc--, argv++)
result |= prune_remote(*argv, dry_run);

memset(&states, 0, sizeof(states));
for (; argc; argc--, argv++) {
int i;

get_remote_ref_states(*argv, &states, GET_REF_STATES);
return result;
}

if (states.stale.nr) {
printf("Pruning %s\n", *argv);
printf("URL: %s\n",
states.remote->url_nr
? states.remote->url[0]
: "(no URL)");
}
static int prune_remote(const char *remote, int dry_run)
{
int result = 0, i;
struct ref_states states;
const char *dangling_msg = dry_run
? " %s will become dangling!\n"
: " %s has become dangling!\n";

for (i = 0; i < states.stale.nr; i++) {
const char *refname = states.stale.items[i].util;
memset(&states, 0, sizeof(states));
get_remote_ref_states(remote, &states, GET_REF_STATES);

if (states.stale.nr) {
printf("Pruning %s\n", remote);
printf("URL: %s\n",
states.remote->url_nr
? states.remote->url[0]
: "(no URL)");
}

if (!dry_run)
result |= delete_ref(refname, NULL, 0);
for (i = 0; i < states.stale.nr; i++) {
const char *refname = states.stale.items[i].util;

printf(" * [%s] %s\n", dry_run ? "would prune" : "pruned",
abbrev_ref(refname, "refs/remotes/"));
warn_dangling_symref(dangling_msg, refname);
}
if (!dry_run)
result |= delete_ref(refname, NULL, 0);

free_remote_ref_states(&states);
printf(" * [%s] %s\n", dry_run ? "would prune" : "pruned",
abbrev_ref(refname, "refs/remotes/"));
warn_dangling_symref(dangling_msg, refname);
}

free_remote_ref_states(&states);
return result;
}

Expand Down

0 comments on commit b92c5f2

Please sign in to comment.