Revert "send-pack --keep: do not explode into loose objects on the receiving end."

This reverts commit c7740a943e.  There should
be a way to make this controllable from the receiver end.
This commit is contained in:
Junio C Hamano 2006-10-30 16:02:07 -08:00
parent 5ca807842f
commit 4508dde169
4 changed files with 10 additions and 48 deletions

View File

@ -8,14 +8,10 @@
static const char receive_pack_usage[] = "git-receive-pack <git-dir>";
static const char *unpacker[] = { "unpack-objects", NULL };
static const char *keep_packer[] = {
"index-pack", "--stdin", "--fix-thin", NULL
};
static int report_status;
static int keep_pack;
static char capabilities[] = "report-status keep-pack";
static char capabilities[] = "report-status";
static int capabilities_sent;
static int show_ref(const char *path, const unsigned char *sha1)
@ -265,8 +261,6 @@ static void read_head_info(void)
if (reflen + 82 < len) {
if (strstr(refname + reflen + 1, "report-status"))
report_status = 1;
if (strstr(refname + reflen + 1, "keep-pack"))
keep_pack = 1;
}
cmd = xmalloc(sizeof(struct command) + len - 80);
hashcpy(cmd->old_sha1, old_sha1);
@ -281,14 +275,7 @@ static void read_head_info(void)
static const char *unpack(int *error_code)
{
int code;
if (keep_pack)
code = run_command_v_opt(ARRAY_SIZE(keep_packer) - 1,
keep_packer, RUN_GIT_CMD);
else
code = run_command_v_opt(ARRAY_SIZE(unpacker) - 1,
unpacker, RUN_GIT_CMD);
int code = run_command_v_opt(1, unpacker, RUN_GIT_CMD);
*error_code = 0;
switch (code) {
@ -348,7 +335,7 @@ int main(int argc, char **argv)
if (!dir)
usage(receive_pack_usage);
if (!enter_repo(dir, 0))
if(!enter_repo(dir, 0))
die("'%s': unable to chdir or not a git archive", dir);
write_head_info();

View File

@ -6,14 +6,13 @@
#include "exec_cmd.h"
static const char send_pack_usage[] =
"git-send-pack [--all] [--keep] [--exec=git-receive-pack] <remote> [<head>...]\n"
"git-send-pack [--all] [--exec=git-receive-pack] <remote> [<head>...]\n"
" --all and explicit <head> specification are mutually exclusive.";
static const char *exec = "git-receive-pack";
static int verbose;
static int send_all;
static int force_update;
static int use_thin_pack;
static int keep_pack;
static int is_zero_sha1(const unsigned char *sha1)
{
@ -271,7 +270,6 @@ static int send_pack(int in, int out, int nr_refspec, char **refspec)
int new_refs;
int ret = 0;
int ask_for_status_report = 0;
int ask_to_keep_pack = 0;
int expect_status_report = 0;
/* No funny business with the matcher */
@ -281,8 +279,6 @@ static int send_pack(int in, int out, int nr_refspec, char **refspec)
/* Does the other end support the reporting? */
if (server_supports("report-status"))
ask_for_status_report = 1;
if (server_supports("keep-pack") && keep_pack)
ask_to_keep_pack = 1;
/* match them up */
if (!remote_tail)
@ -359,17 +355,12 @@ static int send_pack(int in, int out, int nr_refspec, char **refspec)
strcpy(old_hex, sha1_to_hex(ref->old_sha1));
new_hex = sha1_to_hex(ref->new_sha1);
if (ask_for_status_report || ask_to_keep_pack) {
packet_write(out, "%s %s %s%c%s%s",
if (ask_for_status_report) {
packet_write(out, "%s %s %s%c%s",
old_hex, new_hex, ref->name, 0,
ask_for_status_report
? " report-status" : "",
ask_to_keep_pack
? " keep-pack" : "");
if (ask_for_status_report)
expect_status_report = 1;
"report-status");
ask_for_status_report = 0;
ask_to_keep_pack = 0;
expect_status_report = 1;
}
else
packet_write(out, "%s %s %s",
@ -428,10 +419,6 @@ int main(int argc, char **argv)
verbose = 1;
continue;
}
if (!strcmp(arg, "--keep")) {
keep_pack = 1;
continue;
}
if (!strcmp(arg, "--thin")) {
use_thin_pack = 1;
continue;

View File

@ -1292,7 +1292,7 @@ static void *read_packed_sha1(const unsigned char *sha1, char *type, unsigned lo
return unpack_entry(&e, type, size);
}
void *read_sha1_file(const unsigned char *sha1, char *type, unsigned long *size)
void * read_sha1_file(const unsigned char *sha1, char *type, unsigned long *size)
{
unsigned long mapsize;
void *map, *buf;
@ -1757,10 +1757,7 @@ int has_sha1_file(const unsigned char *sha1)
if (find_pack_entry(sha1, &e, NULL))
return 1;
if (find_sha1_file(sha1, &st))
return 1;
reprepare_packed_git();
return find_pack_entry(sha1, &e, NULL);
return find_sha1_file(sha1, &st) ? 1 : 0;
}
/*

View File

@ -78,13 +78,4 @@ test_expect_success \
! diff -u .git/refs/heads/master victim/.git/refs/heads/master
'
test_expect_success 'push with --keep' '
t=`cd victim && git-rev-parse --verify refs/heads/master` &&
git-update-ref refs/heads/master $t &&
: > foo &&
git add foo &&
git commit -m "one more" &&
git-send-pack --keep ./victim/.git/ master
'
test_done