Lib-ify prune-packed

In builtin.h, there exists the distinctly lib-ish function
prune_packed_objects(). This function can currently only be called by
built-in commands but, unlike all of the other functions in the header,
it does not make sense to impose this restriction as the functionality
can be logically reused in libgit.

Extract this function into prune-packed.c so that related definitions
can exist clearly in their own header file.

While we're at it, clean up #includes that are unused.

This patch is best viewed with --color-moved.

Signed-off-by: Denton Liu <liu.denton@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Denton Liu 2020-03-23 21:07:52 -04:00 committed by Junio C Hamano
parent ce6521e441
commit 9460fd48b5
7 changed files with 56 additions and 48 deletions

View File

@ -952,6 +952,7 @@ LIB_OBJS += progress.o
LIB_OBJS += promisor-remote.o LIB_OBJS += promisor-remote.o
LIB_OBJS += prompt.o LIB_OBJS += prompt.o
LIB_OBJS += protocol.o LIB_OBJS += protocol.o
LIB_OBJS += prune-packed.o
LIB_OBJS += quote.o LIB_OBJS += quote.o
LIB_OBJS += range-diff.o LIB_OBJS += range-diff.o
LIB_OBJS += reachable.o LIB_OBJS += reachable.o

View File

@ -97,11 +97,6 @@
extern const char git_usage_string[]; extern const char git_usage_string[];
extern const char git_more_info_string[]; extern const char git_more_info_string[];
#define PRUNE_PACKED_DRY_RUN 01
#define PRUNE_PACKED_VERBOSE 02
void prune_packed_objects(int);
/** /**
* If a built-in has DELAY_PAGER_CONFIG set, the built-in should call this early * If a built-in has DELAY_PAGER_CONFIG set, the built-in should call this early
* when it wishes to respect the `pager.foo`-config. The `cmd` is the name of * when it wishes to respect the `pager.foo`-config. The `cmd` is the name of

View File

@ -1,54 +1,12 @@
#include "builtin.h" #include "builtin.h"
#include "cache.h"
#include "progress.h"
#include "parse-options.h" #include "parse-options.h"
#include "packfile.h" #include "prune-packed.h"
#include "object-store.h"
static const char * const prune_packed_usage[] = { static const char * const prune_packed_usage[] = {
N_("git prune-packed [-n | --dry-run] [-q | --quiet]"), N_("git prune-packed [-n | --dry-run] [-q | --quiet]"),
NULL NULL
}; };
static struct progress *progress;
static int prune_subdir(unsigned int nr, const char *path, void *data)
{
int *opts = data;
display_progress(progress, nr + 1);
if (!(*opts & PRUNE_PACKED_DRY_RUN))
rmdir(path);
return 0;
}
static int prune_object(const struct object_id *oid, const char *path,
void *data)
{
int *opts = data;
if (!has_object_pack(oid))
return 0;
if (*opts & PRUNE_PACKED_DRY_RUN)
printf("rm -f %s\n", path);
else
unlink_or_warn(path);
return 0;
}
void prune_packed_objects(int opts)
{
if (opts & PRUNE_PACKED_VERBOSE)
progress = start_delayed_progress(_("Removing duplicate objects"), 256);
for_each_loose_file_in_objdir(get_object_directory(),
prune_object, NULL, prune_subdir, &opts);
/* Ensure we show 100% before finishing progress */
display_progress(progress, 256);
stop_progress(&progress);
}
int cmd_prune_packed(int argc, const char **argv, const char *prefix) int cmd_prune_packed(int argc, const char **argv, const char *prefix)
{ {
int opts = isatty(2) ? PRUNE_PACKED_VERBOSE : 0; int opts = isatty(2) ? PRUNE_PACKED_VERBOSE : 0;

View File

@ -6,6 +6,7 @@
#include "reachable.h" #include "reachable.h"
#include "parse-options.h" #include "parse-options.h"
#include "progress.h" #include "progress.h"
#include "prune-packed.h"
#include "object-store.h" #include "object-store.h"
static const char * const prune_usage[] = { static const char * const prune_usage[] = {

View File

@ -10,6 +10,7 @@
#include "argv-array.h" #include "argv-array.h"
#include "midx.h" #include "midx.h"
#include "packfile.h" #include "packfile.h"
#include "prune-packed.h"
#include "object-store.h" #include "object-store.h"
#include "promisor-remote.h" #include "promisor-remote.h"

43
prune-packed.c Normal file
View File

@ -0,0 +1,43 @@
#include "object-store.h"
#include "packfile.h"
#include "progress.h"
#include "prune-packed.h"
static struct progress *progress;
static int prune_subdir(unsigned int nr, const char *path, void *data)
{
int *opts = data;
display_progress(progress, nr + 1);
if (!(*opts & PRUNE_PACKED_DRY_RUN))
rmdir(path);
return 0;
}
static int prune_object(const struct object_id *oid, const char *path,
void *data)
{
int *opts = data;
if (!has_object_pack(oid))
return 0;
if (*opts & PRUNE_PACKED_DRY_RUN)
printf("rm -f %s\n", path);
else
unlink_or_warn(path);
return 0;
}
void prune_packed_objects(int opts)
{
if (opts & PRUNE_PACKED_VERBOSE)
progress = start_delayed_progress(_("Removing duplicate objects"), 256);
for_each_loose_file_in_objdir(get_object_directory(),
prune_object, NULL, prune_subdir, &opts);
/* Ensure we show 100% before finishing progress */
display_progress(progress, 256);
stop_progress(&progress);
}

9
prune-packed.h Normal file
View File

@ -0,0 +1,9 @@
#ifndef PRUNE_PACKED_H
#define PRUNE_PACKED_H
#define PRUNE_PACKED_DRY_RUN 01
#define PRUNE_PACKED_VERBOSE 02
void prune_packed_objects(int);
#endif